@charset "UTF-8";
/* Document
 * ========================================================================== */
/**
 * Add border box sizing in all browsers (opinionated).
 */
*,
::before,
::after {
  box-sizing: border-box;
}

/**
 * 1. Add text decoration inheritance in all browsers (opinionated).
 * 2. Add vertical alignment inheritance in all browsers (opinionated).
 */
::before,
::after {
  text-decoration: inherit; /* 1 */
  vertical-align: inherit; /* 2 */
}

/**
 * 1. Use the default cursor in all browsers (opinionated).
 * 2. Change the line height in all browsers (opinionated).
 * 3. Use a 4-space tab width in all browsers (opinionated).
 * 4. Remove the grey highlight on links in iOS (opinionated).
 * 5. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 * 6. Breaks words to prevent overflow in all browsers (opinionated).
 */
html {
  cursor: default; /* 1 */
  line-height: 1.5; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  -webkit-tap-highlight-color: transparent;
  -ms-text-size-adjust: 100%; /* 5 */
  -webkit-text-size-adjust: 100%; /* 5 */
  word-break: break-word; /* 6 */
}

/* Sections
 * ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Edge, Firefox, and Safari.
 */
h1 {
  margin: 0.67em 0;
}

/* Grouping content
 * ========================================================================== */
/**
 * Remove the margin on nested lists in Chrome, Edge, IE, and Safari.
 */
dl dl,
dl ol,
dl ul,
ol dl,
ul dl {
  margin: 0;
}

/**
 * Remove the margin on nested lists in Edge 18- and IE.
 */
ol ol,
ol ul,
ul ol,
ul ul {
  margin: 0;
}

/**
 * 1. Correct the inheritance of border color in Firefox.
 * 2. Add the correct box sizing in Firefox.
 * 3. Show the overflow in Edge 18- and IE.
 */
hr {
  color: inherit; /* 1 */
  height: 0; /* 2 */
  overflow: visible; /* 3 */
}

/**
 * Add the correct display in IE.
 */
main {
  display: block;
}

/**
 * Remove the list style on navigation lists in all browsers (opinionated).
 */
nav ol,
nav ul {
  list-style: none;
  padding: 0;
}

/**
 * Prevent VoiceOver from ignoring list semantics in Safari (opinionated).
 */
nav li::before {
  content: "​";
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 * 3. Prevent overflow of the container in all browsers (opinionated).
 */
pre {
  font-family: monospace; /* 1 */
  font-size: 1em; /* 2 */
  overflow: auto; /* 3 */
  -ms-overflow-style: scrollbar; /* 3 */
}

/* Text-level semantics
 * ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * Add the correct text decoration in Edge 18-, IE, and Safari.
 */
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/* Embedded content
 * ========================================================================== */
/*
 * Change the alignment on media elements in all browsers (opinionated).
 */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on iframes in all browsers (opinionated).
 */
iframe {
  border-style: none;
}

/**
 * Remove the border on images within links in IE 10-.
 */
img {
  border-style: none;
}

/**
 * Change the fill color to match the text color in all browsers (opinionated).
 */
svg:not([fill]) {
  fill: currentColor;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}

/* Tabular data
 * ========================================================================== */
/**
 * 1. Collapse border spacing in all browsers (opinionated).
 * 2. Correct table border color inheritance in all Chrome, Edge, and Safari.
 * 3. Remove text indentation from table contents in Chrome, Edge, and Safari.
 */
table {
  border-collapse: collapse; /* 1 */
  border-color: inherit; /* 2 */
  text-indent: 0; /* 3 */
}

/* Forms
 * ========================================================================== */
/**
 * Remove the margin on controls in Safari.
 */
button,
input,
select {
  margin: 0;
}

/**
 * 1. Show the overflow in IE.
 * 2. Remove the inheritance of text transform in Edge 18-, Firefox, and IE.
 */
button {
  overflow: visible; /* 1 */
  text-transform: none; /* 2 */
}

/**
 * Correct the inability to style buttons in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * 1. Change the inconsistent appearance in all browsers (opinionated).
 * 2. Correct the padding in Firefox.
 */
fieldset {
  border: 1px solid #a0a0a0; /* 1 */
  padding: 0.35em 0.75em 0.625em; /* 2 */
}

/**
 * Show the overflow in Edge 18- and IE.
 */
input {
  overflow: visible;
}

/**
 * 1. Correct the text wrapping in Edge 18- and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 */
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in Edge 18- and IE.
 * 2. Add the correct vertical alignment in Chrome, Edge, and Firefox.
 */
progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the inheritance of text transform in Firefox.
 */
select {
  text-transform: none;
}

/**
 * 1. Remove the margin in Firefox and Safari.
 * 2. Remove the default vertical scrollbar in IE.
 * 3. Change the resize direction in all browsers (opinionated).
 */
textarea {
  margin: 0; /* 1 */
  overflow: auto; /* 2 */
  resize: vertical; /* 3 */
  resize: block; /* 3 */
}

/**
 * Remove the padding in IE 10-.
 */
[type=checkbox],
[type=radio] {
  padding: 0;
}

/**
 * 1. Correct the odd appearance in Chrome, Edge, and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Safari.
 */
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

/**
 * Remove the inner padding in Chrome, Edge, and Safari on macOS.
 */
::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style upload buttons in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/**
 * Remove the inner border and padding of focus outlines in Firefox.
 */
::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus outline styles unset by the previous rule in Firefox.
 */
:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Remove the additional :invalid styles in Firefox.
 */
:-moz-ui-invalid {
  box-shadow: none;
}

/* Interactive
 * ========================================================================== */
/*
 * Add the correct display in Edge 18- and IE.
 */
details {
  display: block;
}

/*
 * Add the correct styles in Edge 18-, IE, and Safari.
 */
dialog {
  background-color: white;
  border: solid;
  color: black;
  display: block;
  height: -moz-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: fit-content;
}

dialog:not([open]) {
  display: none;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Scripting
 * ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */
template {
  display: none;
}

/* User interaction
 * ========================================================================== */
/*
 * Remove the tapping delay in IE 10.
 */
a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation;
}

/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}

/* Accessibility
 * ========================================================================== */
/**
 * Change the cursor on busy elements in all browsers (opinionated).
 */
[aria-busy=true] {
  cursor: progress;
}

/*
 * Change the cursor on control elements in all browsers (opinionated).
 */
[aria-controls] {
  cursor: pointer;
}

/*
 * Change the cursor on disabled, not-editable, or otherwise
 * inoperable elements in all browsers (opinionated).
 */
[aria-disabled=true],
[disabled] {
  cursor: not-allowed;
}

/*
 * Change the display on visually hidden accessible elements
 * in all browsers (opinionated).
 */
[aria-hidden=false][hidden] {
  display: initial;
}

[aria-hidden=false][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  position: absolute;
}

/**
 * Restrict sizing to the page width in all browsers (opinionated).
 */
iframe,
img,
input,
select,
textarea {
  height: auto;
  max-width: 100%;
}

/**
 * 1. Change the inconsistent appearance in all browsers (opinionated).
 * 2. Add typography inheritance in all browsers (opinionated).
 */
button,
input,
select,
textarea {
  background-color: transparent; /* 1 */
  border: 1px solid WindowFrame; /* 1 */
  color: inherit; /* 1 */
  font: inherit; /* 2 */
  letter-spacing: inherit; /* 2 */
  padding: 0.25em 0.375em; /* 1 */
}

/**
 * Change the inconsistent appearance in all browsers (opinionated).
 */
select {
  -moz-appearance: none;
  -webkit-appearance: none;
  background: no-repeat right center/1em;
  border-radius: 0;
  padding-right: 1em;
}

/**
 * Change the inconsistent appearance in all browsers (opinionated).
 */
/**
 * Remove the border and padding in all browsers (opinionated).
 */
[type=color],
[type=range] {
  border-width: 0;
  padding: 0;
}

/**
 * Change the inconsistent appearance in IE (opinionated).
 */
::-ms-expand {
  display: none;
}

/**
 * Correct the inconsistent appearance in IE (opinionated).
 */
:-ms-input-placeholder {
  color: rgba(0, 0, 0, 0.54);
}

/* https://utilitybend.com/blog/added-to-my-css-reset-interpolate-size-the-quality-of-life-feature-we-all-wanted-at-some-point */
@supports (interpolate-size: allow-keywords) {
  :root {
    interpolate-size: allow-keywords;
  }
}

/*
* 1. Remove animations when motion is reduced (opinionated).
* 2. Remove fixed background attachments when motion is reduced (opinionated).
* 3. Remove timed scrolling behaviors when motion is reduced (opinionated).
* 4. Remove transitions when motion is reduced (opinionated).
*/
@media (prefers-reduced-motion: reduce) {
  *,
  ::before,
  ::after {
    animation-delay: -1ms !important; /* 1 */
    animation-duration: 1ms !important; /* 1 */
    animation-iteration-count: 1 !important; /* 1 */
    background-attachment: initial !important; /* 2 */
    scroll-behavior: auto !important; /* 3 */
    transition-delay: 0s !important; /* 4 */
    transition-duration: 0s !important; /* 4 */
  }
}
:root {
  --transitionTime: 300ms;
}

