/* 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: 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: 'Montserrat';

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

  font-weight: 400;

  font-style: normal;

  font-display: swap;
}

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

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

  font-weight: 500;

  font-style: normal;

  font-display: swap;
}

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

  src: url('../../assets/fonts/AttilaSansClassic-Bold.woff2') format('woff2');

  font-weight: 700;

  font-style: normal;

  font-display: swap;
}

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

  font-display: block;

  src: url(data:font/woff2;charset=utf-8;base64,d09GMgABAAAAAAUUAAsAAAAACwQAAATEAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHIFqBmAAhWoKhDCDagE2AiQDZAs0AAQgBYQWB4E0G8UJUVRR7pJ9gW3DHsXcjvfuYAIBAB7gwT4rAAAWFQHABN9DCJ7n98Od+953nybVuLi8JGZoJZpmQiQRorQMm0tNuiYvEiCZMLB7cdeW/Y6HfHrFf6GleBJQ/uG5V+/LWJgtGIGcAAUk6ZhULGONitUPUqjhlAvkM7ZyNVZ2SG5VD0ETIE6SzpA1tcX45oUpXcFVqaZOArEF4AEr4PhNLxMKCNU0xgO5eTkV2VyKqBbuch8EeGYsU+fL7Wvv4PMmuXfE4M8VVOXy+eZUb0tzMCZuKhziO0Nkg/FJcwxaovgcEXB5xVcTqUxMeEOxQChSJTU3EXPl2y+1aKFgX4WBTKjkkCtDzTVUjs7UGLZEvlIund8WKzQM/0hjQn2PvsD77Pfl12zKUMyx+RdafT4zvT+Tg+B+sDU5tnnuXbB+AEygwcT1csnPdOAXXSQmaN7Q3Q2vQSahKZMOeQUT3SAA6BJaJOpAD35AZAHRb2itEeCzFeorKb/GhYlAo7qGGztiJY9Q9FVaQGRmvph9suPZ8BBGb51AcNy7h/EvrKDSACAnpBowGcEHh7DBMQpwghqcIgRniMA5UnCBDFwiATcIwC0acIcK3MMFD8jBEzjgGWLwAiV4yfXwHz2ZMUEPjA49MAb0wJihB0aBQjO0AOa2WcwX8IdvWpBMEsxX04jkviKF1+8k20+v1r2Zw97TxzdnX/Ggd319dviYZghDdTPQc7TXCYTHQdC3tjWHs6lOZLKDIUBLuVrZuHIHE/sJDOrLy5izwmgRgmw0tESi7gOJ163yd62LHptOQO3CCXMIDXMS8NnriPPIi0iKWbZslo1m9aRyw41YHX0VasLkzjWshg0VlWy5UOubQZMNI8M7v9rIwMTkMYibkbrP0OAa0mQlI6PbQMh8+eVlgTpWLLi8/HnlRfD7u4BfLFsAGdtxuAe5qwp6fAVV+HAzJk+WC5bx25xxT2HOLLI3DtLY0kBcPN/1Nd8g7eDKqpwcHA18LAhnDwfxcfxX1/zYD3pMFdUmpYnK9oVhoe4VEjoek1dU/CLN4pjf7rYetaU76Zac3J6cEuKUNXY8fVJ81BBtXFIsNqb1uBcD7coK//UV/yIOXRAkBNpA78JdQiCgNzKtrLQ9BAKaBdYEAboDjgNQ6suv4e6+76u5mHymssISf0NG45eJKcrJSFim4RVLAocCW7Vd3d8E6b+n76TqyZFP9xL19pUbFBhkL6bDZy+mgBeMgq2HEn+PyyL/s1JQbE5l0B8qJcgGvYbJNwCLYwyecXMH+3K7VsmkmUg8CCiRV9ASH8kG/QdMlZ+wJH7Ds+Z/Gd9QY2+asg3b5BndIir21BnzHbn1YZhMzbRvcoEZWQka+FhCW91UxIJlSnA+cTGMkaAwzVHLsBEps9H02dAeQ02p52kks8lfi2fIWYgUph6bue8QayU5lg5mTZlhkC8MmSWsCGROcmQJPFU5U88ISxudYSQBK+t8KAYBAn/Ttckc0sTQxYpYMTNNI51xDcP9m9LzOyn4Nz16m8IJMqJQaXQGk8XmcEvLyisqq6praut4ty+mbhDRym5ZxN41sq2ICJU9/Yp1hzww1OWNdPNRaPV6L9dXcVTXIJwes0k+V1NJV8uZkh4AAA==) format("woff2"),
url(data:application/font-woff;charset=utf-8;base64,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) 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-chevron-down: '\f104';
  --icon-mailto: '\f105';
  --icon-tel: '\f106';
}

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

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

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

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

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

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

:root {
  --color-dark: #4A3041;
  --color-primary: #4A3041;
  --color-aubergine: #4A3041;
  --color-aubergine-shade: #F8F2F6;
  --color-grey: #6B7677;
  --color-grey-shade: #CDD2D2;
  --color-focus: #4A3041;
  --color-light: #FFFFFF;
  --color-accent: #FEEE65;
  --color-design: #F9F3B4;
  --color-fashion: #F6D0C4;
  --color-management: #BEE2D7;
  --color-textil: #99B9D4;
  --space-zero: 0rem;
  --space-3xs: clamp(0.125rem, 0.07rem + 0.20vw, 0.25rem);
  --space-2xs: clamp(0.25rem, 0.14rem + 0.40vw, 0.5rem);
  --space-xs: clamp(0.5rem, 0.29rem + 0.81vw, 1rem);
  --space-s: clamp(1rem, 0.79rem + 0.81vw, 1.5rem);
  --space-m: clamp(1.5rem, 1.29rem + 0.81vw, 2rem);
  --space-l: clamp(2rem, 1.79rem + 0.81vw, 2.5rem);
  --space-xl: clamp(2.5rem, 2.29rem + 0.81vw, 3rem);
  --space-2xl: clamp(3rem, 2.79rem + 0.81vw, 3.5rem);
  --space-3xl: clamp(3.5rem, 2.86rem + 2.43vw, 5rem);
  --space-4xl: clamp(5rem, 2.87rem + 8.10vw, 10rem);
  --space-5xl: clamp(10rem, 8.94rem + 4.05vw, 12.5rem);
  --space-3xs-2xs: clamp(0.125rem, -0.03rem + 0.61vw, 0.5rem);
  --space-2xs-xs: clamp(0.25rem, -0.07rem + 1.21vw, 1rem);
  --space-xs-s: clamp(0.5rem, 0.07rem + 1.62vw, 1.5rem);
  --space-s-m: clamp(1rem, 0.57rem + 1.62vw, 2rem);
  --space-m-l: clamp(1.5rem, 1.07rem + 1.62vw, 2.5rem);
  --space-l-xl: clamp(2rem, 1.57rem + 1.62vw, 3rem);
  --space-xl-2xl: clamp(2.5rem, 2.07rem + 1.62vw, 3.5rem);
  --space-2xl-3xl: clamp(3rem, 2.15rem + 3.24vw, 5rem);
  --space-3xl-4xl: clamp(3.5rem, 0.74rem + 10.53vw, 10rem);
  --space-4xl-5xl: clamp(5rem, 1.81rem + 12.15vw, 12.5rem);
  --space-s-l: clamp(1rem, 0.36rem + 2.43vw, 2.5rem);
  --space-s-xl: clamp(1rem, 0.15rem + 3.24vw, 3rem);
  --space-l-2xl: clamp(2rem, 1.36rem + 2.43vw, 3.5rem);
  --space-s-2xl: clamp(1rem, -0.06rem + 4.05vw, 3.5rem);
  --space-s-3xl: clamp(1rem, -0.70rem + 6.48vw, 5rem);
  --space-l-3xl: clamp(2rem, 0.72rem + 4.86vw, 5rem);
  --space-page-teaser: clamp(1rem, -2.16rem + 12.04vw, 8.4375rem);
  --space-8-48: clamp(0.5rem, -0.56rem + 4.05vw, 3rem);
  --space-32-96: clamp(2rem, 0.30rem + 6.48vw, 6rem);
  --space-32-128: clamp(2rem, -0.55rem + 9.72vw, 8rem);
  --space-32-160: clamp(2rem, -1.40rem + 12.96vw, 10rem);
  --space-32-200: clamp(2rem, -2.46rem + 17.00vw, 12.5rem);
  --space-32-240: clamp(2rem, -3.53rem + 21.05vw, 15rem);
  --size-step-00: 0.875rem;
  --size-step-0: clamp(1.125rem, 1.07rem + 0.20vw, 1.25rem);
  --size-step-1: clamp(1.200625rem, 1.11rem + 0.33vw, 1.40625rem);
  --size-step-2: clamp(1.280625rem, 1.15rem + 0.49vw, 1.581875rem);
  --size-step-3: clamp(1.366875rem, 1.19rem + 0.67vw, 1.78rem);
  --size-step-4: clamp(1.458125rem, 1.23rem + 0.88vw, 2.0025rem);
  --size-step-5: clamp(1.555625rem, 1.26rem + 1.13vw, 2.2525rem);
  --size-step-6: clamp(1.66rem, 1.29rem + 1.42vw, 2.534375rem);
  --size-step-7: clamp(1.77125rem, 1.31rem + 1.75vw, 2.850625rem);
  --size-step-8: clamp(1.89rem, 1.33rem + 2.13vw, 3.2075rem);
  --size-step-9: clamp(2rem, 1.32rem + 2.60vw, 3.608125rem);
  --size-step-0-4: clamp(1.125rem, 0.75rem + 1.42vw, 2rem);
  --size-anchor-nav: clamp(0.9375rem, 0.86rem + 0.30vw, 1.125rem);
  --leading-flat: 1;
  --leading-fine: 1.08;
  --leading-medium: 1.2;
  --leading-relaxed: 1.25;
  --leading-loose: 1.3;
  --font-base: Montserrat,Inter,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;
  --font-headings: AttilaSansClassic,Arial Black,Impact,Gadget,sans-serif;
  --font-mono: DM Mono,monospace;
  --font-regular: 400;
  --font-medium: 500;
  --font-bold: 700;
  --layout-sm: 420px;
  --layout-md: 1028px;
  --layout-lg: 1408px;
  --layout-xl: 1894px;
  --gutter: var(--space-s-m);
  /* content max width without gutter */
  --wrapper-max-width: var(--layout-xl);
  --transition-fast: 150ms ease-out;
  --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-aubergine);
  --stroke-solid: 1px solid var(--color-aubergine);
  --radius-s: 0.2rem;
  --radius-m: 0.75rem;
  --radius-l: 2.5rem;
  --uppercase-kerning: 0.04ch;
  --focus-color: var(--color-focus);
  --focus-offset: 0.2em;
}

