/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

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

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

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

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

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

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

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}

/**
 * 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, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

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

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

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

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}

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

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

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

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

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

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

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

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

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

:root {
  --bp-s0: 0px;
  --bp-s3: 375px;
  --bp-s4: 414px;
  --bp-s5: 568px;
  --bp-s6: 640px;
  --bp-s7: 768px;
  --bp-s10: 1000px;
  --bp-s12: 1280px;
  --bp-s14: 1400px;
  --bp-s16: 1600px;
  --page-max-width: 1600px;
}

:root {
  --c-black: var(--wp--preset--color--black);
  --c-white: var(--wp--preset--color--white);
  --c-grey: #4d4d4d;
  --c-gray: var(--c-grey);
  --c-dark-grey: #212121;
  --c-dark-gray: var(--c-dark-grey);
  --c-text: var(--wp--preset--color--text);
  --c-text-dark: var(--c-black);
  --c-text-light: var(--wp--preset--color--text-light);
  --c-brand-primary-lightest: var(--wp--preset--color--brand-primary-lightest);
  --c-brand-primary-light: var(--wp--preset--color--brand-primary-light);
  --c-brand-primary: var(--wp--preset--color--brand-primary);
  --c-brand-primary-dark: var(--wp--preset--color--brand-primary-dark);
  --c-brand-primary-darker: var(--wp--preset--color--brand-primary-darker);
}

:root {
  --ease-cubic: cubic-bezier(0.3, 1, 0.7, 1);
}

/* @link https://utopia.fyi/type/calculator?c=375,14,1.2,1600,20,1.25,10,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */
/* @link https://utopia.fyi/type/calculator?c=375,14,1.125,1600,20,1.2,10,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */
:root {
  --font-size--2: clamp(0.6914rem, 0.6373rem + 0.2308vw, 0.8681rem);
  --font-size--1: clamp(0.7778rem, 0.697rem + 0.3447vw, 1.0417rem);
  --font-size-0: clamp(0.875rem, 0.7602rem + 0.4898vw, 1.25rem);
  --font-size-1: clamp(0.9844rem, 0.8265rem + 0.6735vw, 1.5rem);
  --font-size-2: clamp(1.1074rem, 0.8954rem + 0.9046vw, 1.8rem);
  --font-size-3: clamp(1.2458rem, 0.966rem + 1.194vw, 2.16rem);
  --font-size-4: clamp(1.4016rem, 1.0372rem + 1.5548vw, 2.592rem);
  --font-size-5: clamp(1.5768rem, 1.1073rem + 2.0031vw, 3.1104rem);
  --font-size-6: clamp(1.7739rem, 1.1743rem + 2.5582vw, 3.7325rem);
  --font-size-7: clamp(1.9956rem, 1.2354rem + 3.2436vw, 4.479rem);
  --font-size-8: clamp(2.2451rem, 1.287rem + 4.0878vw, 5.3748rem);
  --font-size-9: clamp(2.5257rem, 1.3245rem + 5.1253vw, 6.4497rem);
  --font-size-10: clamp(2.8414rem, 1.3419rem + 6.3977vw, 7.7397rem);
}

/* @link https://utopia.fyi/type/calculator?c=375,14,1.2,1600,20,1.25,10,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */
/* @link https://utopia.fyi/type/calculator?c=375,14,1.125,1600,20,1.2,10,2,&s=0.75|0.5|0.25,1.5|2|3|4|6,s-l&g=s,l,xl,12 */
:root {
  --font-size-rel--2: clamp(0.6914rem, 0.6107rem + 0.3442cqi, 0.9549rem);
  --font-size-rel--1: clamp(0.7778rem, 0.6651rem + 0.4807cqi, 1.1458rem);
  --font-size-rel-0: clamp(0.875rem, 0.7219rem + 0.6531cqi, 1.375rem);
  --font-size-rel-1: clamp(0.9844rem, 0.7806rem + 0.8694cqi, 1.65rem);
  --font-size-rel-2: clamp(1.1074rem, 0.8403rem + 1.1397cqi, 1.98rem);
  --font-size-rel-3: clamp(1.2458rem, 0.8999rem + 1.4761cqi, 2.376rem);
  --font-size-rel-4: clamp(1.4016rem, 0.9578rem + 1.8934cqi, 2.8512rem);
  --font-size-rel-5: clamp(1.5768rem, 1.0121rem + 2.4094cqi, 3.4214rem);
  --font-size-rel-6: clamp(1.7739rem, 1.06rem + 3.0457cqi, 4.1057rem);
  --font-size-rel-7: clamp(1.9956rem, 1.0983rem + 3.8286cqi, 4.9269rem);
  --font-size-rel-8: clamp(2.2451rem, 1.1225rem + 4.7898cqi, 5.9122rem);
  --font-size-rel-9: clamp(2.5257rem, 1.127rem + 5.9677cqi, 7.0947rem);
  --font-size-rel-10: clamp(2.8414rem, 1.105rem + 7.4086cqi, 8.5136rem);
}
@media screen and (min-width: 1280px) {
  :root {
    --font-size-rel--2: clamp(0.8889rem, 0.8155rem + 0.3129cqi, 1.1285rem);
    --font-size-rel--1: clamp(1rem, 0.8916rem + 0.4626cqi, 1.3542rem);
    --font-size-rel-0: clamp(1.125rem, 0.9719rem + 0.6531cqi, 1.625rem);
    --font-size-rel-1: clamp(1.2656rem, 1.0561rem + 0.8939cqi, 1.95rem);
    --font-size-rel-2: clamp(1.4238rem, 1.1434rem + 1.1966cqi, 2.34rem);
    --font-size-rel-3: clamp(1.6018rem, 1.2326rem + 1.5754cqi, 2.808rem);
    --font-size-rel-4: clamp(1.802rem, 1.3222rem + 2.0474cqi, 3.3696rem);
    --font-size-rel-5: clamp(2.0273rem, 1.4101rem + 2.6334cqi, 4.0435rem);
    --font-size-rel-6: clamp(2.2807rem, 1.4935rem + 3.3587cqi, 4.8522rem);
    --font-size-rel-7: clamp(2.5658rem, 1.5688rem + 4.2539cqi, 5.8227rem);
    --font-size-rel-8: clamp(2.8865rem, 1.6312rem + 5.356cqi, 6.9872rem);
    --font-size-rel-9: clamp(3.2473rem, 1.6747rem + 6.71cqi, 8.3846rem);
    --font-size-rel-10: clamp(3.6532rem, 1.6915rem + 8.3701cqi, 10.0616rem);
  }
}

