/* Modern reset: https://piccalil.li/blog/a-more-modern-css-reset/ */

/* Box sizing rules */

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

/* Prevent font size inflation */

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}

/* Remove default margin in favour of better control in authored CSS */

body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin-block-end: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */

ul[role='list'],
ol[role='list'] {
  list-style: none;
}

/* Set core body defaults */

body {
  min-height: 100vh;
  line-height: 1.5;
}

/* Set shorter line heights on headings and interactive elements */

h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.1;
}

/* Balance text wrapping on headings */

h1,
h2,
h3,
h4 {
  text-wrap: balance;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  color: currentColor;
}

/* Make images easier to work with */

img,
picture {
  max-width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
  font: inherit;
}

/* Make sure textareas without a rows attribute are not tiny */

textarea:not([rows]) {
  min-height: 10em;
}

/* Anything that has been anchored to should have extra scroll margin */

:target {
  scroll-margin-block: 5ex;
}

/* @font-face declarations for custom fonts */

@font-face {
  font-family: 'GeneralSans';

  src: url('../../assets/fonts/GeneralSans-Regular.woff2') format('woff2');

  font-weight: 400;

  font-style: normal;

  font-display: swap;
}

@font-face {
  font-family: 'GeneralSans';

  src: url('../../assets/fonts/GeneralSans-Medium.woff2') format('woff2');

  font-weight: 500;

  font-style: normal;

  font-display: swap;
}

@font-face {
  font-family: 'GeneralSans';

  src: url('../../assets/fonts/GeneralSans-Semibold.woff2') format('woff2');

  font-weight: 600;

  font-style: normal;

  font-display: swap;
}

@font-face {
  font-family: "iconfont";

  font-display: block;

  src: url(data:font/woff2;charset=utf-8;base64,d09GMgABAAAAAAU0AAsAAAAAC2gAAATjAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHIIUBmAAhhoKhAiDTgE2AiQDdAs8AAQgBYQWB4FQGy8KyC6wbdijjCzndixtbKoRslHvPgIX/FNr5fsNszM9ixhAkoQsc+vCQqY8gTyZiiahD2z4T92rAsRK0nb7OOY6MQXYlZ5klHzyi38RxnTiHWFDmnuZunVD4oHnWP67XnNhU/MaOJMO98bDxptgYtOeR6Z2/w/oL2wEvoDHPv2Yq9PrC03fJK/03VoU/zJXxDxxJCqd4zohTRMi0jgq101qImRU1DmldM4pAV4GgWCeNUzj2jVbSHXiBCrSzqGVgjdSiQvSIqVKiePwGDEZ5BUdJOx1iRUbZwkjFQSprJygrKKqRAlOpT2voAhTK+ksSdU6GByzCvKeLJJYsyvldCS6GoxQaxwvq6qgmeFpKbTdSGeL4xNTdY3qNKOkyvLNX1a8RElVXYcLHNBxPGy2GQSeWG+vC/MDBgwfgk6wfWgpJ4/M/tQoOBhetGRzcLQs8MCCWcBBS9mpT6zTOYsVkvo7D0CRH8WC2U5whFDuExFDxmPEn5sHqkpmdHZNMaOjwTmJuvZCW7dgcllDXkdrkTcKukqassSwC/YJRjJiKAoZOccyrPacmmKlcUCFzE6rojeePPlfSIeGZwHqQXcXzNaQAyeQgFOog9NogzMogLMognOogPOoggsog0togMvIgyvogKtogWtIwXXUwE0EcAtdcBslcBdNcE+dxU8RLGZAALMggDkQwDwIYBEIYBkQwGKImA49ACuWc8hdhPeIrxIWi6+FYzFBcuYo8kVv7cQoOnRmi5BbeQ25NbBVii1QTS4NDMqYWy4sP7d381a5MRrcAHKT5DUl+fTRd/n+j7T0eBM3+jWcPZlfZ4+fqiUKyw+ynqf+iwWD5+40bnkzV722t6D55Nn2wTOXysOjQTJwOHQ5sjg3IW3PhaGt5MXe8/LI8NDgZ2b2646MfIuPa4nBrR9gNsYODX3a5fr3yAFH5/Pnt9em5j19jwNZQ3djV64Yc4pkN75+porlL/n1m4+PRiO85FLJsMapNXa2c/b/L/rrSfGuKOfD5Fo2aV3WT+c/LMzuvnvw4LqJFZfebeq+dfTYpb3z+5/0HjZepl5udmZTU9OmE4NnoFXZO1sPJleOjh3s2HlIdZP7KGRPHrNG2P3Q6D/saVBRav4zvd48BpjhrObH0HiOSJX+68KF7pqFf634CLUl79f2W45iU0dBzKCwvdmwu8pY6Ol0HI6ou9KW/fPmBP8WUXXK536EzzAgCOC5zRR9GaZPn2MKzNNp9zzW4QUInbQBLzUWkdgMBDMt2DpVcUQBhROk6PoPRt4ArKJnQid9Dq/uDSJFnxHs9bZMakpgxgWmlVBn4CaQM75l/k5LPggmclpoJpkOn2U5KDAWAqfbdtAolllEQYXRAV2WcTTwfU1Do11gmLQRw4FUSiRtkGQ6IA5GU4Tx22gTIM3wWQxbMNh/EDAiwYr1U/PNMa+AcDlVhfQtCPC9nLQDdUtMyroNCdboLEMLUGurJYDPOzXqenItF2BQ0vkK7aEBc9lSZ4vSZPc8OM6rgICeTC9gZOXkFSmjWImCUmWVU14FFVVSWRVVVVNdDTXVUlsdddXTGELvTaNzCR8EVrhDjCNtLJMqoA6L2HlgXqVRJjZaJbjOqTKMMToRWJFXrLc7PuqCbbjHPEtGWjkldFkgIZQjKVuhmDzFUuIKFEEAAAAA) format("woff2"),
url(data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAAAc4AAsAAAAAC2gAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAK4AAAEUJNUoqU9TLzIAAAG4AAAAQgAAAGBWT1NAY21hcAAAAfwAAAESAAADGmPbXP9nbHlmAAADEAAAAcMAAAIIzojasWhlYWQAAATUAAAAMgAAADZ2zcSBaGhlYQAABQgAAAAdAAAAJAfRBQBobXR4AAAFKAAAABcAAAB0JxH//mxvY2EAAAVAAAAAHAAAADwLugxGbWF4cAAABVwAAAAfAAAAIAErADtuYW1lAAAFfAAAASkAAAIWm5e+CnBvc3QAAAaoAAAAjwAAANBqdSMEeJxNjT0OgkAQhT8QEFBAEH8AC49gRWllrCyt7Gg0JsTK2gN5Bg/n2zUmbLI7s/O9eQ8HiNmxxz0cT2fSvns+qPH4HcOHvdPfbx3h/yfm2RrqfvCZceHKizcjzba0uEyUEOudkqgWzCnJpY8H85RMu7m2osE0V13YlFAkk8r0gTSZ1SQ06jeslBIozddWKba2tBKvrVOlLd+SpbTGY2xdCjmaDEc0UleKN1/anQzBAAB4nGNgYYxknMDAysDALMm0h4GBoQdCMz5gMGRkYmBgYmBlZsAKAtJcUxgOMOh+5GB+AeRGsTiBhRlRFPEAAO0LCTEAAHictdJLbsIwEAbg3ySE0EASSHjkse6ioncqAtoi+kAUwRV6oK56K5+A/mPPolsqdaJPlkd+jKMB0AUQ0IJCwHzDQOKLWePyAW5cPsQn5zk/WX+PJbbY44izjS8XzaywwwEna1zmdxi3M0eLW9y524boY4oaGbMFSowxQ4oGFRJMeGeLEeYYcGeHN4asNEIPMY+KcF0Mr1wvwdrqLC9KVpU2VcKCWpYz+MNJ/xOuEvOgsxby/z157VL1aaWmtFY1bVRGjyqnJ1XQsyppq8a0UzN6USm9qobeVEXvKqG9mtBBscPwoeQtRzWik5rTWfH11njSpbbjQcbAky61oSedbbuedLyNPMjY8yBj7CH+AYEuM3oAAHicPY7PSxtBFMfnO5MfignprrtZVsQ4sWYNoQkYNyEu9tBbobdCstgiPeRuwJ5sT+ZgL4We9NB7Gg+KJ0+FKoVe/AO8tFAv1TaSFioU1H121tQ+hpk3j/f5fr8MTJX4LE7ZEGOjiA/DgjTPsOiTjr5PHf4L7+ldA33069R5Ga4PmKMBo4BhxBXDz6jbQI/MBvzAwAfaqqOHXp26L0Lm+loxX24ZJ2S0KexSp66kfzaUNL+ijo8+6T4Wg9R/nxL/w6Lq41QtlW3tW20bK/O4cxK+tX87D/jBYEfld3jych4uXA+fLj06VM2tFn+u/COhv9QkflOSrwSvcU4JNVYVucn4XUiWYgaz2Bhj5WzO1eYqZTmbNjUjNoVpTWrRaWm6WjPveXkxGd7UopaYpBbeXH318twPZ0E372HpghI437hoNoOukr7JeqrMsmyGFRmTs5UFzOVKyMVSKMJRp3ofJdUWkI2Zhs4i4bhsoWqZRYgdW9qj+8ZMou0uFYqPxtdHhsRdMWEc23ITaTwOtiw7vmpj40m7tiztY30i6ohkop15WLj3rPxqJJP+qI9Je4e26ccmf1tZrrWDvafjq5HMX7v/hXoAeJxjYGRgYADiiW+NN8bz23xl4GZ+ARSI4ny8rwFG///PwMD8EiTOwMHABCQZAIKEDeMAAHicY2BkYGB+wQAELI/+/weyXzIwMqACWQBzvwTbAAAAeJxjYGBgYHkEw///I9gIPrUBAC6KCy0AeJxjYAACKQYTBj+GBIYShjaGbYwsxEIAhp4DFnicY2BkYGCQZdBnYGEAASYg5gJCBob/YD4DABBMAWcAeJxlkD1uwkAUhMdgSAJSghQpKbNVCiKZn5IDQE9Bl8KYtTGyvdZ6QaLLCXKEHCGniHKCHChj82hgLT9/M2/e7soABviFh3p5uG1qvVq4oTpxm/Qg7JOfhTvo40W4S38o3MMbpsJ9POKdO3j+HZ0BSuEW7vEh3Kb/KeyTv4Q7eMK3cJf+j3APK/wJ9/HqDdPIFLEp3FIn+yy0Z3n+rrStUlOoSTA+WwtdaBs6vVHro6oOydS5WMXW5GrOrs4yo0prdjpywda5cjYaxeIHkcmRIoJBgbipDktoJNgjQwh71b3UK6YtKvq1VpggwPgqtWCqaJIhlcaGyTWOrBUOPG1K1zGt+FrO5KS5zGreJCMr/u+6t6MT0Q+wbaZKzDDiE1/kg+YO+T89EV6oAAAAeJxtxlkOgjAAANGOCMrivi94Aw5FoFDCUlIauL4m/Po+JiMWYhaI/2IWOCxx8VixxicgJGLDlh17Dhw5cebClRt3Hjx58SbmI4LUGD0ljSxsOK+pSmX9+a3u3UzJrI5+HY3uklxPna+k0UmbDrXXplVjtWNlQ4pBM5HQICmwVJQoejJqRjpyWgYhvgmpJOkA) format("woff");
}

i[class^="icon-"] {
  font-family: iconfont !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-style: normal;
  font-variant: normal;
  font-weight: normal;
  speak: none;
  text-decoration: none;
  text-transform: none;
  line-height: 1;
  letter-spacing: normal;
  display: flex;
  align-items: center;
}

:root, .icon, i {
  --icon-arrow-left: '\f101';
  --icon-arrow-right: '\f102';
  --icon-arrow-top: '\f103';
  --icon-check: '\f104';
  --icon-chevron-down: '\f105';
  --icon-hero-mask: '\f106';
  --icon-mailto: '\f107';
  --icon-tel: '\f108';
}

.icon-arrow-left::before {
  content: "\f101";
}

.icon-arrow-right::before {
  content: "\f102";
}

.icon-arrow-top::before {
  content: "\f103";
}

.icon-check::before {
  content: "\f104";
}

.icon-chevron-down::before {
  content: "\f105";
}

.icon-hero-mask::before {
  content: "\f106";
}

.icon-mailto::before {
  content: "\f107";
}

.icon-tel::before {
  content: "\f108";
}

:root {
  --color-dark: #001231;
  --color-light: #FDFDFD;
  --color-primary: #16F78E;
  --color-accent: #16F78E;
  --color-neutral-10: #ECF0F8;
  --color-neutral-20: #DFDDEC;
  --color-neutral-40: #8093B7;
  --color-neutral-60: #183465;
  --color-neutral-80: #001946;
  --color-sky: #00AAAA;
  --color-lilac: #EBBEDC;
  --color-error: #D8443B;
  --color-success: #3BD87A;
  --space-zero: 0rem;
  --space-xs: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
  --space-s: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
  --space-m: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
  --space-l: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
  --space-xl: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  --space-2xl: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  --space-3xl: clamp(2rem, 1.70rem + 1.24vw, 3rem);
  --space-4xl: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
  --space-5xl: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
  --space-6xl: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
  --space-7xl: clamp(6rem, 5.40rem + 2.48vw, 8rem);
  --space-gutter-inline: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
  --space-grid-gutter: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
  --space-3xl-7xl: clamp(2rem, 0.19rem + 7.44vw, 8rem);
  --space-4xl-6xl: clamp(3rem, 2.09rem + 3.72vw, 6rem);
  --size-heading-5xl: clamp(3rem, 2.55rem + 1.86vw, 4.5rem);
  --size-heading-4xl-5xl: clamp(2rem, 1.24rem + 3.10vw, 4.5rem);
  --size-heading-4xl: clamp(2rem, 1.55rem + 1.86vw, 3.5rem);
  --size-heading-3xl: clamp(1.75rem, 1.37rem + 1.55vw, 3rem);
  --size-heading-2xl: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  --size-heading-xl: clamp(1.5rem, 1.42rem + 0.31vw, 1.75rem);
  --size-heading-l: clamp(1.25rem, 1.17rem + 0.31vw, 1.5rem);
  --size-heading-m: clamp(1rem, 0.92rem + 0.31vw, 1.25rem);
  --size-heading-m-fixed: 1.25rem;
  --size-heading-s: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
  --size-heading-xs: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
  --size-body-xl: clamp(1.25rem, 1.17rem + 0.31vw, 1.5rem);
  --size-body-l: clamp(1rem, 0.92rem + 0.31vw, 1.25rem);
  --size-body-l-xl: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  --size-body: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
  --size-body-fixed: 1rem;
  --size-body-s: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
  --size-body-xs: 0.75rem;
  --size-body-nav: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
  --size-button: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
  --size-button-s: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
  --leading-tight: 0.95;
  --leading-flat: 1;
  --leading-fine: 1.16;
  --leading-standard: 1.33;
  --leading-loose: 1.4375;
  --font-base: GeneralSans,Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-mono: SF Mono,Consolas,Liberation Mono,Menlo,Monaco,Courier New,monospace;
  --font-regular: 400;
  --font-medium: 500;
  --font-semibold: 600;
  --gutter: var(--space-gutter-inline);
  --transition-base: 250ms ease;
  --transition-movement: 200ms linear;
  --transition-fade: 300ms ease;
  --transition-bounce: 500ms cubic-bezier(0.5, 0.05, 0.2, 1.5);
  --stroke: 1px dashed var(--color-dark);
  --stroke-solid: 1px solid var(--color-dark);
  --radius-s: 0.25rem;
  --radius-m: 0.75rem;
  --radius-l: 1rem;
  --radius-xl: 1.5rem;
  --uppercase-kerning: 0.04ch;
}

/* 
  Global styles 

  Low-specificity, global styles that apply to the whole 
  project: https://cube.fyi/css.html
*/

body {
  -webkit-font-smoothing: antialiased;
  background: var(--color-light);
  color: var(--color-dark);
  font-size: var(--size-step-1);
  font-family: var(--font-base);
  line-height: var(--leading-standard);
  font-size-adjust: from-font;
  margin: 0;
}

#wpadminbar {
  bottom: 0;
  top: unset;
}