/* 
  Global styles 

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

body {
  background: var(--color-light);
  color: var(--color-dark);
  font-size: var(--size-step-1);
  font-family: var(--font-base);
  line-height: var(--leading-loose);
  font-size-adjust: from-font;
  margin: 0;
  overflow-x: clip;
  -webkit-font-smoothing: subpixel-antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

body:has(#wpadminbar) {
  margin-bottom: var(--wpadminbar-height, 32px);
}

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

h1 {
  font-size: var(--size-step-9);
  max-width: 20ch;
}

h2 {
  font-size: var(--size-step-9);
  max-width: 35ch;
}

h3 {
  font-size: var(--size-step-6);
  max-width: 35ch;
}

:is(h4, h5, h6) {
  font-size: var(--size-step-4);
  font-family: var(--font-headings);
}

strong {
  font-weight: var(--font-bold);
}

j small {
  font-size: var(--size-step-00);
}

ins {
  text-decoration: none;
  background: var(--aubergine-shade);
  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-bold);
}

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-decoration: underline;
  text-underline-offset: 0.3ex;
}

a[href^="tel:"],
a[href^="mailto:"] {
  text-decoration: none !important;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: inline-flex;
  gap: var(--space-2xs);
}

a[href^="tel:"]:hover,
a[href^="mailto:"]:hover {
  color: var(--color-accent) !important;
  & span {
    text-decoration: underline;
    text-underline-offset: 0.3ex;
  }
}

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

: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;
  }
}

::-moz-selection {
  color: var(--color-primary);
  background: var(--color-accent);
}

::selection {
  color: var(--color-primary);
  background: var(--color-accent);
}

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-accent);
  --focus-offset: 0em;
}

:is(input:not([type='checkbox'], [type='radio'], [type='color']), select, textarea) {
  padding: 0.5em 0.8em;
  border-radius: initial;
  border: var(--stroke-solid);
  background: var(--color-light);
  color: var(--color-dark);
  width: 100%;
  &::-moz-placeholder {
    color: var(--color-grey);
  }
  &::placeholder {
    color: var(--color-grey);
  }
}

label {
  line-height: var(--leading-fine);
  font-weight: var(--font-regular);
  font-size: var(--size-step-00);
}

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-regular);
}

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-grey-shade);
}

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: pointer;
}

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

address {
  font-style: normal;
  line-height: var(--leading-loose);
  font-size: var(--size-step-0);
}

/* 
  Global editor styles 
  
  Styles that apply to the WordPress block editor only
*/

