/*
font-face inside ./wp-editor.css
font-family: 'Montserrat', sans-serif;
400, 700

blau > #4258BA
grau > #222
rot  > #E4461F
grün > #0FB963

 */

/* @group Clear Stylesheet */
*,
*::before,
*::after {
  box-sizing: border-box;
}

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,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
  background-image: none;
}
body {
  line-height: 1;
  color: black;
  background: white;
  text-align: left;
}
ol,
ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption,
th,
td {
  text-align: left;
  font-weight: normal;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
}
blockquote,
q {
  quotes: "" "";
}
/* @end */

:root {
  --color-main: #1b3ac3;
  --color-hover: #e53409;
  --color-black: #000000;
  --color-grey: #f1f1f1;
  --color-white: #ffffff;
  --color-nav: #111111;
  --color-separator: rgba(0, 0, 0, 0.2);
  --color-separator-dark: rgba(255, 255, 255, 0.25);

  --radius: 0.5rem;
  --space-xl: 5rem;
  --space-l: 3rem;
  --space-m: 2rem;
  --space-s: 1rem;
  --space-xs: 0.5rem;

  --font-size-xl: 2.8rem;
  --font-size-l: 2.5rem;
  --font-size-m: 1.5rem;
  --font-size-s: 1.2rem;

  --padding-1-column: calc((100vw - var(--space-s) * 7) / 6 + var(--space-s));
}

@media (min-width: 768px) {
  :root {
    --radius: 1rem;
    --space-xl: 7rem;
    --space-l: 5rem;
    --space-m: 3rem;
    --space-s: 2rem;
    --space-xs: 1rem;

    --font-size-xl: 4.5rem;
    --font-size-l: 4rem;
    --font-size-m: 2.5rem;
    --font-size-s: 1.5rem;
  }
}
@media (min-width: 1024px) {
  :root {
    --padding-1-column: calc((100vw - var(--space-s) * 9) / 8 + var(--space-s));
  }
}
@media (min-width: 1920px) {
  :root {
    --padding-1-column: calc(
      (1920px - var(--space-s) * 9) / 8 + var(--space-s)
    );
  }
}

html {
  font-size: 10px;
}
@media (max-width: 320px) {
  html {
    font-size: 9px;
  }
}
@media (min-width: 560px) {
  html {
    font-size: 11px;
  }
}
@media (min-width: 768px) {
  html {
    font-size: 10px;
  }
}
@media (min-width: 1024px) {
  html {
    font-size: 8px;
  }
}
@media (min-width: 1200px) {
  html {
    font-size: 9px;
  }
}
@media (min-width: 1400px) {
  html {
    font-size: 10px;
  }
}
@media (min-width: 1600px) {
  html {
    font-size: 11px;
  }
}

body {
  color: var(--color-black);
  font-family: "ApfelGrotezk", sans-serif;
  font-size: var(--font-size-m);
  min-width: 320px;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
}

a {
  color: currentColor;
  text-decoration: underline;
}

a:hover {
  color: var(--color-hover);
}

b,
strong {
  font-weight: 700;
}

h1,
h2,
h3,
h4,
h5,
p {
  font-weight: 400;
}

h1,
h2,
.typo-xl {
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-xl);
  letter-spacing: -0.06em;
  line-height: 1;
  text-transform: uppercase;
}
h1:not(:first-child),
h2:not(:first-child),
.typo-xl:not(:first-child) {
  margin-top: var(--space-l);
}
h1:not(:last-child),
h2:not(:last-child),
.typo-xl:not(:last-child) {
  margin-bottom: var(--space-l);
}

h3,
.typo-l {
  font-family: "ApfelGrotezk", sans-serif;
  font-size: var(--font-size-l);
  letter-spacing: 0;
  line-height: 1;
  text-transform: none;
}
h3:not(:first-child),
.typo-l:not(:first-child) {
  margin-top: var(--space-m);
}
h3:not(:last-child),
.typo-l:not(:last-child) {
  margin-bottom: var(--space-m);
}

h4,
p,
.typo-m {
  font-family: "ApfelGrotezk", sans-serif;
  font-size: var(--font-size-m);
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: none;
}
h4:not(:first-child),
p:not(:first-child),
.typo-m:not(:first-child) {
  margin-top: var(--space-s);
}
h4:not(:last-child),
p:not(:last-child),
.typo-m:not(:last-child) {
  margin-bottom: var(--space-s);
}

h5,
.typo-s {
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s);
  letter-spacing: 0;
  line-height: 1;
  text-transform: uppercase;
}
h5:not(:first-child),
.typo-s:not(:first-child) {
  margin-top: var(--space-xs);
}
h5:not(:last-child),
.typo-s:not(:last-child) {
  margin-bottom: var(--space-xs);
}

hr {
  margin: 0;
  height: 0;
  border: 0;
  border-top: 1px solid var(--color-separator);
}

.br {
  display: block;
}
h1 .br,
h2 .br,
.typo-xl .br {
  height: var(--space-l);
}
h3 .br,
.typo-l .br {
  height: var(--space-m);
}
h4 .br,
p .br,
.typo-m .br {
  height: var(--space-s);
}
h5 .br,
.typo-s .br {
  height: var(--space-xs);
}