:root {
  --font-family-headline: "poppins", serif;
  --font-family-body: "poppins", sans-serif;
  --font-family-buttons: var(--font-family-headline);
  --font-size-h1: var(--font-size-8);
  --font-size-h2: var(--font-size-5);
  --font-size-h3: var(--font-size-3);
  --font-size-h4: var(--font-size-2);
  --font-size-h5: var(--font-size-1);
  --font-size-body-xlarge: var(--font-size-2);
  --font-size-body-large: var(--font-size-1);
  --font-size-body-small: var(--font-size--1);
  --font-size-body-xsmall: var(--font-size--2);
}

html {
  scroll-behavior: smooth;
}

body {
  overscroll-behavior-y: none;
  margin: 0;
}

::-moz-selection {
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  background-clip: initial;
  -webkit-text-fill-color: initial;
}

::selection {
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  background-clip: initial;
  -webkit-text-fill-color: initial;
}

img::-moz-selection {
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  background-clip: initial;
  -webkit-text-fill-color: initial;
}

img::selection {
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  background-clip: initial;
  -webkit-text-fill-color: initial;
}

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

a {
  transition: all 0.25s;
  color: var(--c-brand-primary);
  text-decoration: none !important;
  outline: none !important;
}
a:hover {
  color: var(--c-brand-primary-dark);
}

.visually-hidden {
  overflow: hidden;
  text-indent: 999px;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
}

.verdaslate-block {
  margin: 0;
}

.alignfull {
  position: relative;
  left: 50%;
  width: 100vw;
  margin-left: -50vw !important;
}

#page-content {
  position: relative;
  min-height: 20em;
  background: #fff;
}

.section-wrapper {
  position: relative;
}

.color-flip-sections {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.color-flip-sections {
  display: flex;
  flex-flow: column;
  pointer-events: none;
}
.color-flip-sections > div {
  flex-grow: 1;
}

span.w,
.field--overline > div,
.field.field--body > div,
.field.field--body-below > div {
  transition: color 1s var(--ease-cubic);
}

body {
  font-family: var(--font-family-body);
  font-weight: 300;
  font-style: normal;
  color: var(--c-text);
  font-size: var(--font-size-0);
  line-height: 1.4em;
  text-wrap: pretty;
  font-optical-sizing: auto;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-family-headline);
  font-weight: var(--font-weight-headline);
  margin: 0;
}

p {
  line-height: inherit;
  margin-top: 0;
  margin-bottom: 0.5em;
}

p.small {
  font-size: 0.9em;
  line-height: 1.6em;
}

strong {
  font-weight: 700;
}

.h1 {
  font-size: var(--font-size-h1);
  line-height: 1em;
}

.h2 {
  font-size: var(--font-size-h2);
  line-height: 1em;
  margin-bottom: 0.25em;
}

.h3 {
  font-size: var(--font-size-h3);
  line-height: 1.1em;
  margin-bottom: 0.25em;
}

.h4 {
  font-size: var(--font-size-h4);
  line-height: 1.2em;
}

.h5 {
  font-size: var(--font-size-h5);
  line-height: 1.4em;
}

.node-article.node-full .field--name-field-page-content > .field-items > .paragraph:not(:last-child, .hr) {
  margin-bottom: 2em;
}

.paragraph--type--basic-page-content > .field--name-field-p > .field-items > *:not(:last-child, .hr) {
  margin-bottom: 2em;
}

.typography {
  line-height: 1.6em;
  font-weight: var(--font-weight-body);
}
.typography p:not(:last-child), .typography ul:not(:last-child), .typography ol:not(:last-child) {
  margin-bottom: 1.5em;
}
.typography p:last-child, .typography ul:last-child, .typography ol:last-child {
  margin-bottom: 0;
}
.typography ul, .typography ol {
  padding-left: 1.25rem;
}
.typography li {
  padding: 0.35em 0;
}
.typography li:last-child {
  padding-bottom: 0;
}
.typography h2, .typography h3, .typography h4, .typography h5, .typography h6 {
  font-weight: 300;
}
.typography h2 {
  font-size: var(--font-size-h3);
  line-height: 1.1em;
  margin-bottom: 0.25em;
  margin-top: 2em;
}
.typography h2:first-child {
  margin-top: 0;
}
.typography h3 {
  font-size: var(--font-size-h4);
  line-height: 1.2em;
  font-family: var(--font-family-body);
  margin-bottom: 0.25em;
  margin-top: 0.5em;
  font-weight: 300;
}
.typography h4 {
  font-weight: 300;
  font-size: 1.2em;
  line-height: 1.2em;
  margin-bottom: 0.5em;
}
.typography h5 {
  font-size: var(--font-size-h4);
  line-height: 1.2em;
  line-height: 1.2em;
  margin-bottom: 0.25em;
  font-weight: 700;
}
.typography h6 {
  font-size: 0.8em;
  line-height: 1.2em;
  margin-bottom: 0.25em;
  font-weight: 700;
}
.typography h2 + h3 {
  margin-top: 0em;
}
.typography hr {
  border: none;
  border-top: 2px solid rgba(0, 0, 0, 0.15);
  margin: 3rem 0;
}
.typography img {
  display: block;
  width: 100%;
  height: auto;
}
.typography .text-align-center {
  text-align: center;
}
.typography table {
  margin-bottom: 2em;
  width: 100%;
}
.typography table td {
  padding: 0 0.5em 0.25em 0;
  vertical-align: top;
}
.typography strong {
  font-weight: 700;
}
.typography > .paragraph:not(.paragraph--divider) {
  margin: 4em 0;
}
.typography > .paragraph:first-child {
  margin-top: 0;
}
.typography p + .paragraph--links-files,
.typography h2 + .paragraph--links-files,
.typography h3 + .paragraph--links-files,
.typography h4 + .paragraph--links-files,
.typography h5 + .paragraph--links-files,
.typography h6 + .paragraph--links-files {
  margin-top: 1.5em !important;
}