:is(h1, h2, h3, h4) {
  line-height: var(--leading-fine);
  text-wrap: balance;
}

h1 {
  font-size: var(--size-heading-4xl);
  max-width: 20ch;
}

h2 {
  font-size: var(--size-heading-3xl);
  max-width: 35ch;
}

h3 {
  font-size: var(--size-heading-2xl);
  max-width: 35ch;
}

h4 {
  font-size: var(--size-heading-xl);
  max-width: 40ch;
}

h5 {
  font-size: var(--size-heading-l);
  max-width: 45ch;
}

h6 {
  font-size: var(--size-heading-m);
  max-width: 50ch;
}

:is(h1, h2, h3, h4, h5, h6) {
  margin-block: 0;
  padding-block: 0;
  font-weight: var(--font-medium);
  line-height: var(--leading-tight);
}

p {
  margin-block: 0;
}

small {
  font-size: var(--size-body-s);
}

ins {
  text-decoration: none;
  background: var(--color-primary);
  color: var(--color-dark);
  padding-inline: 0.3em;
  padding-block-start: 0.2em;
}

:is(code, kbd, samp) {
  font-family: var(--font-mono);
  padding: 0.2em 0.2em 0.05em 0.2em;
  hyphens: none;
  -moz-tab-size: 2;
    -o-tab-size: 2;
       tab-size: 2;
  text-align: left;
  word-spacing: normal;
  word-break: normal;
  word-wrap: normal;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone;
}

/* This is quite a new property, so we want code styles to at least, not be huge or tiny */

@supports not (font-size-adjust: from-font) {
  :is(code, kbd, samp) {
    font-size: 0.8em;
  }
}

pre:has(code) {
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  overflow-x: auto;
}

pre code {
  border: none;
  background: none;
  padding: 0;
}

kbd {
  border: 1px solid;
  padding-block-end: 0.1em;
}

var {
  font-style: normal;
  font-weight: var(--font-medium);
}

q {
  font-style: italic;
}

ul:not([class]) {
  padding-inline-start: 1.5ch;
  list-style-type: disc;
}

ul:not([class])>li {
  padding-inline-start: var(--space-2xs);
}

:is(ol, ul):not([class]) li+* {
  margin-block-start: var(--flow-space, var(--space-2xs));
}

ul ::marker {
  font-size: .9lh;
}