/* #tinymce is for admin cms */
#tinymce ul:not(:first-child),
.wysiwyg ul:not(:first-child),
#tinymce ol:not(:first-child),
.wysiwyg ol:not(:first-child),
#tinymce li ul,
.wysiwyg li ul,
#tinymce li ol,
.wysiwyg li ol {
  margin-top: var(--space-s);
}
#tinymce ul:not(:last-child),
.wysiwyg ul:not(:last-child),
#tinymce ol:not(:last-child),
.wysiwyg ol:not(:last-child) {
  margin-bottom: var(--space-s);
}

#tinymce li,
.wysiwyg li {
  position: relative;
  line-height: 1.2;
  padding-left: var(--padding-1-column);
}
#tinymce li + li,
.wysiwyg li + li {
  margin-top: var(--space-s);
}
#tinymce li::before,
.wysiwyg li::before {
  position: absolute;
  left: 0;
  top: 0;
}

#tinymce ul > li::before,
.wysiwyg ul > li::before {
  content: "→";
}

#tinymce ol,
.wysiwyg ol {
  counter-reset: list;
}
#tinymce ol > li::before,
.wysiwyg ol > li::before {
  counter-increment: list;
  content: counter(list) ". ";
}
#tinymce ol ol > li::before,
.wysiwyg ol ol > li::before {
  content: counter(list, lower-alpha) ") ";
}
#tinymce ol ol ol > li::before,
.wysiwyg ol ol ol > li::before {
  content: counter(list, decimal) ". ";
}

.width {
  position: relative;
  width: 100%;
  max-width: 1920px;
  padding: 0 var(--space-s);
  margin: 0 auto;
}

input,
textarea {
  padding: 1rem;
  background-color: var(--color-grey);
  border: 1px solid var(--color-grey);
  border-radius: var(--radius);
  box-sizing: border-box;
  box-shadow: none;
  color: var(--color-black);
  font-family: "ApfelGrotezk", sans-serif;
  font-size: var(--font-size-m);
  outline: none;
  transition: border-color 0.3s ease-out;
}
input:hover,
textarea:hover {
  border-color: var(--color-separator);
}
input:focus-visible,
textarea:focus-visible {
  border-color: var(--color-black);
}

::-webkit-input-placeholder {
  color: var(--color-black);
  opacity: 0.5;
}
::-moz-placeholder {
  color: var(--color-black);
  opacity: 0.5;
}
:-ms-input-placeholder {
  color: var(--color-black);
  opacity: 0.5;
}
:-moz-placeholder {
  color: var(--color-black);
  opacity: 0.5;
}
::placeholder {
  color: var(--color-black);
  opacity: 0.5;
}

.button,
input[type="submit"],
button,
.button-wrapper a {
  position: relative;
  display: inline-block;
  cursor: pointer;
  background-color: var(--color-main) !important;
  color: var(--color-white) !important;
  padding: 1.2rem 3rem !important;
  border: none;
  border-radius: 8rem;
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s) !important;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  z-index: 20;

  -webkit-transition: background-color 0.2s ease-out;
  -moz-transition: background-color 0.2s ease-out;
  -o-transition: background-color 0.2s ease-out;
  -ms-transition: background-color 0.2s ease-out;
  transition: background-color 0.2s ease-out;
}

.button:hover,
input[type="submit"]:hover,
button:hover,
.button-wrapper a:hover {
  background-color: var(--color-hover) !important;
  text-decoration: none;
}

.button.arrow::after,
input[type="submit"].arrow::after,
button.arrow::after,
.button-wrapper.arrow a::after {
  content: "→";
  display: inline-block;
  margin-left: 2rem;
}

@media (min-width: 768px) {
  .button,
  input[type="submit"],
  button,
  .button-wrapper a {
    padding: 1rem 4rem !important;
    line-height: 2rem;
  }

  .button.arrow::after,
  input[type="submit"].arrow::after,
  button.arrow::after,
  .button-wrapper.arrow a::after {
    margin-left: 1.5rem;
  }
}

.d-grid,
.d-grid-6,
.d-grid-3 {
  display: grid;
  gap: var(--space-s);
}
.d-grid {
  grid-template-columns: repeat(8, 1fr);
}
.d-grid-6 {
  grid-template-columns: repeat(6, 1fr);
}
.d-grid-3 {
  grid-template-columns: repeat(3, 1fr);
}

.g-col-2 {
  grid-column: span 2;
}
.g-col-3 {
  grid-column: span 3;
}
.g-col-4 {
  grid-column: span 4;
}
.g-col-5 {
  grid-column: span 5;
}
.g-col-6 {
  grid-column: span 6;
}
.g-col-7 {
  grid-column: span 7;
}
.g-col-8 {
  grid-column: span 8;
}

@media (max-width: 1023px) {
  .d-grid,
  .d-m-grid {
    grid-template-columns: repeat(6, 1fr);
  }
  .g-col-m-1 {
    grid-column: 1;
  }
  .g-col-m-2 {
    grid-column: span 2;
  }
  .g-col-m-3 {
    grid-column: span 3;
  }
  .g-col-m-4 {
    grid-column: span 4;
  }
  .g-col-m-5 {
    grid-column: span 5;
  }
  .g-col-m-6 {
    grid-column: span 6;
  }
}