:root {
  --button-padding: 1.1em 2.75em 1.1em 2.75em;
  --button-font-family: var(--font-family-sans);
  --button-font-weight: 400;
  --button-text-offest: 0.15em;
  --button-border-radius: 9999px;
  --button-bg: var(--c-brand-primary);
  --button-bg-hover: var(--c-brand-primary-dark);
  --button-color: var(--c-text-light);
  --button-color-hover: var(--c-text-light);
  --button-secondary-bg: #fff;
  --button-secondary-bg-hover: var(--c-brand-primary-light);
  --button-secondary-color: var(--c-brand-primary);
  --button-secondary-color-hover: var(--c-brand-primary-dark);
}

.button,
.bef-link,
.wc-block-components-button {
  display: inline-block;
  line-height: 1em;
  border: none;
  position: relative;
  transition: all 0.25s;
  padding: var(--button-padding);
  font-weight: var(--button-font-weight);
  font-family: var(--button-font-family);
  border-radius: var(--button-border-radius);
  background-color: var(--button-bg);
  color: var(--button-color);
  font-weight: var(--button-font-weight);
}
.button:hover,
.bef-link:hover,
.wc-block-components-button:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
.button.button--secondary,
.bef-link.button--secondary,
.wc-block-components-button.button--secondary {
  background: var(--button-secondary-bg);
  color: var(--button-secondary-color);
  border: 2px solid color-mix(in srgb, var(--button-secondary-color), #fff 50%);
}
.button.button--secondary:hover,
.bef-link.button--secondary:hover,
.wc-block-components-button.button--secondary:hover {
  background: var(--button-secondary-bg-hover);
  color: var(--button-secondary-color-hover);
}

.icon-button {
  display: inline-flex;
  align-items: center;
  padding: 0.5em 0.5em 0.5em 0.5em;
  border-radius: var(--button-border-radius);
  transition: all 0.25s;
  font-weight: var(--button-font-weight);
  background-color: var(--button-bg);
  color: var(--button-color);
}
.icon-button i {
  border-radius: 9999px;
  width: 2.2em;
  height: 2.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  order: 999;
  border-radius: 0.25rem;
  background: var(--c-brand-primary-dark);
  color: var(--c-text-light);
}
.icon-button i svg {
  display: block;
  width: 60%;
  height: auto;
}
.icon-button span.t {
  display: block;
  padding: 0 1.25em;
  padding-right: 1.25em;
  font-size: 0.9em;
  line-height: 1em;
  white-space: nowrap;
  padding-top: var(--button-text-offest);
}
.icon-button:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
.icon-button:hover i {
  color: var(--button-bg-hover);
  background-color: var(--button-color-hover);
}
.icon-button.icon-button--secondary {
  padding-right: 0;
  padding-left: 0;
  background: transparent;
  color: var(--c-brand-primary);
}
.icon-button.icon-button--secondary span.t {
  padding-right: 0.5em;
  padding-left: 0;
}
.icon-button.icon-button--secondary i {
  width: 1.5em;
  background: transparent;
}
.icon-button.icon-button--secondary i svg {
  width: 100%;
  height: auto;
  color: var(--c-brand-primary-dark);
}
.icon-button.icon-button--secondary:hover {
  opacity: 0.5;
}

a.blob-button {
  transition: all 0.25s;
  display: inline-flex;
  position: relative;
}
a.blob-button > span {
  display: flex;
  align-items: center;
  position: relative;
}
a.blob-button .label {
  border-radius: 999px;
  color: #000;
  background: #fff;
  padding: 0 2em;
  line-height: 3em;
  height: 3em;
  padding-top: 0.15em;
  font-weight: 300;
  transition: all 1s var(--ease-cubic);
}
a.blob-button .middle {
  width: 1.5em;
  height: 3em;
  position: absolute;
  right: 2.1em;
  z-index: 1;
  transition: all ease-in 0.35s;
}
a.blob-button .middle::before, a.blob-button .middle::after {
  content: "";
  position: absolute;
  width: 3.5em;
  height: 4em;
  left: 50%;
  transform: translatex(-50%);
  background-color: var(--c-brand-primary);
  border: 1em solid var(--c-brand-primary);
  z-index: 100;
  border-radius: 50%;
  transform-origin: center;
  box-sizing: border-box;
  transition: all ease-in 0.35s, border-color 1s var(--ease-cubic);
}
a.blob-button .middle::before {
  clip-path: polygon(0px 0px, 100% 0px, 91.07% 31.75%, 6px 31.75%);
  top: calc(50% - 0.1rem);
}
a.blob-button .middle::after {
  clip-path: polygon(4px 68.13%, 85.71% 66.56%, 100% 100%, 0px 100%);
  bottom: calc(50% - 0.05rem);
}
a.blob-button .arrow {
  height: 3em;
  width: 3em;
  min-width: 3em;
  margin-left: -0.3em;
  border-radius: 64px;
  background-color: var(--c-brand-primary);
  color: var(--c-text-light);
  transition: all ease-in 0.35s, background-color 1s var(--ease-cubic);
  display: flex;
  vertical-align: middle;
  align-items: center;
  position: relative;
  z-index: 1;
}
a.blob-button .arrow svg {
  margin: auto;
  transform: rotate(-45deg);
  transition: all ease-in 0.35s;
}
a.blob-button:hover .middle {
  right: 2.55em;
}
a.blob-button:hover .middle::before, a.blob-button:hover .middle::after {
  border-width: 0px;
  width: 2em;
}
a.blob-button:hover .arrow {
  margin-left: 0.6em;
}
a.blob-button:hover .arrow svg {
  transform: rotate(0deg);
}

a.icon-swap-button {
  line-height: 1em;
  font-weight: 300;
  display: flex;
  align-items: center;
}
a.icon-swap-button span {
  height: 3em;
  line-height: 3em;
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  border-radius: 1.17em;
}
a.icon-swap-button i {
  width: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
}
a.icon-swap-button i svg {
  display: block;
  position: relative;
  width: 55%;
  height: auto;
  color: var(--c-text-light);
}
a.icon-swap-button span.t {
  padding: 0 2.5em;
  flex-grow: 1;
}
a.icon-swap-button i.right {
  width: 0;
  height: 0;
}
a.icon-swap-button:hover i.left {
  width: 0;
  height: 0;
}
a.icon-swap-button:hover i.right {
  width: 3em;
  height: 3em;
}

a.button--image-subtitle {
  display: inline-flex;
  align-items: center;
  padding: 0.5em;
  padding-right: 1.5em;
  border-radius: 999px;
  transition: all 0.25s;
  font-weight: 300;
  border-radius: 9999px;
  background: var(--c-brand-primary);
}
a.button--image-subtitle i {
  border-radius: 50%;
  width: 3.5em;
  height: 3.5em;
  contain: paint;
}
a.button--image-subtitle i img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
a.button--image-subtitle span.t {
  display: block;
  padding: 0 1.25em;
  padding-right: 1.5em;
  padding-top: 0.15em;
  line-height: 1em;
  white-space: nowrap;
  text-align: left;
  color: var(--c-text-light);
}
a.button--image-subtitle span.t > span {
  display: block;
}
a.button--image-subtitle span.t .title {
  font-weight: 700;
  margin-bottom: 0.2em;
}
a.button--image-subtitle span.t .subtitle {
  font-size: var(--step--1);
  line-height: 1em;
}

.button,
.wp-element-button {
  display: inline-block;
  line-height: 1em;
  border: none;
  position: relative;
  transition: all 0.25s;
  padding: var(--button-padding);
  font-weight: var(--button-font-weight);
  font-family: var(--button-font-family);
  border-radius: var(--button-border-radius);
  background-color: var(--button-bg);
  color: var(--button-color);
  font-weight: var(--button-font-weight);
}
.button:hover,
.wp-element-button:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
.button.button--secondary,
.wp-element-button.button--secondary {
  background: var(--button-secondary-bg);
  color: var(--button-secondary-color);
  border: 2px solid color-mix(in srgb, var(--button-secondary-color), #fff 50%);
}
.button.button--secondary:hover,
.wp-element-button.button--secondary:hover {
  background: var(--button-secondary-bg-hover);
  color: var(--button-secondary-color-hover);
}

.icon-button {
  display: inline-flex;
  align-items: center;
  padding: 0.5em 0.5em 0.5em 0.5em;
  border-radius: var(--button-border-radius);
  transition: all 0.25s;
  font-weight: var(--button-font-weight);
  background-color: var(--button-bg);
  color: var(--button-color);
}
.icon-button i {
  border-radius: 9999px;
  width: 2.2em;
  height: 2.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
  order: 999;
  border-radius: 0.25rem;
  background: var(--c-brand-primary-dark);
  color: var(--c-text-light);
}
.icon-button i svg {
  display: block;
  width: 60%;
  height: auto;
}
.icon-button span.t {
  display: block;
  padding: 0 1.25em;
  padding-right: 1.25em;
  font-size: 0.9em;
  line-height: 1em;
  white-space: nowrap;
  padding-top: var(--button-text-offest);
}
.icon-button:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
.icon-button:hover i {
  color: var(--button-bg-hover);
  background-color: var(--button-color-hover);
}
.icon-button.icon-button--secondary {
  padding-right: 0;
  padding-left: 0;
  background: transparent;
  color: var(--c-brand-primary);
}
.icon-button.icon-button--secondary span.t {
  padding-right: 0.5em;
  padding-left: 0;
}
.icon-button.icon-button--secondary i {
  width: 1.5em;
  background: transparent;
}
.icon-button.icon-button--secondary i svg {
  width: 100%;
  height: auto;
  color: var(--c-brand-primary-dark);
}
.icon-button.icon-button--secondary:hover {
  opacity: 0.5;
}

a.blob-button {
  transition: all 0.25s;
  display: inline-flex;
  position: relative;
}
a.blob-button > span {
  display: flex;
  align-items: center;
  position: relative;
}
a.blob-button .label {
  border-radius: 999px;
  color: #000;
  background: #fff;
  padding: 0 2em;
  line-height: 3em;
  height: 3em;
  padding-top: 0.15em;
  font-weight: 300;
  transition: all 1s var(--ease-cubic);
}
a.blob-button .middle {
  width: 1.5em;
  height: 3em;
  position: absolute;
  right: 2.1em;
  z-index: 1;
  transition: all ease-in 0.35s;
}
a.blob-button .middle::before, a.blob-button .middle::after {
  content: "";
  position: absolute;
  width: 3.5em;
  height: 4em;
  left: 50%;
  transform: translatex(-50%);
  background-color: var(--c-brand-primary);
  border: 1em solid var(--c-brand-primary);
  z-index: 100;
  border-radius: 50%;
  transform-origin: center;
  box-sizing: border-box;
  transition: all ease-in 0.35s, border-color 1s var(--ease-cubic);
}
a.blob-button .middle::before {
  clip-path: polygon(0px 0px, 100% 0px, 91.07% 31.75%, 6px 31.75%);
  top: calc(50% - 0.1rem);
}
a.blob-button .middle::after {
  clip-path: polygon(4px 68.13%, 85.71% 66.56%, 100% 100%, 0px 100%);
  bottom: calc(50% - 0.05rem);
}
a.blob-button .arrow {
  height: 3em;
  width: 3em;
  min-width: 3em;
  margin-left: -0.3em;
  border-radius: 64px;
  background-color: var(--c-brand-primary);
  color: var(--c-text-light);
  transition: all ease-in 0.35s, background-color 1s var(--ease-cubic);
  display: flex;
  vertical-align: middle;
  align-items: center;
  position: relative;
  z-index: 1;
}
a.blob-button .arrow svg {
  margin: auto;
  transform: rotate(-45deg);
  transition: all ease-in 0.35s;
}
a.blob-button:hover .middle {
  right: 2.55em;
}
a.blob-button:hover .middle::before, a.blob-button:hover .middle::after {
  border-width: 0px;
  width: 2em;
}
a.blob-button:hover .arrow {
  margin-left: 0.6em;
}
a.blob-button:hover .arrow svg {
  transform: rotate(0deg);
}

a.icon-swap-button {
  line-height: 1em;
  font-weight: 300;
  display: flex;
  align-items: center;
}
a.icon-swap-button span {
  height: 3em;
  line-height: 3em;
  background: var(--c-brand-primary);
  color: var(--c-text-light);
  border-radius: 1.17em;
}
a.icon-swap-button i {
  width: 3em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.25s;
}
a.icon-swap-button i svg {
  display: block;
  position: relative;
  width: 55%;
  height: auto;
  color: var(--c-text-light);
}
a.icon-swap-button span.t {
  padding: 0 2.5em;
  flex-grow: 1;
}
a.icon-swap-button i.right {
  width: 0;
  height: 0;
}
a.icon-swap-button:hover i.left {
  width: 0;
  height: 0;
}
a.icon-swap-button:hover i.right {
  width: 3em;
  height: 3em;
}

a.button--image-subtitle {
  display: inline-flex;
  align-items: center;
  padding: 0.5em;
  padding-right: 1.5em;
  border-radius: 999px;
  transition: all 0.25s;
  font-weight: 300;
  border-radius: 9999px;
  background: var(--c-brand-primary);
}
a.button--image-subtitle i {
  border-radius: 50%;
  width: 3.5em;
  height: 3.5em;
  contain: paint;
}
a.button--image-subtitle i img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
a.button--image-subtitle span.t {
  display: block;
  padding: 0 1.25em;
  padding-right: 1.5em;
  padding-top: 0.15em;
  line-height: 1em;
  white-space: nowrap;
  text-align: left;
  color: var(--c-text-light);
}
a.button--image-subtitle span.t > span {
  display: block;
}
a.button--image-subtitle span.t .title {
  font-weight: 700;
  margin-bottom: 0.2em;
}
a.button--image-subtitle span.t .subtitle {
  font-size: var(--step--1);
  line-height: 1em;
}

.expandable-container {
  --content-height: 0px;
}
.expandable-container .expandable {
  overflow: hidden;
  transition: all 0.5s var(--ease-cubic);
  height: 0;
}
.expandable-container .expandable > div {
  padding-bottom: 1px;
}
.expandable-container.open .expandable {
  height: var(--content-height);
}
.expandable-container .toggle {
  position: relative;
  font-weight: 700;
  white-space: nowrap;
  padding: 0;
  background: transparent;
  border: none;
  margin-top: 1em;
  transition: all 0.25s;
  font-family: var(--font-family-body);
  color: var(--c-brand-primary);
}
.expandable-container .toggle span {
  transition: all 0.25s;
}
.expandable-container .toggle .less {
  opacity: 0;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
}
.expandable-container .toggle:hover {
  cursor: pointer;
  opacity: 0.5;
}
.expandable-container.open .toggle .more {
  opacity: 0;
}
.expandable-container.open .toggle .less {
  opacity: 1;
}

.section {
  position: relative;
}
.section .bg,
.section .bg > div {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}
.section .bg > div {
  background-size: cover;
  background-position: 50% 50%;
}
.section > .inner {
  padding: clamp(6rem, 14.4vw, 12rem) clamp(2rem, 4.8vw, 4rem) clamp(6rem, 14.4vw, 12rem) clamp(2rem, 4.8vw, 4rem);
}
@media screen and (min-width: 1400px) {
  .section > .inner {
    max-width: clamp(320px, 93vw, var(--page-max-width) * 1);
  }
}
.section > .inner {
  margin: auto;
  position: relative;
  width: 100%;
}
.section.bg-parallax .bg {
  clip-path: inset(0 0 0 0);
}
.section.bg-parallax .bg > div {
  position: fixed;
}

.section-header {
  margin-bottom: clamp(2rem, 4.8vw, 4rem);
  margin-top: clamp(0rem, 0vw, 0rem);
}
.section-header {
  text-align: center;
}
.section-header .h2 {
  margin-bottom: 0.5em;
}
.section-header .field--overline {
  line-height: 1.2em;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  font-weight: 400;
  margin-bottom: 1em;
  color: color-mix(in srgb, var(--c-text), transparent 30%);
}
.section-header .field--subtitle {
  font-weight: 400;
  line-height: 1em;
  font-size: var(--font-size-h4);
}
.section-header .field--body {
  font-size: var(--font-size-body-large);
  line-height: 1.5em;
  max-width: 34em;
}
@media screen and (min-width: 0) and (max-width: 767px) {
  .section-header .field--link {
    margin-top: 0.25em;
  }
}
@media screen and (min-width: 768px) {
  .section-header .field--link a {
    line-height: 1.2em;
    font-family: var(--font-body);
    font-weight: var(--font-weight-buttons);
  }
}
@media screen and (min-width: 0) and (max-width: 767px) {
  .section-header > * {
    margin-left: auto;
    margin-right: auto;
  }
  .section-header .actions,
  .section-header .field--name-field-button {
    justify-content: center;
  }
}
.section-header.centered {
  text-align: center;
}
.section-header.centered .h1,
.section-header.centered .h2 {
  max-width: 28em;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0.25em;
}
.section-header.centered .field--body {
  margin: auto;
}
@media screen and (min-width: 768px) {
  .section-header.split {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
  .section-header.split .h1,
  .section-header.split .h2 {
    margin-bottom: 0;
    padding-right: 2em;
  }
  .section-header.split .field--name-field-body {
    max-width: 32em;
    margin: 0;
  }
}
@media screen and (min-width: 768px) {
  .section-header {
    text-align: left;
  }
}
@media screen and (min-width: 1000px) {
  .section-header .field--name-field-body,
  .section-header .field--name-field-body-below {
    line-height: 1.6em;
  }
  .section-header.scrollin > * {
    transform: translateY(80px);
    opacity: 0;
  }
  .section-header.scrollin.split > *:first-child {
    transform: translateX(-80px);
  }
  .section-header.scrollin.split > *:last-child {
    transform: translateX(80px);
  }
  .section-header.scrollin.loaded > * {
    transition: all 1s var(--ease-cubic);
    transform: none !important;
    opacity: 1;
  }
  .section-header.scrollin.loaded > *:nth-child(2) {
    transition-delay: 0.25s;
  }
  .section-header.scrollin.loaded > *:nth-child(3) {
    transition-delay: 0.5s;
  }
  .section-header.scrollin.loaded > *:nth-child(4) {
    transition-delay: 0.75s;
  }
  .section-header.scrollin.loaded > *:nth-child(5) {
    transition-delay: 1s;
  }
  .section-header.scrollin.loaded.split > * {
    transition-delay: 0s !important;
  }
}

.share {
  padding: clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem) clamp(3rem, 7.2vw, 6rem) clamp(0rem, 0vw, 0rem);
}
.share {
  margin: auto;
  text-align: center;
  display: flex;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .share > .inner {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.share h2 {
  font-size: var(--font-size-3);
  line-height: 1.2em;
  font-weight: 300;
}
.share h2 {
  margin-bottom: 0;
  margin-right: 1em;
}
@media screen and (min-width: 0) and (max-width: 767px) {
  .share h2 {
    font-size: 2em;
    margin-right: 0;
    margin-bottom: 0.5em;
  }
}
.share .addtoany_list {
  display: block;
  text-align: center;
}
.share .addtoany_list a {
  font-size: 1em !important;
  width: 3.5em;
  height: 3.5em;
  margin: 0.25em;
  padding: 2px;
  border-radius: 999px;
  color: #fff;
  transition: all 0.25s !important;
  background: var(--c-brand-primary) !important;
}
.share .addtoany_list a > span.a2a_svg {
  background: transparent !important;
  border-radius: 999px;
  width: 100% !important;
  height: 100% !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
}
.share .addtoany_list a > span.a2a_svg svg {
  background: transparent;
  width: 70%;
  height: 70%;
  color: #fff !important;
}
.share .addtoany_list a > span.a2a_svg svg g,
.share .addtoany_list a > span.a2a_svg svg path {
  fill: #fff !important;
}
.share .addtoany_list a.a2a_button_facebook > span.a2a_svg svg {
  width: 60%;
  height: 60%;
}
.share .addtoany_list a.a2a_button_twitter > span.a2a_svg svg {
  width: 50%;
  height: 50%;
}
.share .addtoany_list a:hover {
  background-color: var(--c-brand-primary-dark) !important;
  opacity: 1;
}
.share .addtoany_list a:hover > span.a2a_svg {
  opacity: 1 !important;
}
.share .addtoany_list a:hover > span.a2a_svg svg {
  opacity: 1 !important;
}

@media screen and (min-width: var(--bp-s7)) {
  .slide-over {
    height: calc(var(--el-height) + 100vh);
    margin-bottom: -100vh;
    clip-path: inset(0 0 0 0);
  }
  .slide-over.stuck > div {
    position: fixed;
    bottom: 0;
    width: 100%;
  }
}

nav.pager {
  margin-top: 6em;
  position: relative;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
nav.pager .pager__item--next a {
  display: inline-block;
  line-height: 1em;
  border: none;
  position: relative;
  transition: all 0.25s;
  padding: var(--button-padding);
  font-weight: var(--button-font-weight);
  font-family: var(--button-font-family);
  border-radius: var(--button-border-radius);
  background-color: var(--button-bg);
  color: var(--button-color);
  font-weight: var(--button-font-weight);
}
nav.pager .pager__item--next a:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
nav.pager .pager__item--next a.button--secondary {
  background: var(--button-secondary-bg);
  color: var(--button-secondary-color);
  border: 2px solid color-mix(in srgb, var(--button-secondary-color), #fff 50%);
}
nav.pager .pager__item--next a.button--secondary:hover {
  background: var(--button-secondary-bg-hover);
  color: var(--button-secondary-color-hover);
}
nav.pager .pager__item--next a {
  color: #fff;
  border-radius: 0.25rem;
  transition: all 0.25s;
  font-weight: var(--font-weight-buttons);
  background: var(--c-brand-primary);
}
nav.pager .pager__item--next a:hover {
  background: var(--c-brand-primary-dark);
}
nav.pager ul {
  padding: 0;
  margin: 0;
  list-style: none;
}
nav.pager ul {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  align-items: flex-end;
}
nav.pager ul li {
  margin: 0.25rem;
}
nav.pager ul li a {
  display: inline-block;
  line-height: 1em;
  border: none;
  position: relative;
  transition: all 0.25s;
  padding: var(--button-padding);
  font-weight: var(--button-font-weight);
  font-family: var(--button-font-family);
  border-radius: var(--button-border-radius);
  background-color: var(--button-bg);
  color: var(--button-color);
  font-weight: var(--button-font-weight);
}
nav.pager ul li a:hover {
  background-color: var(--button-bg-hover);
  color: var(--button-color-hover);
}
nav.pager ul li a.button--secondary {
  background: var(--button-secondary-bg);
  color: var(--button-secondary-color);
  border: 2px solid color-mix(in srgb, var(--button-secondary-color), #fff 50%);
}
nav.pager ul li a.button--secondary:hover {
  background: var(--button-secondary-bg-hover);
  color: var(--button-secondary-color-hover);
}
nav.pager ul li a {
  color: #fff;
  font-weight: 700;
  padding: 0;
  width: 3.5em;
  height: 3.5em;
  line-height: 3.5em;
  text-align: center;
  padding-top: var(--button-text-offset);
}

.messages-wrapper {
  padding: clamp(1rem, 2.4vw, 2rem) clamp(2rem, 4.8vw, 4rem) clamp(1rem, 2.4vw, 2rem) clamp(2rem, 4.8vw, 4rem);
}
.messages-wrapper .message {
  padding: clamp(1rem, 2.4vw, 2rem) clamp(1rem, 2.4vw, 2rem) clamp(1rem, 2.4vw, 2rem) clamp(1rem, 2.4vw, 2rem);
}
@media screen and (min-width: 1400px) {
  .messages-wrapper .message {
    max-width: clamp(320px, 93vw, var(--page-max-width) * 1);
  }
}
.messages-wrapper .message {
  margin: auto;
  border: 0.2em solid red;
  font-size: 1.2em;
  line-height: 1.4em;
  text-align: center;
}
.messages-wrapper .message a {
  font-weight: 700;
}

#cboxOverlay {
  background: #fff;
}

#cboxTitle {
  display: none !important;
}

#cboxContent {
  border-radius: 0 !important;
}

#cboxClose.cbox-close-plain {
  position: fixed;
  right: 1rem;
  top: 1rem;
  width: 3rem;
  height: 3rem;
  opacity: 1 !important;
  text-indent: 9999px;
  background: transparent;
}
#cboxClose.cbox-close-plain::before, #cboxClose.cbox-close-plain::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 1px;
  background: #000;
}
#cboxClose.cbox-close-plain::before {
  transform: translate(-50%, -50%) rotate(-45deg);
}
#cboxClose.cbox-close-plain::after {
  transform: translate(-50%, -50%) rotate(45deg);
}