svg:not([class]):not([role]) {
  width: unset;
  height: unset;
}

/* 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-s-l));
}

/* 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);
}

.reel {
  --color-scrollbar-thumb: var(--color-primary);
  --color-scrollbar-track: var(--color-light);
  --scrollbar-height: .2rem;
  --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:not([data-direction='rtl'])> :first-child {
  flex-basis: var(--sidebar-target-width, 20rem);
  flex-grow: 1;
}

.sidebar:not([data-direction='rtl'])> :last-child {
  flex-basis: 0;
  flex-grow: 999;
  min-width: var(--sidebar-content-min-width, 50%);
}

.sidebar[data-reversed="true"] {
  flex-direction: row-reverse;
}

.sidebar[data-direction='rtl']> :last-child {
  flex-basis: var(--sidebar-target-width, 20rem);
  flex-grow: 1;
}

.sidebar[data-direction='rtl']> :first-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 {
  box-sizing: content-box;
  margin-inline: auto;
  max-width: var(--wrapper-max-width, 1410px);
  padding-inline-start: var(--gutter);
  padding-inline-end: var(--gutter);
  position: relative;
}

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

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

.wp-site-blocks {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  main {
    flex-grow: 1;
  }
}

/* 
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;
}

:is(.button) {
  --focus-offset: 0em;
}

.wp-block-pp-button.button,
.button {
  --button-bg: var(--color-aubergine-shade);
  --button-text: var(--color-dark);
  --button-x-padding: 1rem;
  --button-y-padding: 1rem;
  --button-gutter: 0ch;
  --focus-color: var(--color-primary);
  /* padding is applied to inner span, 
  reset to 0 due to user-agent stylesheet on button-tag */
  padding: 0px;
  transition: background-color 0.3s ease, transform 0.1s ease;
  font-family: var(--font-headings);
  display: inline-flex;
  gap: var(--button-gutter);
  align-items: stretch;
  line-height: var(--leading-flat);
  position: relative;
  border: none;
  cursor: pointer;
  background: var(--button-bg);
  color: var(--button-text);
  letter-spacing: var(--uppercase-kerning);
  text-decoration: none;
  font-weight: var(--font-bold);
  border: 1px solid var(--color-aubergine);
  font-size: clamp(1.125rem, 4.8276vw + -1.7716rem, 2rem);
}

.button>span::-moz-selection, .wp-block-pp-button.button>span::-moz-selection {
  background: var(--color-fashion);
}

.button>span::selection,
.wp-block-pp-button.button>span::selection {
  background: var(--color-fashion);
}