@keyframes appearImage {
  from {
    opacity: 0;
    transform: scale(1.1);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes bounceDown {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(1rem);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes slideUpAppear {
  from {
    opacity: 0;
    transform: translate(0, 10%);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes slideDownAppear {
  from {
    opacity: 0;
    transform: translate(0, -15%);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes swingAppear {
  0% {
    transform: rotate(10deg);
  }
  25% {
    transform: rotate(-8deg);
  }
  50% {
    transform: rotate(6deg);
  }
  75% {
    transform: rotate(-4deg);
  }
  88% {
    transform: rotate(2deg);
  }
  100% {
    transform: rotate(0);
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scaleX(0);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
  }
}
.fade-in {
  opacity: 0;
  transition: var(--transitionTime) opacity ease-in-out;
}
.fade-in-active {
  opacity: 1;
}

.scale-in {
  opacity: 0;
  transform: scale(1.1);
  transition: var(--transitionTime) opacity ease-in-out, var(--transitionTime) transform ease-in-out;
}
.scale-in-active {
  opacity: 1;
  transform: scale(1);
}

.slide-in {
  opacity: 0;
  transform: translateY(4rem);
  transition: transform var(--transitionTime) cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity var(--transitionTime) cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.slide-in-active {
  opacity: 1;
  transform: translateY(0);
}

:root {
  --textHeading: var(--themeTitle, #333333);
  --textHeadingAccent: var(--themeTitleAccent, #000000);
  --text: var(--themeText, #333333);
}

:root {
  --black: #242222;
  --grayDark: #7F7F7F;
  --gray: #838383;
  --grayLight: #DDDDDD;
  --white: #FFFFFF;
  --error: #D86947;
  --success: #C8D57C;
  --ghostWhite: rgba(255, 255, 255, 0.1);
  --ghostWhite5: rgba(255, 255, 255, 0.5);
  --ghostBlack: rgba(0, 0, 0, 0.1);
  --ghostBlack05: rgba(0, 0, 0, 0.05);
  --ghostBlack2: rgba(0, 0, 0, 0.2);
  --ghostBlack5: rgba(0, 0, 0, 0.5);
  --text: var(--themeText, var(--black));
  --textHeading: var(--themeTitle, var(--black));
  --textHeadingAccent: var(--themeTitleAccent, var(--grayDark));
  --icon: var(--icon, var(--text));
}

:root {
  --blockMargin: 3rem;
  --blockPadding: 1.75rem;
  --gridGap: 1.75rem;
  --marginElement2Button: 2.25rem;
  --marginElement2Element: 1.25rem;
  --marginText2Button: 2.75em;
  --marginText2Element: 2.75em;
  --marginText2Text: 1em;
  --marginTitle2Button: 0.82em;
  --marginTitle2Element: 0.82em;
  --marginTitle2Text: 0.82em;
}
@media (min-width: 48em) {
  :root {
    --blockMargin: 3.5rem;
    --marginElement2Element: 1.5rem;
    --marginText2Button: 2.67em;
    --textMaxLineLength: 46rem;
  }
}
@media (min-width: 64em) {
  :root {
    --blockMargin: 4.5rem;
    --gridGap: 2rem;
    --marginElement2Button: 2.625rem;
    --marginElement2Element: 2rem;
    --marginText2Button: 2.7em;
    --marginText2Element: 2em;
    --marginTitle2Button: 0.74em;
    --marginTitle2Text: 0.74em;
  }
}
@media (min-width: 80em) {
  :root {
    --blockMargin: 6rem;
    --blockPadding: 2rem;
    --gridGap: 2.5rem;
    --marginElement2Button: 2.875rem;
    --marginElement2Element: 2.5rem;
    --marginText2Button: 2.75em;
    --marginText2Element: 2.2em;
    --marginTitle2Button: 0.625em;
    --marginTitle2Text: 0.6875em;
  }
}
@media (min-width: 90em) {
  :root {
    --blockMargin: 6.375rem;
    --blockPadding: 2.5rem;
    --marginElement2Button: 3.5rem;
    --marginText2Element: 2.7em;
    --marginTitle2Button: 0.75em;
    --marginTitle2Text: 0.75em;
  }
}
@media (min-width: 120em) {
  :root {
    --blockMargin: 8.5rem;
  }
}
@media (min-width: 160em) {
  :root {
    --blockMargin: 12.5rem;
  }
}

@font-face {
  font-display: optional;
  font-family: "Montserrat";
  font-style: normal;
  font-stretch: normal;
  font-weight: 200;
  src: url("/magiq-assets/fonts/montserrat/montserrat-extralight-200.woff2") format("woff2"), url("/magiq-assets/fonts/montserrat/montserrat-extralight-200.woff") format("woff"), url("/magiq-assets/fonts/montserrat/montserrat-extralight-200.otf") format("opentype");
}
@font-face {
  font-display: optional;
  font-family: "Montserrat";
  font-style: normal;
  font-stretch: normal;
  font-weight: 300;
  src: url("/magiq-assets/fonts/montserrat/montserrat-light-300.woff2") format("woff2"), url("/magiq-assets/fonts/montserrat/montserrat-light-300.woff") format("woff"), url("/magiq-assets/fonts/montserrat/montserrat-light-300.otf") format("opentype");
}
@font-face {
  font-display: optional;
  font-family: "Montserrat";
  font-style: normal;
  font-stretch: normal;
  font-weight: 500;
  src: url("/magiq-assets/fonts/montserrat/montserrat-medium-500.woff2") format("woff2"), url("/magiq-assets/fonts/montserrat/montserrat-medium-500.woff") format("woff"), url("/magiq-assets/fonts/montserrat/montserrat-medium-500.otf") format("opentype");
}
@font-face {
  font-display: optional;
  font-family: "Montserrat";
  font-style: normal;
  font-stretch: normal;
  font-weight: 700;
  src: url("/magiq-assets/fonts/montserrat/montserrat-bold-700.woff2") format("woff2"), url("/magiq-assets/fonts/montserrat/montserrat-bold-700.woff") format("woff"), url("/magiq-assets/fonts/montserrat/montserrat-bold-700.otf") format("opentype");
}
@font-face {
  font-display: optional;
  font-family: "Montserrat";
  font-style: normal;
  font-stretch: normal;
  font-weight: 800;
  src: url("/magiq-assets/fonts/montserrat/montserrat-extrabold-800.woff2") format("woff2"), url("/magiq-assets/fonts/montserrat/montserrat-extrabold-800.woff") format("woff"), url("/magiq-assets/fonts/montserrat/montserrat-extrabold-800.otf") format("opentype");
}
:root {
  --rounding-interval: 0.125rem;
}

@property --h1-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h1-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h1-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 4.5rem;
}
@property --h1-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 2rem;
}
@property --h1-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 4.5rem;
}
@property --h1-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h1-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h1-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h1-font-size: clamp(
    var(--h1-mobile-font-size),
    var(--h1-font-size-val),
    var(--h1-desktop-font-size)
  );
}

h1, .h1 {
  color: var(--themeTitle);
  font-family: var(--h1-font-family);
  font-size: round(nearest, var(--h1-font-size), var(--rounding-interval));
  font-weight: var(--h1-font-weight);
  letter-spacing: var(--h1-letter-spacing);
  line-height: var(--h1-line-height);
}
h1 .accent, .h1 .accent {
  color: var(--themeTitleAccent);
}
h1 b, h1 strong, .h1 b, .h1 strong {
  font-weight: 700;
}

@property --h2xl-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h2xl-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h2xl-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h2xl-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --h2xl-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h2xl-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h2xl-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h2xl-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h2xl-font-size: clamp(
    var(--h2xl-mobile-font-size),
    var(--h2xl-font-size-val),
    var(--h2xl-desktop-font-size)
  );
}

h2xl, .h2xl {
  color: var(--themeTitle);
  font-family: var(--h2xl-font-family);
  font-size: round(nearest, var(--h2xl-font-size), var(--rounding-interval));
  font-weight: var(--h2xl-font-weight);
  letter-spacing: var(--h2xl-letter-spacing);
  line-height: var(--h2xl-line-height);
}
h2xl .accent, .h2xl .accent {
  color: var(--themeTitleAccent);
}
h2xl b, h2xl strong, .h2xl b, .h2xl strong {
  font-weight: 700;
}

@property --h2-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h2-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h2-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h2-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --h2-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h2-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h2-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h2-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h2-font-size: clamp(
    var(--h2-mobile-font-size),
    var(--h2-font-size-val),
    var(--h2-desktop-font-size)
  );
}

h2, .h2 {
  color: var(--themeTitle);
  font-family: var(--h2-font-family);
  font-size: round(nearest, var(--h2-font-size), var(--rounding-interval));
  font-weight: var(--h2-font-weight);
  letter-spacing: var(--h2-letter-spacing);
  line-height: var(--h2-line-height);
}
h2 .accent, .h2 .accent {
  color: var(--themeTitleAccent);
}
h2 b, h2 strong, .h2 b, .h2 strong {
  font-weight: 700;
}

@property --h3-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h3-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h3-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h3-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --h3-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h3-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h3-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h3-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h3-font-size: clamp(
    var(--h3-mobile-font-size),
    var(--h3-font-size-val),
    var(--h3-desktop-font-size)
  );
}

h3, .h3 {
  color: var(--themeTitle);
  font-family: var(--h3-font-family);
  font-size: round(nearest, var(--h3-font-size), var(--rounding-interval));
  font-weight: var(--h3-font-weight);
  letter-spacing: var(--h3-letter-spacing);
  line-height: var(--h3-line-height);
}
h3 .accent, .h3 .accent {
  color: var(--themeTitleAccent);
}
h3 b, h3 strong, .h3 b, .h3 strong {
  font-weight: 700;
}

@property --h4-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h4-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h4-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h4-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --h4-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h4-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h4-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h4-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h4-font-size: clamp(
    var(--h4-mobile-font-size),
    var(--h4-font-size-val),
    var(--h4-desktop-font-size)
  );
}

h4, .h4 {
  color: var(--themeTitle);
  font-family: var(--h4-font-family);
  font-size: round(nearest, var(--h4-font-size), var(--rounding-interval));
  font-weight: var(--h4-font-weight);
  letter-spacing: var(--h4-letter-spacing);
  line-height: var(--h4-line-height);
}
h4 .accent, .h4 .accent {
  color: var(--themeTitleAccent);
}
h4 b, h4 strong, .h4 b, .h4 strong {
  font-weight: 700;
}

@property --h5-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --h5-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --h5-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h5-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --h5-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --h5-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --h5-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --h5-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --h5-font-size: clamp(
    var(--h5-mobile-font-size),
    var(--h5-font-size-val),
    var(--h5-desktop-font-size)
  );
}

h5, .h5 {
  color: var(--themeTitle);
  font-family: var(--h5-font-family);
  font-size: round(nearest, var(--h5-font-size), var(--rounding-interval));
  font-weight: var(--h5-font-weight);
  letter-spacing: var(--h5-letter-spacing);
  line-height: var(--h5-line-height);
}
h5 .accent, .h5 .accent {
  color: var(--themeTitleAccent);
}
h5 b, h5 strong, .h5 b, .h5 strong {
  font-weight: 700;
}

@property --body-font-family {
  syntax: "<string>";
  inherits: true;
  initial-value: "Arial";
}
@property --body-font-weight {
  syntax: "<number> | normal | bold | bolder | lighter";
  inherits: true;
  initial-value: 300;
}
@property --body-desktop-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --body-mobile-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 1.5rem;
}
@property --body-font-size {
  syntax: "<length>";
  inherits: true;
  initial-value: 3rem;
}
@property --body-line-height {
  syntax: "<number>";
  inherits: true;
  initial-value: 1.1;
}
@property --body-letter-spacing {
  syntax: "<length>";
  inherits: true;
  initial-value: 0;
}
@property --body-font-size-val {
  syntax: "<length>";
  inherits: true;
  initial-value: 1rem;
}
:root {
  --body-font-size: clamp(
    var(--body-mobile-font-size),
    var(--body-font-size-val),
    var(--body-desktop-font-size)
  );
}

body, .body {
  color: var(--themeTitle);
  font-family: var(--body-font-family);
  font-size: round(nearest, var(--body-font-size), var(--rounding-interval));
  font-weight: var(--body-font-weight);
  letter-spacing: var(--body-letter-spacing);
  line-height: var(--body-line-height);
}
body .accent, .body .accent {
  color: var(--themeTitleAccent);
}
body b, body strong, .body b, .body strong {
  font-weight: 700;
}

html,
body,
p,
table {
  color: var(--themeText, #333333);
}

html {
  font-size: 100%;
}

main a {
  color: var(--themeText, #333333);
}
main a:hover {
  text-decoration: none;
}

h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4 {
  display: block;
  margin: 0 0 var(--marginTitle2Element);
  word-break: keep-all;
}

em, .intro {
  color: var(--themeTitle, #333333);
}

p {
  margin: 0 0 1rem;
  max-width: var(--textMaxLineLength);
}

@media (min-width: 48em) {
  br.br--mobile {
    display: none;
  }
}

ul, ol {
  margin: 0 0 1rem;
}

.list-unstyle {
  list-style: none;
  margin: 0 0 1rem;
  padding: 0;
}

.list-inline {
  display: inline;
  list-style: none;
}
.list-inline li {
  display: inline;
}
.list-inline li::after {
  content: ", ";
}
.list-inline li:last-child::after {
  content: "";
}

main ul:not([class]),
.list-bullets {
  list-style: none;
  padding: 0;
}
main ul:not([class]) li,
.list-bullets li {
  line-height: 1.25;
  margin: 0;
  padding: 0 0 0 1.5rem;
  position: relative;
}
main ul:not([class]) li::before,
.list-bullets li::before {
  background: var(--themeText, #333333);
  border-radius: 50%;
  content: "";
  display: block;
  height: 0.375rem;
  left: 0;
  position: absolute;
  top: 0.5rem;
  width: 0.375rem;
}

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

html {
  background: var(--themeBackground, #FFFFFF);
  scroll-behavior: smooth;
}
@media (max-width: 47.99em) {
  html.menu-open {
    overflow: hidden;
  }
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
main {
  flex-grow: 1;
  margin-top: 4rem;
}
main.main--landing {
  margin-top: 0;
}
@media (min-width: 48em) {
  main {
    margin-top: 8rem;
  }
  main.main--landing {
    margin-top: 0;
  }
}

.form {
  display: flex;
  flex-direction: column;
  list-style: none;
  margin: 0 0 1rem;
  max-width: 45rem;
  padding: 0;
}
.form li {
  margin: 0 0 1.5rem;
  text-align: left;
}
.form li:last-child {
  margin: 0;
}
.form label {
  color: var(--theme-text);
  cursor: pointer;
  display: block;
  font-size: var(--base-font-size);
  font-weight: 700;
  text-align: left;
}
.form input[type=text],
.form input[type=email],
.form input[type=password],
.form input[type=number],
.form input[type=date],
.form input[type=time],
.form select,
.form textarea {
  background: #FFFFFF;
  border: 1px solid #242222;
  border-radius: 0;
  color: var(--themeText, #333333);
  font-size: 1rem;
  line-height: 1.375rem;
  margin: 0;
  padding: 0.875rem 1.25rem;
  transition: all var(--transitionTime) ease;
  width: 100%;
}
.form input[type=text]:focus,
.form input[type=email]:focus,
.form input[type=password]:focus,
.form input[type=number]:focus,
.form input[type=date]:focus,
.form input[type=time]:focus,
.form select:focus,
.form textarea:focus {
  background-color: color-mix(in srgb, var(--themeInputBackground, var(--white)), var(--themeInputOutline, var(--black)) 10%);
  border-color: var(--themeInputOutline, var(--black));
  color: var(--themeInputText, var(--text));
  outline: none;
}
@container style(--themeInputBackground: transparent) {
  .form input[type=text]:focus,
  .form input[type=email]:focus,
  .form input[type=password]:focus,
  .form input[type=number]:focus,
  .form input[type=date]:focus,
  .form input[type=time]:focus,
  .form select:focus,
  .form textarea:focus {
    --themeInputBackground: color-mix(in srgb, var(--primary, var(--white)), var(--themeBackground, var(--black)) 90%);
  }
}
@media (hover: hover) {
  .form input[type=text]:hover:not(:focus),
  .form input[type=email]:hover:not(:focus),
  .form input[type=password]:hover:not(:focus),
  .form input[type=number]:hover:not(:focus),
  .form input[type=date]:hover:not(:focus),
  .form input[type=time]:hover:not(:focus),
  .form select:hover:not(:focus),
  .form textarea:hover:not(:focus) {
    background-color: color-mix(in srgb, var(--themeInputBackground, var(--white)), var(--themeInputOutline, var(--black)) 5%);
    border-color: var(--themeInputOutline, var(--black));
    color: var(--themeInputText, var(--text));
  }
  @container style(--themeInputBackground: transparent) {
    .form input[type=text]:hover:not(:focus),
    .form input[type=email]:hover:not(:focus),
    .form input[type=password]:hover:not(:focus),
    .form input[type=number]:hover:not(:focus),
    .form input[type=date]:hover:not(:focus),
    .form input[type=time]:hover:not(:focus),
    .form select:hover:not(:focus),
    .form textarea:hover:not(:focus) {
      --themeInputBackground: color-mix(in srgb, var(--primary, var(--white)), var(--themeBackground, var(--black)) 95%);
    }
  }
}
.form input[type=text]:disabled,
.form input[type=email]:disabled,
.form input[type=password]:disabled,
.form input[type=number]:disabled,
.form input[type=date]:disabled,
.form input[type=time]:disabled,
.form select:disabled,
.form textarea:disabled {
  background-color: color-mix(in srgb, var(--themeInputBackground, var(--white)), var(--themeBackground, var(--black)) 75%);
  border-color: color-mix(in srgb, var(--themeInputOutline, var(--black)), var(--themeBackground, var(--black)) 75%);
  color: color-mix(in srgb, var(--themeInputText, var(--black)), var(--themeText, var(--black)) 50%);
}
@container style(--themeInputBackground: transparent) {
  .form input[type=text]:disabled,
  .form input[type=email]:disabled,
  .form input[type=password]:disabled,
  .form input[type=number]:disabled,
  .form input[type=date]:disabled,
  .form input[type=time]:disabled,
  .form select:disabled,
  .form textarea:disabled {
    background-color: color-mix(in srgb, var(--themeInputText, var(--black)), var(--themeBackground, var(--black)) 95%);
    opacity: 0.5;
  }
}
.form select:not([multiple]):not([size]) {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='8'%3E%3Cpath d='M4 0h12L10 8'/%3E%3C/svg%3E");
  background-position: center right;
  background-repeat: no-repeat;
  position: relative;
}
.form textarea {
  min-height: 10rem;
}
.form input[type=checkbox],
.form input[type=radio] {
  height: 0;
  opacity: 0;
  position: relative;
  width: 0;
}
.form input[type=checkbox] + label, .form input[type=checkbox] + span,
.form input[type=radio] + label,
.form input[type=radio] + span {
  color: var(--theme-text);
  font-weight: 400;
  padding: 0 0 0 2rem;
  position: relative;
  transition: all var(--transitionTime) ease;
}
.form input[type=checkbox] + label::before, .form input[type=checkbox] + span::before,
.form input[type=radio] + label::before,
.form input[type=radio] + span::before {
  background-color: #FFFFFF;
  border: 1px solid #7F7F7F;
  content: "";
  display: block;
  height: 1.5rem;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-0.75rem);
  width: 1.5rem;
}
.form input[type=checkbox][type=radio] + label::before, .form input[type=checkbox][type=radio] + span::before,
.form input[type=radio][type=radio] + label::before,
.form input[type=radio][type=radio] + span::before {
  border-radius: 50%;
}
.form input[type=checkbox]:not(:disabled),
.form input[type=radio]:not(:disabled) {
  cursor: pointer;
}
@media (hover: none) {
  .form input[type=checkbox]:not(:disabled):focus + label::before, .form input[type=checkbox]:not(:disabled):focus + span::before,
  .form input[type=radio]:not(:disabled):focus + label::before,
  .form input[type=radio]:not(:disabled):focus + span::before {
    border-color: #242222;
  }
}
@media (hover: hover) {
  .form input[type=checkbox]:not(:disabled):hover + label::before, .form input[type=checkbox]:not(:disabled):hover + span::before,
  .form input[type=radio]:not(:disabled):hover + label::before,
  .form input[type=radio]:not(:disabled):hover + span::before {
    border-color: #242222;
  }
}
@media (hover: none) {
  .form input[type=checkbox]:not(:disabled) + label:focus, .form input[type=checkbox]:not(:disabled) + span:focus,
  .form input[type=radio]:not(:disabled) + label:focus,
  .form input[type=radio]:not(:disabled) + span:focus {
    opacity: 0.9;
  }
}
@media (hover: hover) {
  .form input[type=checkbox]:not(:disabled) + label:hover, .form input[type=checkbox]:not(:disabled) + span:hover,
  .form input[type=radio]:not(:disabled) + label:hover,
  .form input[type=radio]:not(:disabled) + span:hover {
    opacity: 0.9;
  }
}
.form input[type=checkbox]:checked + label, .form input[type=checkbox]:checked + span,
.form input[type=radio]:checked + label,
.form input[type=radio]:checked + span {
  font-weight: 700;
}
.form input[type=checkbox]:checked[type=checkbox] + label::before, .form input[type=checkbox]:checked[type=checkbox] + span::before,
.form input[type=radio]:checked[type=checkbox] + label::before,
.form input[type=radio]:checked[type=checkbox] + span::before {
  background: #242222;
  border-color: #242222;
}
.form input[type=checkbox]:checked[type=checkbox] + label::after, .form input[type=checkbox]:checked[type=checkbox] + span::after,
.form input[type=radio]:checked[type=checkbox] + label::after,
.form input[type=radio]:checked[type=checkbox] + span::after {
  border-bottom: 0.25rem solid #FFFFFF;
  border-right: 0.25rem solid #FFFFFF;
  content: "";
  height: 1rem;
  left: 0.5rem;
  position: absolute;
  top: 50%;
  transform: translateY(-0.625rem) rotate(45deg);
  width: 0.6rem;
}
.form input[type=checkbox]:checked[type=radio] + label::after, .form input[type=checkbox]:checked[type=radio] + span::after,
.form input[type=radio]:checked[type=radio] + label::after,
.form input[type=radio]:checked[type=radio] + span::after {
  background: #242222;
  border-radius: 50%;
  content: "";
  display: block;
  height: 1rem;
  left: 0.25rem;
  position: absolute;
  top: 50%;
  transform: translateY(-0.5rem);
  width: 1rem;
}
.form input[type=checkbox]:disabled + label, .form input[type=checkbox]:disabled + span,
.form input[type=radio]:disabled + label,
.form input[type=radio]:disabled + span {
  color: #DDDDDD;
  cursor: not-allowed;
  font-weight: 400;
}
.form input[type=checkbox]:disabled + label::before, .form input[type=checkbox]:disabled + span::before,
.form input[type=radio]:disabled + label::before,
.form input[type=radio]:disabled + span::before {
  border-color: #DDDDDD;
}
.form__toggles {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0;
}
.form__toggles li {
  margin: 0;
}
.form__toggles--horizontal {
  flex-direction: row;
  gap: 1rem;
}
.form__buttons {
  display: flex;
}
.form__field > label {
  line-height: 1.5rem;
  margin: 0 0 0.5rem;
}
.form__field--required > label::after {
  color: #838383;
  content: "*";
}
.form__field--error label {
  color: #D86947;
}
.form__field--error input[type=checkbox],
.form__field--error input[type=radio] {
  filter: hue-rotate(160deg);
}
.form__field--error input[type=checkbox] + label, .form__field--error input[type=checkbox] + span,
.form__field--error input[type=radio] + label,
.form__field--error input[type=radio] + span {
  color: #D86947;
}
.form__field--error input[type=text]:not(:disabled),
.form__field--error input[type=email]:not(:disabled),
.form__field--error input[type=number]:not(:disabled),
.form__field--error select:not(:disabled),
.form__field--error textarea:not(:disabled) {
  border-color: #D86947;
  box-shadow: 0 0 0.5rem #D86947;
  color: #242222;
}
.form__field--error .btn.btn-cta {
  background-color: #D86947;
  color: #242222;
}
.form__field--disabled label {
  color: #DDDDDD;
}
.form__field__helptext {
  font-size: 1rem;
  font-style: italic;
}
.form .media-library-dropzone-add:not(.disabled) {
  background: #FFFFFF;
  border-color: #242222;
  border-width: 1px;
}
@media (hover: none) {
  .form .media-library-dropzone-add:not(.disabled):focus {
    background-color: rgba(0, 0, 0, 0.1);
  }
}
@media (hover: hover) {
  .form .media-library-dropzone-add:not(.disabled):hover {
    background-color: rgba(0, 0, 0, 0.1);
  }
}
.form .media-library-multiple.media-library-empty .media-library-add .media-library-placeholder::before, .form .media-library-multiple.media-library-empty .media-library-add .media-library-placeholder::after {
  display: none;
}
.form .media-library-button {
  background: var(--themeIcon, var(--theme-primary, #000000));
  border-color: var(--themeIcon, var(--theme-primary, #000000));
  box-shadow: none;
  color: #FFFFFF;
  z-index: 0;
}
.form .media-library-dropzone-add:not(.disabled) {
  background: #FFFFFF;
  border: 1px solid #242222;
}
@media (hover: none) {
  .form .media-library-dropzone-add:not(.disabled):focus {
    background-color: var(--themeButtonBackground, #E5E8C6);
  }
}
@media (hover: hover) {
  .form .media-library-dropzone-add:not(.disabled):hover {
    background-color: var(--themeButtonBackground, #E5E8C6);
  }
}
.form .media-library-listerrors {
  background: #FFFFFF;
  border: none;
  border-bottom: 1px #D86947 dashed;
  margin-bottom: 0;
}
.form .media-library-listerrors .media-library-row-remove {
  opacity: 1;
}
.form .media-library-listerror-icon {
  display: none;
}
.form .media-library-listerror {
  color: #D86947;
  padding: 0 1.25rem;
}
.form .media-library-listerror::before {
  display: none;
}
.form .media-library-help {
  color: var(--themeText, #333333);
  font-weight: 300;
}
@media (min-width: 48em) {
  .form {
    margin: 0 0 2rem;
  }
  .form--grid {
    display: grid;
    grid-gap: 0 var(--gridGap);
    grid-template-columns: 1fr 1fr;
    max-width: none;
  }
  .form--grid .form__field {
    grid-column-end: 1;
    grid-column-start: 1;
  }
  .form--grid .form__field--column {
    display: flex;
    flex-direction: column;
    grid-column-end: 2;
    grid-column-start: 2;
    grid-row-start: 1;
    grid-row-end: 7 span;
  }
  .form--grid .form__field--column textarea {
    height: 100%;
  }
  .form--grid .form__buttons {
    grid-column-end: 2 span;
    grid-column-start: 1;
    padding-top: var(--marginElement2Button);
  }
}
@media (min-width: 80em) {
  .form--grid {
    grid-gap: 0 var(--gridGap);
    margin-bottom: 3rem;
  }
}
@media (min-width: 90em) {
  .form--grid {
    margin-bottom: 5rem;
  }
}

.form input[type=text],
.form input[type=email],
.form input[type=number],
.form input[type=date],
.form input[type=time],
.form select,
.form textarea {
  border-color: var(--main-color_20, #242222);
  color: var(--themeInputText, #7F7F7F);
}
.form input[type=text]:focus,
.form input[type=email]:focus,
.form input[type=number]:focus,
.form input[type=date]:focus,
.form input[type=time]:focus,
.form select:focus,
.form textarea:focus {
  background-color: color-mix(in srgb, var(--themeInputBackground) 90%, var(--themeInputText) 10%);
  border-color: var(--main-color_10, #242222);
  outline: none;
}
@media (hover: hover) {
  .form input[type=text]:hover:not(:focus),
  .form input[type=email]:hover:not(:focus),
  .form input[type=number]:hover:not(:focus),
  .form input[type=date]:hover:not(:focus),
  .form input[type=time]:hover:not(:focus),
  .form select:hover:not(:focus),
  .form textarea:hover:not(:focus) {
    background-color: color-mix(in srgb, var(--themeInputBackground) 95%, var(--themeInputText) 5%);
    border-color: var(--main-color_15, #242222);
    color: var(--main-color_5, #242222);
  }
}
.form input[type=text]:disabled,
.form input[type=email]:disabled,
.form input[type=number]:disabled,
.form input[type=date]:disabled,
.form input[type=time]:disabled,
.form select:disabled,
.form textarea:disabled {
  background-color: #FFFFFF;
  border-color: #DDDDDD;
}
.form input[type=checkbox],
.form input[type=radio] {
  height: 0;
  opacity: 0;
  position: relative;
  width: 0;
}
.form input[type=checkbox] + label, .form input[type=checkbox] + span,
.form input[type=radio] + label,
.form input[type=radio] + span {
  padding: 0 0 0 1.625rem;
}
.form input[type=checkbox] + label::before, .form input[type=checkbox] + span::before,
.form input[type=radio] + label::before,
.form input[type=radio] + span::before {
  height: 1rem;
  transform: translateY(-0.5rem);
  width: 1rem;
}
.form input[type=checkbox][type=checkbox] + label::before, .form input[type=checkbox][type=checkbox] + span::before,
.form input[type=radio][type=checkbox] + label::before,
.form input[type=radio][type=checkbox] + span::before {
  border-radius: 3px;
}
.form input[type=checkbox]:checked[type=checkbox] + label::after, .form input[type=checkbox]:checked[type=checkbox] + span::after,
.form input[type=radio]:checked[type=checkbox] + label::after,
.form input[type=radio]:checked[type=checkbox] + span::after {
  border-bottom: 0.125rem solid #FFFFFF;
  border-right: 0.125rem solid #FFFFFF;
  height: 0.625rem;
  left: 0.3125rem;
  transform: translateY(-0.4rem) rotate(45deg);
  width: 0.375rem;
}
.form input[type=checkbox]:checked[type=radio] + label::after, .form input[type=checkbox]:checked[type=radio] + span::after,
.form input[type=radio]:checked[type=radio] + label::after,
.form input[type=radio]:checked[type=radio] + span::after {
  height: 0.625rem;
  left: 0.1875rem;
  transform: translateY(-0.3125rem);
  width: 0.625rem;
}
.form__toggles--horizontal {
  gap: 1.25rem;
}
.form__field > label {
  text-transform: uppercase;
}

.message {
  color: #FFFFFF;
  display: block;
  margin: 0 0 1rem;
  padding: 0.75rem 1rem 0.75rem 2.75rem;
  position: relative;
}
.message::before {
  background-repeat: no-repeat;
  content: "";
  display: block;
  height: 1.25rem;
  left: 1rem;
  position: absolute;
  top: 1.125rem;
  width: 1.25rem;
}
.message--info {
  background-color: #242222;
  color: #FFFFFF;
}
.message--info::before {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='169' height='727.384' viewBox='0 0 169 727.384'%3e%3cline id='Line_2' data-name='Line 2' y1='3' y2='5' x1='8' x2='8' fill='none' stroke='%23FFFFFF' stroke-miterlimit='10' stroke-width='2'/%3e%3cline id='Line_3' data-name='Line 3' y1='7' y2='13' x1='8' x2='8' fill='none' stroke='%23FFFFFF' stroke-miterlimit='10' stroke-width='2'/%3e%3cg id='Ellipse_4' data-name='Ellipse 4' fill='none' stroke='%23FFFFFF' stroke-width='1'%3e%3ccircle cx='8' cy='8' r='8' stroke='none'/%3e%3ccircle cx='8' cy='8' r='7.5' fill='none'/%3e%3c/g%3e%3c/svg%3e ");
  background-position: 0 1px;
}
.message--error, .form__field--error .message--info {
  background-color: #D86947;
}
.message--error::before, .form__field--error .message--info::before {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='18.005' height='17.861' viewBox='0 0 18.005 17.861'%3e%3cpath id='Path_56' data-name='Path 56' d='M24.964,82.461a1.534,1.534,0,0,0,1.5-1.5,2.348,2.348,0,0,0-.2-.8L19.877,67.4a1.621,1.621,0,0,0-2.793,0L10.6,80.266a1.6,1.6,0,0,0,.1,1.5,1.454,1.454,0,0,0,1.3.7H24.964Zm-13.866-1a.906.906,0,0,1,0-1L17.582,67.6a.959.959,0,0,1,.9-.6.872.872,0,0,1,.9.6l6.384,12.769h0a.733.733,0,0,1,.2.6,1,1,0,0,1-1,1H12A1.19,1.19,0,0,1,11.1,81.463Z' transform='translate(-9.456 -65.6)' fill='%23fff' stroke='%23fff' stroke-width='2'/%3e%3c/svg%3e ");
}
.message--success {
  background-color: #C8D57C;
  color: #242222;
}
.message--success::before {
  background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='13.421' height='9.836' viewBox='0 0 13.421 9.836'%3e%3cpath id='Path_57' data-name='Path 57' d='M26.3,15.8l-7.571,7.714L14.3,19.086' transform='translate(-13.593 -15.099)' fill='none' stroke='%23000' stroke-miterlimit='10' stroke-width='2'/%3e%3c/svg%3e ");
  background-position: 0 4px;
}

.message {
  font-weight: 500;
}
.message--info {
  background-color: #242222;
}

.btn {
  --_border-radius: var(--button-border-radius, 1.75rem);
  --_color: var(--color, var(--themeButtonBackground, var(--primary)));
  --_font-family: var(--button-font-family, var(--font-family));
  --_font-size: var(--button-font-size-val, 1rem);
  --_font-weight: var(--button-font-weight, 500);
  --_icon-color: var(--icon, var(--_text-color));
  --_letter-spacing: var(--button-letter-spacing, 0);
  --_line-height: var(--button-line-height, 1.5);
  --_padding: var(--button-padding, 0.625rem 1.375rem);
  --_text-color: var(--themeButtonText, var(--text, black));
  align-items: center;
  background: var(--_color);
  border: 1px solid var(--_color);
  border-radius: var(--_border-radius);
  color: var(--_text-color);
  cursor: pointer;
  display: inline-flex;
  font-family: var(--_font-family);
  font-size: var(--_font-size);
  font-weight: var(--_font-weight);
  letter-spacing: var(--_letter-spacing);
  line-height: var(--_line-height);
  padding: var(--_padding);
  text-decoration: none;
  transition: all var(--transitionTime) ease-in-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: nowrap;
}
.btn svg.icon.btn--icon {
  color: var(--_icon-color);
  fill: var(--_icon-color);
  height: 1rem;
  transition: all var(--transitionTime) ease-in-out;
  width: 1rem;
}
.btn svg.icon.btn--icon:first-child:not(:last-child) {
  margin-right: 0.5rem;
}
.btn svg.icon.btn--icon:last-child:not(:first-child) {
  margin-left: 0.5rem;
}
.btn.btn--primary {
  --color: var(--btn--primary-background);
  --icon: var(--btn--primary-icon);
  --_text-color: var(--btn--primary-text);
}
.btn.btn--secondary {
  --color: var(--btn--secondary-background);
  --icon: var(--btn--secondary-icon);
  --_text-color: var(--btn--secondary-text);
}
.btn.btn--tertiary {
  --color: var(--btn--tertiary-background);
  --icon: var(--btn--tertiary-icon);
  --_text-color: var(--btn--tertiary-text);
}
.btn.btn--black {
  --color: var(--btn--black-background);
  --icon: var(--btn--black-icon);
  --_text-color: var(--btn--black-text);
}
.btn.btn--white {
  --color: var(--btn--white-background);
  --icon: var(--btn--white-icon);
  --_text-color: var(--btn--white-text);
}
.btn.btn--outline {
  --_icon-color: var(--_color);
  background: transparent;
  color: var(--_color);
}
.btn.btn--outline:is(:hover, :focus) {
  --_icon-color: var(--_text-color);
  background: var(--_color);
  border-color: var(--_color);
  color: var(--_text-color);
}
.btn:focus {
  transform: scale(0.975);
}

.btn.btn--outline {
  --_icon-color: var(--_color);
  background: transparent;
  color: var(--_color);
}
.btn.btn--outline:is(:hover, :focus) {
  --_icon-color: var(--_text-color);
  background: var(--_color);
  border-color: var(--_color);
  color: var(--_text-color);
}
@media (hover: hover) {
  .btn:not(:disabled):hover:not(:focus):not(.focus), .btn:not(:disabled).hover {
    background-color: color-mix(in srgb, var(--_color), var(--_text-color) 8%);
    border-color: color-mix(in srgb, var(--_color), var(--_text-color) 8%);
    color: var(--_text-color);
  }
}
.btn:not(:disabled):focus {
  background-color: color-mix(in srgb, var(--_color), var(--_text-color) 20%);
  border-color: color-mix(in srgb, var(--_color), var(--_text-color) 20%);
  color: var(--_text-color);
}

.stretched-link::after {
  bottom: 0;
  content: "";
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}

.style-default .style-default {
  box-shadow: 1px 1px 1.25rem rgba(0, 0, 0, 0.05);
}

@view-transition {
  navigation: auto;
}
@keyframes move-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes move-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
::view-transition-old(root) {
  animation: 0.4s ease-in both move-out;
}

::view-transition-new(root) {
  animation: 0.4s ease-in both move-in;
}

@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation: none !important;
  }
}
.btn-container {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  grid-gap: 1.25rem;
  width: 100%;
}
.btn-container .btn {
  flex: 0 0 auto;
}
@media (min-width: 48em) {
  .btn-container {
    grid-gap: var(--gridGap);
  }
}
@media (min-width: 90em) {
  .btn-container {
    grid-gap: 2.5rem;
  }
}

:root {
  --container-width: calc(100vw - (2 * min(8.75vw, 3.75rem)));
}
@media (min-width: 48em) {
  :root {
    --container-width: calc(100vw - (2 * 3.75rem));
  }
}
@media (min-width: 80em) {
  :root {
    --container-width: 70rem;
  }
}
@media (min-width: 90em) {
  :root {
    --container-width: 75rem;
  }
}

.container {
  margin: 0 min(8.75vw, 3.75rem);
}
@media (min-width: 48em) {
  .container {
    margin: 0 3.75rem;
  }
}
@media (min-width: 80em) {
  .container {
    margin: 0 auto;
    max-width: var(--container-width);
  }
}

.fl {
  background: var(--themeBackground, #FFFFFF);
  color: var(--themeText, #333333);
}

@media (min-width: 90em) {
  .fl-content__content.text-container:has(+ .btn-container) {
    margin-bottom: 2.5em;
  }
}

@media (min-width: 80em) {
  .fl.fl-narrow .container {
    max-width: 56.25rem;
  }
}

.fl-vertspace + .fl.fl-vertspace {
  padding-top: 0;
}
.fl.fl-vertspace-half {
  padding-bottom: calc(var(--blockMargin) / 2);
  padding-top: calc(var(--blockMargin) / 2);
}
.fl.fl-vertspace-default {
  padding-bottom: var(--blockMargin);
  padding-top: var(--blockMargin);
}
.fl.fl-vertspace-large {
  padding-bottom: calc(var(--blockMargin) * 2);
  padding-top: calc(var(--blockMargin) * 2);
}
.fl.fl--no-spacing-top {
  padding-top: 0;
}
.fl.fl--no-spacing-bottom {
  padding-bottom: 0;
}

:root {
  --grid-gutter: 2rem;
}

.grid {
  --grid-columns: 1;
  display: grid;
  grid-gap: var(--grid-gutter);
  grid-template-columns: repeat(var(--grid-columns), 1fr);
}
@media (min-width: 48em) {
  .grid {
    --grid-columns: 2;
  }
}

.landing {
  display: flex;
  flex-direction: column;
}
.landing__main__logobar {
  display: flex;
  width: 100%;
}
.landing__main__logo {
  display: flex;
  height: 3.25rem;
  justify-content: flex-start;
  margin: 1rem auto 1rem 0;
  position: relative;
  width: 10rem;
}
.landing__main__logo img {
  display: block;
  height: 100%;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.landing__main .fl-vertspace {
  padding-top: var(--marginElement2Element);
}
.landing__main .fl-vertspace:has(+ .fl-vertspace) {
  padding-bottom: 0;
}
@media (max-width: 63.99em) {
  .landing__secondary {
    display: none;
  }
}
@media (min-width: 64em) {
  .landing {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    height: 100vh;
  }
  .landing__main {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .landing__main__logo {
    height: 5.5rem;
    justify-self: flex-start;
    width: 15rem;
  }
  .landing__secondary picture {
    display: block;
    height: 100vh;
    overflow: hidden;
    position: fixed;
    top: 0;
    width: 51%;
  }
  .landing__secondary picture img {
    height: 100%;
    max-width: none;
    -o-object-fit: cover;
       object-fit: cover;
    -o-object-position: center;
       object-position: center;
    width: 100%;
  }
}
@media (min-width: 80em) {
  .landing {
    grid-template-columns: 2fr 3fr;
  }
  .landing__logo img {
    height: 3rem;
    max-width: 12rem;
  }
  .landing .container {
    margin: 0 3.75rem;
  }
}
@media (min-width: 90em) {
  .landing {
    grid-template-columns: 1fr 2fr;
  }
  .landing__secondary picture {
    width: 67%;
  }
}
@media (min-width: 120em) {
  .landing__main .container {
    margin: 0 auto;
    max-width: 33rem;
  }
}

.text-container {
  max-width: var(--textMaxLineLength);
}
.text-container:not(:last-child) {
  margin-bottom: var(--marginText2Element);
}
.text-container:has(+ .text-container) {
  margin-bottom: var(--marginText2Text);
}
.text-container:has(+ .btn), .text-container:has(+ .btn-container) {
  margin-bottom: var(--marginText2Button);
}
.text-container > *:last-child {
  margin-bottom: 0;
}

.title {
  margin-bottom: var(--marginTitle2Element);
}
.title:last-child {
  margin-bottom: 0;
}
.title:has(+ .btn), .title:has(+ .btn-container) {
  margin-bottom: var(--marginTitle2Button);
}
.title:has(+ .text-container) {
  margin-bottom: var(--marginTitle2Text);
}
@media (min-width: 64em) {
  .title {
    max-width: 46rem;
  }
}

header,
.header {
  background: var(--themeBackground, #FFFFFF);
  box-shadow: 0 0 3px 0 rgba(0, 0, 0, 0.1);
  height: 4rem;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 100;
}
header .container,
.header .container {
  align-items: center;
  display: flex;
  flex-direction: row;
  height: 100%;
  justify-content: space-between;
  position: relative;
}
header__logo,
.header__logo {
  display: flex;
  height: 3.25rem;
  position: relative;
  width: 10rem;
}
header__logo img,
.header__logo img {
  display: block;
  height: 100%;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
header .btn,
.header .btn {
  position: relative;
}
@media (max-width: 79.99em) {
  header .btn,
  .header .btn {
    display: none;
  }
}
@media (min-width: 48em) {
  header,
  .header {
    height: 8rem;
  }
  header__logo,
  .header__logo {
    height: 5.5rem;
    justify-self: flex-start;
    width: 15rem;
  }
}
@media (min-width: 80em) {
  header__logo,
  .header__logo {
    margin-right: auto;
  }
  header .container,
  .header .container {
    justify-content: flex-end;
  }
  header .container > .btn,
  .header .container > .btn {
    font-size: 1rem;
    height: 3rem;
    line-height: 3rem;
    padding: 0 1rem;
  }
  header .container > .btn .icon,
  .header .container > .btn .icon {
    height: 0.75rem;
    width: 0.75rem;
  }
  header .container > .btn + .btn,
  .header .container > .btn + .btn {
    margin-left: var(--spacing-xs, 1rem);
  }
}

.menu {
  display: block;
}
@media (max-width: 79.99em) {
  .menu {
    width: 100%;
  }
  .menu__links {
    margin: 0 0 2rem;
    opacity: 0;
    transition: opacity 350ms ease-in-out;
    width: 100%;
  }
  .menu__links ul {
    margin: 0;
    max-height: 0;
    overflow: hidden;
    padding: 0;
    position: relative;
    transition: max-height 350ms ease-in-out, padding 350ms ease-in-out;
    width: 100%;
  }
  .menu__links label.toggle-submenu {
    margin-left: auto;
    margin-right: -0.25rem;
    position: relative;
  }
  .menu__links label.toggle-submenu .icon {
    display: block;
    height: 1.5rem;
    margin-right: 0.5rem;
    width: 1.5rem;
  }
  .menu__links input:first-child + label.toggle-submenu {
    display: flex;
    justify-content: space-between;
    margin-left: 0;
    width: 100%;
  }
  .menu__links input:first-child + label.toggle-submenu .icon {
    margin-right: 0.25rem;
  }
  .menu__links label.toggle-submenu .icon {
    transition: all var(--transitionTime) ease-in-out;
  }
  .menu__links input:checked + label.toggle-submenu .icon {
    transform: rotate(180deg);
  }
  .menu__links input:checked + label.toggle-submenu + ul {
    max-height: 100vh;
    padding: 0 0 1.5rem;
  }
  .menu__links a, .menu__links label.toggle-submenu, .menu__links span {
    color: var(--style-alternate1--Text, var(--themeText, #333333));
    display: inline-block;
    font-size: 1.375rem;
    letter-spacing: 0.04em;
    line-height: 1.2;
    position: relative;
    text-decoration: none;
    white-space: nowrap;
  }
  .menu__links > li {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    padding: 0 min(8.75vw, 3.75rem);
    position: relative;
  }
  .menu__links > li > a,
  .menu__links > li > label.toggle-submenu {
    font-weight: 700;
    padding-bottom: 0.75rem;
    padding-top: 0.75rem;
  }
  .menu__links > li > a {
    margin-right: 3rem;
  }
  .menu__links > li a.active,
  .menu__links > li label.toggle-submenu.active {
    font-weight: 700;
  }
  .menu__links li li {
    padding-right: 3rem;
  }
  .menu__links li li a, .menu__links li li span {
    padding: 0.25rem 0;
  }
  .menu__panel {
    align-items: flex-start;
    background: var(--style-alternate1--Background, var(--primary, #76776A));
    display: flex;
    flex-direction: column;
    height: 100vh;
    left: 0;
    max-height: 0;
    overflow: hidden;
    overflow-y: auto;
    padding: 0;
    position: fixed;
    right: 0;
    top: 0;
    transition: max-height 350ms ease-in-out, padding 350ms ease-in-out;
  }
  input:checked + .menu__toggle + .menu__panel {
    max-height: 100vh;
    padding: 4rem 0 1.5rem;
  }
}
@media (max-width: 79.99em) and (orientation: landscape) {
  input:checked + .menu__toggle + .menu__panel {
    padding: 1.5rem 0;
  }
}
@media (max-width: 79.99em) {
  input:checked + .menu__toggle + .menu__panel .menu__links {
    opacity: 1;
  }
  .menu__toggle {
    align-items: center;
    color: #242222;
    display: flex;
    float: right;
    height: 4rem;
    justify-content: center;
    margin-right: -0.5rem;
    position: relative;
    width: 3.5rem;
    z-index: 2;
  }
  .menu__toggle span, .menu__toggle::after, .menu__toggle::before {
    background: var(--themeText, #333333);
    content: "";
    display: block;
    height: 2px;
    position: absolute;
    transition: all var(--transitionTime) ease;
  }
  .menu__toggle span {
    color: transparent;
    font-size: 1rem;
    left: calc(50% - 0.75rem);
    top: 50%;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    white-space: nowrap;
    width: 2rem;
  }
  .menu__toggle::after, .menu__toggle::before {
    left: calc(50% - 0.5rem);
    width: 1.75rem;
  }
  .menu__toggle::after {
    top: calc(50% - 0.5rem);
  }
  .menu__toggle::before {
    top: calc(50% + 0.5rem);
  }
  input:checked + .menu__toggle span {
    display: none;
  }
  input:checked + .menu__toggle::after, input:checked + .menu__toggle::before {
    background: var(--style-alternate1--Text, var(--themeText, #333333));
    border-bottom-width: 1px;
    border-top-width: 0;
    left: calc(50% - 0.75rem);
    top: 50%;
    width: 2rem;
  }
  input:checked + .menu__toggle::after {
    transform: rotate(45deg);
  }
  input:checked + .menu__toggle::before {
    transform: rotate(-45deg);
  }
  .menu .btn {
    border-color: var(--style-alternate1--Text, var(--themeText, #333333));
    color: var(--style-alternate1--Text, var(--themeText, #333333));
    display: initial;
    justify-self: flex-end;
    margin: 2rem 0 0 min(8.75vw, 3.75rem);
  }
  .menu .btn .icon {
    color: var(--style-alternate1--Text, var(--themeText, #333333));
    fill: var(--style-alternate1--Text, var(--themeText, #333333));
  }
}
@media (min-width: 48em) and (max-width: 79.99em) {
  .menu__links {
    align-self: flex-start;
    margin: 4rem 0 3rem;
    width: calc(50% + 3.75rem);
  }
  .menu__links > li {
    padding: 0 0 0 3.75rem;
  }
  .menu__links > li > a,
  .menu__links > li > label.toggle-submenu {
    font-weight: 700;
    padding-bottom: 1rem;
    padding-top: 1rem;
  }
  .menu__links a, .menu__links label.toggle-submenu {
    font-size: 2rem;
  }
  .menu__links label.toggle-submenu .icon {
    height: 1.5rem;
    width: 3rem;
  }
  .menu .btn {
    margin-left: 3.75rem;
  }
}
@media (min-width: 80em) {
  .menu {
    margin: 0 var(--gridGap) 0 0;
  }
  .menu:last-child {
    margin-right: 0;
  }
  .menu__panel .btn {
    display: none;
  }
  .menu__toggle {
    display: none;
  }
  .menu__links {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    margin: 0;
    width: 100%;
  }
  .menu__links a, .menu__links label.toggle-submenu {
    color: var(--themeText, #333333);
    text-decoration: none;
  }
  .menu__links > li {
    align-items: center;
    display: inline-flex;
    flex-direction: row;
    position: relative;
  }
  .menu__links > li > a,
  .menu__links > li > label.toggle-submenu {
    display: block;
    font-size: 1rem;
    font-weight: 300;
    line-height: 3rem;
    white-space: nowrap;
  }
}
@media (min-width: 80em) and (hover: none) {
  .menu__links > li > a:focus,
  .menu__links > li > label.toggle-submenu:focus {
    color: var(--themeTitleAccent, #000000);
  }
}
@media (min-width: 80em) and (hover: hover) {
  .menu__links > li > a:hover,
  .menu__links > li > label.toggle-submenu:hover {
    color: var(--themeTitleAccent, #000000);
  }
}
@media (min-width: 80em) {
  .menu__links > li > a.active,
  .menu__links > li > label.toggle-submenu.active {
    font-weight: 500;
  }
  .menu__links > li > a {
    padding: 0 0.75rem;
  }
  .menu__links > li > a:not(:last-child) {
    padding-right: 0;
  }
  .menu__links > li > label.toggle-submenu {
    cursor: pointer;
    padding: 0 0.5rem;
  }
  .menu__links > li > label.toggle-submenu .icon {
    color: var(--themeIcon, var(--theme-primary, #000000));
    height: 0.75rem;
    transform: translateY(-2px);
    transition: transform var(--transitionTime) ease-in-out;
    width: 0.75rem;
  }
  .menu__links > li > a + input + label.toggle-submenu {
    width: 1.75rem;
  }
  .menu__links > li > input:first-child + label.toggle-submenu .icon {
    margin-left: 0.5rem;
  }
  .menu__links ul {
    background: var(--style-alternate1--Background, var(--primary, #76776A));
    display: flex;
    flex-direction: column;
    left: -1.5rem;
    margin: 0;
    max-height: 0;
    min-width: 100%;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    top: 100%;
    transition: all 350ms linear;
    white-space: nowrap;
  }
  .menu__links ul a,
  .menu__links ul span {
    color: var(--style-alternate1--Text, var(--themeText, #333333));
    display: block;
    font-size: 1rem;
    letter-spacing: 0.04em;
    line-height: 2rem;
    padding: 0 2.25rem;
    position: relative;
    text-align: left;
  }
  .menu__links ul a.active,
  .menu__links ul span.active {
    font-weight: 500;
  }
  .menu__links ul a::before {
    content: attr(title);
    display: block;
    font-weight: 500;
    height: 0;
    overflow: hidden;
  }
}
@media (min-width: 80em) and (hover: none) {
  .menu__links ul a:focus {
    font-weight: 500;
  }
}
@media (min-width: 80em) and (hover: hover) {
  .menu__links ul a:hover {
    font-weight: 500;
  }
}
@media (min-width: 80em) and (hover: none) {
  .menu__links input:checked + label.toggle-submenu .icon {
    transform: rotate(180deg);
  }
}
@media (min-width: 80em) and (hover: hover) {
  .menu__links a:hover + input + label.toggle-submenu .icon,
  .menu__links label.toggle-submenu:hover .icon {
    transform: rotate(180deg);
  }
}
@media (min-width: 80em) and (hover: none) {
  .menu__links input:checked + label.toggle-submenu + ul {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.1);
    max-height: 100vh;
    opacity: 1;
    padding: 1rem 0;
  }
}
@media (min-width: 80em) and (hover: hover) {
  .menu__links li:focus-within > ul,
  .menu__links a:hover + input + label.toggle-submenu + ul,
  .menu__links label.toggle-submenu:hover + ul,
  .menu__links ul:hover {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.1);
    max-height: 100vh;
    opacity: 1;
    padding: 1rem 0;
  }
}

.hero {
  margin: 0;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.hero__content {
  bottom: 0;
  color: #FFFFFF;
  left: 0;
  padding: 2.75rem 0;
  position: relative;
  right: 0;
  top: 0;
}
.hero__content::before {
  background: rgba(0, 0, 0, 0.37);
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.hero__content .container {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  position: relative;
}
.hero__content__title {
  color: #FFFFFF;
  font-weight: 200;
}
.hero__content__title.title:has(+ .text-container) {
  margin-bottom: 0.5em;
}
.hero__content__title .accent {
  color: #FFFFFF;
  font-weight: 800;
}
.hero__content__subtext.text-container:has(+ .btn-container) {
  margin-bottom: 2em;
}
.hero--background .hero__content {
  color: var(--themeText, #333333);
  position: relative;
}
.hero--background .hero__content::before {
  display: none;
}
.hero--background .hero__content__title {
  color: var(--themeTitle, #333333);
  font-weight: 400;
}
.hero--background .hero__content__title .accent {
  color: var(--themeTitleAccent, #000000);
}
.hero--background + .fl, .hero--background + * > .fl:first-child {
  padding-top: 0;
}
.hero:not(.hero--background) .hero__content {
  padding: 8.5rem 0;
}
.hero picture {
  display: block;
  height: 100%;
  overflow: hidden;
  position: absolute;
  width: 100%;
}
.hero picture img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  width: 100%;
}
@media (max-width: 35.99em) {
  .hero:not(.hero--background) .hero__content {
    padding: 5rem 0;
  }
}
@media (min-width: 48em) {
  .hero:not(.hero--background) .hero__content {
    padding: 8.5rem 0;
  }
  .hero__content__subtext {
    font-size: calc(1.25 * var(--base-font-size));
  }
}
@media (min-width: 80em) {
  .hero__content--narrow .container {
    max-width: 56.25rem;
  }
}
@media (min-width: 90em) {
  .hero:not(.hero--background) .hero__content {
    padding: 12rem 0;
  }
}

footer,
.footer {
  font-weight: 200;
  margin: 0;
}
footer a,
.footer a {
  color: var(--themeText, #333333);
  text-decoration: none;
  transition: all var(--transitionTime) ease-in-out;
}
@media (hover: none) {
  footer a:focus,
  .footer a:focus {
    color: color-mix(in srgb, var(--themeText, #333333), #838383 50%);
    text-shadow: 0 0 1px #838383;
  }
}
@media (hover: hover) {
  footer a:hover,
  .footer a:hover {
    color: color-mix(in srgb, var(--themeText, #333333), #838383 50%);
    text-shadow: 0 0 1px #838383;
  }
}
footer__slogan,
.footer__slogan {
  background: var(--theme-slogan-background, #DDDDDD);
  color: var(--theme-slogan-text, var(--themeText, #333333));
  font-size: 2.25rem;
  font-weight: 200;
  line-height: 2.5rem;
  padding: 3.75rem 0;
}
footer__main,
.footer__main {
  background: var(--themeBackground, #FFFFFF);
  color: var(--themeText, #333333);
  overflow: hidden;
  position: relative;
}
footer__main:first-child,
.footer__main:first-child {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
footer__main .container,
.footer__main .container {
  display: grid;
  grid-gap: 1.75rem;
  padding: 3.5rem 0;
}
footer__main__logo,
.footer__main__logo {
  display: inline-flex;
  height: 4rem;
  justify-content: flex-start;
  margin: 0 0 1.5rem;
  width: 100%;
}
footer__main__logo img,
.footer__main__logo img {
  display: block;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
footer__main__email, footer__main__phone,
.footer__main__email,
.footer__main__phone {
  color: var(--themeText, #333333);
  text-decoration: none;
}
footer__main__column,
.footer__main__column {
  color: var(--themeText, #333333);
  min-width: 10rem;
  white-space: nowrap;
}
footer__main__column p,
.footer__main__column p {
  margin: 0;
}
footer__main__column ul,
.footer__main__column ul {
  margin: 0;
}
footer__main__column ul li,
.footer__main__column ul li {
  align-items: center;
  display: flex;
  flex-direction: row;
}
footer__bottom,
.footer__bottom {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  background: var(--themeBackground, #FFFFFF);
  color: var(--themeText, #333333);
  padding: 2.75rem 0 3rem;
}
footer__bottom ul,
.footer__bottom ul {
  display: inline;
}
footer__bottom ul li,
.footer__bottom ul li {
  display: inline;
  list-style: none;
}
footer__bottom ul li::before,
.footer__bottom ul li::before {
  content: "|";
  display: inline;
  margin: 0 0.5rem 0 0.375rem;
}
footer__bottom ul li:first-child::before,
.footer__bottom ul li:first-child::before {
  display: none;
}
footer__bottom span .icon,
.footer__bottom span .icon {
  color: var(--themeText, #333333);
  height: 1.125rem;
  width: 6.75rem;
}
@media (min-width: 48em) {
  footer__main .container,
  .footer__main .container {
    grid-template-columns: repeat(2, 1fr);
  }
  footer__main__logo,
  .footer__main__logo {
    height: 4.5rem;
    margin: 0 0 2.5rem;
    width: 15rem;
  }
  footer__main__column:last-child,
  .footer__main__column:last-child {
    grid-column-start: 2;
  }
  footer__bottom br,
  .footer__bottom br {
    display: none;
  }
  footer__bottom__copyright,
  .footer__bottom__copyright {
    display: inline;
  }
  footer__bottom__copyright::after,
  .footer__bottom__copyright::after {
    content: "|";
    display: inline;
    margin: 0 0.5rem;
  }
  footer__bottom .container > span:last-child::before,
  .footer__bottom .container > span:last-child::before {
    content: "|";
    display: inline;
    margin: 0 0.625rem 0 0.25rem;
  }
  footer__slogan,
  .footer__slogan {
    font-size: 2.75rem;
    line-height: 2.875rem;
    padding: 4rem 0 4.5rem;
  }
  footer__main .container,
  .footer__main .container {
    padding: 5rem 0;
  }
  footer__main__logo,
  .footer__main__logo {
    width: 15rem;
  }
  footer__bottom,
  .footer__bottom {
    padding: 3.5rem 0;
  }
}
@media (min-width: 64em) {
  footer__main .container,
  .footer__main .container {
    grid-gap: 10rem;
    grid-template-columns: repeat(3, 1fr);
    padding: 7.5rem 0;
  }
  footer__main__logo,
  .footer__main__logo {
    height: 5.5rem;
    margin: 0 0 3rem;
  }
  footer__main__column:last-child,
  .footer__main__column:last-child {
    grid-column-start: initial;
  }
}
@media (min-width: 80em) {
  footer__main .container,
  .footer__main .container {
    padding: 8rem 0;
  }
}

.basicblock {
  position: relative;
}
.basicblock__intro {
  margin: 0 0 2rem;
}
.basicblock__buttons,
.basicblock .basicblock__slider + .btn {
  margin-top: var(--marginElement2Button);
}

.blocks-grid {
  display: grid;
  grid-gap: var(--gridGap);
  margin: 0;
}
@media (min-width: 36em) {
  .blocks-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 80em) {
  .blocks-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.block {
  background: var(--themeBackground, #FFFFFF);
  color: var(--themeText, #333333);
  padding: var(--blockPadding);
  transition: all var(--transitionTime) ease-in-out;
}
.block p:last-child {
  margin-bottom: 0;
}
.blocks5050 .block {
  box-shadow: none;
}
@media (hover: none) {
  .block[href]:focus {
    box-shadow: 1px 1px 0.25rem rgba(0, 0, 0, 0.1);
  }
}
@media (hover: hover) {
  .block[href]:hover {
    box-shadow: 1px 1px 0.25rem rgba(0, 0, 0, 0.1);
  }
}

.style-default .block.style-default {
  box-shadow: 1px 1px 1.25rem rgba(0, 0, 0, 0.05);
}

.blogs__grid {
  display: grid;
  grid-gap: var(--gridGap);
  margin-bottom: var(--marginElement2Button);
}
.blogs__blog {
  display: flex;
  flex-direction: column;
  padding: var(--blockPadding);
  position: relative;
  text-decoration: none;
}
.swiper-slide .blogs__blog {
  display: flex;
}
.blogs__blog__visual {
  display: block;
  margin: 0 0 var(--blockPadding);
}
.blogs__blog__visual picture {
  display: block;
  overflow: hidden;
  padding: 0 0 100%;
  position: relative;
}
.blogs__blog__visual picture img {
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: all var(--transitionTime) ease-in-out;
}
.blogs__blog__visual .blogs__blog__categories {
  inset: 1rem auto auto 1rem;
  position: absolute;
}
.blogs__blog__title {
  font-weight: 700;
  margin: 0 0 1em;
  position: relative;
  text-decoration: none;
  transition: all var(--transitionTime) ease-in-out;
}
.blogs__blog__intro {
  overflow: hidden;
  display: -webkit-box;
  line-clamp: 3;
  margin-bottom: 1rem;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* number of lines to show */
}
.blogs__blog__more {
  align-items: center;
  display: inline-flex;
  font-weight: 400;
  justify-self: flex-end;
  margin-top: auto;
  position: relative;
  text-decoration: none;
}
.blogs__blog__more .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  fill: var(--themeIcon, var(--theme-primary, #000000));
  height: 1rem;
  margin: 0 0 0 0.125rem;
  transform: translateY(1px);
  transition: all var(--transitionTime) ease-in-out;
  width: 1rem;
}
*:has(.blogs__blog--image) > .blogs__blog.default .blogs__blog__visual {
  aspect-ratio: 1/1;
}
.blogs__blog.grid_priority .blogs__blog__more {
  margin-top: 0;
}
.blogs__blog.grid_priority .blogs__blog__more .icon {
  color: var(--themeText, #333333);
  fill: var(--themeText, #333333);
}
.blogs__blog.grid_priority.blogs__blog--image {
  color: #FFFFFF;
}
.blogs__blog.grid_priority.blogs__blog--image .blogs__blog__title {
  color: #FFFFFF;
}
.blogs__blog.grid_priority.blogs__blog--image .blogs__blog__more {
  color: #FFFFFF;
}
.blogs__blog.grid_priority.blogs__blog--image .blogs__blog__more .icon {
  color: #FFFFFF;
  fill: #FFFFFF;
}
.blogs--promo--grid_priority .blogs__blog {
  aspect-ratio: 1/1;
}
.blogs--promo--grid_priority .blogs__blog .blogs__blog__title {
  margin-top: auto;
}
.blogs--promo--grid_priority .blogs__blog:has(.blogs__blog__visual) {
  background: none;
  border: none;
}
.blogs--promo--grid_priority .blogs__blog:has(.blogs__blog__visual) .blogs__blog__title {
  margin-bottom: 0.625em;
}
.blogs--promo--grid_priority .blogs__blog:has(.blogs__blog__visual) .blogs__blog__title,
.blogs--promo--grid_priority .blogs__blog:has(.blogs__blog__visual) .blogs__blog__more {
  color: #FFFFFF;
  text-shadow: 0 0 0.25rem #242222;
}
.blogs--promo--grid_priority .blogs__blog .blogs__blog__visual {
  bottom: 0;
  left: 0;
  margin: 0;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
}
.blogs--promo--grid_priority .blogs__blog .blogs__blog__visual picture {
  height: 100%;
  width: 100%;
}
.blogs--promo--grid_priority .blogs__blog .blogs__blog__visual picture img {
  filter: brightness(85%);
  left: 50%;
  min-height: 100%;
  min-width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media (hover: none) {
  .blogs--promo--grid_priority .blogs__blog:focus .blogs__blog__visual img {
    filter: brightness(70%);
    transform: translate(-50%, -50%) scale(1.02);
  }
  .blogs--promo--grid_priority .blogs__blog:focus:not(:has(.blogs__blog__visual)) {
    filter: brightness(95%);
  }
}
@media (hover: hover) {
  .blogs--promo--grid_priority .blogs__blog:hover .blogs__blog__visual img {
    filter: brightness(70%);
    transform: translate(-50%, -50%) scale(1.02);
  }
  .blogs--promo--grid_priority .blogs__blog:hover:not(:has(.blogs__blog__visual)) {
    filter: brightness(95%);
  }
}
@media (max-width: 47.99em) {
  .blogs__blog.default .blogs__blog__more {
    font-size: 0.875rem;
  }
  .blogs__blog.default .blogs__blog__more .icon {
    height: 0.75rem;
    width: 0.75rem;
  }
}
@media (min-width: 36em) {
  .blogs--promo--grid_priority .blogs__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .blogs--promo--grid_priority .blogs__blog {
    max-height: 45rem;
  }
  .blogs--promo--grid_priority .blogs__blog:first-child {
    aspect-ratio: auto;
    grid-column-start: 1;
    grid-row-end: 2 span;
    grid-row-start: 1;
    justify-content: center;
  }
}
@media (min-width: 48em) and (max-width: 63.99em) {
  .blogs--promo:not(.blogs--promo--grid_priority) .blogs__blog:nth-child(3) {
    display: none;
  }
}
@media (min-width: 48em) {
  .blogs__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .blogs__blog.default .blogs__blog__more {
    font-size: 1rem;
  }
  .blogs--promo--grid_priority .blogs__blog {
    max-height: none;
  }
  .blogs--promo--grid_priority .blogs__blog .blogs__blog__title {
    font-size: 1.5rem;
  }
}
@media (min-width: 64em) {
  .blogs__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .blogs--promo--grid_priority .blogs__blog {
    aspect-ratio: 1.65;
  }
}
@media (min-width: 80em) {
  .blogs--promo:not(.blogs--promo--grid_priority) .blogs__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 90em) {
  .blogs--promo--grid_priority .blogs__blog .blogs__blog__title {
    font-size: 1.75rem;
  }
}

.imageblock {
  align-items: stretch;
  aspect-ratio: 1/1;
  background-color: var(--themeBackground, #FFFFFF);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
  text-decoration: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.imageblock.swiper-slide { /* safari fixes */
  display: flex;
  height: 100% !important;
}
.imageblock picture {
  overflow: hidden;
  position: relative;
  transition: all 350ms ease-in-out;
}
.imageblock picture img {
  filter: brightness(80%);
  height: 100%;
  max-width: none;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 350ms ease-in-out;
  width: 100%;
}
.imageblock picture .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  fill: var(--themeIcon, var(--theme-primary, #000000));
  height: 5rem;
  margin: var(--blockPadding) 0 auto var(--blockPadding);
  width: 5rem;
}
.imageblock picture.image.imageblock__icon {
  display: inline-flex;
  justify-items: flex-start;
  max-width: 75%;
  overflow: hidden;
  width: auto;
}
.imageblock picture.image.imageblock__icon img {
  display: block;
  height: 100%;
  max-width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  width: auto;
}
.imageblock__icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  fill: var(--themeIcon, var(--theme-primary, #000000));
  height: 3rem;
  margin: auto 0 var(--marginElement2Element, 1em) 0;
  transition: all var(--transitionTime) ease-in-out;
  width: 3rem;
}
.imageblock__content {
  --_text: var(--white);
  bottom: var(--blockPadding);
  display: flex;
  flex-direction: column;
  left: var(--blockPadding);
  margin: auto 0 0;
  position: absolute;
  right: var(--blockPadding);
  text-shadow: 0 0 0.25rem #242222;
}
.imageblock__content__title {
  color: var(--_text);
  font-weight: 700;
  margin: 0 0 0.625em;
  position: relative;
  text-decoration: none;
  transition: all var(--transitionTime) ease-in-out;
}
.imageblock__content__intro {
  color: var(--_text);
  display: -webkit-box;
  line-clamp: 3;
  margin-bottom: 1rem;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* number of lines to show */
}
.imageblock__content__more {
  align-items: center;
  color: var(--_text);
  display: inline-flex;
  font-size: 1.125rem;
  font-weight: 700;
  text-shadow: 0 0 0.125rem rgba(0, 0, 0, 0.5);
  transition: all var(--transitionTime) ease-in-out;
}
.imageblock__content__more:first-child {
  align-items: flex-start;
}
.imageblock__content__more .icon {
  color: var(--_text);
  fill: var(--_text);
  height: 1rem;
  margin: 0 0 0 0.5rem;
  transition: all var(--transitionTime) ease-in-out;
  width: 1rem;
}
.imageblock__content__more .icon:first-child {
  margin: 0.4125rem 0.5rem 0 -0.25rem;
}
.imageblock--has-icon {
  transition: all 350ms ease-in-out;
}
.imageblock--has-icon .imageblock__content {
  --_text: var(--themeText);
  text-shadow: none;
  transition: all 350ms ease-in-out;
}
.imageblock--has-icon .imageblock__content .imageblock__content__more {
  text-shadow: none;
}
.imageblock--has-icon .imageblock__content .imageblock__content__more .icon {
  transition: all 350ms ease-in-out;
}
@media (hover: none) {
  .imageblock[href]:focus picture img {
    filter: brightness(60%);
  }
  .imageblock[href]:focus.imageblock--has-icon {
    filter: brightness(110%);
  }
  .imageblock[href]:focus.imageblock--has-icon .imageblock__content .icon {
    color: color-mix(in srgb, var(--theme-accent-on-background, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--theme-accent-on-background, var(--primary, #76776A)), var(--themeText, #333333) 50%);
  }
  .imageblock[href]:focus.imageblock--has-icon .imageblock__content .imageblock__content__more .icon {
    transform: translateX(0.125rem);
  }
  .imageblock[href]:focus.imageblock--has-icon .imageblock__content .imageblock__content__title,
  .imageblock[href]:focus.imageblock--has-icon .imageblock__content .imageblock__content__more {
    color: var(--themeTitle, #333333);
  }
}
@media (hover: hover) {
  .imageblock[href]:hover picture img {
    filter: brightness(60%);
  }
  .imageblock[href]:hover.imageblock--has-icon {
    filter: brightness(110%);
  }
  .imageblock[href]:hover.imageblock--has-icon .imageblock__content .icon {
    color: color-mix(in srgb, var(--theme-accent-on-background, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--theme-accent-on-background, var(--primary, #76776A)), var(--themeText, #333333) 50%);
  }
  .imageblock[href]:hover.imageblock--has-icon .imageblock__content .imageblock__content__more .icon {
    transform: translateX(0.125rem);
  }
  .imageblock[href]:hover.imageblock--has-icon .imageblock__content .imageblock__content__title,
  .imageblock[href]:hover.imageblock--has-icon .imageblock__content .imageblock__content__more {
    color: var(--themeTitle, #333333);
  }
}
@media (min-width: 48em) {
  .imageblock__icon {
    height: 4rem;
    width: 4rem;
  }
  .imageblock__content__title {
    font-size: 1.5rem;
  }
}
@media (min-width: 48em) and (max-width: 63.99em) {
  .imageblock__title {
    word-break: keep-all;
  }
}
@media (min-width: 64em) {
  .imageblock {
    align-self: stretch;
    height: 100%;
  }
}
@media (min-width: 80em) {
  .imageblock--large {
    aspect-ratio: 3/2;
  }
  .imageblock picture .icon {
    height: 6rem;
    width: 6rem;
  }
}

.jobs {
  display: flex;
  flex-direction: column;
  gap: min(8.75vw, 3.75rem);
}
.jobs .job {
  display: flex;
  flex-direction: column;
  text-decoration: none;
}
.jobs .job picture {
  align-items: center;
  aspect-ratio: 3/2;
  background: var(--themeBackground);
  display: flex;
  justify-content: center;
  width: 100%;
}
.jobs .job picture:has(img.job__logo) {
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.1) inset;
}
.jobs .job picture img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.jobs .job picture img.job__logo {
  max-width: 85%;
  -o-object-fit: contain;
     object-fit: contain;
}
.jobs .job__content {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  flex-shrink: 0;
  padding: 1rem;
}
.jobs .job__title {
  display: block;
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0 0 0.25rem;
}
.jobs .job__trigger {
  align-items: center;
  display: flex;
  justify-self: flex-end;
  margin-top: auto;
}
.jobs .job__trigger .icon {
  height: 1rem;
  margin: 0 0 0 1rem;
  width: 1rem;
}
.jobs + .pagination {
  margin-top: 2rem;
}
@media (min-width: 48em) {
  .jobs {
    display: grid;
    grid-gap: 2rem;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 64em) {
  .jobs {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 80em) {
  .jobs .job__content {
    padding: 1.75rem 2rem;
  }
  .jobs .job__title {
    font-size: 1.5rem;
  }
}
@media (min-width: 80em) {
  .jobs .job__content {
    padding: 2rem 2.25rem;
  }
}

.language {
  --_background: var(--white);
  --_toggle: var(--icon);
  --_text: var(--text);
  --_hover-color: var(--themeTitleAccent);
  position: relative;
}
.language__toggle {
  align-items: center;
  color: var(--_text);
  cursor: pointer;
  display: flex;
  justify-content: center;
  line-height: 3rem;
  position: relative;
  text-align: right;
  transition: background-color 250ms ease, color 250ms ease;
  white-space: nowrap;
  width: 3.75rem;
}
.language__toggle .icon {
  color: var(--_toggle);
  fill: var(--_toggle);
  height: 0.75rem;
  margin: 0 0 0 0.5rem;
  transition: transform var(--transitionTime) ease-in-out;
  width: 0.75rem;
}
input:checked + .language__toggle {
  background-color: var(--_background);
}
input:checked + .language__toggle .icon {
  transform: rotate(180deg);
}
.language__panel {
  background-color: var(--_background);
  color: var(--_text);
  margin: 0;
  max-height: 0;
  overflow: hidden;
  padding: 0 1.5rem;
  position: absolute;
  right: 0;
  text-align: right;
  transition: height 250ms ease;
  z-index: 1;
}
.language__panel a {
  color: var(--_text);
  display: block;
  margin: 0.75rem;
  opacity: 0;
  text-decoration: none;
  transition: all 250ms ease;
  white-space: nowrap;
}
@media (hover: none) {
  .language__panel a:focus {
    color: var(--_hover-color);
  }
}
@media (hover: hover) {
  .language__panel a:hover {
    color: var(--_hover-color);
  }
}
.language__panel a.active {
  color: var(--_hover-color);
  font-weight: 700;
}
input:checked + .language__toggle + .language__panel {
  box-shadow: 0 0.25rem 0.125rem rgba(0, 0, 0, 0.1);
  max-height: 90vh;
  padding: 0.75rem 1.5rem;
}
input:checked + .language__toggle + .language__panel a {
  opacity: 1;
}
@media (max-width: 79.99em) {
  .language {
    margin: 0 min(8.75vw, 3.75rem);
  }
  .language__toggle {
    border: 1px solid var(--_toggle);
    border-radius: var(--button-border-radius, 1.75rem);
    padding: 0 0.75rem;
    width: auto;
  }
  .language__panel {
    border-radius: var(--button-border-radius, 1.75rem);
    left: 0;
    margin-top: -1px;
    right: auto;
    text-align: left;
  }
  input:checked + .language__toggle + .language__panel {
    border: 1px solid var(--_toggle);
    box-shadow: none;
  }
  header .container > .language {
    display: none;
  }
}
@media (min-width: 80em) {
  .language {
    margin: 0 0.5rem 0 0;
  }
  .menu__panel > .language {
    display: none;
  }
  .language__toggle {
    margin: 0 0 0 0.375rem;
    width: 4.125rem;
  }
  .language__toggle:not(:last-child) {
    margin-right: 0.375rem;
  }
}

.language {
  --_toggle: var(--themeIcon, var(--theme-primary, #000000));
  font-size: 1rem;
}
@media (max-width: 79.99em) {
  .language {
    --_background: var(--style-alternate1--Background, $primary);
    --_toggle: var(--style-alternate1--Text, $text);
    --_text: var(--style-alternate1--Text, $text);
    --_hover-color: var(--style-alternate1--Text, $text);
  }
}

.pagination {
  align-items: center;
  display: flex;
  flex-direction: row;
  font-size: 1.125rem;
  justify-content: center;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.swiper .pagination, .videos__slider .pagination, .services-promo__slider .pagination, .services-promo__slider--tall .pagination, .reviews__swiper .pagination {
  display: none;
  z-index: 1;
}
.swiper .pagination .pagination__button, .videos__slider .pagination .pagination__button, .services-promo__slider .pagination .pagination__button, .services-promo__slider--tall .pagination .pagination__button, .reviews__swiper .pagination .pagination__button {
  height: 2.25rem;
  min-width: 0;
  width: 2.25rem;
}
.swiper .pagination .pagination__button.swiper-button-next, .videos__slider .pagination .pagination__button.swiper-button-next, .services-promo__slider .pagination .pagination__button.swiper-button-next, .services-promo__slider--tall .pagination .pagination__button.swiper-button-next, .reviews__swiper .pagination .pagination__button.swiper-button-next {
  margin-left: 0.5rem;
}
.swiper .pagination .pagination__button.swiper-button-prev, .videos__slider .pagination .pagination__button.swiper-button-prev, .services-promo__slider .pagination .pagination__button.swiper-button-prev, .services-promo__slider--tall .pagination .pagination__button.swiper-button-prev, .reviews__swiper .pagination .pagination__button.swiper-button-prev {
  margin-right: 0.5rem;
}
.swiper .pagination .pagination__progress, .videos__slider .pagination .pagination__progress, .services-promo__slider .pagination .pagination__progress, .services-promo__slider--tall .pagination .pagination__progress, .reviews__swiper .pagination .pagination__progress {
  background: none;
  bottom: auto;
  color: var(--theme-text);
  display: none;
  font-size: 0.75rem;
  height: var(--button-height);
  justify-self: flex-end;
  left: auto;
  line-height: var(--button-height);
  margin: 0;
  position: relative;
  text-align: center;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.1);
  top: auto;
  width: 3rem;
}
.swiper-initialized .pagination {
  display: flex;
}
@media (hover: none) and (pointer: coarse) {
  .swiper-initialized .pagination {
    display: none;
  }
}
@media (max-width: 47.99em) {
  .swiper-initialized .pagination {
    display: none;
  }
}
.pagination__button {
  align-items: center;
  background: none;
  border: none;
  color: var(--themeText, #333333);
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  height: var(--button-height);
  line-height: var(--button-height);
  margin: 0;
  min-width: var(--button-height);
  text-align: center;
  text-decoration: none;
}
.pagination__button:last-child {
  margin-right: 0;
}
.pagination__button .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  height: 2.25rem;
  width: 2.25rem;
}
@media (hover: hover) and (hover: none) {
  .pagination__buttona:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon, .pagination__button.swiper-button-next:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon, .pagination__button.swiper-button-prev:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon {
    color: var(--themeText, #333333);
  }
}
@media (hover: hover) and (hover: hover) {
  .pagination__buttona:not(.disabled):not(:disabled):not(.swiper-button-disabled):hover .icon, .pagination__button.swiper-button-next:not(.disabled):not(:disabled):not(.swiper-button-disabled):hover .icon, .pagination__button.swiper-button-prev:not(.disabled):not(:disabled):not(.swiper-button-disabled):hover .icon {
    color: var(--themeText, #333333);
  }
}
.pagination__buttona:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon, .pagination__buttona:not(.disabled):not(:disabled):not(.swiper-button-disabled).focus .icon, .pagination__button.swiper-button-next:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon, .pagination__button.swiper-button-next:not(.disabled):not(:disabled):not(.swiper-button-disabled).focus .icon, .pagination__button.swiper-button-prev:not(.disabled):not(:disabled):not(.swiper-button-disabled):focus .icon, .pagination__button.swiper-button-prev:not(.disabled):not(:disabled):not(.swiper-button-disabled).focus .icon {
  color: color-mix(in srgb, var(--themeIcon, var(--theme-primary, #000000)), var(--themeText, #333333) 70%);
}
.pagination__button.disabled, .pagination__button:disabled, .pagination__button.swiper-button-disabled {
  color: #DDDDDD;
  cursor: not-allowed;
  opacity: 0.35;
}
.pagination__button.active {
  position: relative;
}
.pagination__button.active span {
  background-color: #242222;
  color: #FFFFFF;
  position: relative;
}
.pagination__summary {
  display: block;
  line-height: 2rem;
  margin: 0 1rem;
}

.grecaptcha-badge {
  visibility: hidden !important;
}

.row-controls {
  align-items: center;
  display: flex;
  flex-direction: row-reverse;
  gap: var(--blockPadding);
  justify-content: space-between;
  margin-top: var(--marginText2Button);
}
@media (max-width: 47.99em) {
  .row-controls:has(.pagination) {
    flex-direction: row;
  }
}

.skip-link {
  background: #242222;
  color: #FFFFFF;
  left: 0;
  padding: 1rem;
  position: absolute;
  top: -6rem;
  z-index: 100;
}
.skip-link:focus {
  top: 0;
}

.social-media {
  display: flex;
  margin: 0;
  position: relative;
}
.social-media li {
  margin: 0 0.875rem 0 0;
}
.social-media li a {
  align-items: center;
  background: var(--themeButtonBackground, #000000);
  border-radius: 50%;
  color: var(--themeButtonText, #FFFFFF);
  display: flex;
  justify-content: center;
  height: 2.5rem;
  transition: background-color var(--transitionTime) ease-in-out;
  width: 2.5rem;
}
.social-media li a .icon {
  height: 50%;
  transition: color var(--transitionTime) ease-in-out;
  width: 50%;
}
.social-media li a:hover {
  background-color: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 30%);
  color: var(--themeButtonText, #FFFFFF);
}
.social-media li a:focus {
  background-color: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 50%);
  color: var(--themeButtonText, #FFFFFF);
}

.swiper, .videos__slider, .services-promo__slider, .services-promo__slider--tall, .reviews__swiper {
  width: 100%;
  z-index: 0 !important;
}
.swiper.continuous, .continuous.videos__slider, .continuous.services-promo__slider, .continuous.services-promo__slider--tall, .continuous.reviews__swiper {
  transition-timing-function: linear;
}
.swiper.swiper-horizontal, .swiper-horizontal.videos__slider, .swiper-horizontal.services-promo__slider, .swiper-horizontal.services-promo__slider--tall, .swiper-horizontal.reviews__swiper {
  overflow: visible;
}
@media (hover: hover) {
  .swiper.swiper-horizontal:last-child:has(.pagination):not(.album__items), .swiper-horizontal.videos__slider:last-child:has(.pagination):not(.album__items), .swiper-horizontal.services-promo__slider:last-child:has(.pagination):not(.album__items), .swiper-horizontal.services-promo__slider--tall:last-child:has(.pagination):not(.album__items), .swiper-horizontal.reviews__swiper:last-child:has(.pagination):not(.album__items) {
    margin-bottom: calc(var(--marginElement2Button) + var(--button-height));
  }
}
.swiper.imageslideshow, .imageslideshow.videos__slider, .imageslideshow.services-promo__slider, .imageslideshow.services-promo__slider--tall, .imageslideshow.reviews__swiper {
  overflow: hidden;
  position: relative;
}
.swiper.imageslideshow .pagination, .imageslideshow.videos__slider .pagination, .imageslideshow.services-promo__slider .pagination, .imageslideshow.services-promo__slider--tall .pagination, .imageslideshow.reviews__swiper .pagination {
  bottom: 1rem;
  display: flex;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}
.swiper.imageslideshow .pagination .pagination__button.swiper-button-next, .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-next, .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-next, .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-next, .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-next,
.swiper.imageslideshow .pagination .pagination__button.swiper-button-prev,
.imageslideshow.videos__slider .pagination .pagination__button.swiper-button-prev,
.imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-prev,
.imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-prev,
.imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-prev {
  background: var(--themeButtonBackground, #000000);
  border-radius: 50%;
  color: var(--themeButtonText, #FFFFFF);
  height: 2rem;
  padding: 0;
  width: 2rem;
}
.swiper.imageslideshow .pagination .pagination__button.swiper-button-next .icon, .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-next .icon, .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-next .icon, .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-next .icon, .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-next .icon,
.swiper.imageslideshow .pagination .pagination__button.swiper-button-prev .icon,
.imageslideshow.videos__slider .pagination .pagination__button.swiper-button-prev .icon,
.imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-prev .icon,
.imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-prev .icon,
.imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-prev .icon {
  color: var(--themeButtonText, #FFFFFF);
  fill: var(--themeButtonText, #FFFFFF);
}
@media (hover: none) {
  .swiper.imageslideshow .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):focus, .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):focus, .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):focus, .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):focus, .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):focus,
  .swiper.imageslideshow .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):focus,
  .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):focus,
  .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):focus,
  .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):focus,
  .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):focus {
    background: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 30%);
    transform: none !important;
  }
}
@media (hover: hover) {
  .swiper.imageslideshow .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):hover, .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):hover, .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):hover, .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):hover, .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-next:not(:disabled):not(.swiper-button-disabled):hover,
  .swiper.imageslideshow .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):hover,
  .imageslideshow.videos__slider .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):hover,
  .imageslideshow.services-promo__slider .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):hover,
  .imageslideshow.services-promo__slider--tall .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):hover,
  .imageslideshow.reviews__swiper .pagination .pagination__button.swiper-button-prev:not(:disabled):not(.swiper-button-disabled):hover {
    background: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 30%);
    transform: none !important;
  }
}
.swiper-wrapper {
  align-items: stretch;
}
.swiper-wrapper .swiper-slide {
  height: auto;
}
.swiper .pagination, .videos__slider .pagination, .services-promo__slider .pagination, .services-promo__slider--tall .pagination, .reviews__swiper .pagination {
  justify-content: flex-end;
}
.swiper .swiper-pagination, .videos__slider .swiper-pagination, .services-promo__slider .swiper-pagination, .services-promo__slider--tall .swiper-pagination, .reviews__swiper .swiper-pagination {
  bottom: auto;
  left: auto;
  position: relative;
  text-align: right;
  top: auto;
}
.swiper .swiper-pagination .swiper-pagination-bullet, .videos__slider .swiper-pagination .swiper-pagination-bullet, .services-promo__slider .swiper-pagination .swiper-pagination-bullet, .services-promo__slider--tall .swiper-pagination .swiper-pagination-bullet, .reviews__swiper .swiper-pagination .swiper-pagination-bullet {
  background: none;
  border-radius: 0;
  height: 1rem;
  width: 1rem;
}
.swiper .swiper-button-disabled:has(+ .swiper-button-disabled), .videos__slider .swiper-button-disabled:has(+ .swiper-button-disabled), .services-promo__slider .swiper-button-disabled:has(+ .swiper-button-disabled), .services-promo__slider--tall .swiper-button-disabled:has(+ .swiper-button-disabled), .reviews__swiper .swiper-button-disabled:has(+ .swiper-button-disabled),
.swiper .swiper-button-disabled:has(+ .swiper-pagination-progress + .swiper-button-disabled),
.videos__slider .swiper-button-disabled:has(+ .swiper-pagination-progress + .swiper-button-disabled),
.services-promo__slider .swiper-button-disabled:has(+ .swiper-pagination-progress + .swiper-button-disabled),
.services-promo__slider--tall .swiper-button-disabled:has(+ .swiper-pagination-progress + .swiper-button-disabled),
.reviews__swiper .swiper-button-disabled:has(+ .swiper-pagination-progress + .swiper-button-disabled),
.swiper .swiper-button-disabled + .swiper-button-disabled,
.videos__slider .swiper-button-disabled + .swiper-button-disabled,
.services-promo__slider .swiper-button-disabled + .swiper-button-disabled,
.services-promo__slider--tall .swiper-button-disabled + .swiper-button-disabled,
.reviews__swiper .swiper-button-disabled + .swiper-button-disabled,
.swiper .swiper-button-disabled + .swiper-pagination-progress + .swiper-button-disabled,
.videos__slider .swiper-button-disabled + .swiper-pagination-progress + .swiper-button-disabled,
.services-promo__slider .swiper-button-disabled + .swiper-pagination-progress + .swiper-button-disabled,
.services-promo__slider--tall .swiper-button-disabled + .swiper-pagination-progress + .swiper-button-disabled,
.reviews__swiper .swiper-button-disabled + .swiper-pagination-progress + .swiper-button-disabled {
  display: none;
}

.blocks5050__grid {
  display: flex;
  flex-direction: column;
}
.blocks5050__block {
  box-shadow: none !important;
  display: flex;
  flex-direction: column;
  width: 100%;
}
.blocks5050__block__visual {
  background: #FFFFFF;
  display: flex;
  height: 66.6vw;
  overflow: hidden;
  position: relative;
}
.blocks5050__block__visual--has-icon {
  flex-grow: 1;
}
.blocks5050__block__visual img {
  min-height: 100%;
  max-width: none;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 100%;
}
.blocks5050__block__visual .plyr {
  aspect-ratio: 16/9;
  height: 100%;
  width: 100%;
}
.blocks5050__block__visual__icon {
  background: var(--theme-secondary-ghost10);
  color: var(--themeIcon, var(--theme-primary, #000000));
  fill: var(--themeIcon, var(--theme-primary, #000000));
  height: 100%;
  margin: 0 0 var(--marginElement2Text, 1em);
  padding: calc(2 * var(--blockPadding));
  position: absolute;
  width: 100%;
}
.blocks5050__block--video .blocks5050__block__visual {
  aspect-ratio: 16/9;
}
.blocks5050__block__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
}
.blocks5050__block__content table {
  word-break: keep-all;
}
.blocks5050__block__content table td, .blocks5050__block__content table th {
  vertical-align: top;
}
.blocks5050__block__content__text:has(+ .blocks5050__block__content__more) {
  margin-bottom: var(--marginText2Text);
}
.blocks5050__block__content__more {
  align-items: center;
  display: inline-flex;
  font-size: 1rem;
  font-weight: 700;
  text-decoration: none;
}
.blocks5050__block__content__more .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  height: 1rem;
  margin: 0 0 0 0.5rem;
  transition: all var(--transitionTime) ease-in-out;
  width: 1rem;
}
@media (hover: none) {
  .blocks5050__block__content__more:focus {
    text-decoration: underline;
  }
  .blocks5050__block__content__more:focus .icon {
    transform: translateX(0.25rem);
  }
}
@media (hover: hover) {
  .blocks5050__block__content__more:hover {
    text-decoration: underline;
  }
  .blocks5050__block__content__more:hover .icon {
    transform: translateX(0.25rem);
  }
}
@media (max-width: 23.3759em) {
  .blocks5050__content table td, .blocks5050__content table th {
    display: block;
  }
  .blocks5050__content table td {
    padding-bottom: 0.5em;
  }
  .blocks5050__content table th {
    font-weight: 500;
  }
  .blocks5050__content table tr:last-child td {
    padding-bottom: 0;
  }
}
@media (max-width: 47.99em) {
  .blocks5050__grid {
    margin-left: calc(min(8.75vw, 3.75rem) * -1);
    margin-right: calc(min(8.75vw, 3.75rem) * -1);
  }
  .blocks5050__block__content {
    border-left: none;
    border-right: none;
  }
}
@media (min-width: 48em) and (max-width: 63.99em) {
  .blocks5050__block__content table td, .blocks5050__block__content table th {
    display: block;
  }
  .blocks5050__block__content table td {
    padding-bottom: 0.5em;
  }
  .blocks5050__block__content table tr:last-child td {
    padding-bottom: 0;
  }
}
@media (min-width: 48em) {
  .blocks5050__grid {
    display: flex;
    gap: calc(1.25 * var(--blockMargin));
  }
  .blocks5050__block {
    flex-direction: row;
  }
  .blocks5050__block__visual {
    height: auto;
    width: 50%;
  }
  .blocks5050__block__visual__icon {
    height: 100%;
    margin: 0;
    padding: calc(3 * var(--blockPadding));
    width: 100%;
  }
  .blocks5050__block__content {
    padding: calc(2 * var(--blockPadding));
    width: 50%;
  }
  .blocks5050__block--right {
    flex-direction: row-reverse;
  }
  .blocks5050 .blocks5050__block--samestyle.blocks5050__block--left .blocks5050__block__content {
    padding-right: 0;
  }
  .blocks5050 .blocks5050__block--samestyle.blocks5050__block--right .blocks5050__block__content {
    padding-left: 0;
  }
}
@media (min-width: 80em) {
  .blocks5050__block__visual__icon {
    padding: 3.75rem;
  }
}
@media (min-width: 90em) {
  .blocks5050__block__visual__icon {
    padding: 5rem;
  }
  .blocks5050__block__content {
    padding: 3.75rem;
  }
  .blocks5050__block__content__text.text-container:has(+ .btn-container) {
    margin-bottom: 2.75em;
  }
}

.brands__brand.swiper-slide {
  width: auto;
}
.brands__brand.swiper-slide picture {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  margin: 0 auto;
  max-width: 15rem;
  transition: filter var(--transitionTime) ease-in-out;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.brands__brand.swiper-slide picture .brands__brand__svg {
  height: 100%;
  width: 100%;
}
.brands__brand.swiper-slide[href] {
  cursor: pointer;
}
@media (hover: none) {
  .brands__brand.swiper-slide[href]:focus picture {
    filter: opacity(0.75);
  }
}
@media (hover: hover) {
  .brands__brand.swiper-slide[href]:hover picture {
    filter: opacity(0.75);
  }
}
.brands--black-white .brands__brand.swiper-slide picture {
  filter: grayscale(1) opacity(0.5);
}
@media (hover: none) {
  .brands--black-white .brands__brand.swiper-slide[href]:focus picture {
    filter: none;
  }
}
@media (hover: hover) {
  .brands--black-white .brands__brand.swiper-slide[href]:hover picture {
    filter: none;
  }
}

.clickblocks .container {
  display: flex;
  flex-direction: column;
}
.clickblocks__content {
  margin: 0 0 1rem;
}
.clickblocks__blocks {
  display: grid;
  grid-gap: var(--gridGap);
}
.clickblocks__blocks__block {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  transition: var(--transitionTime) ease-in-out all;
}
.clickblocks__blocks__block.swiper-slide {
  display: flex;
}
.clickblocks__blocks__block__title {
  transition: all var(--transitionTime) ease-in-out;
}
.clickblocks__blocks__block__icon {
  color: var(--themeIcon, var(--primary, #76776A));
  fill: var(--themeIcon, var(--primary, #76776A));
  height: 3rem;
  margin: 0 0 var(--marginElement2Element, 1em);
  transition: all var(--transitionTime) ease-in-out;
  width: 3rem;
}
.clickblocks__blocks__block__icon.image {
  display: inline-flex;
  overflow: hidden;
  width: 100%;
}
.clickblocks__blocks__block__icon.image img {
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
}
.clickblocks__blocks__block__image {
  display: block;
  margin: 0 0 1rem;
}
.clickblocks__blocks__block__image img {
  transition: all var(--transitionTime) ease-in-out;
}
.clickblocks__blocks__block__more {
  align-items: center;
  display: flex;
  font-size: 1rem;
  font-weight: 400;
  margin-top: auto;
}
.clickblocks__blocks__block__more .icon {
  color: var(--themeIcon, var(--primary, #76776A));
  fill: var(--themeIcon, var(--primary, #76776A));
  height: 1rem;
  margin: 1px 0 0 0.25rem;
  transition: all var(--transitionTime) ease-in-out;
  width: 1rem;
}
.clickblocks__blocks__block.clickblocks__blocks__block--with-image {
  display: flex;
  flex-direction: column;
}
.clickblocks__blocks__block.clickblocks__blocks__block--with-image .clickblocks__blocks__block__more .icon {
  color: #FFFFFF;
}
.clickblocks__blocks__block.clickblocks__blocks__block--with-image .clickblocks__blocks__block__title {
  margin-bottom: var(--marginTitle2Element);
}
@media (hover: none) {
  .clickblocks__blocks__block:focus .clickblocks__blocks__block__image img {
    filter: brightness(80%);
  }
  .clickblocks__blocks__block:focus .clickblocks__blocks__block__icon {
    color: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
  }
  .clickblocks__blocks__block:focus .clickblocks__blocks__block__title {
    color: color-mix(in srgb, var(--themeText, #333333), var(--themeIcon, var(--primary, #76776A)) 50%);
  }
  .clickblocks__blocks__block:focus .clickblocks__blocks__block__more .icon {
    color: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    transform: translateX(0.125rem);
  }
}
@media (hover: hover) {
  .clickblocks__blocks__block:hover .clickblocks__blocks__block__image img {
    filter: brightness(80%);
  }
  .clickblocks__blocks__block:hover .clickblocks__blocks__block__icon {
    color: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
  }
  .clickblocks__blocks__block:hover .clickblocks__blocks__block__title {
    color: color-mix(in srgb, var(--themeText, #333333), var(--themeIcon, var(--primary, #76776A)) 50%);
  }
  .clickblocks__blocks__block:hover .clickblocks__blocks__block__more .icon {
    color: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    fill: color-mix(in srgb, var(--themeIcon, var(--primary, #76776A)), var(--themeText, #333333) 50%);
    transform: translateX(0.125rem);
  }
}
.clickblocks__blocks:has(.clickblocks__blocks__block__icon) .clickblocks__blocks__block:not(:has(> .clickblocks__blocks__block__icon))::before {
  content: "";
  display: block;
  height: 3rem;
  margin: 0 0 var(--marginElement2Element, 1em);
}
@media (max-width: 47.99em) {
  .clickblocks__blocks--slider {
    margin-bottom: 2rem;
  }
}
@media (min-width: 48em) {
  .clickblocks__blocks {
    grid-template-columns: repeat(2, 1fr);
  }
  .clickblocks__blocks--slider {
    margin-bottom: 4rem;
  }
}
@media (min-width: 64em) {
  .clickblocks__blocks {
    grid-template-columns: repeat(3, 1fr);
  }
  .clickblocks--images .clickblocks__blocks {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 80em) {
  .clickblocks__content {
    margin-bottom: 2.5rem;
  }
  .clickblocks__blocks__block__title {
    font-size: 1.5rem;
  }
}

.content-form__content, .content-form__form {
  display: block;
  margin: 0 0 min(8.75vw, 3.75rem);
}
.content-form__content table td, .content-form__content table th, .content-form__form table td, .content-form__form table th {
  font-weight: inherit;
  text-align: left;
  vertical-align: top;
}
.content-form__content table th, .content-form__form table th {
  padding-right: 2.5rem;
}
@media (min-width: 48em) {
  .content-form__content__title {
    margin-bottom: 1rem;
  }
}
@media (min-width: 80em) {
  .content-form .container {
    align-items: flex-start;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .content-form--openhours .container {
    flex-direction: row;
  }
  .content-form__content, .content-form__form {
    flex-shrink: 0;
    width: calc(50% - 2.5rem);
  }
  .content-form__content {
    float: right;
    grid-column-start: 2;
    grid-row: 1/2 span;
  }
}

.content-image__image {
  display: block;
  margin: 0 0 var(--gridGap);
}
@media (max-width: 47.99em) {
  .content-image__image {
    margin: calc(-1 * var(--blockMargin)) calc(-1 * min(8.75vw, 3.75rem)) var(--gridGap);
  }
  .content-image__content__buttons {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }
}
@media (min-width: 48em) {
  .content-image .container {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  .content-image--left .container {
    flex-direction: row;
  }
  .content-image__content, .content-image__image {
    width: calc(50% - var(--gridGap));
  }
  .content-image__content {
    float: right;
    grid-column-start: 2;
    grid-row: 1/2 span;
  }
  .content-image__image {
    margin-bottom: 0;
    overflow: hidden;
    position: relative;
  }
  .content-image__image img {
    left: 50%;
    min-height: 100%;
    min-width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
  }
}
@media (min-width: 80em) {
  .content-image__content, .content-image__image {
    width: calc(50% - var(--gridGap));
  }
}

.content-openhours__content {
  margin-bottom: var(--blockMargin);
}
.content-openhours__content__buttons {
  display: none;
}
.content-openhours__openhours {
  display: block;
}
.content-openhours__openhours table td, .content-openhours__openhours table th {
  font-weight: inherit;
  text-align: left;
  vertical-align: top;
  word-break: keep-all;
}
.content-openhours__openhours table th {
  padding-right: 2.5rem;
}
.content-openhours__buttons-mobile {
  margin-top: var(--marginElement2Button);
}
@media (max-width: 23.3759em) {
  .content-openhours__openhours .h2 {
    font-size: var(--h3-font-size);
  }
  .content-openhours__openhours table td, .content-openhours__openhours table th {
    display: block;
  }
  .content-openhours__openhours table td {
    padding-bottom: 0.5em;
  }
  .content-openhours__openhours table th {
    font-weight: 500;
  }
  .content-openhours__openhours table tr:last-child td {
    padding-bottom: 0;
  }
}
@media (max-width: 47.99em) {
  .content-openhours__openhours {
    word-break: keep-all;
  }
}
@media (min-width: 48em) {
  .content-openhours .container {
    align-items: center;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }
  .main--landing .content-openhours .container {
    align-items: flex-start;
    flex-direction: column;
  }
  .content-openhours__buttons-mobile {
    display: none;
  }
  .content-openhours__content__buttons {
    display: flex;
  }
  .content-openhours__content, .content-openhours__openhours {
    flex-shrink: 0;
    margin-bottom: 0;
    width: calc(50% - var(--gridGap));
  }
  .main--landing .content-openhours__content, .main--landing .content-openhours__openhours {
    width: 100%;
  }
  .main--landing .content-openhours__content.content-openhours__content, .main--landing .content-openhours__openhours.content-openhours__content {
    margin-bottom: 2.5rem;
  }
  .content-openhours__openhours {
    padding: calc(2 * var(--blockPadding));
  }
  .main--landing .content-openhours__openhours {
    box-shadow: none !important;
    padding: 0;
  }
}
@media (min-width: 48em) and (max-width: 63.99em) {
  .content-openhours__openhours .h2 {
    font-size: var(--h3-font-size);
  }
  .content-openhours__openhours table td, .content-openhours__openhours table th {
    display: block;
  }
  .content-openhours__openhours table td {
    padding-bottom: 0.5em;
  }
  .content-openhours__openhours table th {
    font-weight: 500;
  }
  .content-openhours__openhours table tr:last-child td {
    padding-bottom: 0;
  }
}

.content-tagline__tagline {
  font-weight: 300;
}

.downloads__download {
  align-items: center;
  display: inline-flex;
}
.downloads__download .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  height: 1rem;
  margin: 0 0.75rem 0 0;
  width: 1rem;
}

.faq {
  position: relative;
}
.faq__content {
  margin: 0 0 var(--gridGap);
}
.faq .faq-item {
  cursor: pointer;
  display: block;
  interpolate-size: allow-keywords;
  margin: 0 0 1.25rem;
}
.faq .faq-item:last-child {
  margin: 0;
}
.faq .faq-item summary {
  display: block;
  font-size: var(--base-font-size);
  font-weight: 700;
  padding: 0 2.125rem 0 0;
  position: relative;
}
.faq .faq-item summary::before, .faq .faq-item summary::after {
  background: var(--themeTitle, #333333);
  content: "";
  display: block;
  position: absolute;
}
.faq .faq-item summary::before {
  height: 0.125rem;
  right: 0;
  top: 0.6875rem;
  width: 1rem;
}
.faq .faq-item summary::after {
  height: 1rem;
  right: 0.4375rem;
  top: 0.25rem;
  transition: background-color 350ms ease-in-out;
  width: 0.125rem;
}
.faq .faq-item::details-content {
  block-size: 0;
  display: block;
  overflow: hidden;
  transition: block-size 0.3s, content-visibility 0.3s allow-discrete;
}
.faq .faq-item[open] summary::after {
  background-color: transparent;
}
.faq .faq-item[open]::details-content {
  block-size: auto;
}
@media (min-width: 48em) {
  .faq .faq-item summary::before, .faq .faq-item summary::after {
    transform: translateY(0.125em);
  }
}
@media (max-width: 47.99em) {
  .faq__entries {
    margin-left: -min(8.75vw, 3.75rem);
    margin-right: -min(8.75vw, 3.75rem);
  }
}
@media (min-width: 48em) {
  .faq .faq-item summary::before, .faq .faq-item summary::after {
    transform: translateY(0.125em);
  }
}

.image-fullwidth {
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.image-fullwidth .container {
  margin: 0;
}
@media (max-width: 89.99em) {
  .image-fullwidth {
    padding: 0;
  }
  .image-fullwidth__scroll {
    bottom: 1.25rem;
    color: #FFFFFF;
    height: 1.25rem;
    left: calc(50vw - 0.625rem);
    position: absolute;
    text-align: center;
    text-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
    width: 1.25rem;
    z-index: 1;
  }
}
@media (max-width: 89.99em) and (prefers-reduced-motion: no-preference) {
  .image-fullwidth__scroll {
    animation: bounceDown ease-in-out 2s infinite;
  }
}
@media (max-width: 89.99em) {
  .image-fullwidth__scroll .icon {
    height: 100%;
    width: 100%;
  }
}
@media (min-width: 80em) {
  .image-fullwidth .container {
    max-width: none;
  }
  .image-fullwidth.fl-narrow .container {
    margin: 0 auto;
  }
}
@media (min-width: 90em) {
  .image-fullwidth .container {
    margin: 0 auto;
    max-width: 75rem;
  }
  .image-fullwidth__scroll {
    display: none;
  }
}

.instagram__grid {
  display: grid;
  grid-gap: var(--gridGap);
}
.instagram__post {
  display: flex;
  flex-direction: column;
  margin: 0;
  position: relative;
  text-decoration: none;
  transition: border-color var(--transitionTime) ease-in-out;
}
.instagram__post__picture {
  background: #242222;
  overflow: hidden;
  padding: 0 0 100%;
  position: relative;
  width: 100%;
}
.instagram__post__picture img {
  left: 50%;
  min-height: 100%;
  min-width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}
.instagram__post__picture__carousel {
  bottom: 1.5rem;
  display: flex;
  left: 50%;
  margin: 0;
  padding: 0;
  position: absolute;
  transform: translateX(-50%);
}
.instagram__post__picture__carousel li {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.1);
  display: block;
  height: 0.5rem;
  margin: 0 0.25rem;
  overflow: hidden;
  width: 0.5rem;
}
.instagram__post__picture__carousel li:first-child {
  background: #FFFFFF;
}
.instagram__post__content {
  display: flex;
  height: 100%;
}
.instagram__post__text {
  display: flex;
  flex-direction: column;
}
.instagram__post__text__timeago {
  color: var(--themeTitle, #333333);
  display: block;
  font-weight: 400;
}
.instagram__post__text__caption {
  text-decoration: none;
}
.instagram__post__text__caption__more {
  font-weight: 400;
}
@media (min-width: 48em) {
  .instagram__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 64em) {
  .instagram__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.intro-content__buttons {
  margin-top: var(--marginElement2Button);
}
@media (max-width: 47.99em) {
  .intro-content__buttons {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }
}
@media (min-width: 48em) {
  .intro-content .container {
    display: grid;
    grid-gap: 0 calc(2 * var(--gridGap));
    grid-template-columns: repeat(2, 1fr);
  }
  .intro-content__content {
    float: right;
    grid-column-start: 2;
    grid-row: 1/2 span;
    margin-bottom: 0 !important;
  }
  .intro-content__content p:last-child {
    margin-bottom: 0;
  }
  .intro-content--left .intro-content__content {
    grid-column-start: 1;
  }
  .intro-content__title:has(+ .intro-content__content + .intro-content__buttons) {
    margin-bottom: var(--marginTitle2Button);
  }
}

.plusminus__grid {
  display: grid;
  grid-gap: var(--gridGap);
}
.plusminus__grid__column__title {
  font-weight: 700;
}
.plusminus__grid__column__point {
  margin-bottom: 1rem;
  padding: 0 0 0 1.75rem;
  position: relative;
}
.plusminus__grid__column__point:last-child {
  margin-bottom: 0;
}
.plusminus__grid__column__point__icon {
  height: 1rem;
  left: 0;
  position: absolute;
  top: 0.3125rem;
  width: 1rem;
}
.plusminus__grid__column--negative .plusminus__grid__column__point__icon {
  color: #D86947;
  fill: #D86947;
}
.plusminus__grid__column--positive .plusminus__grid__column__point__icon {
  color: #C8D57C;
  fill: #C8D57C;
}
@media (min-width: 48em) {
  .plusminus__grid__column__point {
    padding: 0 0 0 2.5rem;
  }
  .plusminus__grid__column__point__icon {
    height: 1.25rem;
    top: 0.375rem;
    width: 1.25rem;
  }
}
@media (min-width: 64em) {
  .plusminus .container {
    display: flex;
    flex-direction: column;
  }
  .plusminus__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 90em) {
  .plusminus__grid {
    grid-gap: 3rem;
  }
  .plusminus__grid__column {
    padding: 3rem;
  }
}

.promo-banner__image {
  display: block;
}
.promo-banner__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--blockPadding);
}
@media (max-width: 47.99em) {
  .promo-banner .container {
    margin-left: 0;
    margin-right: 0;
  }
}
@media (min-width: 48em) {
  .promo-banner__content__buttons {
    margin-top: 2rem;
  }
}
@media (min-width: 64em) {
  .promo-banner .container {
    display: grid;
    grid-gap: 0;
    grid-template-columns: 1fr 1fr;
  }
  .promo-banner__content, .promo-banner__image {
    flex-shrink: 0;
  }
  .promo-banner__content__buttons {
    margin-top: 3rem;
  }
  .promo-banner__image {
    border-radius: 0;
    overflow: hidden;
    position: relative;
  }
  .promo-banner__image img {
    height: 100%;
    max-width: none;
    -o-object-fit: cover;
       object-fit: cover;
    position: absolute;
    width: 100%;
  }
}

.quote .container {
  border-left: 1px solid #7F7F7F;
  padding-left: min(8.75vw, 3.75rem);
}
.quote__quote {
  margin: 0 0 0.5rem;
}
.quote__name {
  font-weight: 700;
}
@media (min-width: 48em) {
  .quote .container {
    padding: 1rem 0 1rem 2.5rem;
  }
}
@media (min-width: 64em) {
  .quote .container {
    margin: 0 auto;
    max-width: 50rem;
  }
}

.reviews__content {
  margin-bottom: var(--marginText2Element);
}
.reviews__swiper {
  margin-bottom: 2rem;
  position: relative;
}
.reviews__swiper__bottom {
  display: flex;
  margin-top: var(--marginText2Button);
}

.services-promo__slider, .services-promo__slider--tall {
  position: relative;
}

.steps {
  position: relative;
}
.steps__slider {
  margin: 0 0 var(--marginElement2Button);
}
.steps__slider__step {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.steps__slider__step__icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  fill: var(--themeIcon, var(--theme-primary, #000000));
  height: 3rem;
  margin: 0 0 var(--marginElement2Element, 1em);
  width: 3rem;
}
.steps__slider__step__icon.image {
  display: inline-flex;
  overflow: hidden;
  width: 100%;
}
.steps__slider__step__icon.image img {
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
}
.steps__slider__step__title {
  font-weight: 700;
}
.steps__slider--centered .steps__slider__step {
  align-items: center;
  display: flex;
  flex-direction: column;
  text-align: center;
}
.steps__slider--centered .steps__slider__step .steps__slider__step__icon {
  justify-content: center;
}
.steps__slider:has(.steps__slider__step__icon) .steps__slider__step:not(:has(> .steps__slider__step__icon))::before {
  content: "";
  display: block;
  height: 3rem;
  margin: 0 0 var(--marginElement2Element, 1em);
}
@media (max-width: 47.99em) {
  .steps__buttons {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }
}
@media (min-width: 48em) {
  .steps .container {
    display: flex;
    flex-direction: column;
  }
}
@media (min-width: 80em) {
  .steps__grid__step__title {
    font-size: 1.5rem;
  }
}

.team .container {
  display: flex;
  flex-direction: column;
  position: relative;
}
.team__grid {
  display: grid;
  grid-gap: var(--gridGap);
}
.team__slideshow {
  margin-bottom: 1rem;
}
.team__content {
  margin: 0 0 min(8.75vw, 3.75rem);
}
.team__member {
  align-items: center;
  display: flex;
  flex-direction: column;
  padding: 0;
}
.team__member picture {
  align-items: center;
  aspect-ratio: 1/1;
  background: #F0F0F0;
  display: flex;
  justify-content: center;
  margin: 0;
  overflow: hidden;
  width: 100%;
}
.team__member picture img {
  -o-object-fit: cover;
     object-fit: cover;
}
.team__member picture.empty img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 50%;
}
.team__member__name {
  font-weight: 700;
  margin: 0;
}
.team__member__details {
  padding: var(--blockPadding);
  text-align: left;
  width: 100%;
}
.team__member__details__contact {
  display: flex;
  margin: var(--marginText2Text) 0 0;
}
.team__member__details__contact a {
  align-items: center;
  background: var(--themeButtonBackground, #000000);
  border-radius: 1.25rem;
  display: flex;
  font-weight: 500;
  margin: 0 0 0 0.75rem;
  text-decoration: none;
  transition: all var(--transitionTime) ease-in-out;
}
.team__member__details__contact a:first-child {
  margin: 0;
}
.team__member__details__contact a .icon {
  border-radius: 50%;
  color: var(--themeButtonText, #FFFFFF);
  display: block;
  height: 2.5rem;
  overflow: visible;
  padding: 0.625rem;
  transition: all var(--transitionTime) ease-in-out;
  width: 2.5rem;
}
.team__member__details__contact a span {
  display: none;
  white-space: nowrap;
}
@media (hover: none) {
  .team__member__details__contact a:focus {
    background-color: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 30%);
  }
}
@media (hover: hover) {
  .team__member__details__contact a:hover {
    background-color: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 30%);
  }
}
.team__member__details__contact a:focus {
  background-color: color-mix(in srgb, var(--themeButtonBackground, #000000), var(--themeButtonText, #FFFFFF) 50%);
}
@media (min-width: 48em) {
  .team__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .team__slideshow {
    margin-bottom: 2.5rem;
  }
}
@media (min-width: 64em) {
  .team__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .team__member__details__contact a {
    background: var(--themeButtonBackground, #000000);
    border-radius: 1.25rem;
  }
}

.usps {
  background: var(--themeBackground, #F0F0F0);
  position: relative;
}
.usps[data-block] {
  transition: none;
}
.usps__usp {
  color: var(--themeText, var(--themeText, #333333));
  display: flex;
  font-size: var(--h5-font-size);
  font-weight: 200;
  line-height: 1.1;
  word-break: keep-all;
}
.usps__usp .icon {
  color: var(--theme-accent-on-background, var(--primary, #76776A));
  flex-shrink: 0;
  height: 2rem;
  margin: 1px 1rem 0 0;
  width: 2rem;
}
.usps .container {
  display: flex;
}
@media (max-width: 47.99em) {
  .usps__usp {
    font-weight: 500;
    margin: 0 0 0.75rem;
  }
  .usps__usp .icon {
    margin-top: 0;
  }
  .usps__usp span {
    padding-top: 0.4375rem;
  }
  .usps__usp:last-child {
    margin-bottom: 0;
  }
  .usps .container {
    flex-direction: column;
    padding: min(8.75vw, 3.75rem) 0;
  }
}
@media (min-width: 48em) {
  .usps .container {
    align-items: center;
    grid-gap: 0 var(--gridGap);
    justify-content: center;
    padding: 2.8125rem 0;
  }
  .usps__usp {
    align-items: center;
  }
  .usps__usp .icon {
    height: 1.5rem;
    margin: 1px 0.75rem 0 0;
    width: 1.5rem;
  }
  .hero--default + .usps, .hero--fullpage + .usps, .hero--split + .usps, html:has(.hero--default) .blocktools__none + .blocktools + .usps, html:has(.hero--default) .blocktools__none + .blocktools + .blocktools + .usps, html:has(.hero--fullpage) .blocktools__none + .blocktools + .usps, html:has(.hero--fullpage) .blocktools__none + .blocktools + .blocktools + .usps, html:has(.hero--split) .blocktools__none + .blocktools + .usps, html:has(.hero--split) .blocktools__none + .blocktools + .blocktools + .usps {
    background: none;
    left: 50%;
    position: absolute;
    transform: translate(-50%, -100%);
    width: 100vw;
    z-index: 2;
  }
  .hero--default + .usps .usps__usp, .hero--fullpage + .usps .usps__usp, .hero--split + .usps .usps__usp, html:has(.hero--default) .blocktools__none + .blocktools + .usps .usps__usp, html:has(.hero--default) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp, html:has(.hero--fullpage) .blocktools__none + .blocktools + .usps .usps__usp, html:has(.hero--fullpage) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp, html:has(.hero--split) .blocktools__none + .blocktools + .usps .usps__usp, html:has(.hero--split) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp {
    color: #FFFFFF;
    text-shadow: 0 0 0.25rem rgba(0, 0, 0, 0.1);
  }
  .hero--default + .usps .usps__usp .icon, .hero--fullpage + .usps .usps__usp .icon, .hero--split + .usps .usps__usp .icon, html:has(.hero--default) .blocktools__none + .blocktools + .usps .usps__usp .icon, html:has(.hero--default) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp .icon, html:has(.hero--fullpage) .blocktools__none + .blocktools + .usps .usps__usp .icon, html:has(.hero--fullpage) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp .icon, html:has(.hero--split) .blocktools__none + .blocktools + .usps .usps__usp .icon, html:has(.hero--split) .blocktools__none + .blocktools + .blocktools + .usps .usps__usp .icon {
    color: var(--usp-hero, var(--themeBackground, var(--themeIcon, var(--theme-primary, #000000))));
  }
}
@media (min-width: 80em) {
  .usps__usp .icon {
    height: 2rem;
    margin: 1px 1rem 0 0;
    width: 2rem;
  }
  .usps .container {
    grid-gap: 0 5rem;
  }
}

.usps-promo__usps {
  display: flex;
  flex-direction: column;
}
.usps-promo__usps__buttons {
  display: none;
}
.usps-promo__usps__usp {
  display: flex;
  font-weight: 700;
  line-height: 1.1;
  margin: 0 0 1rem;
}
.usps-promo__usps__usp:has(+ .btn-container), .usps-promo__usps__usp:last-child {
  margin-bottom: 0;
}
.usps-promo__usps__usp .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  flex-shrink: 0;
  height: 1rem;
  margin: 1px 0.5rem 0 0;
  width: 1rem;
}
@media (max-width: 47.99em) {
  .usps-promo__promo__content:has(+ .btn-container) {
    margin-bottom: 1.5em;
  }
  .usps-promo__promo__buttons {
    display: none;
  }
  .usps-promo__usps {
    margin-top: 0;
  }
  .usps-promo__usps__buttons {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
    margin-top: 2em;
  }
  .usps-promo__usps__usp .icon {
    height: 2rem;
    margin: 0 1rem 0 0;
    width: 2rem;
  }
  .usps-promo__usps__usp span {
    padding-top: 0.5rem;
  }
}
@media (min-width: 48em) {
  .usps-promo .container {
    display: grid;
    grid-gap: 4rem;
    grid-template-columns: 1fr 1fr;
  }
  .usps-promo__usps {
    padding: 0.5em 0;
  }
  .usps-promo__usps:has(> *:nth-child(4)) {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .usps-promo__usps__usp {
    font-size: 1.25rem;
    margin: 0 0 1.5rem;
  }
  .usps-promo__usps__usp .icon {
    height: 2rem;
    margin: 1px 1rem 0 0;
    width: 2rem;
  }
  .usps-promo__usps__usp span {
    transform: translateY(0.375rem);
  }
}
@media (min-width: 64em) {
  .usps-promo .container {
    grid-gap: 6rem;
  }
  .usps-promo__promo {
    max-width: 30rem;
  }
}
@media (min-width: 80em) {
  .usps-promo .container {
    grid-gap: 10rem;
  }
  .usps-promo__usps__usp {
    font-size: 1.5rem;
    margin: 0 0 1.5rem;
  }
  .usps-promo__usps__usp .icon {
    height: 2.5rem;
    margin: 1px 1rem 0 0;
    width: 2.5rem;
  }
  .usps-promo__usps__usp span {
    transform: translateY(0.5rem);
  }
}

.video-fullwidth {
  display: block;
  margin: 0;
  position: relative;
  width: 100vw;
}
.video-fullwidth__player {
  overflow: hidden;
  position: relative;
  width: 100%;
}
.video-fullwidth__player video {
  width: 100%;
}
@media (max-width: 47.99em) {
  .video-fullwidth {
    padding: 0;
  }
  .video-fullwidth .container {
    margin: 0;
  }
  .video-fullwidth__player {
    min-height: 56.25vw;
    width: 100vw;
  }
}
@media (min-width: 90em) {
  .video-fullwidth .container {
    margin: 0 auto;
    max-width: 75rem;
  }
}

:root {
  --plyr-color-main: var(--secondary, #9AA171);
}

:root {
  --plyr-color-main: var(--primary);
}

.videos {
  --videos-grid-columns: repeat(1, 1fr);
}
.videos__grid {
  display: grid;
  grid-gap: var(--gridGap);
  grid-template-columns: var(--videos-grid-columns);
}
.videos .video-modal {
  align-items: center;
  display: flex;
  height: 100%;
  inset: 0;
  justify-content: center;
  opacity: 1;
  position: fixed;
  transition: var(--transitionTime);
  width: 100%;
  z-index: 999;
}
@starting-style {
  .videos .video-modal {
    display: none;
    opacity: 0;
  }
}
.videos .video-modal__overlay {
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
  background: rgba(0, 0, 0, 0.4);
  cursor: pointer;
  height: 100%;
  inset: 0;
  position: absolute;
  width: 100%;
}
.videos .video-modal__content {
  max-width: 75rem;
  position: relative;
  width: 90%;
  z-index: 1000;
}
.videos .video-modal__close {
  align-items: center;
  background-color: var(--black);
  border-bottom-left-radius: var(--img-border-radius);
  cursor: pointer;
  display: flex;
  height: 3rem;
  justify-content: center;
  position: fixed;
  right: 0;
  top: 0;
  width: 3rem;
}
.videos .video-modal__close svg {
  fill: var(--white);
  transition: var(--transitionTime);
}
.videos .video-modal__close:is(:hover) svg {
  transform: scale(1.2);
}
@media (max-width: 47.99em) {
  .videos__buttons {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }
}
@media (min-width: 48em) {
  .videos {
    --videos-grid-columns: repeat(2, 1fr);
  }
}
@media (min-width: 80em) {
  .videos {
    --videos-grid-columns: repeat(3, 1fr);
  }
}

.contactdetails {
  margin: 0 0 1rem;
}
.contactdetails th, .contactdetails td {
  text-align: left;
}
.contactdetails th {
  font-weight: 500;
  padding-right: 1.25rem;
}
.contactdetails td a {
  text-decoration: none;
}
@media (hover: none) {
  .contactdetails td a:focus {
    text-decoration: underline;
  }
}
@media (hover: hover) {
  .contactdetails td a:hover {
    text-decoration: underline;
  }
}
@media (max-width: 79.99em) {
  .contactdetails td, .contactdetails th {
    display: block;
  }
  .contactdetails td {
    padding-bottom: 0.5em;
  }
  .contactdetails tr:last-child td {
    padding-bottom: 0;
  }
}

.album--grid .album__items {
  display: grid;
  grid-gap: var(--gridGap);
  grid-template-columns: repeat(2, 1fr);
}
.album--grid .album__items picture {
  aspect-ratio: 1/1;
  border-radius: var(--borderRadius, 0);
  overflow: hidden;
}
.album--grid .album__items picture[data-href] {
  cursor: pointer;
}
.album--grid .album__items picture img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
@media (min-width: 36em) {
  .album--grid .album__items {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 80em) {
  .album--grid .album__items {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 90em) {
  .album--grid .album__items {
    grid-template-columns: repeat(5, 1fr);
  }
}
.album--masonry {
  --masonry-columns: 3;
  --masonry-columns-mobile: 1;
  --masonry-columns-tablet: 2;
}
.album--masonry .album__items .grid-sizer,
.album--masonry .album__items picture {
  width: calc((100% - var(--gridGap) * (var(--masonry-columns-mobile) - 1)) / var(--masonry-columns-mobile));
}
.album--masonry .album__items .gutter-sizer {
  width: var(--gridGap);
}
.album--masonry .album__items picture {
  border-radius: var(--borderRadius, 0);
  display: block;
  margin-bottom: var(--gridGap);
  overflow: hidden;
}
.album--masonry .album__items picture[data-href] {
  cursor: pointer;
}
.album--masonry .album__items picture img {
  display: block;
  height: auto;
  transition: transform 0.4s ease;
  width: 100%;
}
.album--masonry .album__items picture:hover img {
  transform: scale(1.03);
}
@media (min-width: 48em) {
  .album--masonry .album__items .grid-sizer,
  .album--masonry .album__items picture {
    width: calc((100% - var(--gridGap) * (var(--masonry-columns-tablet) - 1)) / var(--masonry-columns-tablet));
  }
}
@media (min-width: 80em) {
  .album--masonry .album__items .grid-sizer,
  .album--masonry .album__items picture {
    width: calc((100% - var(--gridGap) * (var(--masonry-columns) - 1)) / var(--masonry-columns));
  }
}
.album--slideshow .swiper-wrapper picture {
  aspect-ratio: 3/2;
}
.album--slideshow .swiper-wrapper picture img {
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  width: 100%;
}
.album--slideshow .album__items.swiper.swiper-initialized .pagination, .album--slideshow .album__items.swiper-initialized.reviews__swiper .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider--tall .pagination, .album--slideshow .album__items.swiper-initialized.videos__slider .pagination {
  display: flex;
  top: calc(100% + 0.75rem);
}
@media (hover: none) and (pointer: coarse) {
  .album--slideshow .album__items.swiper.swiper-initialized .pagination, .album--slideshow .album__items.swiper-initialized.reviews__swiper .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider--tall .pagination, .album--slideshow .album__items.swiper-initialized.videos__slider .pagination {
    display: flex;
  }
}
@media (max-width: 47.99em) {
  .album--slideshow {
    margin-bottom: 1rem;
  }
}
@media (min-width: 48em) {
  .album--slideshow {
    overflow: hidden;
  }
  .album--slideshow .album__items.swiper.swiper-initialized .pagination, .album--slideshow .album__items.swiper-initialized.reviews__swiper .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider .pagination, .album--slideshow .album__items.swiper-initialized.services-promo__slider--tall .pagination, .album--slideshow .album__items.swiper-initialized.videos__slider .pagination {
    right: 1rem;
    top: calc(100% - 3rem);
  }
}

.popup {
  background: rgba(0, 0, 0, 0.6);
  bottom: 0;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 1000000;
}
.popup__close, .popup__next, .popup__previous {
  border: none;
  cursor: pointer;
  height: 2rem;
  position: absolute;
  transition: all var(--transitionTime) ease-in-out;
  width: 2rem;
}
@media (min-width: 48em) {
  .popup__close, .popup__next, .popup__previous {
    height: 3rem;
    width: 3rem;
  }
}
.popup__next, .popup__previous {
  align-items: center;
  background: #242222;
  border-radius: 50%;
  box-shadow: 0 0 0.25rem rgba(255, 255, 255, 0.1);
  display: flex;
  justify-content: center;
  top: calc(50% - 1.5rem);
}
@media (hover: none) {
  .popup__next:focus, .popup__previous:focus {
    background-color: #393737;
    border-color: var(--themeButtonBackground, #E5E8C6);
  }
}
@media (hover: hover) {
  .popup__next:hover, .popup__previous:hover {
    background-color: #393737;
    border-color: var(--themeButtonBackground, #E5E8C6);
  }
}
.popup__next::after, .popup__previous::after {
  border-bottom: 0.25rem solid transparent;
  border-top: 0.25rem solid transparent;
  top: calc(50% - 0.25rem);
}
.popup__next .icon, .popup__previous .icon {
  color: #FFFFFF;
  height: 1.125rem;
  width: 1.125rem;
}
@media (min-width: 48em) {
  .popup__next .icon, .popup__previous .icon {
    height: 1.5rem;
    width: 1.5rem;
  }
}
.popup__close {
  background: none;
  right: 2rem;
  top: 1.5rem;
}
@media (min-width: 48em) {
  .popup__close {
    right: 1rem;
  }
}
.popup__close::after, .popup__close::before {
  background: #FFFFFF;
  content: "";
  height: 0.125rem;
  left: calc(50% - 0.75rem);
  position: absolute;
  top: calc(50% - 0.125rem);
  width: 1.5rem;
}
.popup__close::after {
  transform: rotate(45deg);
}
.popup__close::before {
  transform: rotate(-45deg);
}
@media (min-width: 48em) {
  .popup__close {
    top: 1rem;
  }
  .popup__close::after, .popup__close::before {
    left: calc(50% - 1rem);
    top: calc(50% - 0.125rem);
    width: 2rem;
  }
}
.popup__next {
  right: 0.5rem;
}
@media (min-width: 48em) {
  .popup__next {
    right: 1rem;
  }
}
.popup__next::after {
  border-left: 0.5rem solid #FFFFFF;
  left: calc(50% - 0.25rem);
}
.popup__previous {
  left: 0.5rem;
}
.popup__previous::after {
  border-right: 0.5rem solid #FFFFFF;
  left: calc(50% - 0.25rem);
}
@media (min-width: 48em) {
  .popup__previous {
    left: 1rem;
  }
}
.popup__picture {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.popup__picture img {
  --object-fit: contain;
  left: 50%;
  max-height: calc(100% - 2rem);
  max-width: 100%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}
@media (min-width: 48em) {
  .popup__picture {
    bottom: 5rem;
    left: 5rem;
    position: absolute;
    right: 5rem;
  }
}
.popup__thumbnails {
  display: none;
}
@media (min-width: 48em) {
  .popup__thumbnails {
    bottom: 0;
    display: flex;
    justify-content: center;
    left: 0;
    overflow: hidden;
    overflow-x: auto;
    position: absolute;
    right: 0;
  }
  .popup__thumbnails__thumb {
    border: 1px solid rgba(255, 255, 255, 0.5);
    display: block;
    flex-shrink: 0;
    height: 5rem;
    margin-right: -1px;
    overflow: hidden;
    width: 5rem;
  }
  .popup__thumbnails__thumb img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
  }
}

.category-labels {
  --category-grid-gap: 0.5rem;
  --category-label-background: var(--white);
  --category-label-color: var(--black);
  --category-label-font-size: 0.875rem;
  --category-label-padding: 0.25rem 1rem;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--category-grid-gap);
  z-index: 1;
}
.category-labels__label {
  background-color: var(--category-label-background);
  border-radius: var(--img-border-radius);
  color: var(--category-label-color);
  font-size: var(--category-label-font-size);
  padding: var(--category-label-padding);
}

.review-item {
  align-items: var(--_review-align-items, flex-start);
  color: var(--themeText, #333333);
  border-radius: var(--img-border-radius);
  display: flex;
  flex-direction: var(--_review-flex-direction, column);
  gap: var(--_review-gap, 2rem);
  justify-content: var(--_review-justify-content, space-between);
  padding-top: var(--_review-padding-top, var(--blockPadding));
  position: relative;
  text-align: var(--_review-text-align, left);
  height: var(--_review-item-height, 100%);
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.review-item::before {
  content: "“";
  display: var(--_review-quote-display, none);
  font-family: sans-serif;
  font-size: var(--_review-quote-font-size, 4rem);
  font-weight: 700;
  line-height: 1rem;
  position: absolute;
  top: var(--_review-quote-top, 0);
}
.review-item__image {
  --_border-radius: 0;
  align-items: center;
  display: flex;
  flex-shrink: 0;
  height: var(--_review-image-height, 4.5rem);
  justify-content: center;
  margin: var(--_review-image-margin, 0 1rem 0 0);
  overflow: hidden;
  position: var(--_review-image-position, relative);
  right: var(--_review-image-right, auto);
  top: var(--_review-image-top, auto);
  width: var(--_review-image-width, 4.5rem);
}
.review-item__image--rounded {
  --_border-radius: 50%;
}
.review-item__image .icon {
  color: var(--themeIcon, var(--theme-primary, #000000));
  height: 1.5rem;
  width: 1.5rem;
}
.review-item__rating {
  color: var(--themeIcon, var(--theme-primary, #000000));
  font-size: 1.5rem;
  order: var(--_review-rating-order, 0);
}
.review-item__quote {
  font-size: var(--_review-quote-text-size, 1.25rem);
  font-weight: var(--_review-quote-font-weight, 400);
  text-align: var(--_review-quote-text-align, left);
  width: var(--_review-quote-width, 100%);
}
.review-item__footer {
  align-items: center;
  display: flex;
  justify-self: flex-end;
  width: var(--_review-footer-width, 100%);
}
.review-item__footer__text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  line-height: 1.35;
}
.review-item__name {
  color: var(--themeText, #333333);
  font-size: 0.875rem;
  font-weight: 700;
  margin: 0 0 0.25rem;
}
.review-item__details {
  font-size: 0.75rem;
}
.review-item--type-1 {
  --_review-justify-content: center;
  --_review-padding-top: 4rem;
  --_review-quote-display: block;
  --_review-quote-font-size: 9rem;
  --_review-quote-font-weight: 700;
  --_review-quote-top: calc(var(--_review-padding-top) / 2);
  --_review-item-height: auto;
}
.review-item--type-1:has(.review-item__rating) {
  --_review-footer-margin-top: auto;
  --_review-justify-content: flex-start;
  --_review-quote-margin-top: 0;
}
.review-item--type-2 {
  --_review-flex-direction: column-reverse;
  --_review-justify-content: center;
  --_review-rating-order: 1;
  --_review-item-height: auto;
}
.review-item--type-2:has(.review-item__rating) {
  --_review-justify-content: flex-end;
}
.review-item--type-3 {
  --_review-justify-content: center;
  --_review-item-height: auto;
}
.review-item--type-3:has(.review-item__rating) {
  --_review-footer-margin-top: auto;
  --_review-footer-padding-top: var(--marginText2Text);
  --_review-justify-content: flex-start;
}
.review-item--type-4 {
  --_review-padding-top: 5rem;
  --_review-quote-display: block;
  --_review-quote-font-size: 4rem;
  --_review-quote-top: 3.25rem;
  --_review-quote-width: calc(100% - 7rem);
  --_review-item-height: auto;
  --_review-justify-content: flex-start;
}
.review-item--type-4:has(.review-item__rating) {
  --_review-image-top: 9.75rem;
}
.review-item--centered.review-item--type-1, .review-item--centered.review-item--type-2, .review-item--centered.review-item--type-3 {
  --_review-align-items: center;
  --_review-footer-width: auto;
  --_review-quote-text-align: center;
}
@media (min-width: 48em) {
  .review-item__rating {
    font-size: 2rem;
  }
  .review-item--type-4 {
    --_review-image-height: 6rem;
    --_review-image-position: absolute;
    --_review-image-right: 1rem;
    --_review-image-top: 5.25rem;
    --_review-image-width: 6rem;
  }
}
@media (min-width: 90em) {
  .review-item__name, .review-item__details {
    font-size: 1rem;
  }
}

.review-item__image {
  --_border-radius: 50%;
}
.review-item__image img {
  border-radius: var(--_border-radius);
}

.service-item {
  --content-padding: var(--grid-gutter);
  --image-ratio: 9 / 16;
  --picture-gradient-color: var(--themeBackground);
  border-radius: var(--img-border-radius);
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.service-item picture {
  aspect-ratio: var(--image-ratio);
  display: block;
  flex-grow: 0;
  flex-shrink: 0;
  height: auto;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.service-item picture img {
  backface-visibility: hidden;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  transform-style: preserve-3d;
  transition: var(--transitionTime) all;
  width: 100%;
  will-change: transform;
  border-radius: 0;
  transition: var(--transitionTime);
}
.service-item:not(:has(img))::after {
  background: linear-gradient(to bottom, color-mix(in srgb, var(--picture-gradient-color), transparent 100%) 0.1%, color-mix(in srgb, var(--picture-gradient-color), transparent 50%) 100%);
  content: "";
  height: 140%;
  inset: 0;
  opacity: 1;
  position: absolute;
  transition: var(--transitionTime) all;
  z-index: 1;
}
.service-item__content {
  align-items: flex-start;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
  padding: var(--content-padding);
  pointer-events: none;
  position: relative;
}
.service-item__content p {
  margin-bottom: 2rem;
}
.service-item__content .btn {
  margin-top: auto;
}
.service-item:is(:hover, :focus) picture img {
  transform: scale(1.02);
}
.service-item:is(:hover, :focus) picture::after {
  opacity: 1;
  transform: translateY(-20%);
}
.service-item:is(:hover, :focus) .service-item__content .btn {
  color: var(--_color);
  background: var(--_text-color);
}
.service-item.style-default {
  --picture-gradient-color: var(--black);
}
.service-item--square {
  --image-ratio: 1 / 1;
}
.service-item--wide {
  --image-ratio: 16 / 13;
}
.service-item--wide.service-item--boxed-content, .service-item--wide.service-item--content {
  --image-ratio: 16 / 11;
}
.service-item--tall_wide {
  --image-ratio: 10 / 16;
}
.service-item--image .service-item__content {
  bottom: 0;
  left: 0;
  position: absolute;
  z-index: 10;
}
.service-item--image .service-item__content p, .service-item--image .service-item__content .btn {
  display: none;
}
.service-item--image .service-item__content .title, .service-item--image .service-item__content h4, .service-item--image .service-item__content .h4 {
  color: var(--white);
  margin-bottom: 0;
}
.service-item--content {
  background: transparent;
}
.service-item--content .service-item__content {
  padding: var(--grid-gutter) 0;
}
.service-item--content picture, .service-item--boxed-content picture {
  border-radius: var(--img-border-radius) var(--img-border-radius) 0 0;
}
.service-item:focus, .service-item:focus-visible, .service-item:focus-within {
  outline: 5px auto Highlight;
  outline: 5px auto -webkit-focus-ring-color;
}

.service-item {
  background: var(--themeBackground);
}
.service-item picture img {
  filter: brightness(80%);
}

.video-item {
  --video-item-content-border-radius: 0;
  --video-item-content-padding: var(--spacing-l) 0 0 0;
  --video-item-icon-color: var(--white);
  --video-item-image-border-radius: var(--img-border-radius);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.video-item__poster {
  aspect-ratio: 16/9;
  border-radius: var(--video-item-image-border-radius);
  display: block;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.video-item__poster img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: var(--transitionTime);
  width: 100%;
}
.video-item__poster__play-button {
  align-items: center;
  border: 0.25rem solid var(--white);
  border-radius: 50%;
  display: flex;
  height: 4.5rem;
  justify-content: center;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: var(--transitionTime);
  width: 4.5rem;
  z-index: 5;
}
.video-item__poster__play-button svg {
  fill: var(--video-item-icon-color);
  height: 3rem;
  transition: var(--transitionTime);
  width: 3rem;
}
.video-item__poster::before {
  background: radial-gradient(rgba(0, 0, 0, 0) 0.1%, rgba(0, 0, 0, 0.5) 100%);
  content: "";
  inset: -6rem;
  position: absolute;
  transition: var(--transitionTime);
  z-index: 3;
}
.video-item__content {
  border-radius: var(--video-item-content-border-radius);
  flex: 1;
  overflow: hidden;
  padding: var(--video-item-content-padding);
  position: relative;
}
.video-item:is(:hover) {
  --video-item-icon-color: var(--primary);
}
.video-item:is(:hover) .video-item__poster img {
  transform: scale(1.05);
}
.video-item:is(:hover) .video-item__poster::before {
  inset: 0;
}
.video-item:is(:hover) .video-item__poster__play-button svg {
  transform: scale(0.8);
}
.video-item--boxed {
  --video-item-content-border-radius: 0 0 var(--img-border-radius) var(--img-border-radius);
  --video-item-content-padding: var(--spacing-l);
  --video-item-image-border-radius: var(--img-border-radius) var(--img-border-radius) 0 0;
}

.replaceme,
.replaceme > *,
.replaceme > * > * {
  color: #D86947 !important;
}