.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.header .logo-wrapper {
  position: relative;
  z-index: 50;
  display: inline-flex;
  align-items: center;
}
.header .logo {
  position: relative;
  display: inline-block;
  height: 7rem;
  width: 28rem;
  margin: 0.5rem;
  color: transparent !important;
}
.header .logo::after {
  content: "";
  position: absolute;
  top: 1.9rem;
  left: 1.5rem;
  width: 25rem;
  height: 3.3rem;
  background: url(../img/hansemold_logo_white.svg) no-repeat center top;
  background-size: contain;
}

.header .fixed {
  position: fixed;
  top: 0.5rem;
  right: 0.5rem;
}

.header .sub-menu-background {
  position: absolute;
  left: 0;
  top: calc(100% + 1px);
  width: 100%;
  height: 20rem;
  border-radius: 1rem;
  background-color: #111;
  opacity: 0;
  transition: opacity 0.3s ease-out, height 0.3s ease-out;
  pointer-events: none;
}
.header .sub-menu-background::after {
  content: "";
  position: absolute;
  left: 0;
  top: -0.3rem;
  height: 0.6rem;
  width: 100%;
}
.header.open .sub-menu-background {
  opacity: 1;
  pointer-events: auto;
}

.header #menu-main {
  position: relative;
  display: flex;
  box-sizing: border-box;
  padding: 1.5rem 1.5rem 1.5rem 0.5rem;
  border-radius: 1rem;
  transition: background-color 0.3s ease-out;
}
.header.open #menu-main,
.header.not-top #menu-main {
  background-color: #111;
}

.header #menu-main > .menu-item:not(.button-wrapper) > a {
  transition: opacity 0.2s ease-out;
}
.header.open #menu-main > .menu-item:not(.button-wrapper) > a {
  opacity: 0.5;
}
.header.open #menu-main > .menu-item.hover > a {
  opacity: 1;
}

.header #menu-main > .menu-item.button-wrapper {
  margin-left: 1.5rem;
}

.header .menu a {
  display: inline-block;
  padding: 1rem 1.5rem;
  font-family: "JetBrainsMono", sans-serif;
  color: white;
  font-size: var(--font-size-s);
  font-weight: 400;
  line-height: 2rem;
  text-decoration: none;
  text-transform: uppercase;
}

.header .menu-item:not(.button-wrapper) a:hover,
.header .current-menu-item > a,
.header .current-page-ancestor > a {
  text-decoration: underline;
}

.header .sub-menu-wrapper {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 1px;
  height: 0;
  opacity: 0;
  overflow: hidden;
  transition: opacity 0.3s ease-out, height 0.3s ease-out;
  pointer-events: none;
}
.header.open .sub-menu-wrapper {
  transition: opacity 0.3s ease-out, transform 0.3s ease-out,
    height 0.3s ease-out;
}
.header .menu-item-has-children.hover .sub-menu-wrapper {
  opacity: 1;
  pointer-events: auto;
}
.header .sub-menu {
  display: block;
  white-space: nowrap;
  padding: 1.5rem 0;
  box-sizing: border-box;
}

.header li {
  display: block;
}

.header .sub-menu a {
  display: block;
}

.header .language-switcher {
  position: relative;
  margin-left: 2.5rem;
}
.header .language-switcher::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -0.2rem;
  width: 1rem;
  height: 0.6rem;
  background: url(../img/icons/language-arrow-down.svg) no-repeat center center /
    contain;
  pointer-events: none;
}
.header .language-switcher select {
  padding: 0.5rem 2rem 0.5rem 0.5rem;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  color: var(--color-white);
  outline: none;
  border: none;
  font-size: var(--font-size-s);
  text-transform: uppercase;
  cursor: pointer;
}
.header .language-switcher option {
  color: black;
}

.header .burger {
  display: none;
}

@media (max-width: 767.8px) {
  .header .logo {
    margin: 0;
  }
  .header .logo::after {
    left: 1rem;
  }
  .header .language-switcher::after {
    margin-top: -0.3rem;
  }
  .header .language-switcher select {
    padding-right: 1.5rem;
  }
}