.wp-block-pp-button.button>span.button__text,
.button>span.button__text {
  font-size: inherit;
  flex-grow: 0;
  display: inline-block;
  padding: var(--button-y-padding) var(--button-x-padding);
  text-box-trim: trim-both;
  text-box-edge: cap alphabetic;
}

.wp-block-pp-button.button>.button__icon,
.button>.button__icon {
  position: relative;
  flex-basis: 3.75rem;
  width: 3.75rem;
  flex-grow: 0;
  flex-shrink: 0;
  display: inline-block;
  font-size: inherit;
  border-inline-start: 1px solid var(--color-aubergine);
  svg {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 1.04rem;
    height: auto;
  }
}

.wp-block-pp-button.button[data-variant="dark"],
.button[data-variant="dark"] {
  --button-bg: var(--color-light);
}

.wp-block-pp-button.button:hover,
.wp-core-ui .button:hover,
.button:hover {
  background-color: var(--color-accent);
}

.wp-block-pp-button.button:active,
.wp-core-ui .button:active,
.button:active {
  background-color: var(--color-accent);
  transform: scale(99%);
}

.accordion__panel>.mauticform_wrapper {
  max-width: 600px;
  margin-left: 0;
  margin-right: auto;
}

.accordion__panel label.mauticform-label {
  font-size: var(--size-step-00);
}

.accordion__panel h3.mauticform-label {
  font-weight: var(--font-regular);
  font-family: var(--font-base);
  line-height: var(--leading-loose);
}

.accordion__panel .mauticform-row:has(h3) {
  margin: 0;
  padding: 0;
}

.accordion__panel [for$="uhrzeit"],
.accordion__panel [for$="datum"] {
  &::before {
    padding-inline-end: .5ch;
  }
}

.accordion__panel [for$="datum"]::before {
  content: "🗓️";
}

.accordion__panel [for$="uhrzeit"]::before {
  content: "🕗";
}

.accordion__panel button[type="submit"] {
  --button-bg: var(--color-aubergine-shade);
  --button-text: var(--color-dark);
  --button-gutter: 0ch;
  --focus-color: var(--color-primary);
  border-radius: 0px !important;
  font-family: var(--font-headings);
  display: inline-flex;
  gap: var(--button-gutter);
  align-items: stretch;
  line-height: var(--leading-flat);
  position: relative;
  border: none;
  cursor: pointer;
  background: var(--button-bg);
  color: var(--button-text) !important;
  letter-spacing: var(--uppercase-kerning);
  text-decoration: none;
  font-weight: var(--font-bold);
  border: 1px solid var(--color-aubergine) !important;
  font-size: var(--size-step-0-4);
  padding: 1.25rem 1rem .75rem 1rem !important;
}

.accordion__panel button:hover {
  background-color: var(--color-accent) !important;
}

.accordion__panel button:active {
  background-color: var(--color-accent) !important;
  transform: scale(99%);
}

.wp-block-gallery {
  display: grid !important;
  padding: 0 !important;
  margin: 0 !important;
  margin-block: var(--space-s-l) !important;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
  gap: var(--space-s-l) !important;
}

.wp-block-gallery .wp-block-image {
  width: unset !important;
}

ul.wp-block-list {
  margin-block: 0;
  padding-inline-start: 2.5ch;
  & li+li {
    margin-block-start: .25em;
  }
  &:last-child {
    margin-block-end: var(--space-xs);
  }
}

*+ul.wp-block-list {
  margin-block-start: 1em;
}

.wp-block-navigation>.wp-block-navigation__container .wp-block-navigation-item__content {
  font-size: var(--size-step-00);
  font-weight: var(--font-regular);
}

.wp-block-navigation>.wp-block-navigation__container .wp-block-navigation-item {
  padding-block: var(--space-3xs);
  padding-inline: var(--space-xs);
  line-height: var(--leading-loose);
  &:first-child {
    padding-inline-start: 0;
  }
}

.wp-block-navigation>.wp-block-navigation__container .wp-block-navigation-item:hover a {
  text-decoration: underline;
  text-decoration-color: var(--color-light);
}

.wp-block-navigation>.wp-block-navigation__container .wp-block-navigation-item a:focus-visible {
  outline-color: var(--color-light);
}

.wp-block-navigation .rich-text {
  color: var(--color-light);
}

.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: 1028px) {
  .prose :is(h1, h2, h3) {
    overflow-wrap: unset;
    hyphens: unset;
  }
}

ul.wp-block-social-links {
  gap: .5rem;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
}

.wp-block-social-links li {
  & svg[role='img'] {
    height: var(--space-l-xl);
    width: var(--space-l-xl);
    & circle {
      color: var(--color-light);
    }
    & path {
      fill: var(--color-aubergine);
    }
  }
}

.wp-block-social-links li a,
.wp-block-social-links li button {
  border-radius: 100%;
  overflow: clip;
}

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

/* 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;
}

/**
 * WordPress Spacing Preset Overrides
 * Maps WordPress core spacing presets to custom design tokens
 * 
 * WP Default Scale → Custom Spacing Scale
 * --wp--preset--spacing--20 (10px)  → --space-2xs (4-8px)
 * --wp--preset--spacing--30 (20px)  → --space-s (16-24px)
 * --wp--preset--spacing--40 (30px)  → --space-m (24-32px)
 * --wp--preset--spacing--50 (40px)  → --space-l-xl (32-48px)
 * --wp--preset--spacing--60 (60px)  → --space-2xl-3xl (48-80px)
 * --wp--preset--spacing--70 (80px)  → --space-3xl (56-80px)
 * --wp--preset--spacing--80 (100px) → --space-4xl (80-160px)
 */