ol ::marker {
  font-size: 1em;
  font-weight: var(--font-bold);
}

/* Lists with classes and roles will be out of standard flow, so remove the default spacing */

[role='list'][class],
[role='tablist'][class] {
  margin-block: 0;
  padding: 0;
}

dt {
  font-weight: var(--font-medium);
}

dt+dd {
  margin-block-start: var(--space-xs);
}

dd+dt {
  margin-block-start: var(--space-s);
}

dd {
  margin-inline-start: 1.5ch;
}

blockquote {
  margin-inline: 0;
  color: var(--color-violett);
}

blockquote footer {
  margin-block-start: var(--space-s);
  color: var(--color-primary);
  font-size: var(--size-step-0);
}

blockquote q {
  font-style: normal;
}

:is(video, iframe[src*='youtube'], iframe[src*='vimeo']) {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}

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

figcaption {
  padding-block-start: 0.5em;
  font-size: var(--size-step-0);
  font-family: monospace;
}

table {
  border: var(--stroke);
  border-collapse: collapse;
  width: 100%;
}

th {
  text-align: left;
  font-weight: var(--font-bold);
  line-height: var(--leading-fine);
}

thead th {
  padding-block: var(--space-s);
}

td,
th {
  padding: var(--space-xs) var(--space-s);
}

th:not(:only-of-type) {
  border-block-end: var(--stroke);
}

th:only-of-type {
  border-inline-end: var(--stroke);
}

:is(th, td)~ :is(th, td) {
  border-inline-start: var(--stroke);
}

tr+tr :is(th, td) {
  border-block-start: var(--stroke);
}

caption {
  caption-side: bottom;
  margin-block-start: var(--space-s);
}

a:not([class]):hover {
  text-underline-offset: 0.2lh;
}

:is(h1, h2, h3, h4) a:not([class]) {
  text-decoration-thickness: 0.1ex;
  text-underline-offset: 0.2ex;
}

:is(h1, h2, h3, h4) a:not([class]):hover {
  text-underline-offset: 0.3ex;
}

:focus {
  outline: none;
}

:focus-visible {
  outline: 2px solid var(--focus-color, currentColor);
  outline-offset: var(--focus-offset, 0.2lh);
}

/* Firefox is the only browser that doesn't outline the whole element unless you make it display: inline-block. That in itself causes multiple flow issues so we can detect it, using its own vendor prefix and reduce focus offset
*/

@supports (-moz-appearance: none) {
  :root {
    --focus-offset: 0.08em;
  }
}

:target {
  scroll-margin-block: 5lh;
}

::-moz-selection {
  color: var(--color-dark);
  background: var(--color-lilac);
}

::selection {
  color: var(--color-dark);
  background: var(--color-lilac);
}

hr {
  border: none;
  border-block-start: var(--stroke);
  margin-block: var(--flow-space, var(--space-xl));
}

/*
svg:not([class]) {
  width: auto;
  height: 1lh;
}

svg {
  flex-shrink: 0;
}

svg[role='img'][width][height] {
  width: revert;
  height: revert;
  background: var(--color-light);
  padding: var(--space-xs);
}*/

/* There's a .flow composition, but this prevents forms from having to have that applied where markup is harder to control in certain systems. It still uses the --flow-space variables though to make managing space easier */

form>*+* {
  margin-top: var(--flow-space, 1rem);
}

:is(input, select, textarea) {
  accent-color: var(--color-tuerkis);
}

:is(input:not([type='checkbox'], [type='radio'], [type='color']), select, textarea) {
  padding: 2em 0.5em 1em 0.5em;
  color: var(--color-dark);
  width: 100%;
  &::-moz-placeholder {
    color: var(--color-neutral-80);
  }
  &::placeholder {
    color: var(--color-neutral-80);
  }
}

label {
  line-height: var(--leading-loose);
  font-weight: var(--font-regular);
}

label::after {
  content: '\A';
  white-space: pre;
}

/* Usually label wraps checkbox and radio buttons, so we give ourselves more layout and text-flow control with flex */

label:has(input) {
  display: flex;
  align-items: baseline;
  gap: var(--space-s);
  font-weight: var(--font-normal);
}

label:has(input)+label:has(input) {
  --flow-space: var(--space-s-m);
}

/* Slightly adjusts the vertical position of the check/radio */

label:has(input) input {
  transform: translateY(-0.1ex);
}

input:disabled {
  background: var(--color-blaugrau);
}

input:disabled,
label input:disabled+* {
  cursor: not-allowed;
}

fieldset {
  border: var(--stroke);
  padding: var(--space-s);
}

legend {
  font-weight: var(--font-medium);
  padding-inline: var(--space-xs);
}

summary {
  font-weight: var(--font-bold);
  cursor: poin ter;
}

details[open] summary {
  margin-block-end: var(--space-s);
}

address {
  font-size: var(--size-body);
  line-height: var(--leading-loose);
  font-weight: var(--font-regular);
  font-style: normal;
}

iframe body {
  background-color: transparent;
}

figure {
  margin: 0;
}

/* Turn cross-document view-transitions on */

/* Note that this at-rule is all that is needed to create the default cross-fade animation  */

@view-transition {
  navigation: auto;
}

/* Customize the default animation behavior */

/*
::view-transition-group(root) {
  animation-duration: 0.5s;
}
*/

/* Create a custom animation */

/*
@keyframes move-out {
  from {
    transform: translateY(0%);
  }

  to {
    transform: translateY(-100%);
  }
}

@keyframes move-in {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0%);
  }
}
*/

/* Apply the custom animation to the old and new page states */

/*
::view-transition-old(root) {
  animation: 0.4s ease-in both move-out;

}

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

/*
CLUSTER
More info: https://every-layout.dev/layouts/cluster/
A layout that lets you distribute items with consitent
spacing, regardless of their size

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--cluster-horizontal-alignment (flex-start) How items should align
horizontally. Can be any acceptable flexbox aligmnent value.

--cluster-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-m));
  justify-content: var(--cluster-horizontal-alignment, flex-start);
  align-items: var(--cluster-vertical-alignment, center);
}

/* 
FLOW COMPOSITION 
Like the Every Layout stack: https://every-layout.dev/layouts/stack/
Info about this implementation: https://piccalil.li/quick-tip/flow-utility/ 
*/

.flow>*+* {
  margin-block-start: var(--flow-space, 1em);
}

.frame {
  --n: 16;
  --d: 9;
  aspect-ratio: var(--n) / var(--d);
  overflow: clip;
  display: flex;
  justify-content: center;
  align-items: center;
}

.frame>img,
.frame>video {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* AUTO GRID
Related Every Layout: https://every-layout.dev/layouts/grid/
More info on the flexible nature: https://piccalil.li/tutorial/create-a-responsive-grid-layout-with-no-media-queries-using-css-grid/
A flexible layout that will create an auto-fill grid with
configurable grid item sizes

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--grid-min-item-size (14rem): How large each item should be
ideally, as a minimum.

--grid-placement (auto-fill): Set either auto-fit or auto-fill
to change how empty grid tracks are handled */

.grid {
  display: grid;
  grid-template-columns: repeat(var(--grid-placement, auto-fill),
      minmax(var(--grid-min-item-size, 16rem), 1fr));
  gap: var(--gutter, var(--space-grid-gutter));
}

/* A split 50/50 layout */

.grid[data-layout='halves'] {
  --grid-placement: auto-fit;
  --grid-min-item-size: clamp(16rem, 50vw, 33rem);
}

/* Three column grid layout */

.grid[data-layout='thirds'] {
  --grid-placement: auto-fit;
  --grid-min-item-size: clamp(16rem, 33%, 20rem);
}

.grid[data-layout='teaser-grid-gap'] {
  --gutter: var(--space-grid-gutter);
  row-gap: 3rem;
  @media (min-width: 767px) {
    row-gap: var(--gutter);
  }
}

.layout-grid {
  display: grid;
  -moz-column-gap: var(--space-grid-gutter);
       column-gap: var(--space-grid-gutter);
  grid-template-columns: repeat(12, minmax(0, 1fr));
  container-name: layout-grid;
  container-type: inline-size;
}

.min-width-220 {
  min-width: min(220px, 100%);
}

.min-width-360 {
  min-width: min(360px, 100%);
}

.max-width-640 {
  max-width: 640px;
}

.flex-grow-1 {
  flex-grow: 1;
}

.flow-space-m-fixed {
  &>*+* {
    margin-top: .5rem
  }
}

@container layout-grid (max-width: 767px) {
  .sticky-sidebar {
    padding-bottom: 0 !important;
  }
}

@media (min-width: 767px) {
  .sticky-sidebar-grid {
    align-items: start;
    & .sticky-sidebar {
      position: sticky;
      top: var(--header-height, 0px);
    }
  }

  .single .sticky-sidebar-grid .sticky-sidebar {
    top: calc(var(--header-height) + var(--space-2xl));
  }
}

.reel {
  --color-scrollbar-thumb: var(--color-primary);
  --color-scrollbar-track: var(--color-light);
  --scrollbar-height: 1rem;
  --reel-gap: var(--space-m);
  display: flex;
  block-size: auto;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-color: var(--color-scrollbar-thumb) var(--color-scrollbar-track);
}

.reel::-webkit-scrollbar {
  block-size: var(--scrollbar-height);
}

.reel::-webkit-scrollbar-track {
  background-color: var(--color-scrollbar-track);
}

.reel::-webkit-scrollbar-thumb {
  background-color: var(--color-scrollbar-thumb);
  background-image: linear-gradient(var(--color-scrollbar-track) 0,
      var(--color-scrollbar-track) calc(.25 * var(--scrollbar-height)),
      var(--color-scrollbar-thumb) calc(.25 * var(--scrollbar-height)),
      var(--color-scrollbar-thumb) calc(.75 * var(--scrollbar-height)),
      var(--color-scrollbar-track) calc(.75 * var(--scrollbar-height)),
    );
}

.reel>* {
  flex: 0 0 auto;
}

.reel>img {
  block-size: 100%;
  flex-basis: auto;
  width: auto;
}

.reel>*+* {
  margin-inline-start: var(--reel-gap);
}

.reel.overflowing {
  padding-block-end: var(--scrollbar-height);
}

/*
REPEL
A little layout that pushes items away from each other where
there is space in the viewport and stacks on small viewports

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-s-m)): This defines the space
between each item.

--repel-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.repel {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: var(--repel-vertical-alignment, center);
  gap: var(--gutter, var(--space-s-m));
}

.repel[data-nowrap] {
  flex-wrap: nowrap;
}

/* 
SIDEBAR
More info: https://every-layout.dev/layouts/sidebar/
A layout that allows you to have a flexible main content area
and a "fixed" width sidebar that sits on the left or right.
If there is not enough viewport space to fit both the sidebar
width *and* the main content minimum width, they will stack
on top of each other

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between the sidebar and main content.

--sidebar-target-width (20rem): How large the sidebar should be

--sidebar-content-min-width(50%): The minimum size of the main content area

EXCEPTIONS
.sidebar[data-direction='rtl']: flips the sidebar to be on the right 
*/

.sidebar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-l));
}