@media (max-width: 1023px) {
  .header .logo-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    transition: transform 0.2s ease-out;
  }
  .header.not-top .logo-wrapper {
    transform: translateY(-100%);
  }
  .header.open .logo-wrapper {
    transform: translateY(0);
    transition-delay: 0.2s;
  }
  .header .logo {
    margin-top: 0;
    width: 17rem;
    height: 5.6rem;
  }
  .header .logo::after {
    top: 1.8rem;
    width: 15rem;
    height: 2rem;
  }

  .header .burger {
    position: absolute;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 5rem;
    height: 3.6rem;
    right: 1rem;
    top: 1rem;
    border: 1px solid var(--color-white);
    border-radius: 8rem;
    cursor: pointer;
    z-index: 2;
    transition: background-color 0.2s ease-out, border-color 0.2s ease-out;
  }
  .header .burger .icon {
    position: relative;
    width: 2rem;
    height: 1rem;
  }
  .header .burger .icon:before,
  .header .burger .icon:after {
    content: "";
    position: absolute;
    width: 2rem;
    height: 2px;
    right: 0;
    background-color: var(--color-white);
    transition: transform 0.2s ease-out;
  }
  .header .burger .icon:before {
    top: 0;
  }
  .header .burger .icon:after {
    bottom: 0;
  }
  .header.open .burger .icon:before {
    transform: translateY(0.4rem) rotate(-33deg);
  }
  .header.open .burger .icon:after {
    transform: translateY(-0.4rem) rotate(33deg);
  }

  .header.not-top .burger {
    background-color: var(--color-main);
    border-color: var(--color-main);
  }
  .header.not-top .burger:hover {
    background-color: var(--color-hover);
    border-color: var(--color-hover);
  }
  .header.not-top.open .burger {
    background-color: transparent;
    border-color: var(--color-white);
  }

  .header .sub-menu-background {
    top: 0;
    height: 5.6rem;
    z-index: 1;
    transform: translateX(100%);
    transition: transform 0.3s ease-out;
  }
  .header.open .sub-menu-background {
    transform: translateX(0%);
  }
  .header .open .sub-menu-wrapper {
    pointer-events: auto;
  }

  .header .fixed {
    top: 0;
    left: 0;
    width: 100%;
  }
  .header #menu-main {
    position: absolute;
    flex-direction: column;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    padding: 6.6rem var(--space-s) var(--space-m);
    border-radius: 0;
    transform: translateX(100%);
    transition: transform 0.3s ease-out;
    overflow: auto;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .header #menu-main::-webkit-scrollbar {
    display: none;
  }
  .header.open #menu-main {
    transform: translateX(0%);
  }
  .header.open #menu-main > .menu-item:not(.button-wrapper) {
    order: 2;
    border-top: 1px solid var(--color-separator-dark);
  }
  .header.open #menu-main > .button-wrapper {
    order: 1;
    margin-left: 0;
    margin-bottom: var(--space-m);
  }

  .header.open #menu-main > .menu-item:not(.button-wrapper) > a {
    padding: 1.5rem 0;
    opacity: 1;
  }

  .header #menu-main li {
    position: relative;
  }

  .header #menu-main li a {
    display: block;
  }

  .header #menu-main > li.menu-item-has-children:after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    top: 0px;
    width: 5rem;
    height: 5rem;
    background: url(../img/icons/triangle-down.svg) no-repeat center center /
      contain;
    cursor: pointer;
  }

  .header #menu-main > li.menu-item-has-children.open:after {
    transform: rotate(180deg);
  }

  .header.open .sub-menu-wrapper {
    position: static;
    top: 0;
    margin-top: 0;
    opacity: 1;
    transition: height 0.2s ease-out;
  }

  .header .sub-menu {
    padding: 0;
  }
  .header .sub-menu a {
    padding: 1.5rem 0;
  }
  .header .sub-menu a::before {
    content: "→";
    display: inline-block;
    width: 16.667%;
  }

  .header #menu-main .button-wrapper a {
    padding: 0.8rem 1.5rem !important;
  }

  .header .language-switcher {
    margin-left: 1.5rem;
  }
}

.footer {
  position: relative;
  height: 41rem;
  padding-top: 5rem;
  color: var(--color-white);
  overflow: hidden;
}

.footer .background {
  position: absolute;
  z-index: -1;
  inset: 5rem 0 0;
  background-color: var(--color-black);
}

.footer .content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding-top: var(--space-s);
  padding-bottom: var(--space-s);
}

.footer .background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.footer .contacts {
  margin-top: var(--space-m);
  gap: var(--space-xs) var(--space-s);
}
.footer .label {
  opacity: 0.5;
}

.footer .menu-wropper {
  display: flex;
  justify-content: space-between;
}

#menu-footer a {
  text-decoration: none;
}
#menu-footer li + li {
  margin-top: var(--space-xs);
}

@media (max-width: 767px) {
  .footer {
    height: 34rem;
    padding-top: 4rem;
  }
  .footer .background {
    inset: 4rem 0 0;
  }
  .footer h2.typo-s {
    margin-bottom: 2rem;
  }
}

.main {
  min-height: 100vh;
  min-height: 100svh;
}

.contentblock,
.block {
  padding: var(--space-s) 0 var(--space-xl);
}

/* Hero full */
.hero-full {
  height: 100vh;
  height: 100lvh;

  position: relative;
  overflow: hidden;
  color: var(--color-white);
}

.hero-full .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
  pointer-events: none;
  z-index: 1;
}
.hero-full .slide.active {
  opacity: 1;
  pointer-events: auto;
  z-index: 2;
}

.hero-full .background {
  position: absolute;
  inset: 0;
  background-color: var(--color-black);
}
.hero-full .background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-full .width {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  height: 100dvh;
  transition: height 0.3s ease-out;
}

.hero-full .content {
  min-height: 50%;
  padding-bottom: var(--space-s);
}

.hero-full .right {
  display: flex;
  flex-direction: column;
}