:root {
  --wp--preset--spacing--20: var(--space-2xs);
  --wp--preset--spacing--30: var(--space-s);
  --wp--preset--spacing--40: var(--space-m);
  --wp--preset--spacing--50: var(--space-l-xl);
  --wp--preset--spacing--60: var(--space-2xl-3xl);
  --wp--preset--spacing--70: var(--space-3xl);
  --wp--preset--spacing--80: var(--space-4xl);
}

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);
}

:root {
  --header-top: calc(2 * var(--space-s) + 2 * var(--space-2xs) + 10px);
}

.mb-header {
  margin-block: var(--header-top);
}

header {
  position: fixed;
  top: var(--header-top);
  left: max(0px, (100% - var(--wrapper-max-width)) / 2);
  /* 64px to 100px */
  --header-size: clamp(4rem, 3.0435rem + 3.6437vw, 6.25rem);
  height: var(--header-size);
  z-index: 10;
  aspect-ratio: 1;
  overflow: clip;
  display: block;
}

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;
}

.mt-2xl {
  margin-top: clamp(3rem, 2.79rem + 0.81vw, 3.5rem);
}

.mt-2xl-3xl {
  margin-top: clamp(3rem, 2.15rem + 3.24vw, 5rem);
}

.mt-2xs {
  margin-top: clamp(0.25rem, 0.14rem + 0.40vw, 0.5rem);
}

.mt-2xs-xs {
  margin-top: clamp(0.25rem, -0.07rem + 1.21vw, 1rem);
}

.mt-32-128 {
  margin-top: clamp(2rem, -0.55rem + 9.72vw, 8rem);
}

.mt-32-160 {
  margin-top: clamp(2rem, -1.40rem + 12.96vw, 10rem);
}

.mt-32-200 {
  margin-top: clamp(2rem, -2.46rem + 17.00vw, 12.5rem);
}

.mt-32-240 {
  margin-top: clamp(2rem, -3.53rem + 21.05vw, 15rem);
}

.mt-32-96 {
  margin-top: clamp(2rem, 0.30rem + 6.48vw, 6rem);
}

.mt-3xl {
  margin-top: clamp(3.5rem, 2.86rem + 2.43vw, 5rem);
}

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

.mt-3xs {
  margin-top: clamp(0.125rem, 0.07rem + 0.20vw, 0.25rem);
}

.mt-3xs-2xs {
  margin-top: clamp(0.125rem, -0.03rem + 0.61vw, 0.5rem);
}

.mt-4xl {
  margin-top: clamp(5rem, 2.87rem + 8.10vw, 10rem);
}

.mt-4xl-5xl {
  margin-top: clamp(5rem, 1.81rem + 12.15vw, 12.5rem);
}

.mt-5xl {
  margin-top: clamp(10rem, 8.94rem + 4.05vw, 12.5rem);
}

.mt-8-48 {
  margin-top: clamp(0.5rem, -0.56rem + 4.05vw, 3rem);
}

.mt-l {
  margin-top: clamp(2rem, 1.79rem + 0.81vw, 2.5rem);
}

.mt-l-2xl {
  margin-top: clamp(2rem, 1.36rem + 2.43vw, 3.5rem);
}

.mt-l-3xl {
  margin-top: clamp(2rem, 0.72rem + 4.86vw, 5rem);
}

.mt-l-xl {
  margin-top: clamp(2rem, 1.57rem + 1.62vw, 3rem);
}

.mt-m {
  margin-top: clamp(1.5rem, 1.29rem + 0.81vw, 2rem);
}

.mt-m-l {
  margin-top: clamp(1.5rem, 1.07rem + 1.62vw, 2.5rem);
}

.mt-page-teaser {
  margin-top: clamp(1rem, -2.16rem + 12.04vw, 8.4375rem);
}

.mt-s {
  margin-top: clamp(1rem, 0.79rem + 0.81vw, 1.5rem);
}

.mt-s-2xl {
  margin-top: clamp(1rem, -0.06rem + 4.05vw, 3.5rem);
}

.mt-s-3xl {
  margin-top: clamp(1rem, -0.70rem + 6.48vw, 5rem);
}

.mt-s-l {
  margin-top: clamp(1rem, 0.36rem + 2.43vw, 2.5rem);
}

.mt-s-m {
  margin-top: clamp(1rem, 0.57rem + 1.62vw, 2rem);
}

.mt-s-xl {
  margin-top: clamp(1rem, 0.15rem + 3.24vw, 3rem);
}

.mt-xl {
  margin-top: clamp(2.5rem, 2.29rem + 0.81vw, 3rem);
}

.mt-xl-2xl {
  margin-top: clamp(2.5rem, 2.07rem + 1.62vw, 3.5rem);
}

.mt-xs {
  margin-top: clamp(0.5rem, 0.29rem + 0.81vw, 1rem);
}

.mt-xs-s {
  margin-top: clamp(0.5rem, 0.07rem + 1.62vw, 1.5rem);
}

.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: #FEEE65;
}

.bg-aubergine {
  background-color: #4A3041;
}