.sidebar> :first-child {
  flex-basis: var(--sidebar-target-width, 20rem);
  flex-grow: 1;
}

.sidebar> :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: var(--sidebar-content-min-width, 50%);
}

/*
SWITCHER
More info: https://every-layout.dev/layouts/switcher/
A layout that allows you to lay **2** items next to each other
until there is not enough horizontal space to allow that.

CUSTOM PROPERTIES AND CONFIGURATION
--gutter (var(--space-size-1)): This defines the space
between each item

--switcher-target-container-width (40rem): How large the container
needs to be to allow items to sit inline with each other

--switcher-vertical-alignment How items should align vertically.
Can be any acceptable flexbox alignment value.
*/

.switcher {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gutter, var(--space-s-l));
  align-items: var(--switcher-vertical-alignment, flex-start);
}

.switcher>* {
  flex-grow: 1;
  flex-basis: calc((var(--switcher-target-container-width, 40rem) - 100%) * 999);
}

/* Max 2 items,
so anything greater than 2 is full width */

.switcher> :nth-child(n + 3) {
  flex-basis: 100%;
}

/*
WRAPPER COMPOSITION 
A common wrapper/container
*/

.wrapper {
  margin-inline: auto;
  max-width: clamp(16rem, var(--wrapper-max-width, 1416px), 105rem);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  position: relative;
}

.wrapper-min {
  --wrapper-max-width: 390px;
}

.wrapper-mid {
  --wrapper-max-width: 1310px;
}

.wrapper-max {
  --wrapper-max-width: 1680px;
}

.corner-top-right-round {
  position: relative;
  border-top-right-radius: var(--space-5xl);
  &:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: inherit;
    height: var(--space-5xl);
  }
}

.basis-full {
  flex-basis: 100%;
}

.flex-grow-1 {
  flex-grow: 1;
}

.no-measure {
  max-width: unset;
}

/* 
REGION UTILITY
Consistent block padding for page sections
*/

.region {
  padding-block: var(--region-space, var(--space-xl-2xl));
}

/* 
VISUALLY HIDDEN UTILITY
Info: https://piccalil.li/quick-tip/visually-hidden/ 
*/

.visually-hidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 0;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

.wp-block-pp-button.button,
.wp-core-ui .button,
:is(.button) {
  --button-bg: var(--color-primary);
  --button-bg-hover: var(--color-neutral-80);
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-light);
  --circle-color: var(--color-neutral-80);
  --circle-color-hover: var(--color-primary);
  --arrow-fill: var(--color-primary);
  --arrow-fill-hover: var(--color-neutral-80);
  --button-x-padding: .5rem 1rem;
  --button-y-padding: var(--space-m);
  --button-gutter: var(--space-m);
  --focus-color: var(--color-neutral-80);
  --icon-transform: rotate(-45deg);
  position: relative;
  display: inline-flex;
  gap: var(--button-gutter);
  align-items: center;
  cursor: pointer;
  background: var(--button-bg);
  color: var(--button-text);
  padding-inline: var(--button-x-padding);
  padding-block: var(--button-y-padding);
  text-decoration: none;
  font-size: var(--size-button);
  font-weight: var(--font-regular);
  line-height: var(--leading-tight);
  white-space: nowrap;
  border: none;
  border-radius: var(--radius-xl);
  transition: background-color var(--transition-fade),
    color var(--transition-fade),
    transform var(--transition-fade),
    fill var(--transition-fade),
    box-shadow var(--transition-fade);
  & * {
    transition: inherit;
  }
  & .button-icon {
    border-radius: 50%;
    width: 32px;
    height: 32px;
  }
  & .button-icon circle {
    color: var(--circle-color);
  }
  & .button-icon path.arrow {
    transform-origin: center center;
    fill: var(--arrow-fill);
  }
  & span.button-text {
    display: inline-block;
    text-box-trim: trim-both;
    text-box-edge: cap alphabetic;
  }
}

.wp-block-pp-button.button:hover,
.wp-core-ui .button:hover,
.button:hover {
  @media (hover: hover) and (pointer: fine) {
    background: var(--button-bg-hover);

    color: var(--button-text-hover);

    & .button-icon {
      box-shadow: 0 0 8px 0 var(--circle-color-hover);
    }

    & .button-icon circle {
      color: var(--circle-color-hover);
    }

    & .button-icon path.arrow {
      transform: var(--icon-transform);
      fill: var(--arrow-fill-hover);
    }
  }
}

.wp-block-pp-button.button:active,
.wp-core-ui .button:active,
.button:active {
  transform: scale(0.99);
}

.wp-block-pp-button.button:disabled,
.wp-core-ui .button:disabled,
.button:disabled {
  opacity: .24;
}

.button[data-size="small"] {
  font-size: var(--size-button-s);
  --button-x-padding: .5rem calc(1rem * 0.75);
  & .button-icon {
    width: 28px;
    height: 28px;
  }
}

.button[data-variant="secondary"] {
  --button-bg: var(--color-neutral-10);
  --button-bg-hover: var(--color-neutral-80);
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-light);
  --circle-color: var(--color-primary);
  --arrow-fill: var(--color-dark);
}

.button[data-variant="tertiary"] {
  --button-x-padding: 0;
  --button-y-padding: 0;
  --button-bg: transparent;
  --button-bg-hover: transparent;
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-neutral-80);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-primary);
}

.button[data-variant="back-button"] {
  --button-x-padding: 0;
  --button-y-padding: 0;
  --button-bg: transparent;
  --button-bg-hover: transparent;
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-neutral-80);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-primary);
  --icon-transform: rotate(0deg);
  & .button-icon {
    transform: rotate(180deg);
  }
}

.button[data-background="green"] {
  --focus-color: var(--color-neutral-80);
}

.button[data-background="dark"] {
  --focus-color: var(--color-primary);
}

.button[data-variant="primary"][data-background="dark"] {
  --button-bg: var(--color-light);
  --button-bg-hover: var(--color-primary);
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-neutral-80);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-primary);
}

.button[data-variant="secondary"][data-background="dark"] {
  --button-bg: var(--color-primary);
  --button-bg-hover: var(--color-light);
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-neutral-80);
  --circle-color-hover: var(--color-neutral-80);
  --arrow-fill: var(--color-primary);
  --arrow-fill-hover: var(--color-primary);
}

.button[data-variant="tertiary"][data-background="dark"] {
  --button-text: var(--color-light);
  --button-text-hover: var(--color-light);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-light);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-neutral-80);
}

.button[data-variant="primary"][data-background="green"] {
  --button-text-hover: var(--color-light);
  --button-bg: var(--color-light);
  --button-text: var(--color-neutral-80);
  --circle-color: var(--color-neutral-80);
  --circle-color-hover: var(--color-primary);
  --arrow-fill: var(--color-primary);
  --arrow-fill-hover: var(--color-neutral-80);
}

.button[data-variant="secondary"][data-background="green"] {
  --button-bg: var(--color-neutral-80);
  --button-bg-hover: var(--color-light);
  --button-text: var(--color-light);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-primary);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-neutral-80);
}

.button[data-variant="tertiary"][data-background="green"] {
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-light);
  --circle-color-hover: var(--color-neutral-80);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-primary);
}

.button[data-display="icon-only"] {
  --button-x-padding: var(--space-m);
  --button-y-padding: var(--space-m);
  & .button-icon {
    background-color: var(--color-neutral-10);
  }
  & .button-text {
    visibility: hidden;
    border: 0;
    clip: rect(0 0 0 0);
    height: 0;
    margin: 0;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    white-space: nowrap;
  }
}

.button[data-display="no-icon"] {
  padding: 18px 16px;
  .button-icon {
    display: none;
  }
}