.hero-full .key {
  opacity: 0.5;
  margin: 0;
}

.hero-full .value {
  margin: 0;
}

.hero-full .slide .button-wrapper {
  margin-top: auto;
}
.hero-full .slide .benefit + .button-wrapper a {
  margin-top: var(--space-s);
}

.hero-full .slider-controll {
  position: absolute;
  z-index: 3;
  bottom: var(--space-s);
  right: calc((100% - 4rem) * 0.25);
  display: flex;
  gap: var(--space-xs);
  transform: translateX(100%);
}

.hero-full .prev,
.hero-full .next,
.hero-full .arrow-down {
  font-family: "JetBrainsMono", sans-serif;
  font-size: 1.6rem !important;
  line-height: 1;
  border-radius: 8rem;
}
.hero-full .prev,
.hero-full .next {
  padding: 1.1rem 2.4rem !important;
  background-color: transparent !important;
  color: var(--color-white);
  border: 1px solid var(--color-white);
  transition: border-color 0.2s ease-out, color 0.2s ease-out;
}
.hero-full .prev:hover,
.hero-full .next:hover {
  color: var(--color-hover) !important;
  border-color: var(--color-hover);
}

.hero-full .arrow-down {
  position: absolute;
  z-index: 3;
  bottom: var(--space-s);
  right: var(--space-s);
  padding: 1.2rem 2.5rem !important;
  background-color: var(--color-white) !important;
  color: var(--color-black) !important;
  transition: background-color 0.2s ease-out, color 0.2s ease-out;
}
.hero-full .arrow-down:hover {
  background-color: var(--color-hover) !important;
  color: var(--color-white) !important;
}

@media (max-width: 1023px) {
  .hero-full .content {
    display: flex;
    flex-direction: column;
  }

  .hero-full .right {
    flex: 1;
  }

  .hero-full .slider-controll {
    right: var(--space-s);
    transform: none;
  }

  .hero-full .arrow-down {
    display: none;
  }
}
@media (max-width: 767px) {
  .hero-full .next,
  .hero-full .prev {
    padding: 1.1rem 2rem !important;
    font-size: 1.2rem !important;
  }
}

/* Hero half */

.hero-half {
  position: relative;
  height: 52rem;
  overflow: hidden;
  color: var(--color-white);
}

.hero-half .background {
  position: absolute;
  inset: 0;
  background-color: var(--color-black);
}
.hero-half .background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-half .width {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
}

.hero-half .content {
  position: relative;
  z-index: 1;
  padding-bottom: var(--space-s);
}

.hero-half .right {
  display: flex;
  flex-direction: column;
}

@media (max-width: 1023px) {
  .hero-half .content {
    display: flex;
    flex-direction: column;
  }
  .hero-half .right {
    flex: 1;
  }
}
@media (max-width: 767px) {
  .hero-half {
    height: 42rem;
  }
}

/* Hero small */

.hero-small {
  padding: 13rem 0 var(--space-s);
  background-color: var(--color-black);
  color: var(--color-white);
}
@media (max-width: 767px) {
  .hero-small {
    padding-top: 9rem;
  }
}

.columns-pictograms .grid {
  gap: var(--space-m) var(--space-s);
}
.columns-pictograms .label {
  margin-top: var(--space-xs);
}

.columns-text .entry {
  padding: var(--space-s);
  min-height: 37.5rem;
  background-color: var(--color-grey);
  border-radius: var(--radius);
}
.columns-text .subheading {
  min-height: 12rem;
  margin-bottom: 2rem;

  word-wrap: break-word;
  overflow-wrap: break-word;

  -webkit-hyphens: auto;
  -moz-hyphens: auto;
  hyphens: auto;

  -webkit-hyphenate-limit-before: 3; /* For Safari */
  -webkit-hyphenate-limit-after: 3; /* For Safari */
  -ms-hyphenate-limit-chars: 10 3 3;
  hyphenate-limit-chars: 10 3 3;
}

@media (max-width: 1023px) {
  .columns-text .entry {
    min-height: 14rem;
  }
  .columns-text .subheading {
    min-height: initial;
  }
}

.columns-link .entry {
  color: var(--color-black);
  text-decoration: none;
}

.columns-link .image {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
}
.columns-link .image img {
  width: 100%;
  height: 100%;
  border-radius: var(--radius);
  object-fit: cover;
}
.columns-link .button {
  position: absolute;
  right: var(--space-xs);
  bottom: var(--space-xs);
  padding: 1rem 2.5rem !important;
}
.columns-link .arrow::after {
  margin-left: 0;
}
.columns-link .entry:hover .button {
  background-color: var(--color-hover) !important;
}
@media (max-width: 767px) {
  .columns-link .d-grid {
    gap: var(--space-m) var(--space-s);
  }
  .columns-link .button {
    padding: 1.2rem 1.9rem !important;
  }
}