.bg-aubergine-shade {
  background-color: #F8F2F6;
}

.bg-dark {
  background-color: #4A3041;
}

.bg-design {
  background-color: #F9F3B4;
}

.bg-fashion {
  background-color: #F6D0C4;
}

.bg-focus {
  background-color: #4A3041;
}

.bg-grey {
  background-color: #6B7677;
}

.bg-grey-shade {
  background-color: #CDD2D2;
}

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

.bg-management {
  background-color: #BEE2D7;
}

.bg-primary {
  background-color: #4A3041;
}

.bg-textil {
  background-color: #99B9D4;
}

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

.font-headings {
  font-family: AttilaSansClassic, Arial Black, Impact, Gadget, sans-serif;
}

.font-mono {
  font-family: DM Mono, monospace;
}

.text-anchor-nav {
  font-size: clamp(0.9375rem, 0.86rem + 0.30vw, 1.125rem);
}

.text-step-0 {
  font-size: clamp(1.125rem, 1.07rem + 0.20vw, 1.25rem);
}

.text-step-0-4 {
  font-size: clamp(1.125rem, 0.75rem + 1.42vw, 2rem);
}

.text-step-00 {
  font-size: 0.875rem;
}

.text-step-1 {
  font-size: clamp(1.200625rem, 1.11rem + 0.33vw, 1.40625rem);
}

.text-step-2 {
  font-size: clamp(1.280625rem, 1.15rem + 0.49vw, 1.581875rem);
}

.text-step-3 {
  font-size: clamp(1.366875rem, 1.19rem + 0.67vw, 1.78rem);
}

.text-step-4 {
  font-size: clamp(1.458125rem, 1.23rem + 0.88vw, 2.0025rem);
}

.text-step-5 {
  font-size: clamp(1.555625rem, 1.26rem + 1.13vw, 2.2525rem);
}

.text-step-6 {
  font-size: clamp(1.66rem, 1.29rem + 1.42vw, 2.534375rem);
}

.text-step-7 {
  font-size: clamp(1.77125rem, 1.31rem + 1.75vw, 2.850625rem);
}

.text-step-8 {
  font-size: clamp(1.89rem, 1.33rem + 2.13vw, 3.2075rem);
}

.text-step-9 {
  font-size: clamp(2rem, 1.32rem + 2.60vw, 3.608125rem);
}

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

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

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

.leading-medium {
  line-height: 1.2;
}

.leading-relaxed {
  line-height: 1.25;
}

.text-accent {
  color: #FEEE65;
}

.text-aubergine {
  color: #4A3041;
}

.text-aubergine-shade {
  color: #F8F2F6;
}

.text-dark {
  color: #4A3041;
}

.text-design {
  color: #F9F3B4;
}

.text-fashion {
  color: #F6D0C4;
}

.text-focus {
  color: #4A3041;
}

.text-grey {
  color: #6B7677;
}

.text-grey-shade {
  color: #CDD2D2;
}

.text-light {
  color: #FFFFFF;
}

.text-management {
  color: #BEE2D7;
}

.text-primary {
  color: #4A3041;
}

.text-textil {
  color: #99B9D4;
}

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

.flow-space-3xs {
  --flow-space: clamp(0.125rem, 0.07rem + 0.20vw, 0.25rem);
}

.flow-space-2xs {
  --flow-space: clamp(0.25rem, 0.14rem + 0.40vw, 0.5rem);
}

.flow-space-xs {
  --flow-space: clamp(0.5rem, 0.29rem + 0.81vw, 1rem);
}

.flow-space-s {
  --flow-space: clamp(1rem, 0.79rem + 0.81vw, 1.5rem);
}

.flow-space-m {
  --flow-space: clamp(1.5rem, 1.29rem + 0.81vw, 2rem);
}

.flow-space-l {
  --flow-space: clamp(2rem, 1.79rem + 0.81vw, 2.5rem);
}

.flow-space-xl {
  --flow-space: clamp(2.5rem, 2.29rem + 0.81vw, 3rem);
}

.flow-space-2xl {
  --flow-space: clamp(3rem, 2.79rem + 0.81vw, 3.5rem);
}

.flow-space-3xl {
  --flow-space: clamp(3.5rem, 2.86rem + 2.43vw, 5rem);
}

.flow-space-4xl {
  --flow-space: clamp(5rem, 2.87rem + 8.10vw, 10rem);
}

.flow-space-5xl {
  --flow-space: clamp(10rem, 8.94rem + 4.05vw, 12.5rem);
}

.flow-space-3xs-2xs {
  --flow-space: clamp(0.125rem, -0.03rem + 0.61vw, 0.5rem);
}

.flow-space-2xs-xs {
  --flow-space: clamp(0.25rem, -0.07rem + 1.21vw, 1rem);
}

.flow-space-xs-s {
  --flow-space: clamp(0.5rem, 0.07rem + 1.62vw, 1.5rem);
}

.flow-space-s-m {
  --flow-space: clamp(1rem, 0.57rem + 1.62vw, 2rem);
}

.flow-space-m-l {
  --flow-space: clamp(1.5rem, 1.07rem + 1.62vw, 2.5rem);
}

.flow-space-l-xl {
  --flow-space: clamp(2rem, 1.57rem + 1.62vw, 3rem);
}