.button[data-icon-down] {
  & .button-icon path.arrow {
    transform: rotate(90deg);
  }
}

.button[data-icon-down]:hover {
  & .button-icon path.arrow {
    transform: rotate(90deg);
  }
}

button.wpforms-submit,
.wp-load-more__button {
  margin-block-start: var(--space-2xl);
  position: relative;
  transition: background-color var(--transition-base);
  --button-bg: var(--color-neutral-80);
  --button-bg-hover: var(--color-light);
  --button-text: var(--color-light);
  --button-text-hover: var(--color-neutral-80);
  --circle-color: var(--color-primary);
  --circle-color-hover: var(--color-primary);
  --arrow-fill: var(--color-neutral-80);
  --arrow-fill-hover: var(--color-neutral-80);
  --button-x-padding: var(--space-m) var(--space-l);
  --button-y-padding: var(--space-m);
  --button-gutter: var(--space-m);
  --focus-color: var(--color-dark);
  display: inline-flex;
  gap: var(--button-gutter);
  align-items: center;
  padding-block: var(--button-y-padding);
  padding-inline: var(--button-x-padding);
  border-radius: var(--radius-xl);
  background-color: var(--button-bg);
  color: var(--button-text);
  font-size: var(--size-button);
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  outline: none;
  border: none;
  &::before {
    content: '';
    border-radius: 100%;
    padding: var(--space-m);
    background-color: var(--circle-color);
    width: 32px;
    height: 32px;
  }
  &::after {
    content: var(--icon-arrow-right);
    font-family: "iconfont";
    position: absolute;
    left: calc(var(--space-m) + 9px);
    top: calc(var(--space-m) + 6px);
    will-change: transform;
    transition: transform var(--transition-base);
    color: var(--arrow-fill-hover);
    font-size: 18px;
    transform-origin: calc(var(--space-m) + 16px) 45%;
  }
  &:hover {
    @media (hover: hover) and (pointer: fine) {
      background-color: var(--button-bg-hover);

      color: var(--button-text-hover);

      &::after {
        color: var(--button-text-hover);
      }
    }
  }
  &:hover::before {
    box-shadow: 0 0 8px 0 var(--circle-color-hover);
  }
  &:hover::after {
    transform: translate(-25%, -50%) rotate(-45deg);
  }
  &:focus-visible {
    outline: 2px solid var(--focus-color);
    outline-offset: 2px;
  }
  &:active {
    transform: scale(0.99);
  }
  &::after {
    color: var(--arrow-fill);
  }
  &:hover::before {
    background-color: var(--circle-color-hover);
  }
  &:hover::after {
    color: var(--arrow-fill-hover);
  }
  > span {
    padding-block-start: var(--space-xs);
    text-decoration: none !important;
    text-decoration-line: none !important;
    border-bottom: none !important;
  }
}

a.wp-load-more__button {
  text-decoration: none;
  --button-bg: var(--color-primary);
  --button-bg-hover: var(--color-neutral-80);
  --button-text: var(--color-neutral-80);
  --button-text-hover: var(--color-light);
  --circle-color: var(--color-neutral-80);
  --circle-color-hover: var(--color-primary);
  --arrow-fill: var(--color-primary);
  --arrow-fill-hover: var(--color-neutral-80);
  --button-x-padding: var(--space-m) var(--space-l);
  --button-y-padding: var(--space-m);
  --button-gutter: var(--space-m);
  --focus-color: var(--color-neutral-80);
  --icon-transform: rotate(-45deg);
}

button.wpforms-submit {
  --arrow-fill-hover: var(--color-neutral-80);
  &:hover::after {
    color: var(--arrow-fill-hover);
  }
}

.wpforms-container {
  padding: 0;
  margin: 0;
  container-name: form;
  container-type: inline-size;
  .wpforms-layout-row {
    margin: 0 !important;
    -moz-column-gap: var(--space-grid-gutter);
         column-gap: var(--space-grid-gutter);
  }
  .wpforms-layout-column {
    padding: 0 !important;
  }
}

@container form (max-width: 500px) {
  .wpforms-layout-row {
    flex-direction: column;
    row-gap: var(--space-l);
  }

  .wpforms-layout-column-50 {
    width: unset !important;
  }
}

.wpforms-field-container {
  margin: 0;
  display: flex;
  flex-direction: column;
  row-gap: var(--space-l);
}

.wpforms-field-text,
.wpforms-field-textarea,
.wpforms-field-select {
  position: relative;
}

.wpforms-field.filled>label,
.wpforms-field:has(> input:focus-visible)>label,
.wpforms-field:has(> textarea:focus-visible)>label {
  top: 1em;
  font-size: var(--size-body-s);
}

.wpforms-field input:focus-visible,
.wpforms-field textarea:focus-visible,
.wpforms-field select:focus-visible {
  outline-color: transparent;
}

.wpforms-error {
  color: var(--color-error);
  font-size: var(--size-body-s);
  padding-block-start: var(--space-s);
  padding-inline-start: .5em;
  font-weight: var(--font-regular);
  font-style: normal;
}

.wpforms-field-text label,
.wpforms-field-textarea label,
.wpforms-field-select label {
  transition: top var(--transition-base), font-size var(--transition-base);
  font-size: var(--size-body);
  color: var(--color-dark);
  position: absolute;
  top: 50%;
  left: 0.5em;
  line-height: var(--leading-loose);
  transform: translateY(-50%);
}

.wpforms-field-textarea label {
  top: 2em;
}

.wpforms-field-text input,
.wpforms-field-textarea textarea,
.wpforms-field-select select {
  background-color: transparent;
  font-size: var(--size-body);
  border: none;
  border-bottom: 2px solid var(--color-light);
  outline-offset: -2px;
  outline-color: var(--color-neutral-80);
}

.wpforms-field-select select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 0;
  padding-block: 2em 1em;
  padding-inline-start: .5em;
  padding-inline-end: 2em;
  background-image: url('data:image/svg+xml,%3Csvg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M12.5929 13.106L6.57868 7.0918L5.17868 8.4918L12.5929 15.906L20.0071 8.4918L18.6071 7.0918L12.5929 13.106Z" fill="currentColor"/%3E%3C/svg%3E');
  background-repeat: no-repeat;
  background-position: calc(100% - 0.5em) calc(50% + .5em);
  background-size: var(--space-xl);
}