.cboxPhoto {
  border-radius: 0 !important;
}

#cboxPrevious,
#cboxNext {
  position: fixed !important;
  top: 50%;
  width: 2.5em;
  height: 2.5em;
  border: 1px solid #000;
  clip: initial;
  overflow: clip;
  text-indent: -9999px;
}

#cboxPrevious {
  left: 2em;
  border-style: none none solid solid;
  transform: translate(0, -50%) rotate(45deg);
}

#cboxNext {
  right: 2em;
  border-style: solid solid none none;
  transform: translate(0, -50%) rotate(45deg);
}

@media screen and (min-width: 0) and (max-width: 767px) {
  #cboxClose.cbox-close-plain {
    width: 2.5rem;
    height: 2.5rem;
  }
  #cboxPrevious,
  #cboxNext {
    width: 1.75em;
    height: 1.75em;
  }
  #cboxPrevious {
    left: 1em;
  }
  #cboxNext {
    right: 1em;
  }
}
ul.social {
  padding: 0;
  margin: 0;
  list-style: none;
}
ul.social {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
}
ul.social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3em;
  height: 3em;
  color: var(--c-text-light);
  background: var(--c-brand-primary);
  border-radius: 50%;
}
ul.social a svg {
  display: block;
  width: 50%;
  height: auto;
}
ul.social a:hover {
  background: var(--c-brand-primary-dark);
  opacity: 1 !important;
}
@media screen and (min-width: 0) and (max-width: 767px) {
  ul.social {
    margin-bottom: 1.5em;
    width: 100%;
    justify-content: center;
  }
  ul.social li {
    margin: 0 0.25em;
  }
}
@media screen and (min-width: 768px) {
  ul.social li:not(:last-child) {
    margin-right: 1em;
  }
}