.flow-space-xl-2xl {
  --flow-space: clamp(2.5rem, 2.07rem + 1.62vw, 3.5rem);
}

.flow-space-2xl-3xl {
  --flow-space: clamp(3rem, 2.15rem + 3.24vw, 5rem);
}

.flow-space-3xl-4xl {
  --flow-space: clamp(3.5rem, 0.74rem + 10.53vw, 10rem);
}

.flow-space-4xl-5xl {
  --flow-space: clamp(5rem, 1.81rem + 12.15vw, 12.5rem);
}

.flow-space-s-l {
  --flow-space: clamp(1rem, 0.36rem + 2.43vw, 2.5rem);
}

.flow-space-s-xl {
  --flow-space: clamp(1rem, 0.15rem + 3.24vw, 3rem);
}

.flow-space-l-2xl {
  --flow-space: clamp(2rem, 1.36rem + 2.43vw, 3.5rem);
}

.flow-space-s-2xl {
  --flow-space: clamp(1rem, -0.06rem + 4.05vw, 3.5rem);
}

.flow-space-s-3xl {
  --flow-space: clamp(1rem, -0.70rem + 6.48vw, 5rem);
}

.flow-space-l-3xl {
  --flow-space: clamp(2rem, 0.72rem + 4.86vw, 5rem);
}

.flow-space-page-teaser {
  --flow-space: clamp(1rem, -2.16rem + 12.04vw, 8.4375rem);
}

.flow-space-8-48 {
  --flow-space: clamp(0.5rem, -0.56rem + 4.05vw, 3rem);
}

.flow-space-32-96 {
  --flow-space: clamp(2rem, 0.30rem + 6.48vw, 6rem);
}

.flow-space-32-128 {
  --flow-space: clamp(2rem, -0.55rem + 9.72vw, 8rem);
}

.flow-space-32-160 {
  --flow-space: clamp(2rem, -1.40rem + 12.96vw, 10rem);
}

.flow-space-32-200 {
  --flow-space: clamp(2rem, -2.46rem + 17.00vw, 12.5rem);
}

.flow-space-32-240 {
  --flow-space: clamp(2rem, -3.53rem + 21.05vw, 15rem);
}

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

.region-space-3xs {
  --region-space: clamp(0.125rem, 0.07rem + 0.20vw, 0.25rem);
}

.region-space-2xs {
  --region-space: clamp(0.25rem, 0.14rem + 0.40vw, 0.5rem);
}

.region-space-xs {
  --region-space: clamp(0.5rem, 0.29rem + 0.81vw, 1rem);
}

.region-space-s {
  --region-space: clamp(1rem, 0.79rem + 0.81vw, 1.5rem);
}

.region-space-m {
  --region-space: clamp(1.5rem, 1.29rem + 0.81vw, 2rem);
}

.region-space-l {
  --region-space: clamp(2rem, 1.79rem + 0.81vw, 2.5rem);
}

.region-space-xl {
  --region-space: clamp(2.5rem, 2.29rem + 0.81vw, 3rem);
}

.region-space-2xl {
  --region-space: clamp(3rem, 2.79rem + 0.81vw, 3.5rem);
}

.region-space-3xl {
  --region-space: clamp(3.5rem, 2.86rem + 2.43vw, 5rem);
}

.region-space-4xl {
  --region-space: clamp(5rem, 2.87rem + 8.10vw, 10rem);
}

.region-space-5xl {
  --region-space: clamp(10rem, 8.94rem + 4.05vw, 12.5rem);
}

.region-space-3xs-2xs {
  --region-space: clamp(0.125rem, -0.03rem + 0.61vw, 0.5rem);
}

.region-space-2xs-xs {
  --region-space: clamp(0.25rem, -0.07rem + 1.21vw, 1rem);
}

.region-space-xs-s {
  --region-space: clamp(0.5rem, 0.07rem + 1.62vw, 1.5rem);
}

.region-space-s-m {
  --region-space: clamp(1rem, 0.57rem + 1.62vw, 2rem);
}

.region-space-m-l {
  --region-space: clamp(1.5rem, 1.07rem + 1.62vw, 2.5rem);
}

.region-space-l-xl {
  --region-space: clamp(2rem, 1.57rem + 1.62vw, 3rem);
}

.region-space-xl-2xl {
  --region-space: clamp(2.5rem, 2.07rem + 1.62vw, 3.5rem);
}

.region-space-2xl-3xl {
  --region-space: clamp(3rem, 2.15rem + 3.24vw, 5rem);
}

.region-space-3xl-4xl {
  --region-space: clamp(3.5rem, 0.74rem + 10.53vw, 10rem);
}

.region-space-4xl-5xl {
  --region-space: clamp(5rem, 1.81rem + 12.15vw, 12.5rem);
}

.region-space-s-l {
  --region-space: clamp(1rem, 0.36rem + 2.43vw, 2.5rem);
}

.region-space-s-xl {
  --region-space: clamp(1rem, 0.15rem + 3.24vw, 3rem);
}

.region-space-l-2xl {
  --region-space: clamp(2rem, 1.36rem + 2.43vw, 3.5rem);
}

.region-space-s-2xl {
  --region-space: clamp(1rem, -0.06rem + 4.05vw, 3.5rem);
}

.region-space-s-3xl {
  --region-space: clamp(1rem, -0.70rem + 6.48vw, 5rem);
}