.contentblock-image-text {
  position: relative;
}
.contentblock-image-text + .contentblock-image-text {
  margin-top: -4rem;
}
.image-text .top {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.image-text .top .border {
  height: 1px;
  background-color: var(--color-separator);
}
.image-text .heading-wrapper {
  margin-bottom: var(--space-l);
}
.image-text .heading-wrapper * {
  margin: 0;
}
.image-text .image {
  aspect-ratio: 1.4;
  border-radius: var(--radius);
  overflow: hidden;
}
.image-text .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius);
  overflow: hidden;
}
.image-text .text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.image-text .text p:not(:last-child) {
  margin-bottom: var(--space-m);
}

@media (max-width: 1023px) {
  .image-text .grid {
    display: block;
  }
  .image-text .image {
    margin-bottom: var(--space-m);
  }
  .image-text .text {
    padding-left: var(--padding-1-column);
  }
}
@media (max-width: 767px) {
  .contentblock-image-text + .contentblock-image-text {
    margin-top: -2rem;
  }
}

.contentblock-rich-text .wysiwyg {
  padding-right: calc(2 * var(--padding-1-column));
}
@media (max-width: 1023px) {
  .contentblock-rich-text .wysiwyg {
    padding-right: 0;
  }
}

.contentblock-paragraph {
  counter-increment: paragraph;
}
.contentblock-paragraph .content {
  padding-right: calc(2 * var(--padding-1-column));
}
.contentblock-paragraph h2,
.contentblock-paragraph .wysiwyg {
  padding-left: var(--padding-1-column);
}
.contentblock-paragraph h2 {
  position: relative;
}
.contentblock-paragraph h2::before {
  content: "§" counter(paragraph) " ";
  position: absolute;
  top: 0;
  left: 0;
}

.contentblock-paragraph .without-paragraph h2::before {
  content: counter(paragraph) ". ";
}
.contentblock-paragraph .without-paragraph .wysiwyg ol > li::before {
  content: counter(list, lower-alpha) ") ";
}
.contentblock-paragraph .without-paragraph .wysiwyg ol ol > li::before {
  content: counter(list, decimal) ". ";
}

@media (max-width: 1023px) {
  .contentblock-paragraph .content {
    padding-right: 0;
  }
}

.linklist ul {
  list-style: none;
  padding: 0;
}

.linklist li {
  display: block;
  padding: 0;
  border-top: 1px solid var(--color-separator);
}
.linklist li + li {
  margin-top: var(--space-xs);
}

.linklist a {
  text-decoration: none;
}
.linklist a:hover {
  color: currentColor;
}
.linklist a:hover .arrow {
  transform: translateX(-2rem);
}
.linklist .arrow {
  margin: 0;
  text-align: right;
  transition: transform 0.2s ease-out;
}

.linklist h3,
.linklist p {
  margin: 0;
}

.linklist .content {
  padding: var(--space-s) 0;
}

.linklist .image {
  width: 100%;
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
}
.linklist .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius);
}

@media (max-width: 1023px) {
  .linklist li + li {
    margin-top: var(--space-m);
  }
  .linklist a .arrow {
    display: none;
  }
  .linklist h3 {
    position: relative;
    margin-bottom: var(--space-m);
  }
  .linklist a h3::after {
    content: "→";
    position: absolute;
    top: 0;
    right: 0;
    transition: transform 0.2s ease-out;
  }
  .linklist a:hover h3::after {
    transform: translateX(-1rem);
  }
  .linklist .text {
    display: block;
  }
}

.table li {
  border-top: 1px solid var(--color-separator);
  padding: var(--space-s) 0;
}
.table li + li {
  margin-top: var(--space-xs);
}
.table h3,
.table p {
  margin: 0;
}

.contentblock-cta {
  padding: var(--space-s) 0;
}
.contentblock-cta .background {
  min-height: 40rem;
  background-color: var(--color-main);
  border-radius: var(--radius);
  overflow: hidden;
}
.contentblock-cta .background img,
.contentblock-cta .background video {
  display: block;
  width: 100%;
  height: 60rem;
  object-fit: cover;
  border-radius: var(--radius);
}
.contentblock-cta .content {
  position: absolute;
  inset: var(--space-s);
  color: var(--color-white);
}
.contentblock-cta .left {
  padding-left: var(--space-s);
}
.contentblock-cta .right {
  display: flex;
  flex-direction: column;
}
.contentblock-cta .key {
  opacity: 0.5;
  margin: 0;
}
.contentblock-cta .value {
  margin: 0;
}

.contentblock-cta .benefit + .button-wrapper a {
  margin-top: var(--space-s);
}
.contentblock-cta .button-wrapper {
  margin-top: auto;
}
.contentblock-cta .button-wrapper.black a {
  background-color: var(--color-black) !important;
}
.contentblock-cta .button-wrapper.black a:hover {
  background-color: var(--color-hover) !important;
}

@media (max-width: 1023px) {
  .contentblock-cta .background img,
  .contentblock-cta .background video {
    height: 46rem;
  }
  .contentblock-cta .content {
    display: flex;
    flex-direction: column;
    gap: var(--space-m);
  }
  .contentblock-cta .right {
    flex: 1;
    padding-left: var(--space-s);
  }
}

/* Content Block Toggles */
.toggles .headings .typo-s {
  margin: 0 0 var(--space-s);
}
.toggles .toggle-wrapper {
  border-top: 1px solid var(--color-separator);
}