.wpforms-confirmation-container {
  font-size: var(--size-body-xl);
  min-height: 20em;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  background-color: var(--color-light);
  &:after{
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 100%;
    border-radius: 0 0 var(--space-l, 16px) var(--space-l, 16px);
    background: var(--color-neutral-0, #FFF);
    /* shadow */
    box-shadow: 0 12px 16px -4px rgba(16, 24, 40, 0.08), 0 4px 6px -2px rgba(16, 24, 40, 0.03);
  }
  @media screen and (max-width: 719px) {
    padding-block-start: 50px;
  }
}

:root {
  /* calculated header height based on button plus 32px/var(--space-xl) spacing */
  --header-height: calc(80px + (2 * var(--space-xl)));
  @media screen and (min-width: 720px) {
    --header-height: calc(48px + (2 * var(--space-xl)) + (2 * var(--space-m)));
  }
}

main {
  margin-top: var(--header-height);
}

.icon-check {
  background-color: var(--color-primary);
  font-size: var(--size-heading-l);
  width: 1em;
  height: 1em;
  border-radius: 50%;
  box-shadow: 0 0 10px 0 var(--color-primary);
  &::before {
    /* 2px in 24px font size */
    padding-left: 0.0833em;
  }
  &.icon-check--large {
    font-size: calc(1.25 * var(--size-heading-2xl));
    &::before {
      padding-left: 0.1em;
    }
  }
}

.icon-check--large {
  display: inline-block;
  width: calc(1.25 * var(--space-2xl));
  height: calc(1.25 * var(--space-2xl));
  padding: calc(.2 * var(--space-2xl));
  background-color: var(--color-primary);
  border-radius: 50%;
  box-shadow: 0 0 10px 0 var(--color-primary);
}

.wp-block-image {
  border-radius: var(--radius-l);
  overflow: clip;
  width: 100%;
}

.wp-block-image img[style*="object-fit"] {
  width: 100%;
  height: 100%;
}

.wp-block-navigation__responsive-container {
}

/* ------------------------------------
    Loxo overwrites
------------------------------------- */

/*toggle button*/

.wp-block-navigation__responsive-container-close,
.wp-block-navigation__responsive-container-open:not(.always-shown) {
  display: flex;
  align-items: center;
  -moz-column-gap: var(--space-m);
       column-gap: var(--space-m);
  svg{
    padding: 6px;
    background: var(--color-neutral-80);
    border-radius: 50%;
    width: 28px;
    height: 28px;
    color: var(--color-primary);
  }
  &:before {
    content: '';
    position: absolute;
    z-index: -1;
    inset: 0;
    width: calc(100% + 20px);
    height: calc(100% + 16px);
    transform: translate(-8px, -8px);
    border-radius: 500px;
    background: var(--color-primary);
  }
  &:after {
    content: 'Menu';
    font-size: var(--size-button-s);
  }
  @media screen and (min-width: 720px) {
    display: none;
  }
}

.wp-block-navigation__responsive-container-close{
  &.wp-block-navigation__responsive-container-close:after {
    content: 'Schliessen';
  }
}

/*desktop nav*/

.wp-block-navigation__responsive-container:not(.hidden-by-default):not(.is-menu-open) {
  display: none;
  @media screen and (min-width: 720px) {
    display: block;
  }
}

/* Primary Navigation Styles */

nav.wp-block-navigation {
  --box-shadow-navigation: 0 0 .14em .07em var(--color-primary);
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation-item__content {
  display: inline-flex;
  align-items: center;
  gap: var(--space-m);
  padding-block: var(--space-l);
  padding-inline: calc(.75 * var(--space-l));
  line-height: var(--leading-standard);
  color: var(--color-neutral-80);
  border-radius: var(--radius-s);
  cursor: pointer;
  transition: background-color var(--transition-fade);
  &::before {
    content: '';
    display: block;
    width: var(--space-m);
    aspect-ratio: 1;
    background-color: var(--color-primary);
    border-radius: 100%;
    box-shadow: 0 0 8px 0 var(--color-primary);
    opacity: 0;
    transition: opacity var(--transition-fade), box-shadow var(--transition-fade);
  }
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation-item__content[aria-current="page"] {
  &::before {
    box-shadow: none;
    opacity: 1;
  }
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation-item__content:hover {
  background-color: var(--color-neutral-10);
  &::before {
    box-shadow: var(--box-shadow-navigation);
    opacity: 1;
  }
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation__responsive-container-content {
  gap: var(--space-zero);
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation-item__label {
  display: inline-block;
  text-box-edge: cap alphabetic;
  text-box-trim: trim-both;
}

/* Allow button block in navigation */

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-pp-button {
  margin-block: 0;
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-pp-button .button {
  /* Remove the dot indicator for button items */
  &::before {
    content: none !important;
  }
}

nav.wp-block-navigation[aria-label="Primary Navigation"] ul.wp-block-navigation__container + .button {
  margin-inline-start: var(--space-l);
}

nav.wp-block-navigation[aria-label="Primary Navigation"] .wp-block-navigation__responsive-container-content {
  flex-wrap: nowrap;
  & .wp-block-navigation__container {
    flex-wrap: nowrap;
  }
}

nav .wp-block-navigation__responsive-container.has-modal-open {
  padding: 0;
  z-index: 99 !important;
  & .wp-block-navigation__responsive-dialog {
    padding: 0 !important;
  }
  & .wp-block-navigation__responsive-container-content {
    padding-inline: var(--space-grid-gutter);
  }
  & .wp-block-navigation__container.is-responsive li a::before {
    width: var(--space-l);
    box-shadow: 0 0 8px 0 var(--color-primary);
  }
  & .wp-block-navigation__container.is-responsive li a {
    font-size: var(--size-heading-2xl);
    padding-inline: var(--space-l);
    gap: var(--space-l);
    & span {
      line-height: var(--leading-loose);
      text-box-edge: auto;
      text-box-trim: none;
    }
  }
  & .wp-block-navigation__container.is-responsive li + li {
    margin-block-start: var(--space-xl);
  }
  & .button {
    margin-block-start: var(--space-2xl);
  }
  & .wp-block-navigation__responsive-container-close {
    position: fixed;
    top: var(--space-grid-gutter);
    right: var(--space-grid-gutter);
  }
}

/* Footer Navigation Styles */

nav.wp-block-navigation[aria-label="Footer Navigation"] {
  font-size: var(--size-heading-xl);
  ul {
    gap: calc(1.5 * var(--space-m));
  }
}

nav.wp-block-navigation[aria-label="Footer Navigation"] a.wp-block-navigation-item__content {
  display: inline-flex;
  align-items: center;
  position: relative;
  &::before {
    content: "";
    width: 0;
    background-color: var(--color-primary);
    transition: width var(--transition-fade);
  }
  &::after {
    content: "";
    font-size: var(--size-heading-xl);
    position: absolute;
    aspect-ratio: 1;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    background-color: var(--color-primary);
    border-radius: 100%;
    opacity: 0;
    width: .29em;
    transition: opacity var(--transition-fade), box-shadow var(--transition-fade);
  }
}

nav.wp-block-navigation[aria-label="Footer Navigation"] a.wp-block-navigation-item__content:hover {
  &::before {
    width: .58em;
  }
  &::after {
    box-shadow: var(--box-shadow-navigation);
    opacity: 1;
  }
}

nav.wp-block-navigation[aria-label="Legal Navigation"] {
  font-size: var(--size-button-s);
  & ul {
    gap: var(--space-xl);
  }
}

/* query loop grid formatting */

.news {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 350px), 1fr));
  align-items: start;
  gap: var(--space-4xl);
  @media (min-width: 767px) {
    gap: var(--space-grid-gutter);
  }
}

/* Default styling for all post featured images */

.wp-block-post-featured-image img {
  border-radius: var(--radius-l);
}

.wp-block-post-featured-image:has(img.size-usecase-featured-image) {
  aspect-ratio: 1042 / 456;
  img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.prose {
  --flow-space: var(--space-s);
}

.prose :is(h1, h2, h3) {
  overflow-wrap: anywhere;
  hyphens: auto;
}

.prose :is(p, li, dl, figcaption, blockquote) {
  max-width: 60ch;
  text-wrap: pretty;
}

.prose :is(h1, h2, h3, h4)+*:not([class]) {
  --flow-space: var(--space-m);
}

/* Add more space on and around figures and tables */

.prose :is(figure, table),
.prose :is(figure, table)+* {
  --flow-space: var(--space-2xl);
}

/* Add more space to headings on block start */

.prose *+ :is(h1, h2, h3, h4):not([class]) {
  --flow-space: var(--space-xl);
}

.prose :is(ul, ol):not([class]) li+li,
.prose :is(ul, ol):not([class]) li> :is(ol, ul) {
  --flow-space: var(--space-zero);
}

.prose hr {
  --flow-space: var(--space-2xl);
}

.prose :is(img, picture, video) {
  border: var(--stroke-solid);
}

@media (min-width: 767px) {
  .prose :is(h1, h2, h3) {
    overflow-wrap: unset;
    hyphens: unset;
  }
}

.hyphens-auto {
  hyphens: auto;
  * {
    hyphens: inherit;
  }
}

ul.wp-block-social-links {
  gap: var(--space-l);
  display: inline-flex !important;
  padding: 0;
  margin: 0;
}

.wp-block-social-links li {
  color: var(--color-primary);
  background-color: transparent;
  & svg[role='img'][width][height] {
    width: var(--space-xl);
    height: var(--space-xl);
    aspect-ratio: 1 / 1;
    background-color: transparent;
    color: var(--color-light);
    transition: color var(--transition-fade);
  }
}

.wp-block-social-links li a,
.wp-block-social-links li button {
  padding: 0;
}

.wp-block-social-links li:hover svg[role='img'][width][height] {
  color: var(--color-accent);
}

/* hide label text for screen readers */

.wp-block-social-links .wp-block-social-link-label.screen-reader-text {
  border: 0;
  clip: rect(0 0 0 0);
  height: 0;
  margin: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}

.wp-block-video {
  border-radius: .5rem;
  overflow: clip;
}

footer .wp-block-navigation-item__label {
  color: var(--color-light);
}

/* include .footer as in part editor there is no footer element,
so I manually added .footer class */

footer a,
footer button,
.footer a,
.footer button {
  --focus-color: var(--color-light);
  color: var(--color-light);
}

header {
  z-index: 100;
}

body.error404 .wp-site-blocks {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
}

body.error404 .wp-site-blocks>main {
  flex-grow: 1;
}

.m-2xl {
  margin: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.m-3xl {
  margin: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.m-3xl-7xl {
  margin: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.m-4xl {
  margin: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.m-4xl-6xl {
  margin: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.m-5xl {
  margin: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.m-6xl {
  margin: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.m-7xl {
  margin: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.m-grid-gutter {
  margin: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.m-gutter-inline {
  margin: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.m-l {
  margin: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.m-m {
  margin: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.m-s {
  margin: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.m-xl {
  margin: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.m-xs {
  margin: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.m-zero {
  margin: 0rem;
}

.mx-2xl {
  margin-left: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  margin-right: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.mx-3xl {
  margin-left: clamp(2rem, 1.70rem + 1.24vw, 3rem);
  margin-right: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.mx-3xl-7xl {
  margin-left: clamp(2rem, 0.19rem + 7.44vw, 8rem);
  margin-right: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.mx-4xl {
  margin-left: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
  margin-right: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.mx-4xl-6xl {
  margin-left: clamp(3rem, 2.09rem + 3.72vw, 6rem);
  margin-right: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.mx-5xl {
  margin-left: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
  margin-right: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.mx-6xl {
  margin-left: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
  margin-right: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.mx-7xl {
  margin-left: clamp(6rem, 5.40rem + 2.48vw, 8rem);
  margin-right: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.mx-grid-gutter {
  margin-left: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
  margin-right: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.mx-gutter-inline {
  margin-left: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
  margin-right: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.mx-l {
  margin-left: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
  margin-right: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.mx-m {
  margin-left: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
  margin-right: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.mx-s {
  margin-left: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
  margin-right: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.mx-xl {
  margin-left: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  margin-right: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.mx-xs {
  margin-left: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
  margin-right: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.mx-zero {
  margin-left: 0rem;
  margin-right: 0rem;
}

.my-2xl {
  margin-top: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  margin-bottom: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.my-3xl {
  margin-top: clamp(2rem, 1.70rem + 1.24vw, 3rem);
  margin-bottom: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.my-3xl-7xl {
  margin-top: clamp(2rem, 0.19rem + 7.44vw, 8rem);
  margin-bottom: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.my-4xl {
  margin-top: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
  margin-bottom: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.my-4xl-6xl {
  margin-top: clamp(3rem, 2.09rem + 3.72vw, 6rem);
  margin-bottom: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.my-5xl {
  margin-top: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
  margin-bottom: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.my-6xl {
  margin-top: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
  margin-bottom: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.my-7xl {
  margin-top: clamp(6rem, 5.40rem + 2.48vw, 8rem);
  margin-bottom: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.my-grid-gutter {
  margin-top: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
  margin-bottom: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.my-gutter-inline {
  margin-top: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
  margin-bottom: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.my-l {
  margin-top: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
  margin-bottom: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.my-m {
  margin-top: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
  margin-bottom: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.my-s {
  margin-top: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
  margin-bottom: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.my-xl {
  margin-top: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  margin-bottom: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.my-xs {
  margin-top: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
  margin-bottom: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.my-zero {
  margin-top: 0rem;
  margin-bottom: 0rem;
}

.mb-2xl {
  margin-bottom: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.mb-3xl {
  margin-bottom: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.mb-3xl-7xl {
  margin-bottom: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.mb-4xl {
  margin-bottom: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.mb-4xl-6xl {
  margin-bottom: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.mb-5xl {
  margin-bottom: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.mb-6xl {
  margin-bottom: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.mb-7xl {
  margin-bottom: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.mb-grid-gutter {
  margin-bottom: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.mb-gutter-inline {
  margin-bottom: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.mb-l {
  margin-bottom: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.mb-m {
  margin-bottom: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.mb-s {
  margin-bottom: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.mb-xl {
  margin-bottom: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.mb-xs {
  margin-bottom: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.mb-zero {
  margin-bottom: 0rem;
}

.ml-2xl {
  margin-left: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.ml-3xl {
  margin-left: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.ml-3xl-7xl {
  margin-left: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.ml-4xl {
  margin-left: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.ml-4xl-6xl {
  margin-left: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.ml-5xl {
  margin-left: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.ml-6xl {
  margin-left: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.ml-7xl {
  margin-left: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.ml-grid-gutter {
  margin-left: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.ml-gutter-inline {
  margin-left: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.ml-l {
  margin-left: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.ml-m {
  margin-left: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.ml-s {
  margin-left: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.ml-xl {
  margin-left: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.ml-xs {
  margin-left: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.ml-zero {
  margin-left: 0rem;
}

.mr-2xl {
  margin-right: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.mr-3xl {
  margin-right: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.mr-3xl-7xl {
  margin-right: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.mr-4xl {
  margin-right: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.mr-4xl-6xl {
  margin-right: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.mr-5xl {
  margin-right: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.mr-6xl {
  margin-right: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.mr-7xl {
  margin-right: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.mr-grid-gutter {
  margin-right: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.mr-gutter-inline {
  margin-right: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.mr-l {
  margin-right: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.mr-m {
  margin-right: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.mr-s {
  margin-right: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.mr-xl {
  margin-right: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.mr-xs {
  margin-right: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.mr-zero {
  margin-right: 0rem;
}

.mt-2xl {
  margin-top: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.mt-3xl {
  margin-top: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.mt-3xl-7xl {
  margin-top: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.mt-4xl {
  margin-top: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.mt-4xl-6xl {
  margin-top: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.mt-5xl {
  margin-top: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.mt-6xl {
  margin-top: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.mt-7xl {
  margin-top: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.mt-grid-gutter {
  margin-top: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.mt-gutter-inline {
  margin-top: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.mt-l {
  margin-top: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.mt-m {
  margin-top: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.mt-s {
  margin-top: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.mt-xl {
  margin-top: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.mt-xs {
  margin-top: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.mt-zero {
  margin-top: 0rem;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.flex-row {
  flex-direction: row;
}

.flex-row-reverse {
  flex-direction: row-reverse;
}

.flex-col {
  flex-direction: column;
}

.flex-col-reverse {
  flex-direction: column-reverse;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-wrap-reverse {
  flex-wrap: wrap-reverse;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

.items-start {
  align-items: flex-start;
}

.items-end {
  align-items: flex-end;
}

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

.items-baseline {
  align-items: baseline;
}

.items-stretch {
  align-items: stretch;
}

.justify-start {
  justify-content: flex-start;
}

.justify-end {
  justify-content: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.justify-around {
  justify-content: space-around;
}

.justify-evenly {
  justify-content: space-evenly;
}

.bg-accent {
  background-color: #16F78E;
}

.bg-dark {
  background-color: #001231;
}

.bg-error {
  background-color: #D8443B;
}

.bg-light {
  background-color: #FDFDFD;
}

.bg-lilac {
  background-color: #EBBEDC;
}

.bg-neutral-10 {
  background-color: #ECF0F8;
}

.bg-neutral-20 {
  background-color: #DFDDEC;
}

.bg-neutral-40 {
  background-color: #8093B7;
}

.bg-neutral-60 {
  background-color: #183465;
}

.bg-neutral-80 {
  background-color: #001946;
}

.bg-primary {
  background-color: #16F78E;
}

.bg-sky {
  background-color: #00AAAA;
}

.bg-success {
  background-color: #3BD87A;
}

.p-2xl {
  padding: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.p-3xl {
  padding: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.p-3xl-7xl {
  padding: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.p-4xl {
  padding: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.p-4xl-6xl {
  padding: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.p-5xl {
  padding: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.p-6xl {
  padding: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.p-7xl {
  padding: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.p-grid-gutter {
  padding: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.p-gutter-inline {
  padding: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.p-l {
  padding: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.p-m {
  padding: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.p-s {
  padding: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.p-xl {
  padding: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.p-xs {
  padding: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.p-zero {
  padding: 0rem;
}

.px-2xl {
  padding-left: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  padding-right: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.px-3xl {
  padding-left: clamp(2rem, 1.70rem + 1.24vw, 3rem);
  padding-right: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.px-3xl-7xl {
  padding-left: clamp(2rem, 0.19rem + 7.44vw, 8rem);
  padding-right: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.px-4xl {
  padding-left: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
  padding-right: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.px-4xl-6xl {
  padding-left: clamp(3rem, 2.09rem + 3.72vw, 6rem);
  padding-right: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.px-5xl {
  padding-left: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
  padding-right: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.px-6xl {
  padding-left: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
  padding-right: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.px-7xl {
  padding-left: clamp(6rem, 5.40rem + 2.48vw, 8rem);
  padding-right: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.px-grid-gutter {
  padding-left: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
  padding-right: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.px-gutter-inline {
  padding-left: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
  padding-right: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.px-l {
  padding-left: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
  padding-right: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.px-m {
  padding-left: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
  padding-right: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.px-s {
  padding-left: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
  padding-right: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.px-xl {
  padding-left: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  padding-right: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.px-xs {
  padding-left: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
  padding-right: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.px-zero {
  padding-left: 0rem;
  padding-right: 0rem;
}

.py-2xl {
  padding-top: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  padding-bottom: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.py-3xl {
  padding-top: clamp(2rem, 1.70rem + 1.24vw, 3rem);
  padding-bottom: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.py-3xl-7xl {
  padding-top: clamp(2rem, 0.19rem + 7.44vw, 8rem);
  padding-bottom: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.py-4xl {
  padding-top: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
  padding-bottom: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.py-4xl-6xl {
  padding-top: clamp(3rem, 2.09rem + 3.72vw, 6rem);
  padding-bottom: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.py-5xl {
  padding-top: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
  padding-bottom: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.py-6xl {
  padding-top: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
  padding-bottom: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.py-7xl {
  padding-top: clamp(6rem, 5.40rem + 2.48vw, 8rem);
  padding-bottom: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.py-grid-gutter {
  padding-top: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
  padding-bottom: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.py-gutter-inline {
  padding-top: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
  padding-bottom: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.py-l {
  padding-top: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
  padding-bottom: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.py-m {
  padding-top: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
  padding-bottom: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.py-s {
  padding-top: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
  padding-bottom: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.py-xl {
  padding-top: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
  padding-bottom: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.py-xs {
  padding-top: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
  padding-bottom: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.py-zero {
  padding-top: 0rem;
  padding-bottom: 0rem;
}

.pb-2xl {
  padding-bottom: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.pb-3xl {
  padding-bottom: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.pb-3xl-7xl {
  padding-bottom: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.pb-4xl {
  padding-bottom: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.pb-4xl-6xl {
  padding-bottom: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.pb-5xl {
  padding-bottom: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.pb-6xl {
  padding-bottom: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.pb-7xl {
  padding-bottom: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.pb-grid-gutter {
  padding-bottom: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.pb-gutter-inline {
  padding-bottom: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.pb-l {
  padding-bottom: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.pb-m {
  padding-bottom: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.pb-s {
  padding-bottom: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.pb-xl {
  padding-bottom: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.pb-xs {
  padding-bottom: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.pb-zero {
  padding-bottom: 0rem;
}

.pl-2xl {
  padding-left: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.pl-3xl {
  padding-left: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.pl-3xl-7xl {
  padding-left: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.pl-4xl {
  padding-left: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.pl-4xl-6xl {
  padding-left: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.pl-5xl {
  padding-left: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.pl-6xl {
  padding-left: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.pl-7xl {
  padding-left: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.pl-grid-gutter {
  padding-left: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.pl-gutter-inline {
  padding-left: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.pl-l {
  padding-left: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.pl-m {
  padding-left: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.pl-s {
  padding-left: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.pl-xl {
  padding-left: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.pl-xs {
  padding-left: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.pl-zero {
  padding-left: 0rem;
}

.pr-2xl {
  padding-right: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.pr-3xl {
  padding-right: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.pr-3xl-7xl {
  padding-right: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.pr-4xl {
  padding-right: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.pr-4xl-6xl {
  padding-right: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.pr-5xl {
  padding-right: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.pr-6xl {
  padding-right: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.pr-7xl {
  padding-right: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.pr-grid-gutter {
  padding-right: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.pr-gutter-inline {
  padding-right: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.pr-l {
  padding-right: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.pr-m {
  padding-right: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.pr-s {
  padding-right: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.pr-xl {
  padding-right: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.pr-xs {
  padding-right: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.pr-zero {
  padding-right: 0rem;
}

.pt-2xl {
  padding-top: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.pt-3xl {
  padding-top: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.pt-3xl-7xl {
  padding-top: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.pt-4xl {
  padding-top: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.pt-4xl-6xl {
  padding-top: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.pt-5xl {
  padding-top: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.pt-6xl {
  padding-top: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.pt-7xl {
  padding-top: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.pt-grid-gutter {
  padding-top: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.pt-gutter-inline {
  padding-top: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.pt-l {
  padding-top: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.pt-m {
  padding-top: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.pt-s {
  padding-top: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.pt-xl {
  padding-top: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.pt-xs {
  padding-top: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.pt-zero {
  padding-top: 0rem;
}

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

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

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

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

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

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

.font-base {
  font-family: GeneralSans, Inter, Segoe UI, Roboto, Helvetica Neue, Arial, sans-serif;
}

.font-mono {
  font-family: SF Mono, Consolas, Liberation Mono, Menlo, Monaco, Courier New, monospace;
}

.text-body {
  font-size: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
}

.text-body-fixed {
  font-size: 1rem;
}

.text-body-l {
  font-size: clamp(1rem, 0.92rem + 0.31vw, 1.25rem);
}

.text-body-l-xl {
  font-size: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.text-body-nav {
  font-size: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
}

.text-body-s {
  font-size: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
}

.text-body-xl {
  font-size: clamp(1.25rem, 1.17rem + 0.31vw, 1.5rem);
}

.text-body-xs {
  font-size: 0.75rem;
}

.text-button {
  font-size: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
}

.text-button-s {
  font-size: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
}

.text-heading-2xl {
  font-size: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.text-heading-3xl {
  font-size: clamp(1.75rem, 1.37rem + 1.55vw, 3rem);
}

.text-heading-4xl {
  font-size: clamp(2rem, 1.55rem + 1.86vw, 3.5rem);
}

.text-heading-4xl-5xl {
  font-size: clamp(2rem, 1.24rem + 3.10vw, 4.5rem);
}

.text-heading-5xl {
  font-size: clamp(3rem, 2.55rem + 1.86vw, 4.5rem);
}

.text-heading-l {
  font-size: clamp(1.25rem, 1.17rem + 0.31vw, 1.5rem);
}

.text-heading-m {
  font-size: clamp(1rem, 0.92rem + 0.31vw, 1.25rem);
}

.text-heading-m-fixed {
  font-size: 1.25rem;
}

.text-heading-s {
  font-size: clamp(0.875rem, 0.84rem + 0.16vw, 1rem);
}

.text-heading-xl {
  font-size: clamp(1.5rem, 1.42rem + 0.31vw, 1.75rem);
}

.text-heading-xs {
  font-size: clamp(0.75rem, 0.71rem + 0.16vw, 0.875rem);
}

.leading-fine {
  line-height: 1.16;
}

.leading-flat {
  line-height: 1;
}

.leading-loose {
  line-height: 1.4375;
}

.leading-standard {
  line-height: 1.33;
}

.leading-tight {
  line-height: 0.95;
}

.text-accent {
  color: #16F78E;
}

.text-dark {
  color: #001231;
}

.text-error {
  color: #D8443B;
}

.text-light {
  color: #FDFDFD;
}

.text-lilac {
  color: #EBBEDC;
}

.text-neutral-10 {
  color: #ECF0F8;
}

.text-neutral-20 {
  color: #DFDDEC;
}

.text-neutral-40 {
  color: #8093B7;
}

.text-neutral-60 {
  color: #183465;
}

.text-neutral-80 {
  color: #001946;
}

.text-primary {
  color: #16F78E;
}

.text-sky {
  color: #00AAAA;
}

.text-success {
  color: #3BD87A;
}

.flow-space-zero > * {
  --flow-space: 0rem;
}

.flow-space-xs > * {
  --flow-space: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.flow-space-s > * {
  --flow-space: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.flow-space-m > * {
  --flow-space: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.flow-space-l > * {
  --flow-space: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.flow-space-xl > * {
  --flow-space: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.flow-space-2xl > * {
  --flow-space: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.flow-space-3xl > * {
  --flow-space: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.flow-space-4xl > * {
  --flow-space: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.flow-space-5xl > * {
  --flow-space: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.flow-space-6xl > * {
  --flow-space: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.flow-space-7xl > * {
  --flow-space: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.flow-space-gutter-inline > * {
  --flow-space: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.flow-space-grid-gutter > * {
  --flow-space: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.flow-space-3xl-7xl > * {
  --flow-space: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.flow-space-4xl-6xl > * {
  --flow-space: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.region-space-zero {
  --region-space: 0rem;
}

.region-space-xs {
  --region-space: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.region-space-s {
  --region-space: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.region-space-m {
  --region-space: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.region-space-l {
  --region-space: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.region-space-xl {
  --region-space: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.region-space-2xl {
  --region-space: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.region-space-3xl {
  --region-space: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.region-space-4xl {
  --region-space: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.region-space-5xl {
  --region-space: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.region-space-6xl {
  --region-space: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.region-space-7xl {
  --region-space: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.region-space-gutter-inline {
  --region-space: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.region-space-grid-gutter {
  --region-space: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.region-space-3xl-7xl {
  --region-space: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.region-space-4xl-6xl {
  --region-space: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.gutter-zero {
  --gutter: 0rem;
}

.gutter-xs {
  --gutter: clamp(0.0625rem, 0.04rem + 0.08vw, 0.125rem);
}

.gutter-s {
  --gutter: clamp(0.125rem, 0.09rem + 0.16vw, 0.25rem);
}

.gutter-m {
  --gutter: clamp(0.25rem, 0.17rem + 0.31vw, 0.5rem);
}

.gutter-l {
  --gutter: clamp(0.5rem, 0.35rem + 0.62vw, 1rem);
}

.gutter-xl {
  --gutter: clamp(1rem, 0.85rem + 0.62vw, 1.5rem);
}

.gutter-2xl {
  --gutter: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
}

.gutter-3xl {
  --gutter: clamp(2rem, 1.70rem + 1.24vw, 3rem);
}

.gutter-4xl {
  --gutter: clamp(3rem, 2.85rem + 0.62vw, 3.5rem);
}

.gutter-5xl {
  --gutter: clamp(3.5rem, 3.20rem + 1.24vw, 4.5rem);
}

.gutter-6xl {
  --gutter: clamp(4.5rem, 4.05rem + 1.86vw, 6rem);
}

.gutter-7xl {
  --gutter: clamp(6rem, 5.40rem + 2.48vw, 8rem);
}

.gutter-gutter-inline {
  --gutter: clamp(1.0625rem, 0.42rem + 2.64vw, 3.1875rem);
}

.gutter-grid-gutter {
  --gutter: clamp(1.25rem, 1.06rem + 0.78vw, 1.875rem);
}

.gutter-3xl-7xl {
  --gutter: clamp(2rem, 0.19rem + 7.44vw, 8rem);
}

.gutter-4xl-6xl {
  --gutter: clamp(3rem, 2.09rem + 3.72vw, 6rem);
}

.text-regular {
  font-weight: 400;
}

.text-medium {
  font-weight: 500;
}

.text-semibold {
  font-weight: 600;
}

.col-1-13 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-1-13 {
    grid-column: 1 / -1;
  }
}

.col-2-12 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-2-12 {
    grid-column: 2 / 12;
  }
}

.col-3-11 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-3-11 {
    grid-column: 3 / 11;
  }
}

.col-4-10 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-4-10 {
    grid-column: 4 / 10;
  }
}

.col-1-8 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-1-8 {
    grid-column: 1 / 8;
  }
}

.col-1-6 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-1-6 {
    grid-column: 1 / 6;
  }
}

.col-2-7 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-2-7 {
    grid-column: 2 / 7;
  }
}

.col-8-12 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-8-12 {
    grid-column: 8 / 12;
  }
}

.col-1-5 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-1-5 {
    grid-column: 1 / 5;
  }
}

.col-8-13 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-8-13 {
    grid-column: 8 / -1;
  }
}

.col-5-13 {
  grid-column: 1 / -1;
}

@container layout-grid (min-width: 767px) {
  .col-5-13 {
    grid-column: 5 / -1;
  }
}

@media not all and (min-width: 767px) {
  .max-md\:mt-2xl {
    margin-top: clamp(1.5rem, 1.35rem + 0.62vw, 2rem);
  }
}

@media (min-width: 767px) {
  .md\:text-center {
    text-align: center;
  }
}