.region-space-l-3xl {
  --region-space: clamp(2rem, 0.72rem + 4.86vw, 5rem);
}

.region-space-page-teaser {
  --region-space: clamp(1rem, -2.16rem + 12.04vw, 8.4375rem);
}

.region-space-8-48 {
  --region-space: clamp(0.5rem, -0.56rem + 4.05vw, 3rem);
}

.region-space-32-96 {
  --region-space: clamp(2rem, 0.30rem + 6.48vw, 6rem);
}

.region-space-32-128 {
  --region-space: clamp(2rem, -0.55rem + 9.72vw, 8rem);
}

.region-space-32-160 {
  --region-space: clamp(2rem, -1.40rem + 12.96vw, 10rem);
}

.region-space-32-200 {
  --region-space: clamp(2rem, -2.46rem + 17.00vw, 12.5rem);
}

.region-space-32-240 {
  --region-space: clamp(2rem, -3.53rem + 21.05vw, 15rem);
}

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

.gutter-3xs {
  --gutter: clamp(0.125rem, 0.07rem + 0.20vw, 0.25rem);
}

.gutter-2xs {
  --gutter: clamp(0.25rem, 0.14rem + 0.40vw, 0.5rem);
}

.gutter-xs {
  --gutter: clamp(0.5rem, 0.29rem + 0.81vw, 1rem);
}

.gutter-s {
  --gutter: clamp(1rem, 0.79rem + 0.81vw, 1.5rem);
}

.gutter-m {
  --gutter: clamp(1.5rem, 1.29rem + 0.81vw, 2rem);
}

.gutter-l {
  --gutter: clamp(2rem, 1.79rem + 0.81vw, 2.5rem);
}

.gutter-xl {
  --gutter: clamp(2.5rem, 2.29rem + 0.81vw, 3rem);
}

.gutter-2xl {
  --gutter: clamp(3rem, 2.79rem + 0.81vw, 3.5rem);
}

.gutter-3xl {
  --gutter: clamp(3.5rem, 2.86rem + 2.43vw, 5rem);
}

.gutter-4xl {
  --gutter: clamp(5rem, 2.87rem + 8.10vw, 10rem);
}

.gutter-5xl {
  --gutter: clamp(10rem, 8.94rem + 4.05vw, 12.5rem);
}

.gutter-3xs-2xs {
  --gutter: clamp(0.125rem, -0.03rem + 0.61vw, 0.5rem);
}

.gutter-2xs-xs {
  --gutter: clamp(0.25rem, -0.07rem + 1.21vw, 1rem);
}

.gutter-xs-s {
  --gutter: clamp(0.5rem, 0.07rem + 1.62vw, 1.5rem);
}

.gutter-s-m {
  --gutter: clamp(1rem, 0.57rem + 1.62vw, 2rem);
}

.gutter-m-l {
  --gutter: clamp(1.5rem, 1.07rem + 1.62vw, 2.5rem);
}

.gutter-l-xl {
  --gutter: clamp(2rem, 1.57rem + 1.62vw, 3rem);
}

.gutter-xl-2xl {
  --gutter: clamp(2.5rem, 2.07rem + 1.62vw, 3.5rem);
}

.gutter-2xl-3xl {
  --gutter: clamp(3rem, 2.15rem + 3.24vw, 5rem);
}

.gutter-3xl-4xl {
  --gutter: clamp(3.5rem, 0.74rem + 10.53vw, 10rem);
}

.gutter-4xl-5xl {
  --gutter: clamp(5rem, 1.81rem + 12.15vw, 12.5rem);
}

.gutter-s-l {
  --gutter: clamp(1rem, 0.36rem + 2.43vw, 2.5rem);
}

.gutter-s-xl {
  --gutter: clamp(1rem, 0.15rem + 3.24vw, 3rem);
}

.gutter-l-2xl {
  --gutter: clamp(2rem, 1.36rem + 2.43vw, 3.5rem);
}

.gutter-s-2xl {
  --gutter: clamp(1rem, -0.06rem + 4.05vw, 3.5rem);
}

.gutter-s-3xl {
  --gutter: clamp(1rem, -0.70rem + 6.48vw, 5rem);
}

.gutter-l-3xl {
  --gutter: clamp(2rem, 0.72rem + 4.86vw, 5rem);
}

.gutter-page-teaser {
  --gutter: clamp(1rem, -2.16rem + 12.04vw, 8.4375rem);
}

.gutter-8-48 {
  --gutter: clamp(0.5rem, -0.56rem + 4.05vw, 3rem);
}

.gutter-32-96 {
  --gutter: clamp(2rem, 0.30rem + 6.48vw, 6rem);
}

.gutter-32-128 {
  --gutter: clamp(2rem, -0.55rem + 9.72vw, 8rem);
}

.gutter-32-160 {
  --gutter: clamp(2rem, -1.40rem + 12.96vw, 10rem);
}

.gutter-32-200 {
  --gutter: clamp(2rem, -2.46rem + 17.00vw, 12.5rem);
}

.gutter-32-240 {
  --gutter: clamp(2rem, -3.53rem + 21.05vw, 15rem);
}

.layout-sm {
  --wrapper-max-width: 420px;
}

.layout-md {
  --wrapper-max-width: 1028px;
}

.layout-lg {
  --wrapper-max-width: 1408px;
}

.layout-xl {
  --wrapper-max-width: 1894px;
}