.toggles .toggle-button {
  position: relative;
  padding: 2rem 0;
  cursor: pointer;
}
.toggles .toggle-button > *:last-child {
  padding-right: 6rem;
}
.toggles .toggle-button::before,
.toggles .toggle-button::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -0.2rem;
  height: 3px;
  width: 3rem;
  background: var(--color-black);
}
.toggles .toggle-button::after {
  transform: rotate(90deg);
}
.toggles .toggle-wrapper.open .toggle-button::after {
  display: none;
}

.toggles .toggle-button .typo-l,
.toggles .toggle-button .typo-m {
  margin: 0;
  align-self: center;
}

.toggles .toggle-content {
  height: 0;
  overflow: hidden;
  transition: height 0.3s ease-out;
}

.toggles .content > div {
  padding-bottom: var(--space-m);
}
.toggles .content > div:first-child {
  padding-top: 2rem;
}
.toggles .content > div:last-child {
  padding-bottom: var(--space-l);
}
.toggles .label {
  opacity: 0.5;
}
.toggles .wysiwyg {
  padding-right: calc(var(--padding-1-column) * 2);
}
@media (max-width: 767px) {
  .toggles .toggle-button::before,
  .toggles .toggle-button::after {
    margin-top: -0.1rem;
    height: 2px;
    width: 2rem;
  }
  .toggles .content > div:first-child {
    padding-top: 1.5rem;
  }
  .toggles .wysiwyg {
    padding-right: 0;
  }
}

/* Content Block Form */
@media (max-width: 1023px) {
  .contentblock-form .gap {
    display: none;
  }
  .contentblock-form .d-grid {
    gap: 3rem;
  }
}

/* CF7 form */
.wpcf7-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-s);
}

.wpcf7-form label {
  display: block;
  width: 100%;
  margin: 0 0 var(--space-s);
}
.wpcf7-form label span {
  display: none;
}

.wpcf7-form input,
.wpcf7-form textarea {
  width: 100%;
}
.wpcf7-form input.wpcf7-not-valid,
.wpcf7-form textarea.wpcf7-not-valid {
  border-color: var(--color-hover);
}

.wpcf7-form input[type="submit"] {
  width: auto;
}

.wpcf7-form label span.wpcf7-form-control-wrap {
  display: inline;
}

.wpcf7-form .form-consent {
  margin: 0;
}
.wpcf7-form .form-consent .wpcf7-list-item {
  margin: 0;
}
.wpcf7-form .form-consent label {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 4rem;
  cursor: pointer;
}
.wpcf7-form .form-consent input {
  position: absolute;
  opacity: 0;
  width: 1px;
}
.wpcf7-form .form-consent .wpcf7-list-item-label {
  display: block;
  padding-left: calc(var(--space-s) + 4rem);
}
.wpcf7-form .form-consent .wpcf7-list-item-label::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  height: 4rem;
  width: 4rem;
  background-color: var(--color-grey);
  border: 1px solid var(--color-grey);
  border-radius: var(--radius);
  font-size: 3rem;
  line-height: 4rem;
  text-align: center;
}
.wpcf7-form .form-consent input:checked + .wpcf7-list-item-label::before {
  content: "✓";
}
.wpcf7-form .form-consent label:hover .wpcf7-list-item-label::before {
  border-color: var(--color-separator);
}
.wpcf7-form .form-consent input:focus-visible + .wpcf7-list-item-label::before {
  border-color: var(--color-black);
}

.wpcf7 .wpcf7-form .wpcf7-response-output {
  width: 100%;
  margin: var(--space-s) 0 0;
  padding: var(--space-s);
  border: 1px solid var(--color-main);
  border-radius: var(--radius);
}
.wpcf7 .wpcf7-form.invalid .wpcf7-response-output {
  position: relative;
  padding-left: var(--padding-1-column);
  background-color: var(--color-hover);
  border: none;
  color: var(--color-white);
}
.wpcf7 .wpcf7-form.invalid .wpcf7-response-output::before {
  content: "Error";
  position: absolute;
  left: var(--space-s);
  top: var(--space-s);
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s);
  text-transform: uppercase;
}

@media (max-width: 1023px) {
  .wpcf7-form .form-row {
    display: block;
  }

  .wpcf7-form .form-consent label {
    min-height: 3rem;
  }

  .wpcf7-form .form-consent .wpcf7-list-item-label {
    padding-left: calc(var(--space-s) + 3rem);
  }
  .wpcf7-form .form-consent .wpcf7-list-item-label::before {
    height: 3rem;
    width: 3rem;
    font-size: 2.4rem;
    line-height: 3rem;
  }
}

.wpcf7-form .codedropz-upload-wrapper {
  margin-bottom: var(--space-s);
}

.wpcf7-form .codedropz-upload-handler {
  background-color: var(--color-grey);
  border: 1px dashed var(--color-separator);
  border-radius: var(--radius);
}
.wpcf7-form .codedropz-upload-handler:hover {
  border-style: solid;
}
.wpcf7-form .codedropz-upload-handler.codedropz-dragover {
  border: 1px dashed var(--color-black);
}

.wpcf7-form .codedropz-upload-container {
  padding: 1rem;
}