#sidebar {
  margin-bottom: 6em;
}
#sidebar > .inner {
  position: sticky;
  top: 2rem;
  transition: top 0.5s;
}
@media screen and (min-width: 768px) {
  #sidebar > .inner {
    max-width: 19em;
  }
}
.scrolling-up #sidebar > .inner {
  top: 8rem;
  transition: top 0.5s 0.25s;
}
#sidebar nav button {
  display: none;
}
#sidebar nav h2 {
  font-size: var(--font-size-h3);
  font-weight: 300;
  line-height: 1em;
}
#sidebar nav h2 > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#sidebar nav h2 button {
  display: block;
  width: 3em;
  height: 3em;
  margin-top: 0;
}
#sidebar nav h2 button > span:first-child {
  overflow: hidden;
  text-indent: 999px;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
}
#sidebar nav h2 button > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#sidebar nav h2 button.open .icon .l.t, #sidebar nav h2 button.open .icon .l.b {
  transform: rotate(45deg);
  margin-top: 0;
}
#sidebar nav h2 button.open .icon .l.b {
  opacity: 0;
}
#sidebar nav h2 button.open .icon .l.m {
  transform: rotate(-45deg);
}
@media screen and (min-width: 768px) {
  #sidebar nav h2 {
    padding: 0 4rem 1.5rem 0rem;
  }
  #sidebar nav h2 button {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  #sidebar nav .expandable {
    height: auto !important;
  }
}
#sidebar nav ul {
  padding: 0;
  margin: 0;
  list-style: none;
}
#sidebar nav ul li {
  border-bottom: 2px solid rgba(0, 0, 0, 0.1);
}
#sidebar nav ul a {
  display: block;
  padding: 1.35rem 2rem 1.15rem 0rem;
  transition: all 0.25s;
  overflow: hidden;
  font-weight: 700;
  color: var(--c-text);
}
#sidebar nav ul a span {
  display: block;
  position: relative;
  transition: all 0.25s;
}
#sidebar nav ul a span::before {
  content: "";
  position: absolute;
  left: -1em;
  top: 50%;
  width: 0.7em;
  height: 0.7em;
  border: 3px solid var(--c-text);
  border-style: solid solid none none;
  transform: translate(-100%, -50%) rotate(45deg);
}
#sidebar nav ul a:hover, #sidebar nav ul a.is-active, #sidebar nav ul a.active {
  padding-right: 0rem;
  padding-left: 2rem;
}
#sidebar nav .menu-item.expanded {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#sidebar nav .menu-item.expanded > a {
  flex: 1 1 auto;
  min-width: 0;
}
#sidebar nav .menu-item.expanded > button.toggle {
  flex: 0 0 3em;
  width: 3em;
  height: 3em;
  padding: 0;
  margin: 0;
  background: none;
  border: none;
  cursor: pointer;
  transition: transform 0.25s;
  display: flex;
  align-items: center;
  justify-content: center;
}
#sidebar nav .menu-item.expanded > button.toggle .visually-hidden {
  overflow: hidden;
  text-indent: 999px;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
}
#sidebar nav .menu-item.expanded > button.toggle::after {
  content: "";
  display: block;
  width: 0.6em;
  height: 0.6em;
  border: 2px solid #fff;
  border-style: none none solid solid;
  transform: rotate(-135deg);
  transition: transform 0.25s;
}
#sidebar nav .menu-item.expanded .menu-container {
  flex: 1 1 100%;
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease-out;
}
#sidebar nav .menu-item.expanded .menu-container .back {
  display: none;
}
#sidebar nav .menu-item.expanded .menu-container > ul.menu {
  padding-left: 1.5rem;
}
#sidebar nav .menu-item.expanded .menu-container > ul.menu .menu-item a {
  font-size: 0.95em;
  padding-top: 1.1rem;
  padding-bottom: 0.9rem;
  border-bottom-color: rgba(0, 0, 0, 0.05);
}
#sidebar nav .menu-item.expanded.open > button.toggle::after {
  transform: rotate(-45deg);
}
#sidebar nav .menu-item.expanded.open > .menu-container {
  max-height: 2000px;
  transition: max-height 0.5s ease-in;
}
#sidebar nav .menu-item .menu-item.expanded .menu-container > ul.menu, #sidebar nav .menu-item .menu-item.collapsed .menu-container > ul.menu {
  padding-left: 1.5rem;
}
#sidebar nav .menu-item .menu-item.expanded .menu-container > ul.menu .menu-item a, #sidebar nav .menu-item .menu-item.collapsed .menu-container > ul.menu .menu-item a {
  font-size: 0.9em;
  font-weight: 400;
  padding-top: 0.9rem;
  padding-bottom: 0.75rem;
}
#sidebar .expandable-container .headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#sidebar .expandable-container .headline h2 {
  margin-bottom: 0;
}
#sidebar .expandable-container button.toggle {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 3em;
  height: 3em;
  margin-top: 0;
}
#sidebar .expandable-container button.toggle > span:first-child {
  overflow: hidden;
  text-indent: 999px;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  position: absolute;
  white-space: nowrap;
  width: 1px;
  height: 1px;
}
#sidebar .expandable-container button.toggle .icon {
  display: block;
  position: relative;
  width: 2em;
  height: 2em;
}
#sidebar .expandable-container button.toggle .icon .l {
  position: absolute;
  left: 25%;
  width: 100%;
  height: 4px;
  background: var(--c-brand-primary);
  transition: all 0.25s;
  opacity: 1;
  top: 50%;
  transform: translateY(-50%);
}
#sidebar .expandable-container button.toggle .icon .l.t {
  margin-top: -8px;
}
#sidebar .expandable-container button.toggle .icon .l.b {
  margin-top: 8px;
}
#sidebar .expandable-container.open button.toggle .icon .l.t, #sidebar .expandable-container.open button.toggle .icon .l.b {
  transform: rotate(45deg);
  margin-top: 0;
}
#sidebar .expandable-container.open button.toggle .icon .l.b {
  opacity: 0;
}
#sidebar .expandable-container.open button.toggle .icon .l.m {
  transform: rotate(-45deg);
}
@media screen and (min-width: 0) and (max-width: 999px) {
  #sidebar .expandable-container h2 {
    padding: 0 !important;
  }
}
@media screen and (min-width: 1000px) {
  #sidebar .expandable-container button.toggle {
    display: none;
  }
  #sidebar .expandable-container .expandable {
    height: auto !important;
  }
}
#sidebar .text-box {
  padding: clamp(3rem, 7.2vw, 6rem) clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem);
}
#sidebar .text-box h2, #sidebar .text-box h3 {
  font-size: var(--font-size-h4);
  font-weight: 300;
  line-height: 1em;
  max-width: 8em;
  margin-bottom: 0.5em;
}
#sidebar .text-box .field--body {
  color: color-mix(in srgb, var(--c-text) 70%, transparent);
  max-width: 18em;
}
#sidebar .text-box .field--body a {
  color: #000;
  font-weight: 700;
}
#sidebar .text-box .field--button {
  margin-top: 1.5em;
}

@media screen and (min-width: 1000px) {
  div.scrollin:has(> #sidebar) {
    display: flex;
    justify-content: space-between;
  }
  div.scrollin:has(> #sidebar) #sidebar {
    padding: clamp(0rem, 0vw, 0rem) clamp(1rem, 2.4vw, 2rem) clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem);
  }
  div.scrollin:has(> #sidebar) #sidebar {
    max-width: 24em;
    min-width: 18em;
    flex-basis: 35%;
    transform: translateX(-80px);
    opacity: 0;
    transition: all 1s var(--ease-cubic);
  }
  div.scrollin:has(> #sidebar) #sidebar + div {
    padding: clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem) clamp(0rem, 0vw, 0rem) clamp(1rem, 2.4vw, 2rem);
  }
  div.scrollin:has(> #sidebar) #sidebar + div {
    flex-grow: 1;
    transform: translateX(80px);
    opacity: 0;
  }
  div.scrollin:has(> #sidebar).loaded #sidebar,
  div.scrollin:has(> #sidebar).loaded #sidebar + div {
    transform: none;
    opacity: 1;
    transition: all 1s var(--ease-cubic);
  }
}