.wpcf7-form .codedropz-upload-inner {
  min-height: 18rem;
  display: flex;
  flex-direction: column;
  text-align: left;
}
.wpcf7-form .codedropz-upload-inner h3 {
  margin: 0;
  font-size: var(--font-size-m);
  line-height: 1.2;
}
.wpcf7-form .codedropz-upload-handler span,
.wpcf7-form .cd-upload-btn {
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s);
  text-transform: uppercase;
}
.wpcf7-form .codedropz-upload-inner span {
  display: block;
  margin-top: auto;
  opacity: 0.5;
}
.wpcf7-form .cd-upload-btn {
  display: flex;
  padding: 0.75rem 0;
}
.wpcf7-form .dnd-upload-counter {
  right: 1rem;
  bottom: 1.75rem;
  opacity: 0.5;
}

.wpcf7-form .dnd-upload-status {
  padding: 1rem 0;
}
.wpcf7-form .dnd-upload-status.in-progress {
  margin-bottom: var(--space-s);
}
.wpcf7-form .dnd-upload-status.in-progress:last-child {
  margin-bottom: var(--space-m);
}
.wpcf7-form .dnd-upload-status .dnd-upload-image {
  position: absolute;
  left: 0;
  top: 1rem;
  width: 1.6rem;
  height: 3rem;
  border: none;
}
.wpcf7-form .dnd-upload-status .dnd-upload-image span.file {
  background-image: url(../img/icons/icon-file.svg);
}
.wpcf7-form .dnd-upload-status .dnd-upload-details {
  padding-left: 2.6rem;
  width: 100%;
}
.wpcf7-form .dnd-upload-status .dnd-upload-details .name {
  display: flex;
  align-items: center;
  padding: 0;
  color: var(--color-black);
  font-size: var(--font-size-m);
  line-height: 1.2;
}
.wpcf7-form .dnd-upload-status .dnd-upload-details .name em {
  display: inline-block;
  margin-right: 2.5rem;
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s);
  text-transform: uppercase;
  opacity: 0.5;
}

.wpcf7-form .dnd-upload-status .dnd-upload-details .remove-file {
  top: 1.2rem;
}
.wpcf7-form .dnd-upload-status .dnd-upload-details .remove-file span:after {
  content: "✕";
  width: 2.5rem;
  height: 3rem;
  background: none;
  text-align: right;
}
.wpcf7-form .dnd-upload-status .dnd-upload-details .remove-file .deleting {
  font-family: "JetBrainsMono", sans-serif;
  text-transform: uppercase;
  color: rgba(0, 0, 0, 0.5);
}

.wpcf7-form .dnd-upload-status .dnd-upload-details .dnd-progress-bar {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: var(--color-separator);
  border-radius: 0;
  overflow: visible;
}
.wpcf7-form .dnd-upload-status .dnd-upload-details .dnd-progress-bar span {
  background-color: var(--color-black);
  color: rgba(0, 0, 0, 0.5);
}
.wpcf7-form
  .dnd-upload-status.complete
  .dnd-upload-details
  .dnd-progress-bar
  span {
  opacity: 0;
}

.wpcf7-form .dnd-upload-status .dnd-upload-details span.has-error {
  display: block;
  color: var(--color-hover);
  font-family: "JetBrainsMono", sans-serif;
  font-size: var(--font-size-s);
  text-transform: uppercase;
}

@media (max-width: 1023px) {
  .wpcf7-form .codedropz-upload-inner {
    min-height: initial;
  }
  .wpcf7-form .codedropz-upload-inner h3,
  .wpcf7-form .codedropz-upload-inner span {
    display: none;
  }
  .wpcf7-form .cd-upload-btn {
    display: block;
    height: 10rem;
    padding: 0;
  }

  .wpcf7-form .dnd-upload-counter {
    left: 1rem;
    right: initial;
    bottom: 1rem;
  }

  .wpcf7-form .dnd-upload-status .dnd-upload-image {
    width: 1.5rem;
    height: 1.8rem;
  }
  .wpcf7-form .dnd-upload-status .dnd-upload-image span.file {
    width: 1.4rem;
    height: 1.8rem;
  }

  .wpcf7-form .dnd-upload-status .dnd-upload-details {
    padding-left: 2.4rem;
  }
}

#cookiebar {
}

#cookiebar,
#cookiebar .bar {
  height: 64px;
}

#cookiebar .bar {
  width: 100%;
  background: #fff;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 1200;
  box-sizing: border-box;
  padding: 9px 0;
}

#cookiebar .bar .button {
  margin: 5px;
  padding: 6px 10px !important;
  font-size: 0.7rem;
  border-width: 2px;
}

@media (max-width: 840px) {
  #cookiebar,
  #cookiebar .bar {
    height: auto;
    padding: 10px 0;
  }
}

.error404 {
  background-color: var(--color-main);
  color: var(--color-white);
}
.error404 .main {
  min-height: calc(100vh - 410px);
}
.error404 .main .content {
  padding: 12rem 0 7rem;
}
@media (max-width: 767px) {
  .error404 .main {
    min-height: calc(100vh - 34rem);
  }
}
