:root {
  --body-color: #555;
  --text-color: #555;
  --primary: #28A144;
  --primary-bg: #28A144;
  --primary-text: #28A144;
  --primary-bg-text: #28A144;
  --primary-color: #28A144;
  --primary-hover: #48af60;
  --primary-hover-color: #48af60;
  --primary-border: #28A144;
  --primary-lighten: #48af60;
  --primary-darken: #22893a;
  --primary-contrast: #fff;
  --primary-transparent: rgba(40, 161, 68, 0.8);
  --primary-muted: #7ec78f;
  --secondary: #fc0;
  --secondary-bg: #fc0;
  --secondary-text: #fc0;
  --secondary-bg-text: #fc0;
  --secondary-color: #fc0;
  --secondary-hover: #ffd426;
  --secondary-hover-color: #ffd426;
  --secondary-border: #fc0;
  --secondary-lighten: #ffd426;
  --secondary-darken: #d9ad00;
  --secondary-contrast: #fff;
  --secondary-transparent: rgba(255, 204, 0, 0.8);
  --secondary-muted: #ffe066;
  --default-text: #555;
  --default-text-bg: #555;
  --default-text-text: #555;
  --default-text-bg-text: #555;
  --default-text-color: #555;
  --default-text-hover: #6f6f6f;
  --default-text-hover-color: #6f6f6f;
  --default-text-border: #555;
  --default-text-lighten: #6f6f6f;
  --default-text-darken: #484848;
  --default-text-contrast: #fff;
  --default-text-transparent: rgba(85, 85, 85, 0.8);
  --default-text-muted: #999999;
  --light: #fff;
  --light-bg: #fff;
  --light-text: #fff;
  --light-bg-text: #fff;
  --light-color: #fff;
  --light-hover: #d9d9d9;
  --light-hover-color: #d9d9d9;
  --light-border: #fff;
  --light-lighten: white;
  --light-darken: #d9d9d9;
  --light-contrast: #000;
  --light-transparent: rgba(255, 255, 255, 0.8);
  --light-muted: white;
  --dark: #000;
  --dark-bg: #000;
  --dark-text: #000;
  --dark-bg-text: #000;
  --dark-color: #000;
  --dark-hover: #262626;
  --dark-hover-color: #262626;
  --dark-border: #000;
  --dark-lighten: #262626;
  --dark-darken: black;
  --dark-contrast: #fff;
  --dark-transparent: rgba(0, 0, 0, 0.8);
  --dark-muted: #666666;
  --error: #F06162;
  --error-bg: #F06162;
  --error-text: #F06162;
  --error-bg-text: #F06162;
  --error-color: #F06162;
  --error-hover: #cc5253;
  --error-hover-color: #cc5253;
  --error-border: #F06162;
  --error-lighten: #f2797a;
  --error-darken: #cc5253;
  --error-contrast: #ffffff;
  --error-transparent: rgba(240, 97, 98, 0.8);
  --error-muted: #f6a0a1;
  --success: #27af00;
  --success-bg: #27af00;
  --success-text: #27af00;
  --success-bg-text: #27af00;
  --success-color: #27af00;
  --success-hover: #47bb26;
  --success-hover-color: #47bb26;
  --success-border: #27af00;
  --success-lighten: #47bb26;
  --success-darken: #219500;
  --success-contrast: #fff;
  --success-transparent: rgba(39, 175, 0, 0.8);
  --success-muted: #7dcf66;
  --spa: #fc0;
  --spa-bg: #fc0;
  --spa-text: #fc0;
  --spa-bg-text: #fc0;
  --spa-color: #fc0;
  --spa-hover: #ffd426;
  --spa-hover-color: #ffd426;
  --spa-border: #fc0;
  --spa-lighten: #ffd426;
  --spa-darken: #d9ad00;
  --spa-contrast: #fff;
  --spa-transparent: rgba(255, 204, 0, 0.8);
  --spa-muted: #ffe066;
  --hygromatik: #28A144;
  --hygromatik-bg: #28A144;
  --hygromatik-text: #28A144;
  --hygromatik-bg-text: #28A144;
  --hygromatik-color: #28A144;
  --hygromatik-hover: #48af60;
  --hygromatik-hover-color: #48af60;
  --hygromatik-border: #28A144;
  --hygromatik-lighten: #48af60;
  --hygromatik-darken: #22893a;
  --hygromatik-contrast: #fff;
  --hygromatik-transparent: rgba(40, 161, 68, 0.8);
  --hygromatik-muted: #7ec78f;
  --carel: #ED1C24;
  --carel-bg: #ED1C24;
  --carel-text: #ED1C24;
  --carel-bg-text: #ED1C24;
  --carel-color: #ED1C24;
  --carel-hover: #c9181f;
  --carel-hover-color: #c9181f;
  --carel-border: #ED1C24;
  --carel-lighten: #f03e45;
  --carel-darken: #c9181f;
  --carel-contrast: #fff;
  --carel-transparent: rgba(237, 28, 36, 0.8);
  --carel-muted: #f4777c;
  --body-bg: #fff;
  --body-bg-bg: #fff;
  --body-bg-text: #fff;
  --body-bg-bg-text: #fff;
  --body-bg-color: #fff;
  --body-bg-hover: #d9d9d9;
  --body-bg-hover-color: #d9d9d9;
  --body-bg-border: #fff;
  --body-bg-lighten: white;
  --body-bg-darken: #d9d9d9;
  --body-bg-contrast: #000;
  --body-bg-transparent: rgba(255, 255, 255, 0.8);
  --body-bg-muted: white;
  --form-bg: #cccccc;
  --form-bg-bg: #cccccc;
  --form-bg-text: #cccccc;
  --form-bg-bg-text: #cccccc;
  --form-bg-color: #cccccc;
  --form-bg-hover: #adadad;
  --form-bg-hover-color: #adadad;
  --form-bg-border: #cccccc;
  --form-bg-lighten: #d4d4d4;
  --form-bg-darken: #adadad;
  --form-bg-contrast: #000;
  --form-bg-transparent: rgba(204, 204, 204, 0.8);
  --form-bg-muted: #e0e0e0;
  --brand-1: #ff00ff;
  --brand-1-bg: #ff00ff;
  --brand-1-text: #ff00ff;
  --brand-1-bg-text: #ff00ff;
  --brand-1-color: #ff00ff;
  --brand-1-hover: #ff26ff;
  --brand-1-hover-color: #ff26ff;
  --brand-1-border: #ff00ff;
  --brand-1-lighten: #ff26ff;
  --brand-1-darken: #d900d9;
  --brand-1-contrast: #000;
  --brand-1-transparent: rgba(255, 0, 255, 0.8);
  --brand-1-muted: #ff66ff;
  --brand-2: #00ffFF;
  --brand-2-bg: #00ffFF;
  --brand-2-text: #00ffFF;
  --brand-2-bg-text: #00ffFF;
  --brand-2-color: #00ffFF;
  --brand-2-hover: #26ffff;
  --brand-2-hover-color: #26ffff;
  --brand-2-border: #00ffFF;
  --brand-2-lighten: #26ffff;
  --brand-2-darken: #00d9d9;
  --brand-2-contrast: #000;
  --brand-2-transparent: rgba(0, 255, 255, 0.8);
  --brand-2-muted: #66ffff;
  --brand-3: #0000ff;
  --brand-3-bg: #0000ff;
  --brand-3-text: #0000ff;
  --brand-3-bg-text: #0000ff;
  --brand-3-color: #0000ff;
  --brand-3-hover: #2626ff;
  --brand-3-hover-color: #2626ff;
  --brand-3-border: #0000ff;
  --brand-3-lighten: #2626ff;
  --brand-3-darken: #0000d9;
  --brand-3-contrast: #000;
  --brand-3-transparent: rgba(0, 0, 255, 0.8);
  --brand-3-muted: #6666ff;
  --white: #fff;
  --white-bg: #fff;
  --white-text: #fff;
  --white-bg-text: #fff;
  --white-color: #fff;
  --white-hover: #d9d9d9;
  --white-hover-color: #d9d9d9;
  --white-border: #fff;
  --white-lighten: white;
  --white-darken: #d9d9d9;
  --white-contrast: #000;
  --white-transparent: rgba(255, 255, 255, 0.8);
  --white-muted: white;
  --black: #000;
  --black-bg: #000;
  --black-text: #000;
  --black-bg-text: #000;
  --black-color: #000;
  --black-hover: #262626;
  --black-hover-color: #262626;
  --black-border: #000;
  --black-lighten: #262626;
  --black-darken: black;
  --black-contrast: #fff;
  --black-transparent: rgba(0, 0, 0, 0.8);
  --black-muted: #666666;
  --nav-line: #D6D6D5;
  --nav-line-bg: #D6D6D5;
  --nav-line-text: #D6D6D5;
  --nav-line-bg-text: #D6D6D5;
  --nav-line-color: #D6D6D5;
  --nav-line-hover: #b6b6b5;
  --nav-line-hover-color: #b6b6b5;
  --nav-line-border: #D6D6D5;
  --nav-line-lighten: #dcdcdb;
  --nav-line-darken: #b6b6b5;
  --nav-line-contrast: #000;
  --nav-line-transparent: rgba(214, 214, 213, 0.8);
  --nav-line-muted: #e6e6e6;
  --accent-color: #9C9D9F;
  --accent-color-bg: #9C9D9F;
  --accent-color-text: #9C9D9F;
  --accent-color-bg-text: #9C9D9F;
  --accent-color-color: #9C9D9F;
  --accent-color-hover: #858587;
  --accent-color-hover-color: #858587;
  --accent-color-border: #9C9D9F;
  --accent-color-lighten: #abacad;
  --accent-color-darken: #858587;
  --accent-color-contrast: #000;
  --accent-color-transparent: rgba(156, 157, 159, 0.8);
  --accent-color-muted: #c4c4c5;
  --bg-body: #fff;
  --bg-body-contrast: #000;
  --bg-header: #fff;
  --bg-hader-contrast: #000;
  --bg-footer:var(--primary);
  --bg-footer-contrast: var(--primary-contrast);
  --moving-overlay-bg: #fff;
  --shadow-color: #555;
  --default-font-size: 20px;
  --text-font-size-x-small: 0.6rem;
  --text-font-size-small: 0.8rem;
  --text-font-size-default: 1rem;
  --text-font-size-large: 1.2rem;
  --text-font-size-x-large: 1.4rem;
  --text-font-weight-default: 100;
  --headline-font-size-xx-small: 1.8rem;
  --headline-font-size-x-small: 2rem;
  --headline-font-size-small: 2.25rem;
  --headline-font-size-default: 2.45rem;
  --headline-font-size-large: 2.65rem;
  --headline-font-size-x-large: 2.85rem;
  --teaser-headline-font-size-x-small: 2rem;
  --teaser-headline-font-size-small: 2.25rem;
  --teaser-headline-font-size-default: 2.45rem;
  --teaser-headline-font-size-large: 2.65rem;
  --teaser-headline-font-size-x-large: 2.85rem;
  --footer-font-size-default: 0.8rem;
  --footer-icon-size-default: 2rem;
  --subtitle-font-size-x-small: 0.8rem;
  --subtitle-font-size-small: 1rem;
  --subtitle-font-size-default: 1.2rem;
  --subtitle-font-size-large: 1.4rem;
  --subtitle-font-size-x-large: 1.6rem;
  --gap-none: 0;
  --gap-small: 0.4rem;
  --gap-medium: 1rem;
  --gap-large: 1.4rem;
  --input-border:1px solid var(--accent-color);
  --input-radius:5px;
}
@media screen and (max-width: 1024px) {
  :root {
    --default-font-size: 18px;
  }
}
@media screen and (max-width: 720px) {
  :root {
    --default-font-size: 16px;
    --headline-font-size-x-small: 1.6rem;
    --headline-font-size-small: 1.85rem;
    --headline-font-size-default: 2.05rem;
    --headline-font-size-large: 2.25rem;
    --headline-font-size-x-large: 2.65rem;
    --teaser-headline-font-size-x-small: 1.6rem;
    --teaser-headline-font-size-small: 1.85rem;
    --teaser-headline-font-size-default: 2.05rem;
    --teaser-headline-font-size-large: 2.25rem;
    --teaser-headline-font-size-x-large: 2.65rem;
  }
}

.frame-primary {
  --color:var(--primary);
  --bg:var(--primary-bg);
  --text:var(--primary-text);
  --bg-text: var(--primary-bg-text);
  --hover:var(--primary-hover);
  --hover-color:var(--primary-hover-color);
  --border:var(--primary-border);
  --lighten:var(--primary-lighten);
  --darken:var(--primary-darken);
  --contrast:var(--primary-contrast);
}

.frame-secondary {
  --color:var(--secondary);
  --bg:var(--secondary-bg);
  --text:var(--secondary-text);
  --bg-text: var(--secondary-bg-text);
  --hover:var(--secondary-hover);
  --hover-color:var(--secondary-hover-color);
  --border:var(--secondary-border);
  --lighten:var(--secondary-lighten);
  --darken:var(--secondary-darken);
  --contrast:var(--secondary-contrast);
}

.frame-default-text {
  --color:var(--default-text);
  --bg:var(--default-text-bg);
  --text:var(--default-text-text);
  --bg-text: var(--default-text-bg-text);
  --hover:var(--default-text-hover);
  --hover-color:var(--default-text-hover-color);
  --border:var(--default-text-border);
  --lighten:var(--default-text-lighten);
  --darken:var(--default-text-darken);
  --contrast:var(--default-text-contrast);
}

.frame-light {
  --color:var(--light);
  --bg:var(--light-bg);
  --text:var(--light-text);
  --bg-text: var(--light-bg-text);
  --hover:var(--light-hover);
  --hover-color:var(--light-hover-color);
  --border:var(--light-border);
  --lighten:var(--light-lighten);
  --darken:var(--light-darken);
  --contrast:var(--light-contrast);
}

.frame-dark {
  --color:var(--dark);
  --bg:var(--dark-bg);
  --text:var(--dark-text);
  --bg-text: var(--dark-bg-text);
  --hover:var(--dark-hover);
  --hover-color:var(--dark-hover-color);
  --border:var(--dark-border);
  --lighten:var(--dark-lighten);
  --darken:var(--dark-darken);
  --contrast:var(--dark-contrast);
}

.frame-error {
  --color:var(--error);
  --bg:var(--error-bg);
  --text:var(--error-text);
  --bg-text: var(--error-bg-text);
  --hover:var(--error-hover);
  --hover-color:var(--error-hover-color);
  --border:var(--error-border);
  --lighten:var(--error-lighten);
  --darken:var(--error-darken);
  --contrast:var(--error-contrast);
}

.frame-success {
  --color:var(--success);
  --bg:var(--success-bg);
  --text:var(--success-text);
  --bg-text: var(--success-bg-text);
  --hover:var(--success-hover);
  --hover-color:var(--success-hover-color);
  --border:var(--success-border);
  --lighten:var(--success-lighten);
  --darken:var(--success-darken);
  --contrast:var(--success-contrast);
}

.frame-spa {
  --color:var(--spa);
  --bg:var(--spa-bg);
  --text:var(--spa-text);
  --bg-text: var(--spa-bg-text);
  --hover:var(--spa-hover);
  --hover-color:var(--spa-hover-color);
  --border:var(--spa-border);
  --lighten:var(--spa-lighten);
  --darken:var(--spa-darken);
  --contrast:var(--spa-contrast);
}

.frame-hygromatik {
  --color:var(--hygromatik);
  --bg:var(--hygromatik-bg);
  --text:var(--hygromatik-text);
  --bg-text: var(--hygromatik-bg-text);
  --hover:var(--hygromatik-hover);
  --hover-color:var(--hygromatik-hover-color);
  --border:var(--hygromatik-border);
  --lighten:var(--hygromatik-lighten);
  --darken:var(--hygromatik-darken);
  --contrast:var(--hygromatik-contrast);
}

.frame-carel {
  --color:var(--carel);
  --bg:var(--carel-bg);
  --text:var(--carel-text);
  --bg-text: var(--carel-bg-text);
  --hover:var(--carel-hover);
  --hover-color:var(--carel-hover-color);
  --border:var(--carel-border);
  --lighten:var(--carel-lighten);
  --darken:var(--carel-darken);
  --contrast:var(--carel-contrast);
}

.frame-body-bg {
  --color:var(--body-bg);
  --bg:var(--body-bg-bg);
  --text:var(--body-bg-text);
  --bg-text: var(--body-bg-bg-text);
  --hover:var(--body-bg-hover);
  --hover-color:var(--body-bg-hover-color);
  --border:var(--body-bg-border);
  --lighten:var(--body-bg-lighten);
  --darken:var(--body-bg-darken);
  --contrast:var(--body-bg-contrast);
}

.frame-form-bg {
  --color:var(--form-bg);
  --bg:var(--form-bg-bg);
  --text:var(--form-bg-text);
  --bg-text: var(--form-bg-bg-text);
  --hover:var(--form-bg-hover);
  --hover-color:var(--form-bg-hover-color);
  --border:var(--form-bg-border);
  --lighten:var(--form-bg-lighten);
  --darken:var(--form-bg-darken);
  --contrast:var(--form-bg-contrast);
}

.frame-brand-1 {
  --color:var(--brand-1);
  --bg:var(--brand-1-bg);
  --text:var(--brand-1-text);
  --bg-text: var(--brand-1-bg-text);
  --hover:var(--brand-1-hover);
  --hover-color:var(--brand-1-hover-color);
  --border:var(--brand-1-border);
  --lighten:var(--brand-1-lighten);
  --darken:var(--brand-1-darken);
  --contrast:var(--brand-1-contrast);
}

.frame-brand-2 {
  --color:var(--brand-2);
  --bg:var(--brand-2-bg);
  --text:var(--brand-2-text);
  --bg-text: var(--brand-2-bg-text);
  --hover:var(--brand-2-hover);
  --hover-color:var(--brand-2-hover-color);
  --border:var(--brand-2-border);
  --lighten:var(--brand-2-lighten);
  --darken:var(--brand-2-darken);
  --contrast:var(--brand-2-contrast);
}

.frame-brand-3 {
  --color:var(--brand-3);
  --bg:var(--brand-3-bg);
  --text:var(--brand-3-text);
  --bg-text: var(--brand-3-bg-text);
  --hover:var(--brand-3-hover);
  --hover-color:var(--brand-3-hover-color);
  --border:var(--brand-3-border);
  --lighten:var(--brand-3-lighten);
  --darken:var(--brand-3-darken);
  --contrast:var(--brand-3-contrast);
}

.frame-white {
  --color:var(--white);
  --bg:var(--white-bg);
  --text:var(--white-text);
  --bg-text: var(--white-bg-text);
  --hover:var(--white-hover);
  --hover-color:var(--white-hover-color);
  --border:var(--white-border);
  --lighten:var(--white-lighten);
  --darken:var(--white-darken);
  --contrast:var(--white-contrast);
}

.frame-black {
  --color:var(--black);
  --bg:var(--black-bg);
  --text:var(--black-text);
  --bg-text: var(--black-bg-text);
  --hover:var(--black-hover);
  --hover-color:var(--black-hover-color);
  --border:var(--black-border);
  --lighten:var(--black-lighten);
  --darken:var(--black-darken);
  --contrast:var(--black-contrast);
}

.frame-nav-line {
  --color:var(--nav-line);
  --bg:var(--nav-line-bg);
  --text:var(--nav-line-text);
  --bg-text: var(--nav-line-bg-text);
  --hover:var(--nav-line-hover);
  --hover-color:var(--nav-line-hover-color);
  --border:var(--nav-line-border);
  --lighten:var(--nav-line-lighten);
  --darken:var(--nav-line-darken);
  --contrast:var(--nav-line-contrast);
}

.frame-accent-color {
  --color:var(--accent-color);
  --bg:var(--accent-color-bg);
  --text:var(--accent-color-text);
  --bg-text: var(--accent-color-bg-text);
  --hover:var(--accent-color-hover);
  --hover-color:var(--accent-color-hover-color);
  --border:var(--accent-color-border);
  --lighten:var(--accent-color-lighten);
  --darken:var(--accent-color-darken);
  --contrast:var(--accent-color-contrast);
}

.color-selector .color-label .color-select.color-select.primary {
  background-color: transparent !important;
  background: linear-gradient(to right, var(--hygromatik) 0, var(--hygromatik) 33%, var(--spa) 33%, var(--spa) 66%, var(--carel) 66%, var(--carel) 100%);
}

.color-selector .color-label .color-select.color-select.secondary {
  background-color: transparent !important;
  background: linear-gradient(to left, var(--hygromatik) 0, var(--hygromatik) 50%, var(--spa) 50%, var(--spa) 100%);
}

:root {
  --text-font-size: var(--text-font-size-default);
  --text-color: var(--text-color);
  --text-line-height: 1.6;
  --text-align: left;
  --text-transform: none;
  --text-link-color:var(--primary);
  --text-font-weight: var(--text-font-weight-default);
  --headline-font-size: var(--headline-font-size-default);
  --headline-line-height: 1.2;
  --headline-color: var(--primary);
  --headline-weight: normal;
  --footer-font-size: var(--footer-font-size-default);
  --footer-icon-size: var(--footer-icon-size-default);
  --footer-color: var(--light);
  --paragraph-margin: 0 0 0.6rem 0;
}

:root {
  --container-pad-0: 0rem;
  --row-gap-0: clamp(0rem, 0vw, 0rem);
  --container-pad-1: 0.5rem;
  --row-gap-1: clamp(0.125rem, 0.5434782609vw, 0.5rem);
  --container-pad-2: 1rem;
  --row-gap-2: clamp(0.25rem, 1.0869565217vw, 1rem);
  --container-pad-3: 2rem;
  --row-gap-3: clamp(0.5rem, 2.1739130435vw, 2rem);
  --container-pad-4: 3rem;
  --row-gap-4: clamp(0.75rem, 3.2608695652vw, 3rem);
  --container-pad-5: 6rem;
  --row-gap-5: clamp(1.5rem, 6.5217391304vw, 6rem);
}
@media screen and (max-width: 720px) {
  :root {
    --container-pad-0: 0rem;
    --row-gap-0: clamp(0rem, 0vw, 0rem);
    --container-pad-1: 0.4rem;
    --row-gap-1: clamp(0.1rem, 0.4347826087vw, 0.5rem);
    --container-pad-2: 0.8rem;
    --row-gap-2: clamp(0.2rem, 0.8695652174vw, 1rem);
    --container-pad-3: 1.6rem;
    --row-gap-3: clamp(0.4rem, 1.7391304348vw, 2rem);
    --container-pad-4: 2.4rem;
    --row-gap-4: clamp(0.6rem, 2.6086956522vw, 3rem);
    --container-pad-5: 4.8rem;
    --row-gap-5: clamp(1.2rem, 5.2173913043vw, 6rem);
  }
}
@media screen and (max-width: 1024px) {
  :root {
    --container-pad-0: 0rem;
    --row-gap-0: clamp(0rem, 0vw, 0rem);
    --container-pad-1: 0.45rem;
    --row-gap-1: clamp(0.1125rem, 0.4891304348vw, 0.5rem);
    --container-pad-2: 0.9rem;
    --row-gap-2: clamp(0.225rem, 0.9782608696vw, 1rem);
    --container-pad-3: 1.8rem;
    --row-gap-3: clamp(0.45rem, 1.9565217391vw, 2rem);
    --container-pad-4: 2.7rem;
    --row-gap-4: clamp(0.675rem, 2.9347826087vw, 3rem);
    --container-pad-5: 5.4rem;
    --row-gap-5: clamp(1.35rem, 5.8695652174vw, 6rem);
  }
}
@media screen and (max-width: 1500px) {
  :root {
    --container-pad-0: 0rem;
    --row-gap-0: clamp(0rem, 0vw, 0rem);
    --container-pad-1: 0.5rem;
    --row-gap-1: clamp(0.125rem, 0.5434782609vw, 0.5rem);
    --container-pad-2: 1rem;
    --row-gap-2: clamp(0.25rem, 1.0869565217vw, 1rem);
    --container-pad-3: 2rem;
    --row-gap-3: clamp(0.5rem, 2.1739130435vw, 2rem);
    --container-pad-4: 3rem;
    --row-gap-4: clamp(0.75rem, 3.2608695652vw, 3rem);
    --container-pad-5: 6rem;
    --row-gap-5: clamp(1.5rem, 6.5217391304vw, 6rem);
  }
}

@font-face {
  font-family: "Roboto";
  src: url("../../thirdparty/fonts/roboto/font/Roboto-Light.ttf") format("truetype");
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  src: url("../../thirdparty/fonts/roboto/font/Roboto-Medium.ttf") format("truetype");
  font-weight: bold;
  font-display: swap;
}
main,
footer,
header,
article,
section {
  display: block;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

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

.preload * {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -ms-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}

html, body {
  width: 100%;
  background-color: #fff;
  color: #555;
  font-family: "Roboto", Arial;
  font-size: var(--default-font-size, 20px);
  box-sizing: border-box;
  min-height: 100vh;
  scroll-behavior: smooth;
  accent-color: var(--primary);
}

@media screen and (prefers-reduced-motion: reduce) {
  html, body {
    scroll-behavior: auto;
  }
}
body {
  display: flex;
  flex-direction: column;
}
body header, body footer {
  flex-grow: 0;
}
body main {
  flex-grow: 1;
  width: 100%;
  margin: var(--header-height, 0) auto 0;
}

body.header-fixed main h1[id],
body.header-fixed main h2[id],
body.header-fixed main h3[id],
body.header-fixed main section[id],
body.header-fixed main article[id],
body.header-fixed main div[id] {
  scroll-margin-top: calc(var(--header-height) + 2rem);
}

img {
  border: 0;
  max-width: 100%;
}

a {
  text-decoration: none;
  color: var(--primary);
}

header {
  display: block;
}

.page_404 h1 {
  font-size: 1.2em;
  color: rgb(24, 24, 24);
  margin: 2em 0 20px 0;
  font-weight: lighter;
}

.page_404 p {
  font-size: 1em;
  color: #424242;
  line-height: 1.5em;
}

img {
  display: block;
}

header.desktop {
  display: block;
  padding: 0;
}
header.desktop .header-inner {
  max-width: 1840px;
  margin: 0 auto;
  padding: 1rem 0;
}
header.desktop .header-main {
  display: grid;
  grid-template-columns: 45% 1fr 250px;
  gap: 30px;
  align-items: end;
  padding: 0 2rem;
}
header.desktop .header-main .logo .image-item {
  display: flex;
  justify-content: start;
  max-width: 400px;
}
header.desktop .header-main .logo .image-item img {
  width: auto !important;
}
header.desktop .header-main .appendix {
  display: grid;
  justify-items: flex-end;
  justify-content: flex-end;
}
header.desktop .header-main .appendix .service {
  width: 100%;
  max-width: 320px;
  justify-self: center;
  display: grid;
  align-items: center;
  align-content: center;
  grid-template-rows: auto auto;
  grid-template-columns: 30px 1fr;
  grid-template-areas: "logo top" "logo bottom";
  column-gap: 5px;
}
header.desktop .header-main .appendix .service .service-logo {
  grid-area: logo;
}
header.desktop .header-main .appendix .service .service-top {
  grid-area: top;
}
header.desktop .header-main .appendix .service .service-bottom {
  grid-area: bottom;
}
header.desktop .header-main .appendix .service .service-text {
  color: var(--primary);
}
header.desktop .header-main .legend {
  justify-items: flex-end;
  justify-content: flex-end;
}
header.desktop .header-nav-bar {
  background-color: var(--primary);
}
header.desktop .header-nav-bar .header-inner {
  padding: 0;
}

@media screen and (max-width: 1024px) {
  header.desktop {
    display: none;
  }
}
header.mobile {
  display: none;
}
header.mobile .legend {
  background-color: #28A144;
  padding-top: 5px;
  padding-bottom: 5px;
}
header.mobile .legend .lang-select {
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
}
header.mobile .legend .lang-select .lang-select {
  gap: 0;
  grid-template-columns: 1fr 22px;
}
header.mobile .header-main {
  position: relative;
}
header.mobile .header-main .menu-bar-button {
  position: absolute;
  top: 50%;
  left: 1rem;
  transform: translateY(-50%);
}
header.mobile .header-main .logo {
  padding-top: 30px;
  padding-bottom: 30px;
}
header.mobile .header-main .logo .image-item {
  display: flex;
  justify-content: center;
}
header.mobile .header-main .logo .image-item img {
  max-height: 60px;
  width: auto !important;
}

@media screen and (max-width: 1024px) {
  header.mobile {
    display: block;
  }
}
.lang-select {
  width: 80%;
  margin-left: 20%;
  position: relative;
  cursor: pointer;
  color: var(--default-text);
}
.lang-select .selected-lang {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  justify-content: flex-end;
  justify-items: flex-end;
  align-content: center;
  align-items: center;
  grid-template-areas: "selected expand";
  gap: 2px;
}
.lang-select .selected-lang .lang-option {
  grid-area: selected;
  width: 100%;
  color: var(--default-text);
}
.lang-select .selected-lang .expand {
  width: 100%;
  grid-area: expand;
  display: grid;
  justify-content: center;
  justify-items: center;
  align-content: center;
  align-items: center;
  color: var(--default-text);
  padding: 4px;
}
.lang-select .lang-options {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  display: none;
  z-index: 50;
}
.lang-select .lang-options.shown {
  display: block;
}
.lang-select .lang-option {
  display: grid;
  grid-template-columns: 40px 1fr;
  justify-content: flex-start;
  justify-items: flex-start;
  align-content: center;
  align-items: center;
  grid-template-areas: "flag name";
  gap: 10px;
  padding: 5px;
  background-color: var(--light);
  color: var(--default-text);
}
.lang-select .lang-option .flag {
  grid-area: flag;
}
.lang-select .lang-option .flag img {
  width: 40px;
}
.lang-select .lang-option .lang {
  grid-area: name;
  white-space: nowrap;
  text-overflow: fade;
}

header {
  background-color: var(--bg-header);
  z-index: 2;
  width: 100%;
}
body.header-fixed header {
  position: fixed;
  z-index: 20;
  top: 0;
  left: 0;
}

footer {
  background-color: var(--bg-footer);
  color: var(--footer-color);
  font-size: var(--footer-font-size);
}
footer .footer-inner {
  max-width: 1840px;
  padding: 1rem 2rem;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 3fr 2fr;
  justify-content: start;
  justify-items: start;
  align-content: center;
  align-items: center;
  gap: 1rem;
}
footer .footer-inner .footer-middle {
  display: flex;
  gap: 10px;
  align-content: center;
  align-items: center;
  justify-content: center;
  justify-items: center;
  justify-self: center;
}
footer .footer-inner .footer-middle .carel_logo .image-item img {
  max-height: 35px;
  max-width: 99px !important;
}
footer .footer-inner .footer-middle .linked_in_logo .image-item img {
  max-height: 35px;
  max-width: 98px !important;
}
footer .footer-inner .footer-middle .footer-icon {
  color: var(--footer-color);
  font-size: var(--footer-icon-size);
}
footer .footer-inner .footer-right {
  justify-self: flex-end;
}
@media screen and (max-width: 1024px) {
  footer .footer-inner { /* tablet */ }
  footer .footer-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    align-items: center;
  }
  footer .footer-inner .footer-left, footer .footer-inner .footer-middle {
    display: flex;
    gap: 10px;
    align-content: center;
    align-items: center;
    justify-content: center;
    justify-items: center;
    justify-self: center;
  }
  footer .footer-inner .footer-right {
    grid-column: 1/3;
    grid-row: 2;
    justify-self: center;
    padding-bottom: 0px;
  }
}
@media screen and (max-width: 720px) {
  footer .footer-inner { /* smartphone */ }
  footer .footer-inner {
    display: block;
  }
  footer .footer-inner .footer-left, footer .footer-inner .footer-middle, footer .footer-inner .footer-right {
    width: 100%;
    text-align: center;
  }
  footer .footer-inner .footer-middle {
    padding-top: 10px;
    padding-bottom: 10px;
  }
  footer .footer-inner .footer-right {
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

.btn, .cta {
  border: 0 none;
  box-sizing: border-box;
  cursor: pointer;
  display: inline-block;
  padding: 0.375rem 0.75rem;
  text-align: center;
  text-decoration: none;
  font-size: var(--button-font-size, var(--text-font-size, var(--default-font-size)));
}
.btn.btn-block, .btn-block.cta {
  display: block;
  width: 100%;
}
.btn.btn-icon:after, .btn-icon.cta:after {
  content: "\f178";
  font-family: "Font Awesome 5 Pro";
  font-weight: 300;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  line-height: 1;
  font-size: 1em;
  margin-left: 0.4em;
}

.btn-primary, .cta-primary {
  border: 2px solid var(--primary-border);
  background-color: var(--primary-bg);
  color: var(--primary-contrast);
}
.btn-primary:hover, .cta-primary:hover {
  background-color: var(--primary-hover);
}
.btn-primary.btn-transparent:hover, .btn-transparent.cta-primary:hover {
  background-color: var(--primary-bg);
}

.btn-hover-bg-primary:hover, .cta-hover-bg-primary:hover {
  background-color: var(--primary-hover) !important;
  color: var(--primary-hover) !important;
}

.btn-text-color-primary, .cta-text-color-primary {
  color: var(--primary-color) !important;
}

.btn-outline-primary {
  border: 2px solid var(--primary-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-primary:hover {
  background-color: var(--primary-hover);
  color: var(--primary-contrast);
}

.btn-secondary, .cta-secondary {
  border: 2px solid var(--secondary-border);
  background-color: var(--secondary-bg);
  color: var(--secondary-contrast);
}
.btn-secondary:hover, .cta-secondary:hover {
  background-color: var(--secondary-hover);
}
.btn-secondary.btn-transparent:hover, .btn-transparent.cta-secondary:hover {
  background-color: var(--secondary-bg);
}

.btn-hover-bg-secondary:hover, .cta-hover-bg-secondary:hover {
  background-color: var(--secondary-hover) !important;
  color: var(--secondary-hover) !important;
}

.btn-text-color-secondary, .cta-text-color-secondary {
  color: var(--secondary-color) !important;
}

.btn-outline-secondary {
  border: 2px solid var(--secondary-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-secondary:hover {
  background-color: var(--secondary-hover);
  color: var(--secondary-contrast);
}

.btn-default-text, .cta-default-text {
  border: 2px solid var(--default-text-border);
  background-color: var(--default-text-bg);
  color: var(--default-text-contrast);
}
.btn-default-text:hover, .cta-default-text:hover {
  background-color: var(--default-text-hover);
}
.btn-default-text.btn-transparent:hover, .btn-transparent.cta-default-text:hover {
  background-color: var(--default-text-bg);
}

.btn-hover-bg-default-text:hover, .cta-hover-bg-default-text:hover {
  background-color: var(--default-text-hover) !important;
  color: var(--default-text-hover) !important;
}

.btn-text-color-default-text, .cta-text-color-default-text {
  color: var(--default-text-color) !important;
}

.btn-outline-default-text {
  border: 2px solid var(--default-text-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-default-text:hover {
  background-color: var(--default-text-hover);
  color: var(--default-text-contrast);
}

.btn-light, .cta-light {
  border: 2px solid var(--light-border);
  background-color: var(--light-bg);
  color: var(--light-contrast);
}
.btn-light:hover, .cta-light:hover {
  background-color: var(--light-hover);
}
.btn-light.btn-transparent:hover, .btn-transparent.cta-light:hover {
  background-color: var(--light-bg);
}

.btn-hover-bg-light:hover, .cta-hover-bg-light:hover {
  background-color: var(--light-hover) !important;
  color: var(--light-hover) !important;
}

.btn-text-color-light, .cta-text-color-light {
  color: var(--light-color) !important;
}

.btn-outline-light {
  border: 2px solid var(--light-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-light:hover {
  background-color: var(--light-hover);
  color: var(--light-contrast);
}

.btn-dark, .cta-dark {
  border: 2px solid var(--dark-border);
  background-color: var(--dark-bg);
  color: var(--dark-contrast);
}
.btn-dark:hover, .cta-dark:hover {
  background-color: var(--dark-hover);
}
.btn-dark.btn-transparent:hover, .btn-transparent.cta-dark:hover {
  background-color: var(--dark-bg);
}

.btn-hover-bg-dark:hover, .cta-hover-bg-dark:hover {
  background-color: var(--dark-hover) !important;
  color: var(--dark-hover) !important;
}

.btn-text-color-dark, .cta-text-color-dark {
  color: var(--dark-color) !important;
}

.btn-outline-dark {
  border: 2px solid var(--dark-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-dark:hover {
  background-color: var(--dark-hover);
  color: var(--dark-contrast);
}

.btn-error, .cta-error {
  border: 2px solid var(--error-border);
  background-color: var(--error-bg);
  color: var(--error-contrast);
}
.btn-error:hover, .cta-error:hover {
  background-color: var(--error-hover);
}
.btn-error.btn-transparent:hover, .btn-transparent.cta-error:hover {
  background-color: var(--error-bg);
}

.btn-hover-bg-error:hover, .cta-hover-bg-error:hover {
  background-color: var(--error-hover) !important;
  color: var(--error-hover) !important;
}

.btn-text-color-error, .cta-text-color-error {
  color: var(--error-color) !important;
}

.btn-outline-error {
  border: 2px solid var(--error-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-error:hover {
  background-color: var(--error-hover);
  color: var(--error-contrast);
}

.btn-success, .cta-success {
  border: 2px solid var(--success-border);
  background-color: var(--success-bg);
  color: var(--success-contrast);
}
.btn-success:hover, .cta-success:hover {
  background-color: var(--success-hover);
}
.btn-success.btn-transparent:hover, .btn-transparent.cta-success:hover {
  background-color: var(--success-bg);
}

.btn-hover-bg-success:hover, .cta-hover-bg-success:hover {
  background-color: var(--success-hover) !important;
  color: var(--success-hover) !important;
}

.btn-text-color-success, .cta-text-color-success {
  color: var(--success-color) !important;
}

.btn-outline-success {
  border: 2px solid var(--success-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-success:hover {
  background-color: var(--success-hover);
  color: var(--success-contrast);
}

.btn-spa, .cta-spa {
  border: 2px solid var(--spa-border);
  background-color: var(--spa-bg);
  color: var(--spa-contrast);
}
.btn-spa:hover, .cta-spa:hover {
  background-color: var(--spa-hover);
}
.btn-spa.btn-transparent:hover, .btn-transparent.cta-spa:hover {
  background-color: var(--spa-bg);
}

.btn-hover-bg-spa:hover, .cta-hover-bg-spa:hover {
  background-color: var(--spa-hover) !important;
  color: var(--spa-hover) !important;
}

.btn-text-color-spa, .cta-text-color-spa {
  color: var(--spa-color) !important;
}

.btn-outline-spa {
  border: 2px solid var(--spa-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-spa:hover {
  background-color: var(--spa-hover);
  color: var(--spa-contrast);
}

.btn-hygromatik, .cta-hygromatik {
  border: 2px solid var(--hygromatik-border);
  background-color: var(--hygromatik-bg);
  color: var(--hygromatik-contrast);
}
.btn-hygromatik:hover, .cta-hygromatik:hover {
  background-color: var(--hygromatik-hover);
}
.btn-hygromatik.btn-transparent:hover, .btn-transparent.cta-hygromatik:hover {
  background-color: var(--hygromatik-bg);
}

.btn-hover-bg-hygromatik:hover, .cta-hover-bg-hygromatik:hover {
  background-color: var(--hygromatik-hover) !important;
  color: var(--hygromatik-hover) !important;
}

.btn-text-color-hygromatik, .cta-text-color-hygromatik {
  color: var(--hygromatik-color) !important;
}

.btn-outline-hygromatik {
  border: 2px solid var(--hygromatik-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-hygromatik:hover {
  background-color: var(--hygromatik-hover);
  color: var(--hygromatik-contrast);
}

.btn-carel, .cta-carel {
  border: 2px solid var(--carel-border);
  background-color: var(--carel-bg);
  color: var(--carel-contrast);
}
.btn-carel:hover, .cta-carel:hover {
  background-color: var(--carel-hover);
}
.btn-carel.btn-transparent:hover, .btn-transparent.cta-carel:hover {
  background-color: var(--carel-bg);
}

.btn-hover-bg-carel:hover, .cta-hover-bg-carel:hover {
  background-color: var(--carel-hover) !important;
  color: var(--carel-hover) !important;
}

.btn-text-color-carel, .cta-text-color-carel {
  color: var(--carel-color) !important;
}

.btn-outline-carel {
  border: 2px solid var(--carel-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-carel:hover {
  background-color: var(--carel-hover);
  color: var(--carel-contrast);
}

.btn-body-bg, .cta-body-bg {
  border: 2px solid var(--body-bg-border);
  background-color: var(--body-bg-bg);
  color: var(--body-bg-contrast);
}
.btn-body-bg:hover, .cta-body-bg:hover {
  background-color: var(--body-bg-hover);
}
.btn-body-bg.btn-transparent:hover, .btn-transparent.cta-body-bg:hover {
  background-color: var(--body-bg-bg);
}

.btn-hover-bg-body-bg:hover, .cta-hover-bg-body-bg:hover {
  background-color: var(--body-bg-hover) !important;
  color: var(--body-bg-hover) !important;
}

.btn-text-color-body-bg, .cta-text-color-body-bg {
  color: var(--body-bg-color) !important;
}

.btn-outline-body-bg {
  border: 2px solid var(--body-bg-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-body-bg:hover {
  background-color: var(--body-bg-hover);
  color: var(--body-bg-contrast);
}

.btn-form-bg, .cta-form-bg {
  border: 2px solid var(--form-bg-border);
  background-color: var(--form-bg-bg);
  color: var(--form-bg-contrast);
}
.btn-form-bg:hover, .cta-form-bg:hover {
  background-color: var(--form-bg-hover);
}
.btn-form-bg.btn-transparent:hover, .btn-transparent.cta-form-bg:hover {
  background-color: var(--form-bg-bg);
}

.btn-hover-bg-form-bg:hover, .cta-hover-bg-form-bg:hover {
  background-color: var(--form-bg-hover) !important;
  color: var(--form-bg-hover) !important;
}

.btn-text-color-form-bg, .cta-text-color-form-bg {
  color: var(--form-bg-color) !important;
}

.btn-outline-form-bg {
  border: 2px solid var(--form-bg-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-form-bg:hover {
  background-color: var(--form-bg-hover);
  color: var(--form-bg-contrast);
}

.btn-brand-1, .cta-brand-1 {
  border: 2px solid var(--brand-1-border);
  background-color: var(--brand-1-bg);
  color: var(--brand-1-contrast);
}
.btn-brand-1:hover, .cta-brand-1:hover {
  background-color: var(--brand-1-hover);
}
.btn-brand-1.btn-transparent:hover, .btn-transparent.cta-brand-1:hover {
  background-color: var(--brand-1-bg);
}

.btn-hover-bg-brand-1:hover, .cta-hover-bg-brand-1:hover {
  background-color: var(--brand-1-hover) !important;
  color: var(--brand-1-hover) !important;
}

.btn-text-color-brand-1, .cta-text-color-brand-1 {
  color: var(--brand-1-color) !important;
}

.btn-outline-brand-1 {
  border: 2px solid var(--brand-1-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-brand-1:hover {
  background-color: var(--brand-1-hover);
  color: var(--brand-1-contrast);
}

.btn-brand-2, .cta-brand-2 {
  border: 2px solid var(--brand-2-border);
  background-color: var(--brand-2-bg);
  color: var(--brand-2-contrast);
}
.btn-brand-2:hover, .cta-brand-2:hover {
  background-color: var(--brand-2-hover);
}
.btn-brand-2.btn-transparent:hover, .btn-transparent.cta-brand-2:hover {
  background-color: var(--brand-2-bg);
}

.btn-hover-bg-brand-2:hover, .cta-hover-bg-brand-2:hover {
  background-color: var(--brand-2-hover) !important;
  color: var(--brand-2-hover) !important;
}

.btn-text-color-brand-2, .cta-text-color-brand-2 {
  color: var(--brand-2-color) !important;
}

.btn-outline-brand-2 {
  border: 2px solid var(--brand-2-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-brand-2:hover {
  background-color: var(--brand-2-hover);
  color: var(--brand-2-contrast);
}

.btn-brand-3, .cta-brand-3 {
  border: 2px solid var(--brand-3-border);
  background-color: var(--brand-3-bg);
  color: var(--brand-3-contrast);
}
.btn-brand-3:hover, .cta-brand-3:hover {
  background-color: var(--brand-3-hover);
}
.btn-brand-3.btn-transparent:hover, .btn-transparent.cta-brand-3:hover {
  background-color: var(--brand-3-bg);
}

.btn-hover-bg-brand-3:hover, .cta-hover-bg-brand-3:hover {
  background-color: var(--brand-3-hover) !important;
  color: var(--brand-3-hover) !important;
}

.btn-text-color-brand-3, .cta-text-color-brand-3 {
  color: var(--brand-3-color) !important;
}

.btn-outline-brand-3 {
  border: 2px solid var(--brand-3-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-brand-3:hover {
  background-color: var(--brand-3-hover);
  color: var(--brand-3-contrast);
}

.btn-white, .cta-white {
  border: 2px solid var(--white-border);
  background-color: var(--white-bg);
  color: var(--white-contrast);
}
.btn-white:hover, .cta-white:hover {
  background-color: var(--white-hover);
}
.btn-white.btn-transparent:hover, .btn-transparent.cta-white:hover {
  background-color: var(--white-bg);
}

.btn-hover-bg-white:hover, .cta-hover-bg-white:hover {
  background-color: var(--white-hover) !important;
  color: var(--white-hover) !important;
}

.btn-text-color-white, .cta-text-color-white {
  color: var(--white-color) !important;
}

.btn-outline-white {
  border: 2px solid var(--white-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-white:hover {
  background-color: var(--white-hover);
  color: var(--white-contrast);
}

.btn-black, .cta-black {
  border: 2px solid var(--black-border);
  background-color: var(--black-bg);
  color: var(--black-contrast);
}
.btn-black:hover, .cta-black:hover {
  background-color: var(--black-hover);
}
.btn-black.btn-transparent:hover, .btn-transparent.cta-black:hover {
  background-color: var(--black-bg);
}

.btn-hover-bg-black:hover, .cta-hover-bg-black:hover {
  background-color: var(--black-hover) !important;
  color: var(--black-hover) !important;
}

.btn-text-color-black, .cta-text-color-black {
  color: var(--black-color) !important;
}

.btn-outline-black {
  border: 2px solid var(--black-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-black:hover {
  background-color: var(--black-hover);
  color: var(--black-contrast);
}

.btn-nav-line, .cta-nav-line {
  border: 2px solid var(--nav-line-border);
  background-color: var(--nav-line-bg);
  color: var(--nav-line-contrast);
}
.btn-nav-line:hover, .cta-nav-line:hover {
  background-color: var(--nav-line-hover);
}
.btn-nav-line.btn-transparent:hover, .btn-transparent.cta-nav-line:hover {
  background-color: var(--nav-line-bg);
}

.btn-hover-bg-nav-line:hover, .cta-hover-bg-nav-line:hover {
  background-color: var(--nav-line-hover) !important;
  color: var(--nav-line-hover) !important;
}

.btn-text-color-nav-line, .cta-text-color-nav-line {
  color: var(--nav-line-color) !important;
}

.btn-outline-nav-line {
  border: 2px solid var(--nav-line-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-nav-line:hover {
  background-color: var(--nav-line-hover);
  color: var(--nav-line-contrast);
}

.btn-accent-color, .cta-accent-color {
  border: 2px solid var(--accent-color-border);
  background-color: var(--accent-color-bg);
  color: var(--accent-color-contrast);
}
.btn-accent-color:hover, .cta-accent-color:hover {
  background-color: var(--accent-color-hover);
}
.btn-accent-color.btn-transparent:hover, .btn-transparent.cta-accent-color:hover {
  background-color: var(--accent-color-bg);
}

.btn-hover-bg-accent-color:hover, .cta-hover-bg-accent-color:hover {
  background-color: var(--accent-color-hover) !important;
  color: var(--accent-color-hover) !important;
}

.btn-text-color-accent-color, .cta-text-color-accent-color {
  color: var(--accent-color-color) !important;
}

.btn-outline-accent-color {
  border: 2px solid var(--accent-color-border);
  background-color: var(--body-bg);
  color: var(--default-text);
  transition: background-color 0.4s, color 0.4s;
}
.btn-outline-accent-color:hover {
  background-color: var(--accent-color-hover);
  color: var(--accent-color-contrast);
}

.btn-transparent {
  background-color: transparent;
  color: #555;
}

.btn-hover-bg-transparent:hover {
  background-color: transparent !important;
  color: #555 !important;
}

.cta {
  border-radius: 1rem;
  --button-font-size:2rem;
}

.like-input,
textarea,
select,
input:not([type=checkbox], [type=radio], [type=range]) {
  background-color: var(--input-bg, var(--body-bg));
  border-radius: var(--input-radius, 0);
  border: var(--input-border, 1px solid var(--body-color));
  box-shadow: none;
  color: var(--input-text-color, var(--body-color));
  padding: var(--input-padding, 0.375rem 0.75rem);
  box-sizing: border-box;
  -webkit-appearance: none;
  display: block;
  width: 100%;
  font-size: inherit;
  font-family: inherit;
}
.like-input option,
textarea option,
select option,
input:not([type=checkbox], [type=radio], [type=range]) option {
  font-size: inherit;
  font-family: inherit;
}
.like-input.mce-textbox,
textarea.mce-textbox,
select.mce-textbox,
input:not([type=checkbox], [type=radio], [type=range]).mce-textbox {
  width: inherit;
}
.like-input.error,
textarea.error,
select.error,
input:not([type=checkbox], [type=radio], [type=range]).error {
  border-color: var(--error);
}
.like-input:required::placeholder,
textarea:required::placeholder,
select:required::placeholder,
input:not([type=checkbox], [type=radio], [type=range]):required::placeholder {
  color: var(--primary-muted);
}

select {
  cursor: pointer;
}

.input-checkbox {
  display: flex;
  gap: 0.4rem;
  align-items: center;
}

.animated-bar-button {
  width: var(--animated-button-width, 30px);
  height: 45px;
  transition: left 0.1s;
  cursor: pointer;
  position: relative;
  display: block;
}
.animated-bar-button span {
  position: absolute;
  top: 50%;
  left: 0px;
  right: 0px;
  display: block;
  height: 4px;
  margin-top: -2px;
  background-color: var(--burger-button-color, var(--primary));
  font-size: 0;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  cursor: pointer;
}
.animated-bar-button span:before, .animated-bar-button span:after {
  position: absolute;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: var(--burger-button-color, var(--primary));
  content: " ";
  -webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
}
.animated-bar-button span:after {
  -webkit-transform: translateY(250%);
  transform: translateY(250%);
}
.animated-bar-button span:before {
  -webkit-transform: translateY(-250%);
  transform: translateY(-250%);
}
.open-mobile-menu .animated-bar-button span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: transparent;
  content: " ";
  -webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
}
.open-mobile-menu .animated-bar-button span:after, .open-mobile-menu .animated-bar-button span:before {
  position: absolute;
  left: 0;
  width: 100%;
  height: 4px;
  background-color: var(--burger_button_color_hover, var(--primary-hover));
  content: " ";
  -webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
}
.open-mobile-menu .animated-bar-button span:after {
  -webkit-transform: translateY(0) rotate(-45deg);
  transform: translateY(0) rotate(-45deg);
}
.open-mobile-menu .animated-bar-button span:before {
  -webkit-transform: translateY(0) rotate(45deg);
  transform: translateY(0) rotate(45deg);
}

.bg-primary {
  background-color: var(--primary-bg);
}
.bg-primary.bg-contrast-color {
  color: var(--primary-bg-text);
}

.bg-secondary {
  background-color: var(--secondary-bg);
}
.bg-secondary.bg-contrast-color {
  color: var(--secondary-bg-text);
}

.bg-default-text {
  background-color: var(--default-text-bg);
}
.bg-default-text.bg-contrast-color {
  color: var(--default-text-bg-text);
}

.bg-light {
  background-color: var(--light-bg);
}
.bg-light.bg-contrast-color {
  color: var(--light-bg-text);
}

.bg-dark {
  background-color: var(--dark-bg);
}
.bg-dark.bg-contrast-color {
  color: var(--dark-bg-text);
}

.bg-error {
  background-color: var(--error-bg);
}
.bg-error.bg-contrast-color {
  color: var(--error-bg-text);
}

.bg-success {
  background-color: var(--success-bg);
}
.bg-success.bg-contrast-color {
  color: var(--success-bg-text);
}

.bg-spa {
  background-color: var(--spa-bg);
}
.bg-spa.bg-contrast-color {
  color: var(--spa-bg-text);
}

.bg-hygromatik {
  background-color: var(--hygromatik-bg);
}
.bg-hygromatik.bg-contrast-color {
  color: var(--hygromatik-bg-text);
}

.bg-carel {
  background-color: var(--carel-bg);
}
.bg-carel.bg-contrast-color {
  color: var(--carel-bg-text);
}

.bg-body-bg {
  background-color: var(--body-bg-bg);
}
.bg-body-bg.bg-contrast-color {
  color: var(--body-bg-bg-text);
}

.bg-form-bg {
  background-color: var(--form-bg-bg);
}
.bg-form-bg.bg-contrast-color {
  color: var(--form-bg-bg-text);
}

.bg-brand-1 {
  background-color: var(--brand-1-bg);
}
.bg-brand-1.bg-contrast-color {
  color: var(--brand-1-bg-text);
}

.bg-brand-2 {
  background-color: var(--brand-2-bg);
}
.bg-brand-2.bg-contrast-color {
  color: var(--brand-2-bg-text);
}

.bg-brand-3 {
  background-color: var(--brand-3-bg);
}
.bg-brand-3.bg-contrast-color {
  color: var(--brand-3-bg-text);
}

.bg-white {
  background-color: var(--white-bg);
}
.bg-white.bg-contrast-color {
  color: var(--white-bg-text);
}

.bg-black {
  background-color: var(--black-bg);
}
.bg-black.bg-contrast-color {
  color: var(--black-bg-text);
}

.bg-nav-line {
  background-color: var(--nav-line-bg);
}
.bg-nav-line.bg-contrast-color {
  color: var(--nav-line-bg-text);
}

.bg-accent-color {
  background-color: var(--accent-color-bg);
}
.bg-accent-color.bg-contrast-color {
  color: var(--accent-color-bg-text);
}

.row-with-bg-gradient {
  background: linear-gradient(to bottom, var(--bg-gradient-first) 0%, var(--bg-gradient-first) 50%, var(--bg-gradient-second, var(--body-bg)) 50%, var(--bg-gradient-second, var(--body-bg)) 100%);
}

.border {
  border: 1px solid #28A144;
}

.border-primary {
  border-color: var(--primary-border);
}

.border-secondary {
  border-color: var(--secondary-border);
}

.border-default-text {
  border-color: var(--default-text-border);
}

.border-light {
  border-color: var(--light-border);
}

.border-dark {
  border-color: var(--dark-border);
}

.border-error {
  border-color: var(--error-border);
}

.border-success {
  border-color: var(--success-border);
}

.border-spa {
  border-color: var(--spa-border);
}

.border-hygromatik {
  border-color: var(--hygromatik-border);
}

.border-carel {
  border-color: var(--carel-border);
}

.border-body-bg {
  border-color: var(--body-bg-border);
}

.border-form-bg {
  border-color: var(--form-bg-border);
}

.border-brand-1 {
  border-color: var(--brand-1-border);
}

.border-brand-2 {
  border-color: var(--brand-2-border);
}

.border-brand-3 {
  border-color: var(--brand-3-border);
}

.border-white {
  border-color: var(--white-border);
}

.border-black {
  border-color: var(--black-border);
}

.border-nav-line {
  border-color: var(--nav-line-border);
}

.border-accent-color {
  border-color: var(--accent-color-border);
}

.color-primary {
  color: var(--primary);
}
.color-primary a {
  color: var(--primary-contrast);
}

.color-secondary {
  color: var(--secondary);
}
.color-secondary a {
  color: var(--secondary-contrast);
}

.color-default-text {
  color: var(--default-text);
}
.color-default-text a {
  color: var(--default-text-contrast);
}

.color-light {
  color: var(--light);
}
.color-light a {
  color: var(--light-contrast);
}

.color-dark {
  color: var(--dark);
}
.color-dark a {
  color: var(--dark-contrast);
}

.color-error {
  color: var(--error);
}
.color-error a {
  color: var(--error-contrast);
}

.color-success {
  color: var(--success);
}
.color-success a {
  color: var(--success-contrast);
}

.color-spa {
  color: var(--spa);
}
.color-spa a {
  color: var(--spa-contrast);
}

.color-hygromatik {
  color: var(--hygromatik);
}
.color-hygromatik a {
  color: var(--hygromatik-contrast);
}

.color-carel {
  color: var(--carel);
}
.color-carel a {
  color: var(--carel-contrast);
}

.color-body-bg {
  color: var(--body-bg);
}
.color-body-bg a {
  color: var(--body-bg-contrast);
}

.color-form-bg {
  color: var(--form-bg);
}
.color-form-bg a {
  color: var(--form-bg-contrast);
}

.color-brand-1 {
  color: var(--brand-1);
}
.color-brand-1 a {
  color: var(--brand-1-contrast);
}

.color-brand-2 {
  color: var(--brand-2);
}
.color-brand-2 a {
  color: var(--brand-2-contrast);
}

.color-brand-3 {
  color: var(--brand-3);
}
.color-brand-3 a {
  color: var(--brand-3-contrast);
}

.color-white {
  color: var(--white);
}
.color-white a {
  color: var(--white-contrast);
}

.color-black {
  color: var(--black);
}
.color-black a {
  color: var(--black-contrast);
}

.color-nav-line {
  color: var(--nav-line);
}
.color-nav-line a {
  color: var(--nav-line-contrast);
}

.color-accent-color {
  color: var(--accent-color);
}
.color-accent-color a {
  color: var(--accent-color-contrast);
}

.content_row_outer {
  scroll-margin-top: var(--header-height);
}
.content_row_outer.row-with-bg-color {
  background-color: var(--row-bg-color, #fff);
}
.content_row_outer.effect {
  --intersection-ratio: 1;
  --effect-offset: 0;
}
.content_row_outer[id] {
  content-visibility: visible;
}

/*
@media (prefers-reduced-motion) {
  .content_row_outer,
  .content_row {
    &.effect {
      --intersection-ratio: 1!important;
    }
  }
}
 */
.content_row {
  display: grid;
  gap: var(--row-gap, 2rem);
  grid-template-columns: repeat(12, 1fr);
  max-width: 1840px;
  margin: 0 auto;
}
.content_row.full-width {
  max-width: 100%;
}
.content_row.restricted-width {
  max-width: 1472px;
}
.content_row.devider {
  border-bottom: 1px solid var(--devider-color, var(--primary));
}
.content_row:has(.slidy-container) {
  max-width: min(100vw - min(4.1666666667vw, 80px), 1840px + min(2.0833333333vw, 40px));
}

.content_row_outer.has-devider {
  border-bottom: 1px solid var(--primary);
}

.content_row .content_container {
  display: inline-block;
  width: 100%;
  vertical-align: top;
  box-sizing: border-box;
  padding: var(--container-pad, 0);
  background-color: color-mix(in srgb, var(--container-bg-color, transparent) var(--container-bg-opacity, 100%), transparent);
}
.content_row .content_container[style*="--container-bg-blur"]:not([style*="--container-bg-blur: 0px"]) {
  backdrop-filter: blur(var(--container-bg-blur, 0px));
}

.content_row_outer .content_row_image_overlay {
  display: none;
}

.content_row_outer.bg-image-enable {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  position: relative;
}
.content_row_outer.bg-image-enable .content_row {
  background-image: none !important;
}
.content_row_outer.bg-image-enable.bg-image-attachment-fixed {
  background-attachment: fixed;
}
@media screen and (max-width: 1800px) {
  .content_row_outer.bg-image-enable {
    --container-pad: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_row_outer.bg-image-enable.bg-image-mobile-self-sized {
    aspect-ratio: var(--background-image-ratio, 1);
  }
  .content_row_outer.bg-image-enable.bg-image-mobile-self-sized.full-height {
    min-height: auto;
  }
}
.content_row_outer.bg-image-enable .content_row_image_overlay {
  display: block;
  position: absolute;
  left: 2rem;
  top: 2rem;
  border: 2px solid #fff;
  opacity: 0.6;
  width: 300px;
  height: 168px;
  background-size: cover;
  background-attachment: unset;
  background-repeat: no-repeat;
  cursor: pointer;
  transition: opacity 0.4s, background-color 0.4s;
  backdrop-filter: blur(4px);
}
.content_row_outer.bg-image-enable .content_row_image_overlay:hover {
  opacity: 1;
  background-color: transparent;
  backdrop-filter: none;
}

.content_row_outer .brick-select-button {
  position: absolute;
  top: 14px;
  right: 14px;
}

.content_row.row-layout-overlap-left .content_container:first-child {
  width: minmax(120%, 1840px) !important;
  z-index: 1;
}

.content_row.row-layout-overlap-right .content_container:last-child {
  width: minmax(120%, 1840px) !important;
  margin-left: -20%;
  z-index: 1;
}

.content_row_outer.full-height {
  min-height: calc(100vh - var(--header-height, 0px));
}
.content_row_outer.full-height:first-child {
  min-height: 100vh;
}
.content_row_outer.full-height.vertical-align-top {
  display: flex;
  align-items: start;
}
.content_row_outer.full-height.vertical-align-center {
  display: flex;
  align-items: center;
}
.content_row_outer.full-height.vertical-align-bottom {
  display: flex;
  align-items: end;
}
.content_row_outer.full-height.horizontal-align-left {
  display: flex;
  justify-content: left;
}
.content_row_outer.full-height.horizontal-align-center {
  display: flex;
  justify-content: center;
}
.content_row_outer.full-height.horizontal-align-right {
  display: flex;
  justify-content: right;
}

.content_row {
  align-items: start;
}
.content_row.container-align-top {
  align-items: start;
}
.content_row.container-align-center {
  align-items: center;
}
.content_row.container-align-bottom {
  align-items: flex-end;
}
.content_row.container-stretch {
  justify-content: stretch;
  align-items: stretch;
}
.content_row.container-stretch.container-align-top .content_container {
  display: flex;
  justify-content: start;
  flex-direction: column;
}
.content_row.container-stretch.container-align-center .content_container {
  display: flex;
  justify-content: center;
  flex-direction: column;
}
.content_row.container-stretch.container-align-bottom .content_container {
  display: flex;
  justify-content: end;
  flex-direction: column;
}
.content_row.container-stretch.container-align-between .content_container {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
.content_row.container-stretch.container-align-around .content_container {
  display: flex;
  justify-content: space-around;
  flex-direction: column;
  font-size: 1rem;
}
.content_row.container-stretch .content_element {
  height: 100%;
}

.content_row .content_container {
  display: flex;
  flex-direction: column;
  width: 100%;
  vertical-align: top;
  box-sizing: border-box;
  grid-column: auto/span 12;
  box-shadow: 0 0 var(--container-shadow-width, 0) var(--shadow-color);
}
.content_row .content_container .content_element {
  width: 100%;
}

.content_row .content_container.w_100 {
  grid-column: auto/span 12;
  --container-max-width: 1840px;
}

.content_row .content_container.w_66 {
  grid-column: auto/span 8;
  --container-max-width: calc(1214px - (var(--row-gap, 0rem) * 0.34));
}

.content_row .content_container.w_50 {
  grid-column: auto/span 6;
  --container-max-width: calc(920px - (var(--row-gap, 0rem) * 0.5));
}

.content_row .content_container.w_33 {
  grid-column: auto/span 4;
  --container-max-width: calc(607px - (var(--row-gap, 0rem) * 0.67));
}

.content_row .content_container.w_25 {
  grid-column: auto/span 3;
  --container-max-width: calc(460px - (var(--row-gap, 0rem) * 0.75));
}

.content_row .content_container.limit-content-width .content_element {
  max-width: var(--container-max-width, 100%);
}

.content_row .content_element.indented {
  max-width: var(--container-max-width, 100%);
  align-self: var(--element-align, start);
}

@media screen and (max-width: 1800px) {
  .content_row:not(.bg-image-enable) {
    margin-left: 2rem;
    margin-right: 2rem;
  }
  .content_row.full-width .content_element:not(:has(img)),
  .content_row.bg-image-enable .content_element:not(:has(img)) {
    width: calc(100% - 2rem - 2rem);
    margin-left: 2rem;
    margin-right: 2rem;
  }
  .content_row:has(.slidy-container) {
    max-width: 100%;
    margin-right: min(40px * var(--slidy-scale), 40px);
    margin-left: min(40px * var(--slidy-scale), 40px);
  }
}
@media screen and (max-width: 720px) {
  .content_row {
    display: flex;
    flex-direction: column;
  }
  .content_row .content_container.w_100,
  .content_row .content_container.w_66,
  .content_row .content_container.w_50,
  .content_row .content_container.w_33,
  .content_row .content_container.w_25 {
    grid-column: auto/span 12;
  }
  .content_row.row-layout-overlap-left .content_container:first-child,
  .content_row.row-layout-overlap-right .content_container:last-child {
    width: 100% !important;
    margin-left: 0;
    margin-right: 0;
    z-index: 1;
  }
  .content_row:not(.bg-image-enable) {
    margin-left: 1rem;
    margin-right: 1rem;
  }
  .content_row.full-width .content_element:not(:has(img)),
  .content_row.bg-image-enable .content_element:not(:has(img)) {
    width: calc(100% - 1rem - 1rem);
    margin-left: 1rem;
    margin-right: 1rem;
  }
  .content_row:has(.slidy-container) {
    margin-right: min(80px * var(--slidy-scale), 80px);
    margin-left: min(80px * var(--slidy-scale), 80px);
  }
}
.content_row_outer.effect:not(.intersected) * {
  transition: none !important;
}

.content_row_outer.effect.effect-fade-in .content_container {
  --raw-effect: calc(1 - (1 - var(--intersection-ratio)) * (1 - var(--intersection-ratio)));
  --scaled-effect: calc((var(--raw-effect) - var(--effect-offset)) / (1 - var(--effect-offset)));
  --effect-value: max(0, min(1, var(--scaled-effect)));
  opacity: var(--effect-value);
}

.content_row_outer.effect.effect-snap-in .content_container {
  --raw-effect: calc(1 - (1 - var(--intersection-ratio)) * (1 - var(--intersection-ratio)));
  --scaled-effect: calc((var(--raw-effect) - var(--effect-offset)) / (1 - var(--effect-offset)));
  --effect-value: max(0, min(1, var(--scaled-effect)));
  overflow: hidden;
}
.content_row_outer.effect.effect-snap-in .content_container .content_element {
  transform: translateY(calc((1 - var(--effect-value, 0)) * 100%)) translateX(0);
  transform-origin: 0 0;
}
.content_row_outer.effect.effect-snap-in .content_container:first-child .content_element {
  transform: translateY(0) translateX(calc((1 - var(--effect-value, 0)) * -100%));
}
.content_row_outer.effect.effect-snap-in .content_container:last-child .content_element {
  transform: translateY(0) translateX(calc((1 - var(--effect-value, 0)) * 100%));
}

.content_row_outer.effect.effect-pop-in .content_container {
  overflow: hidden;
  --animated-index: var(--container-index);
  --effect-value: max(0, min(1, var(--intersection-ratio)));
}
.content_row_outer.effect.effect-pop-in .content_container .content_element {
  --eased-value: round(up, var(--effect-value), 1);
  transition: opacity 0.4s;
  transition-delay: calc(var(--animated-index) * 0.4s);
  transition-timing-function: ease-in;
  opacity: var(--eased-value);
  transform: scale(calc(0.95 + 0.05 * var(--eased-value)));
}
.content_row_outer.effect.effect-pop-in[data-intersection-direction=out] .content_container {
  --animated-index: calc(var(--container-count) - 1 - var(--container-index));
}

.content_row_outer.effect.effect-ltr-in {
  --intersection-direction: 0;
}
.content_row_outer.effect.effect-ltr-in .content_container {
  overflow: hidden;
  --raw-effect: calc(1 - (1 - var(--intersection-ratio)) * (1 - var(--intersection-ratio)));
  --scaled-effect: calc((var(--raw-effect) - var(--effect-offset)) / (1 - var(--effect-offset)));
  --effect-value: max(0, min(1, var(--scaled-effect)));
}
.content_row_outer.effect.effect-ltr-in .content_container .content_element {
  transform: translateX(calc(var(--intersection-direction, 0) * (1 - var(--effect-value, 1)) * 100%));
}

.message {
  display: block;
  padding: 0.375rem 0.75rem;
  font-weight: bold;
}

.message-primary {
  border: 2px solid var(--primary-border);
  background-color: var(--primary-bg);
  color: var(--primary-contrast);
}

.message-secondary {
  border: 2px solid var(--secondary-border);
  background-color: var(--secondary-bg);
  color: var(--secondary-contrast);
}

.message-default-text {
  border: 2px solid var(--default-text-border);
  background-color: var(--default-text-bg);
  color: var(--default-text-contrast);
}

.message-light {
  border: 2px solid var(--light-border);
  background-color: var(--light-bg);
  color: var(--light-contrast);
}

.message-dark {
  border: 2px solid var(--dark-border);
  background-color: var(--dark-bg);
  color: var(--dark-contrast);
}

.message-error {
  border: 2px solid var(--error-border);
  background-color: var(--error-bg);
  color: var(--error-contrast);
}

.message-success {
  border: 2px solid var(--success-border);
  background-color: var(--success-bg);
  color: var(--success-contrast);
}

.message-spa {
  border: 2px solid var(--spa-border);
  background-color: var(--spa-bg);
  color: var(--spa-contrast);
}

.message-hygromatik {
  border: 2px solid var(--hygromatik-border);
  background-color: var(--hygromatik-bg);
  color: var(--hygromatik-contrast);
}

.message-carel {
  border: 2px solid var(--carel-border);
  background-color: var(--carel-bg);
  color: var(--carel-contrast);
}

.message-body-bg {
  border: 2px solid var(--body-bg-border);
  background-color: var(--body-bg-bg);
  color: var(--body-bg-contrast);
}

.message-form-bg {
  border: 2px solid var(--form-bg-border);
  background-color: var(--form-bg-bg);
  color: var(--form-bg-contrast);
}

.message-brand-1 {
  border: 2px solid var(--brand-1-border);
  background-color: var(--brand-1-bg);
  color: var(--brand-1-contrast);
}

.message-brand-2 {
  border: 2px solid var(--brand-2-border);
  background-color: var(--brand-2-bg);
  color: var(--brand-2-contrast);
}

.message-brand-3 {
  border: 2px solid var(--brand-3-border);
  background-color: var(--brand-3-bg);
  color: var(--brand-3-contrast);
}

.message-white {
  border: 2px solid var(--white-border);
  background-color: var(--white-bg);
  color: var(--white-contrast);
}

.message-black {
  border: 2px solid var(--black-border);
  background-color: var(--black-bg);
  color: var(--black-contrast);
}

.message-nav-line {
  border: 2px solid var(--nav-line-border);
  background-color: var(--nav-line-bg);
  color: var(--nav-line-contrast);
}

.message-accent-color {
  border: 2px solid var(--accent-color-border);
  background-color: var(--accent-color-bg);
  color: var(--accent-color-contrast);
}

.moving-overlay {
  display: none;
  position: fixed;
  justify-content: center;
  align-items: center;
  width: 100vw;
  height: 100vh;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--moving-overlay-bg, var(--body-bg));
  color: #fff;
  flex-direction: column;
  z-index: 105;
}
.moving-overlay .moving-overlay-header {
  font-size: 2rem;
  flex-grow: 0;
  text-align: right;
  padding: 0 0.375rem;
  background-color: var(--bg-header);
}
.moving-overlay .moving-overlay-header .moving-overlay-close {
  display: block;
  line-height: 1;
  cursor: pointer;
}
.moving-overlay .moving-overlay-body {
  width: 100%;
  flex-grow: 1;
  overflow-y: scroll;
  max-width: 1840px;
  margin: 0 auto;
}
.moving-overlay .moving-overlay-loader {
  display: none;
  justify-content: center;
  align-items: center;
  font-size: 4rem;
  color: var(--secondary);
  height: 100%;
  flex-grow: 1;
}
.moving-overlay.loading .moving-overlay-body {
  display: none;
}
.moving-overlay.loading .moving-overlay-loader {
  display: flex;
}

.popup::backdrop {
  background-color: color-mix(in srgb, var(--body-bg) 30%, transparent);
  backdrop-filter: blur(2px);
  width: 100vw;
  height: 100vh;
}
.popup .popup-content {
  background-color: var(--body-bg);
  box-shadow: var(--body-bg-contrast);
  min-width: 220px;
}
.popup .popup-header {
  padding: 0.375rem 0.75rem;
  text-align: right;
}
.popup .popup-header .close-button {
  cursor: pointer;
}
.popup .popup-body {
  padding: 0.375rem 0.75rem;
}
.popup .popup-body .headline {
  color: var(--headline-color, var(--text-color));
}
.popup.popup-fullscreen .popup-content {
  width: 100%;
  height: 100%;
}

dialog {
  background-color: transparent;
  border: 0;
}

dialog:modal {
  width: 100vw;
  max-width: 100vw;
  height: 100vh;
  max-height: 100vh;
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.row {
  --row-gutter-x: 1.5rem;
  --row-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--row-gutter-y));
  margin-right: calc(-0.5 * var(--row-gutter-x));
  margin-left: calc(-0.5 * var(--row-gutter-x));
}
.row > * {
  flex-shrink: 1;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--row-gutter-x) * 0.5);
  padding-left: calc(var(--row-gutter-x) * 0.5);
  margin-top: var(--row-gutter-y);
}

.col {
  flex: 1 0 0%;
}

.row-cols-auto > * {
  flex: 0 0 auto;
  width: auto;
}

.row-cols-1 > * {
  flex: 0 0 auto;
  width: 100%;
}

.row-cols-2 > * {
  flex: 0 0 auto;
  width: 50%;
}

.row-cols-3 > * {
  flex: 0 0 auto;
  width: 33.3333333333%;
}

.row-cols-4 > * {
  flex: 0 0 auto;
  width: 25%;
}

.row-cols-5 > * {
  flex: 0 0 auto;
  width: 20%;
}

.row-cols-6 > * {
  flex: 0 0 auto;
  width: 16.6666666667%;
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
}

.col-1 {
  flex: 0 0 auto;
  width: 8.33333333%;
}

.col-2 {
  flex: 0 0 auto;
  width: 16.66666667%;
}

.col-3 {
  flex: 0 0 auto;
  width: 25%;
}

.col-4 {
  flex: 0 0 auto;
  width: 33.33333333%;
}

.col-5 {
  flex: 0 0 auto;
  width: 41.66666667%;
}

.col-6 {
  flex: 0 0 auto;
  width: 50%;
}

.col-7 {
  flex: 0 0 auto;
  width: 58.33333333%;
}

.col-8 {
  flex: 0 0 auto;
  width: 66.66666667%;
}

.col-9 {
  flex: 0 0 auto;
  width: 75%;
}

.col-10 {
  flex: 0 0 auto;
  width: 83.33333333%;
}

.col-11 {
  flex: 0 0 auto;
  width: 91.66666667%;
}

.col-12 {
  flex: 0 0 auto;
  width: 100%;
}

.offset-1 {
  margin-left: 8.33333333%;
}

.offset-2 {
  margin-left: 16.66666667%;
}

.offset-3 {
  margin-left: 25%;
}

.offset-4 {
  margin-left: 33.33333333%;
}

.offset-5 {
  margin-left: 41.66666667%;
}

.offset-6 {
  margin-left: 50%;
}

.offset-7 {
  margin-left: 58.33333333%;
}

.offset-8 {
  margin-left: 66.66666667%;
}

.offset-9 {
  margin-left: 75%;
}

.offset-10 {
  margin-left: 83.33333333%;
}

.offset-11 {
  margin-left: 91.66666667%;
}

.g-0,
.gx-0 {
  --row-gutter-x: 0rem;
}

.g-0,
.gy-0 {
  --row-gutter-y: 0rem;
}

.g-1,
.gx-1 {
  --row-gutter-x: 0.5rem;
}

.g-1,
.gy-1 {
  --row-gutter-y: 0.5rem;
}

.g-2,
.gx-2 {
  --row-gutter-x: 1rem;
}

.g-2,
.gy-2 {
  --row-gutter-y: 1rem;
}

.g-3,
.gx-3 {
  --row-gutter-x: 2rem;
}

.g-3,
.gy-3 {
  --row-gutter-y: 2rem;
}

.g-4,
.gx-4 {
  --row-gutter-x: 3rem;
}

.g-4,
.gy-4 {
  --row-gutter-y: 3rem;
}

.g-5,
.gx-5 {
  --row-gutter-x: 6rem;
}

.g-5,
.gy-5 {
  --row-gutter-y: 6rem;
}

@media (min-width: 720px) {
  .col-sm {
    flex: 1 0 0%;
  }
  .row-cols-sm-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-sm-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-sm-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-sm-3 > * {
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .row-cols-sm-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-sm-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-sm-6 > * {
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-sm-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-sm-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-sm-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-sm-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-sm-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-sm-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-sm-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-sm-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-sm-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-sm-0 {
    margin-left: 0;
  }
  .offset-sm-1 {
    margin-left: 8.33333333%;
  }
  .offset-sm-2 {
    margin-left: 16.66666667%;
  }
  .offset-sm-3 {
    margin-left: 25%;
  }
  .offset-sm-4 {
    margin-left: 33.33333333%;
  }
  .offset-sm-5 {
    margin-left: 41.66666667%;
  }
  .offset-sm-6 {
    margin-left: 50%;
  }
  .offset-sm-7 {
    margin-left: 58.33333333%;
  }
  .offset-sm-8 {
    margin-left: 66.66666667%;
  }
  .offset-sm-9 {
    margin-left: 75%;
  }
  .offset-sm-10 {
    margin-left: 83.33333333%;
  }
  .offset-sm-11 {
    margin-left: 91.66666667%;
  }
  .g-sm-0,
  .gx-sm-0 {
    --row-gutter-x: 0rem;
  }
  .g-sm-0,
  .gy-sm-0 {
    --row-gutter-y: 0rem;
  }
  .g-sm-1,
  .gx-sm-1 {
    --row-gutter-x: 0.5rem;
  }
  .g-sm-1,
  .gy-sm-1 {
    --row-gutter-y: 0.5rem;
  }
  .g-sm-2,
  .gx-sm-2 {
    --row-gutter-x: 1rem;
  }
  .g-sm-2,
  .gy-sm-2 {
    --row-gutter-y: 1rem;
  }
  .g-sm-3,
  .gx-sm-3 {
    --row-gutter-x: 2rem;
  }
  .g-sm-3,
  .gy-sm-3 {
    --row-gutter-y: 2rem;
  }
  .g-sm-4,
  .gx-sm-4 {
    --row-gutter-x: 3rem;
  }
  .g-sm-4,
  .gy-sm-4 {
    --row-gutter-y: 3rem;
  }
  .g-sm-5,
  .gx-sm-5 {
    --row-gutter-x: 6rem;
  }
  .g-sm-5,
  .gy-sm-5 {
    --row-gutter-y: 6rem;
  }
}
@media (min-width: 1024px) {
  .col-md {
    flex: 1 0 0%;
  }
  .row-cols-md-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-md-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-md-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-md-3 > * {
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .row-cols-md-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-md-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-md-6 > * {
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-md-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-md-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-md-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-md-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-md-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-md-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-md-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-md-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.33333333%;
  }
  .offset-md-2 {
    margin-left: 16.66666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.33333333%;
  }
  .offset-md-5 {
    margin-left: 41.66666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.33333333%;
  }
  .offset-md-8 {
    margin-left: 66.66666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.33333333%;
  }
  .offset-md-11 {
    margin-left: 91.66666667%;
  }
  .g-md-0,
  .gx-md-0 {
    --row-gutter-x: 0rem;
  }
  .g-md-0,
  .gy-md-0 {
    --row-gutter-y: 0rem;
  }
  .g-md-1,
  .gx-md-1 {
    --row-gutter-x: 0.5rem;
  }
  .g-md-1,
  .gy-md-1 {
    --row-gutter-y: 0.5rem;
  }
  .g-md-2,
  .gx-md-2 {
    --row-gutter-x: 1rem;
  }
  .g-md-2,
  .gy-md-2 {
    --row-gutter-y: 1rem;
  }
  .g-md-3,
  .gx-md-3 {
    --row-gutter-x: 2rem;
  }
  .g-md-3,
  .gy-md-3 {
    --row-gutter-y: 2rem;
  }
  .g-md-4,
  .gx-md-4 {
    --row-gutter-x: 3rem;
  }
  .g-md-4,
  .gy-md-4 {
    --row-gutter-y: 3rem;
  }
  .g-md-5,
  .gx-md-5 {
    --row-gutter-x: 6rem;
  }
  .g-md-5,
  .gy-md-5 {
    --row-gutter-y: 6rem;
  }
}
@media (min-width: 1500px) {
  .col-lg {
    flex: 1 0 0%;
  }
  .row-cols-lg-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-lg-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-lg-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-lg-3 > * {
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .row-cols-lg-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-lg-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-lg-6 > * {
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-lg-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-lg-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-lg-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-lg-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-lg-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-lg-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-lg-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-lg-0 {
    margin-left: 0;
  }
  .offset-lg-1 {
    margin-left: 8.33333333%;
  }
  .offset-lg-2 {
    margin-left: 16.66666667%;
  }
  .offset-lg-3 {
    margin-left: 25%;
  }
  .offset-lg-4 {
    margin-left: 33.33333333%;
  }
  .offset-lg-5 {
    margin-left: 41.66666667%;
  }
  .offset-lg-6 {
    margin-left: 50%;
  }
  .offset-lg-7 {
    margin-left: 58.33333333%;
  }
  .offset-lg-8 {
    margin-left: 66.66666667%;
  }
  .offset-lg-9 {
    margin-left: 75%;
  }
  .offset-lg-10 {
    margin-left: 83.33333333%;
  }
  .offset-lg-11 {
    margin-left: 91.66666667%;
  }
  .g-lg-0,
  .gx-lg-0 {
    --row-gutter-x: 0rem;
  }
  .g-lg-0,
  .gy-lg-0 {
    --row-gutter-y: 0rem;
  }
  .g-lg-1,
  .gx-lg-1 {
    --row-gutter-x: 0.5rem;
  }
  .g-lg-1,
  .gy-lg-1 {
    --row-gutter-y: 0.5rem;
  }
  .g-lg-2,
  .gx-lg-2 {
    --row-gutter-x: 1rem;
  }
  .g-lg-2,
  .gy-lg-2 {
    --row-gutter-y: 1rem;
  }
  .g-lg-3,
  .gx-lg-3 {
    --row-gutter-x: 2rem;
  }
  .g-lg-3,
  .gy-lg-3 {
    --row-gutter-y: 2rem;
  }
  .g-lg-4,
  .gx-lg-4 {
    --row-gutter-x: 3rem;
  }
  .g-lg-4,
  .gy-lg-4 {
    --row-gutter-y: 3rem;
  }
  .g-lg-5,
  .gx-lg-5 {
    --row-gutter-x: 6rem;
  }
  .g-lg-5,
  .gy-lg-5 {
    --row-gutter-y: 6rem;
  }
}
@media (min-width: 1800px) {
  .col-xl {
    flex: 1 0 0%;
  }
  .row-cols-xl-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-xl-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-xl-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-xl-3 > * {
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .row-cols-xl-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-xl-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-xl-6 > * {
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xl-0 {
    margin-left: 0;
  }
  .offset-xl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xl-3 {
    margin-left: 25%;
  }
  .offset-xl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xl-6 {
    margin-left: 50%;
  }
  .offset-xl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xl-9 {
    margin-left: 75%;
  }
  .offset-xl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xl-11 {
    margin-left: 91.66666667%;
  }
  .g-xl-0,
  .gx-xl-0 {
    --row-gutter-x: 0rem;
  }
  .g-xl-0,
  .gy-xl-0 {
    --row-gutter-y: 0rem;
  }
  .g-xl-1,
  .gx-xl-1 {
    --row-gutter-x: 0.5rem;
  }
  .g-xl-1,
  .gy-xl-1 {
    --row-gutter-y: 0.5rem;
  }
  .g-xl-2,
  .gx-xl-2 {
    --row-gutter-x: 1rem;
  }
  .g-xl-2,
  .gy-xl-2 {
    --row-gutter-y: 1rem;
  }
  .g-xl-3,
  .gx-xl-3 {
    --row-gutter-x: 2rem;
  }
  .g-xl-3,
  .gy-xl-3 {
    --row-gutter-y: 2rem;
  }
  .g-xl-4,
  .gx-xl-4 {
    --row-gutter-x: 3rem;
  }
  .g-xl-4,
  .gy-xl-4 {
    --row-gutter-y: 3rem;
  }
  .g-xl-5,
  .gx-xl-5 {
    --row-gutter-x: 6rem;
  }
  .g-xl-5,
  .gy-xl-5 {
    --row-gutter-y: 6rem;
  }
}
.padding-min {
  padding: 2rem;
}

.content_element.padding-top-min,
.content_row.padding-top-min {
  padding-top: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-top-min,
  .content_row.padding-top-min {
    padding-top: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-top-min,
  .content_row.padding-top-min {
    padding-top: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-top-min,
  .content_row.padding-top-min {
    padding-top: 0.5rem;
  }
}

.content_element.margin-top-min,
.content_row.margin-top-min {
  margin-top: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-top-min,
  .content_row.margin-top-min {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-top-min,
  .content_row.margin-top-min {
    margin-top: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-top-min,
  .content_row.margin-top-min {
    margin-top: 0.5rem;
  }
}

.padding-oben-min {
  padding-top: 2rem;
}

.content_element.padding-bottom-min,
.content_row.padding-bottom-min {
  padding-bottom: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-bottom-min,
  .content_row.padding-bottom-min {
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-bottom-min,
  .content_row.padding-bottom-min {
    padding-bottom: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-bottom-min,
  .content_row.padding-bottom-min {
    padding-bottom: 0.5rem;
  }
}

.content_element.margin-bottom-min,
.content_row.margin-bottom-min {
  margin-bottom: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-bottom-min,
  .content_row.margin-bottom-min {
    margin-bottom: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-bottom-min,
  .content_row.margin-bottom-min {
    margin-bottom: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-bottom-min,
  .content_row.margin-bottom-min {
    margin-bottom: 0.5rem;
  }
}

.padding-unten-min {
  padding-bottom: 2rem;
}

.content_element.padding-left-min,
.content_row.padding-left-min {
  padding-left: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-left-min,
  .content_row.padding-left-min {
    padding-left: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-left-min,
  .content_row.padding-left-min {
    padding-left: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-left-min,
  .content_row.padding-left-min {
    padding-left: 0.5rem;
  }
}

.content_element.margin-left-min,
.content_row.margin-left-min {
  margin-left: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-left-min,
  .content_row.margin-left-min {
    margin-left: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-left-min,
  .content_row.margin-left-min {
    margin-left: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-left-min,
  .content_row.margin-left-min {
    margin-left: 0.5rem;
  }
}

.padding-links-min {
  padding-left: 2rem;
}

.content_element.padding-right-min,
.content_row.padding-right-min {
  padding-right: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-right-min,
  .content_row.padding-right-min {
    padding-right: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-right-min,
  .content_row.padding-right-min {
    padding-right: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-right-min,
  .content_row.padding-right-min {
    padding-right: 0.5rem;
  }
}

.content_element.margin-right-min,
.content_row.margin-right-min {
  margin-right: 2rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-right-min,
  .content_row.margin-right-min {
    margin-right: 2rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-right-min,
  .content_row.margin-right-min {
    margin-right: 1.5rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-right-min,
  .content_row.margin-right-min {
    margin-right: 0.5rem;
  }
}

.padding-rechts-min {
  padding-right: 2rem;
}

.padding-med {
  padding: 4rem;
}

.content_element.padding-top-med,
.content_row.padding-top-med {
  padding-top: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-top-med,
  .content_row.padding-top-med {
    padding-top: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-top-med,
  .content_row.padding-top-med {
    padding-top: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-top-med,
  .content_row.padding-top-med {
    padding-top: 1rem;
  }
}

.content_element.margin-top-med,
.content_row.margin-top-med {
  margin-top: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-top-med,
  .content_row.margin-top-med {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-top-med,
  .content_row.margin-top-med {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-top-med,
  .content_row.margin-top-med {
    margin-top: 1rem;
  }
}

.padding-oben-med {
  padding-top: 4rem;
}

.content_element.padding-bottom-med,
.content_row.padding-bottom-med {
  padding-bottom: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-bottom-med,
  .content_row.padding-bottom-med {
    padding-bottom: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-bottom-med,
  .content_row.padding-bottom-med {
    padding-bottom: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-bottom-med,
  .content_row.padding-bottom-med {
    padding-bottom: 1rem;
  }
}

.content_element.margin-bottom-med,
.content_row.margin-bottom-med {
  margin-bottom: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-bottom-med,
  .content_row.margin-bottom-med {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-bottom-med,
  .content_row.margin-bottom-med {
    margin-bottom: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-bottom-med,
  .content_row.margin-bottom-med {
    margin-bottom: 1rem;
  }
}

.padding-unten-med {
  padding-bottom: 4rem;
}

.content_element.padding-left-med,
.content_row.padding-left-med {
  padding-left: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-left-med,
  .content_row.padding-left-med {
    padding-left: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-left-med,
  .content_row.padding-left-med {
    padding-left: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-left-med,
  .content_row.padding-left-med {
    padding-left: 1rem;
  }
}

.content_element.margin-left-med,
.content_row.margin-left-med {
  margin-left: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-left-med,
  .content_row.margin-left-med {
    margin-left: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-left-med,
  .content_row.margin-left-med {
    margin-left: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-left-med,
  .content_row.margin-left-med {
    margin-left: 1rem;
  }
}

.padding-links-med {
  padding-left: 4rem;
}

.content_element.padding-right-med,
.content_row.padding-right-med {
  padding-right: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-right-med,
  .content_row.padding-right-med {
    padding-right: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-right-med,
  .content_row.padding-right-med {
    padding-right: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-right-med,
  .content_row.padding-right-med {
    padding-right: 1rem;
  }
}

.content_element.margin-right-med,
.content_row.margin-right-med {
  margin-right: 4rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-right-med,
  .content_row.margin-right-med {
    margin-right: 4rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-right-med,
  .content_row.margin-right-med {
    margin-right: 3rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-right-med,
  .content_row.margin-right-med {
    margin-right: 1rem;
  }
}

.padding-rechts-med {
  padding-right: 4rem;
}

.padding-max {
  padding: 8rem;
}

.content_element.padding-top-max,
.content_row.padding-top-max {
  padding-top: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-top-max,
  .content_row.padding-top-max {
    padding-top: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-top-max,
  .content_row.padding-top-max {
    padding-top: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-top-max,
  .content_row.padding-top-max {
    padding-top: 2rem;
  }
}

.content_element.margin-top-max,
.content_row.margin-top-max {
  margin-top: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-top-max,
  .content_row.margin-top-max {
    margin-top: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-top-max,
  .content_row.margin-top-max {
    margin-top: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-top-max,
  .content_row.margin-top-max {
    margin-top: 2rem;
  }
}

.padding-oben-max {
  padding-top: 8rem;
}

.content_element.padding-bottom-max,
.content_row.padding-bottom-max {
  padding-bottom: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-bottom-max,
  .content_row.padding-bottom-max {
    padding-bottom: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-bottom-max,
  .content_row.padding-bottom-max {
    padding-bottom: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-bottom-max,
  .content_row.padding-bottom-max {
    padding-bottom: 2rem;
  }
}

.content_element.margin-bottom-max,
.content_row.margin-bottom-max {
  margin-bottom: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-bottom-max,
  .content_row.margin-bottom-max {
    margin-bottom: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-bottom-max,
  .content_row.margin-bottom-max {
    margin-bottom: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-bottom-max,
  .content_row.margin-bottom-max {
    margin-bottom: 2rem;
  }
}

.padding-unten-max {
  padding-bottom: 8rem;
}

.content_element.padding-left-max,
.content_row.padding-left-max {
  padding-left: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-left-max,
  .content_row.padding-left-max {
    padding-left: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-left-max,
  .content_row.padding-left-max {
    padding-left: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-left-max,
  .content_row.padding-left-max {
    padding-left: 2rem;
  }
}

.content_element.margin-left-max,
.content_row.margin-left-max {
  margin-left: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-left-max,
  .content_row.margin-left-max {
    margin-left: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-left-max,
  .content_row.margin-left-max {
    margin-left: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-left-max,
  .content_row.margin-left-max {
    margin-left: 2rem;
  }
}

.padding-links-max {
  padding-left: 8rem;
}

.content_element.padding-right-max,
.content_row.padding-right-max {
  padding-right: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.padding-right-max,
  .content_row.padding-right-max {
    padding-right: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.padding-right-max,
  .content_row.padding-right-max {
    padding-right: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.padding-right-max,
  .content_row.padding-right-max {
    padding-right: 2rem;
  }
}

.content_element.margin-right-max,
.content_row.margin-right-max {
  margin-right: 8rem;
}
@media screen and (max-width: 1500px) {
  .content_element.margin-right-max,
  .content_row.margin-right-max {
    margin-right: 8rem;
  }
}
@media screen and (max-width: 1024px) {
  .content_element.margin-right-max,
  .content_row.margin-right-max {
    margin-right: 6rem;
  }
}
@media screen and (max-width: 720px) {
  .content_element.margin-right-max,
  .content_row.margin-right-max {
    margin-right: 2rem;
  }
}

.padding-rechts-max {
  padding-right: 8rem;
}

.p-0 {
  padding: 0rem;
}

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

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

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

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

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

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

.m-0 {
  margin: 0rem;
}

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

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

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

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

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

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

.p-1 {
  padding: 0.5rem;
}

.px-1 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.py-1 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.pt-1 {
  padding-top: 0.5rem;
}

.pr-1 {
  padding-right: 0.5rem;
}

.pb-1 {
  padding-bottom: 0.5rem;
}

.pl-1 {
  padding-left: 0.5rem;
}

.m-1 {
  margin: 0.5rem;
}

.mx-1 {
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

.my-1 {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.mt-1 {
  margin-top: 0.5rem;
}

.mr-1 {
  margin-right: 0.5rem;
}

.mb-1 {
  margin-bottom: 0.5rem;
}

.ml-1 {
  margin-left: 0.5rem;
}

.p-2 {
  padding: 1rem;
}

.px-2 {
  padding-left: 1rem;
  padding-right: 1rem;
}

.py-2 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.pt-2 {
  padding-top: 1rem;
}

.pr-2 {
  padding-right: 1rem;
}

.pb-2 {
  padding-bottom: 1rem;
}

.pl-2 {
  padding-left: 1rem;
}

.m-2 {
  margin: 1rem;
}

.mx-2 {
  margin-left: 1rem;
  margin-right: 1rem;
}

.my-2 {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.mt-2 {
  margin-top: 1rem;
}

.mr-2 {
  margin-right: 1rem;
}

.mb-2 {
  margin-bottom: 1rem;
}

.ml-2 {
  margin-left: 1rem;
}

.p-3 {
  padding: 2rem;
}

.px-3 {
  padding-left: 2rem;
  padding-right: 2rem;
}

.py-3 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.pt-3 {
  padding-top: 2rem;
}

.pr-3 {
  padding-right: 2rem;
}

.pb-3 {
  padding-bottom: 2rem;
}

.pl-3 {
  padding-left: 2rem;
}

.m-3 {
  margin: 2rem;
}

.mx-3 {
  margin-left: 2rem;
  margin-right: 2rem;
}

.my-3 {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.mt-3 {
  margin-top: 2rem;
}

.mr-3 {
  margin-right: 2rem;
}

.mb-3 {
  margin-bottom: 2rem;
}

.ml-3 {
  margin-left: 2rem;
}

.p-4 {
  padding: 3rem;
}

.px-4 {
  padding-left: 3rem;
  padding-right: 3rem;
}

.py-4 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.pt-4 {
  padding-top: 3rem;
}

.pr-4 {
  padding-right: 3rem;
}

.pb-4 {
  padding-bottom: 3rem;
}

.pl-4 {
  padding-left: 3rem;
}

.m-4 {
  margin: 3rem;
}

.mx-4 {
  margin-left: 3rem;
  margin-right: 3rem;
}

.my-4 {
  margin-top: 3rem;
  margin-bottom: 3rem;
}

.mt-4 {
  margin-top: 3rem;
}

.mr-4 {
  margin-right: 3rem;
}

.mb-4 {
  margin-bottom: 3rem;
}

.ml-4 {
  margin-left: 3rem;
}

.p-5 {
  padding: 6rem;
}

.px-5 {
  padding-left: 6rem;
  padding-right: 6rem;
}

.py-5 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.pt-5 {
  padding-top: 6rem;
}

.pr-5 {
  padding-right: 6rem;
}

.pb-5 {
  padding-bottom: 6rem;
}

.pl-5 {
  padding-left: 6rem;
}

.m-5 {
  margin: 6rem;
}

.mx-5 {
  margin-left: 6rem;
  margin-right: 6rem;
}

.my-5 {
  margin-top: 6rem;
  margin-bottom: 6rem;
}

.mt-5 {
  margin-top: 6rem;
}

.mr-5 {
  margin-right: 6rem;
}

.mb-5 {
  margin-bottom: 6rem;
}

.ml-5 {
  margin-left: 6rem;
}

.card-items {
  --headline-font-size:1.4rem;
  display: flex;
  justify-content: start;
  flex-wrap: wrap;
  gap: calc(var(--gap, 2rem) * 2) var(--gap, 2rem);
}
.card-items .card-item {
  --card-columns: var(--grid-columns, 3);
  flex: 1 1 calc((100% - var(--gap, 2rem) * (var(--card-columns, 3) - 1)) / var(--card-columns, 3));
  max-width: calc((100% - var(--gap, 2rem) * (var(--card-columns, 3) - 1)) / var(--card-columns, 3));
}
@media screen and (max-width: 1024px) {
  .card-items .card-item {
    --card-columns:round(up, calc(var(--grid-columns, 3) / 2));
  }
}
@media screen and (max-width: 720px) {
  .card-items .card-item {
    --card-columns: 1;
  }
}
.card-items.slick-initialized .card-item {
  max-width: none;
}
.card-align-right .card-items {
  justify-content: end;
}
.card-align-center .card-items {
  justify-content: center;
}
.card-items .card-item {
  position: relative;
  display: flex;
  flex-direction: column;
}
.card-items .card-image,
.card-items .card-head,
.card-items .card-footer {
  flex-grow: 0;
}
.card-items .card-body {
  flex-grow: 1;
}
.card-items .card-head {
  font-size: var(--headline-font-size, var(--headline-font-size-default, 1.4rem));
  color: var(--headline-color, var(--body-color));
  font-weight: var(--headline-weight, normal);
  text-transform: var(--headline-transform, none);
  text-align: var(--headline-align, start);
  line-height: var(--headline-line-height, 1.4);
}
.card-items .card-body {
  color: var(--text-color, var(--body-color));
  text-align: var(--text-align, start);
  line-height: var(--text-line-height, 1.4);
  font-size: var(--text-font-size, var(--text-font-size-default, 18px));
}
.card-items .card-body > :not(:last-child) {
  margin: var(--paragraph-margin, 0);
}
.card-items .card-body strong {
  font-size: 1em;
  font-weight: bold;
}
.card-items .card-footer {
  padding-top: 20px;
}

.list {
  display: flex;
  flex-direction: column;
  --headline-font-size: 1.4rem;
}
.list .list-item {
  margin-bottom: 50px;
  width: 100%;
  max-width: none;
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-areas: "head image" "body image" "footer image";
  position: relative;
}
@media screen and (max-width: 720px) {
  .list .list-item {
    grid-template-columns: 1fr;
    grid-template-areas: "head" "image" "body" "footer";
  }
}
.list .list-item .item-image {
  grid-area: image;
}
.list .list-item .item-head {
  grid-area: head;
  font-size: var(--headline-font-size);
  color: var(--primary);
}
.list .list-item .item-body {
  grid-area: body;
  font-size: var(--text-font-size-default);
  color: var(--default-text);
}
@media screen and (max-width: 720px) {
  .list .list-item .item-body {
    margin-top: 1rem;
  }
}
.list .list-item .item-footer {
  grid-area: footer;
}

.teaser-wrap .teaser-headline {
  font-size: calc(var(--text-font-size, var(--text-font-size-default, 1.4rem)) + 0.1rem);
  text-align: var(--text-align, start);
  line-height: var(--text-line-height, 1.4);
  color: var(--primary);
}
.teaser-wrap .teaser-headline:not(:empty) {
  margin-bottom: 1rem;
}
.teaser-wrap .headline:not(:empty) {
  margin-bottom: 1rem;
}

.teaser-item .card-image {
  opacity: 0.8;
  margin-bottom: 1.8rem;
  transition: opacity 0.4s;
}
.teaser-item:hover .card-image {
  opacity: 1;
}
.teaser-item .card-head {
  margin-bottom: 1rem;
}

.teaser-slider {
  position: relative;
}
.teaser-slider .slick-list {
  width: calc(100% + 2rem);
  margin-left: -1rem;
}
.teaser-slider .slick-list .slick-track {
  min-width: 100%;
}
.teaser-slider .teaser-arrow {
  position: absolute;
  top: 20%;
  color: var(--primary);
  z-index: 2;
  padding: 0 0.25rem;
  border-radius: 0.25rem;
  background-color: var(--light-transparent);
  cursor: pointer;
}
.teaser-slider .teaser-arrow.teaser-arrow-left {
  left: 0;
}
.teaser-slider .teaser-arrow.teaser-arrow-right {
  right: 0;
}
.teaser-slider .teaser-slide {
  padding: 0 2rem;
}

.nav-entry .link-item {
  padding: 8px 0;
  text-decoration: none;
  display: inline-block;
  width: 100%;
  text-transform: none;
  color: var(--primary-contrast);
  font-size: 1rem;
  border: 0;
  appearance: none;
  cursor: pointer;
  background-color: transparent;
  text-align: start;
}
.nav-entry .link-item:not(.level-1) {
  display: flex;
  justify-content: center;
  justify-items: center;
  align-content: center;
  align-items: center;
}
.nav-entry .link-item:not(.level-1) .image-item {
  display: flex;
  max-width: 60px;
}
.nav-entry.subgroup > .link-item {
  border-bottom: 1px solid var(--nav-line);
  cursor: default;
}
.nav-entry:hover > .link-item, .nav-entry.active > .link-item {
  color: var(--primary-contrast);
}
.nav-entry.parent-active > .link-item {
  color: var(--primary-contrast);
}

.navigation-header-hover-submenu {
  display: flex;
  align-items: start;
  justify-content: space-around;
  gap: 1rem;
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap {
  position: relative;
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub {
  display: none;
  background-color: var(--bg-body);
  position: fixed;
  box-shadow: 0 0 4px var(--dark);
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub.show {
  display: block;
  background-color: var(--bg-body);
  position: fixed;
  padding: 1rem;
  margin-top: 29px;
  box-shadow: 0 0 4px var(--dark);
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .nav-entry {
  max-height: none;
  white-space: nowrap;
  display: block;
  padding-left: 1rem;
  padding-right: 1rem;
  background-color: var(--bg-body);
  transition: background-color 0.4s, color 0.4s;
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .nav-entry .link-item {
  font-size: var(--navigation-font-size);
  text-transform: none;
  color: var(--default-text);
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .nav-entry .link-item:hover {
  color: var(--primary);
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .has-sub-nav {
  display: flex;
  flex-direction: column;
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .has-sub-nav .link-item {
  order: 1;
}
.navigation-header-hover-submenu .nav-entry .nav-sub-wrap > .nav-sub .has-sub-nav .nav-sub-wrap {
  order: 0;
  transform: translateX(calc(100% + 1rem));
}
.navigation-header-hover-submenu .nav-entry.has-sub-nav:hover > .nav-sub-wrap > .nav-sub {
  display: block;
}

nav.footer-static-submenu .nav-entry .link-item {
  font-size: 1rem;
  text-transform: none;
  color: var(--bg-footer-contrast);
  padding: 0;
  line-height: 1.4;
}
nav.footer-static-submenu .nav-entry:hover > .link-item, nav.footer-static-submenu .nav-entry.active > .link-item {
  color: var(--secondary);
}
nav.footer-static-submenu .nav-entry.parent-active > .link-item {
  color: var(--secondary);
}
nav.footer-static-submenu .nav-entry .nav-entry {
  padding-left: 1rem;
}
nav.footer-static-submenu .nav-entry .nav-entry .link-item {
  font-size: 1rem;
  font-weight: normal;
}
@media screen and (max-width: 1024px) {
  nav.footer-static-submenu {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 720px) {
  nav.footer-static-submenu {
    grid-template-columns: 1fr;
  }
}

.separate-submenu-slide.separate-submenu-slide-children {
  position: fixed;
  z-index: 19;
  top: var(--header-height);
  width: 100%;
  pointer-events: none;
}
.separate-submenu-slide .parent-navigation {
  display: flex;
  align-items: start;
  justify-content: start;
  gap: 1rem;
}
.separate-submenu-slide .child-navigation {
  position: relative;
  left: 0;
  right: 0;
  width: 100%;
  background-color: var(--bg-header);
  overflow: hidden;
  transform: translateY(-100%);
  transition: transform 0.4s ease-in-out;
}
.separate-submenu-slide .child-navigation .child-navigation-wrapper-outer {
  max-width: 1280px;
  margin: 0 auto;
}
.separate-submenu-slide .child-navigation .child-navigation-wrapper {
  display: flex;
  flex-wrap: nowrap;
  transform: translateX(0);
  transition: transform 0.4s;
}
.separate-submenu-slide .child-navigation .child-navigation-wrapper > .nav-entry {
  width: 100%;
  flex-shrink: 0;
}
.separate-submenu-slide .child-navigation .child-navigation-wrapper > .nav-entry:not(.has-children) {
  display: none;
}
.separate-submenu-slide .child-navigation .child-navigation-wrapper > .nav-entry > .link-item {
  display: none;
}
.separate-submenu-slide.show-children {
  pointer-events: inherit;
}
.separate-submenu-slide.show-children .child-navigation {
  transform: translateY(0);
}

nav.footer-list {
  display: flex;
  flex-direction: row;
}
nav.footer-list .nav-entry:not(:last-of-type) :after {
  content: "|";
  margin: 0 5px;
}
nav.footer-list .nav-entry .link-item {
  font-weight: normal;
  font-size: var(--footer-font-size);
  text-transform: none;
  color: var(--footer-color);
  padding: 0;
  line-height: 1.4;
}
.nav-entry.with-image {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas: "image name" "image submenu";
  gap: 1rem;
}
.nav-entry.with-image .link-item {
  grid-area: name;
}
.nav-entry.with-image .img {
  grid-area: image;
}
.nav-entry.with-image .nav-sub-wrap {
  grid-area: submenu;
}

.mobile-navigation {
  background-color: #28A144;
}
.mobile-navigation .nav-entry.level-1 {
  border-bottom: 1px solid white;
}
.mobile-navigation .nav-entry.level-1 .nav-sub > nav {
  background-color: white;
}
.mobile-navigation .nav-entry.level-1 .nav-sub > nav .nav-item-sub-opener {
  color: #28A144;
}
.mobile-navigation .nav-entry.level-1 .nav-sub > nav .nav-entry.level-2 .link-item {
  color: #28A144;
}
.mobile-navigation .nav-entry.level-1 .nav-sub > nav .nav-entry.level-3 .link-item {
  color: #555;
}
.mobile-navigation .nav-entry .link-item {
  padding: 0.75rem 1.5rem;
  border-bottom: 0px;
  justify-content: start;
}
.mobile-navigation .nav-entry:last-of-type .link-item {
  border-bottom: 0px;
}
.mobile-navigation .parent-item {
  display: grid;
  grid-template-columns: 1fr 3rem;
  font-size: 1.4rem;
  border-bottom: 0px;
}
.mobile-navigation .parent-item .link-item {
  border-bottom: 0;
}
.mobile-navigation .parent-item .nav-item-sub-opener {
  color: white;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.mobile-navigation .nav-entry:not(.show-sub) > .nav-sub-wrap {
  display: none;
}
.mobile-navigation .nav-entry.level-2 .link-item {
  padding-left: 2.25rem;
}
.mobile-navigation .nav-entry.level-3 .link-item {
  padding-left: 3rem;
}

.navigation-cards {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns, 4), minmax(0, 1fr));
  gap: var(--gap, 1rem);
  justify-content: start;
}
@media screen and (max-width: 1024px) {
  .navigation-cards {
    grid-template-columns: repeat(calc(var(--grid-columns, 4) / 2), 1fr);
  }
}
@media screen and (max-width: 720px) {
  .navigation-cards {
    grid-template-columns: 1fr;
  }
}
.card-align-right .navigation-cards, .card-align-center .navigation-cards {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.card-align-right .navigation-cards .navigation-card, .card-align-center .navigation-cards .navigation-card {
  --card-columns: var(--grid-columns, 4);
  flex: 1 1 calc((100% - var(--gap, 1rem) * (var(--card-columns, 4) - 1)) / var(--card-columns, 4));
  max-width: calc((100% - var(--gap, 1rem) * (var(--card-columns, 4) - 1)) / var(--card-columns, 4));
}
@media screen and (max-width: 1024px) {
  .card-align-right .navigation-cards .navigation-card, .card-align-center .navigation-cards .navigation-card {
    --card-columns:calc(var(--grid-columns, 4) / 2);
  }
}
@media screen and (max-width: 720px) {
  .card-align-right .navigation-cards .navigation-card, .card-align-center .navigation-cards .navigation-card {
    --card-columns: 1;
  }
}
.card-align-right .navigation-cards {
  justify-content: end;
}
.navigation-cards .navigation-card {
  position: relative;
  cursor: pointer;
  display: flex;
  flex-direction: column;
}
.navigation-cards .navigation-card .image-item {
  overflow: hidden;
}
.navigation-cards .navigation-card .image-item img {
  object-fit: cover;
  object-position: calc(var(--center-x, 50) * 1%) calc(var(--center-y, 50) * 1%);
  width: 100% !important;
  height: 100% !important;
}
.navigation-cards .navigation-card .headline:not(:empty) {
  padding: calc(var(--gap, 1rem) / 2) var(--gap, 1rem);
  font-size: var(--headline-font-size, var(--headline-font-size-default, 1.4rem));
  color: var(--headline-color, var(--body-color));
  font-weight: var(--headline-weight, normal);
  text-transform: var(--headline-transform, none);
  text-align: var(--headline-align, left);
}
.navigation-cards .navigation-card .text:not(:empty) {
  padding: calc(var(--gap, 1rem) / 2) var(--gap, 1rem);
  color: var(--text-color, var(--body-color));
  text-align: var(--text-align, left);
  line-height: var(--text-line-height, 1.4);
  font-size: var(--text-font-size, var(--text-font-size-default, 18px));
}
.navigation-list .navigation-item {
  margin-bottom: 1rem;
  display: block;
}
.navigation-list .navigation-item .headline:not(:empty) {
  padding: 0 var(--gap, 1rem);
  font-size: var(--headline-font-size, var(--headline-font-size-default, 1.4rem));
  color: var(--headline-color, var(--body-color));
  font-weight: var(--headline-weight, normal);
  text-transform: var(--headline-transform, none);
  text-align: var(--headline-align, left);
}
.navigation-list .navigation-item .text:not(:empty) {
  padding: 0 var(--gap, 1rem);
  color: var(--text-color, var(--body-color));
  text-align: var(--text-align, left);
  line-height: var(--text-line-height, 1.4);
  font-size: calc(var(--text-font-size, var(--text-font-size-default, 18px)) * 0.8);
}

.footer-linkboxen {
  margin-top: 80px;
}
.footer-linkboxen .linkbox-title {
  color: var(--hygromatik);
  font-size: 1.4rem;
  max-width: 1840px;
  margin: 0 auto;
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid #9c9d9f;
}
@media screen and (max-width: 1500px) {
  .footer-linkboxen .linkbox-title { /* main max width */
    margin-left: 2rem;
    margin-right: 2rem;
  }
}
.footer-linkboxen .navigation-linkboxen {
  display: grid;
  grid-auto-flow: row;
  align-items: stretch;
  grid-template-columns: repeat(var(--grid-columns, 4), minmax(0, 1fr));
  gap: var(--gap, 1rem);
  overflow: hidden;
  justify-content: start;
}
@media screen and (max-width: 1800px) {
  .footer-linkboxen .navigation-linkboxen { /* main max width */
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media screen and (max-width: 1500px) {
  .footer-linkboxen .navigation-linkboxen { /* tablet */
    grid-template-columns: 1fr 1fr 1fr;
  }
}
@media screen and (max-width: 1024px) {
  .footer-linkboxen .navigation-linkboxen { /* mobile */
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 720px) {
  .footer-linkboxen .navigation-linkboxen { /* mobile */
    grid-template-columns: 1fr;
  }
}
.footer-linkboxen .navigation-linkboxen .navigation-card {
  position: relative;
  margin-top: 60px;
  display: flex;
  flex-direction: column;
  height: max-content;
  flex: 1;
}
@media screen and (max-width: 1500px) {
  .footer-linkboxen .navigation-linkboxen .navigation-card { /* tablet */
    margin: 0;
    margin-top: 60px;
  }
}
.footer-linkboxen .navigation-linkboxen .navigation-card .image-item {
  position: absolute;
  width: 100%;
}
.footer-linkboxen .navigation-linkboxen .navigation-card .image-item img {
  width: 160px;
  max-width: 160px !important;
  background-color: var(--light);
  transform: translateY(-50%);
  margin: 0 auto;
}
.footer-linkboxen .navigation-linkboxen .navigation-card .card-text {
  color: var(--hygromatik);
  padding: 75px 40px 40px;
  min-height: 150px;
  font-size: 24px;
  font-weight: normal !important;
  text-align: center;
  border: 1px solid #9c9d9f;
}
@media screen and (max-width: 720px) {
  .footer-linkboxen .navigation-linkboxen .navigation-card .card-text {
    hyphens: auto;
  }
}

.navigation-hauptnavigation {
  display: flex;
  align-items: start;
  justify-content: center;
  position: relative;
}
.navigation-hauptnavigation .nav-entry.level-1 {
  flex-grow: 1;
  border-right: 1px solid var(--light);
}
.navigation-hauptnavigation .nav-entry.level-1:first-of-type {
  border-left: 1px solid var(--light);
}
.navigation-hauptnavigation .nav-entry.level-1 > .link-item {
  text-align: center;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap {
  padding: 0 20px;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap.relative-wrap {
  position: relative;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub {
  display: none;
  position: absolute;
  background-color: var(--light);
  top: 100%;
  left: 0;
  width: 100%;
  justify-content: center;
  gap: 0;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub.not-subbed {
  width: 300px;
  flex-direction: column;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub.not-subbed .nav-entry.level-2 > .link-item {
  font-size: 0.85rem;
  border-bottom: none;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub .nav-entry .link-item {
  color: var(--default-text);
  text-align: center;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub .nav-entry.level-2 {
  flex-grow: 1;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub .nav-entry.level-2 > .link-item {
  font-size: 0.85rem;
  border-bottom: 1px solid #D6D6D5;
}
.navigation-hauptnavigation .nav-entry.level-1 > .nav-sub-wrap > .nav-sub .nav-entry.level-3 .link-item {
  font-size: 0.85rem;
}
.navigation-hauptnavigation .nav-entry.level-1.has-sub-nav:hover > .nav-sub-wrap > .nav-sub {
  display: flex;
}

.image-placeholder {
  display: flex !important;
  background-color: #181818;
  color: #ffffff;
  aspect-ratio: 16/9;
  width: 100%;
  justify-content: center;
  align-items: center;
}
.image-placeholder:after {
  content: "\f03e";
  font-family: "Font Awesome 5 Pro";
  font-size: 3rem;
}

img.empty-image-placeholder {
  position: relative;
  display: block;
  background-color: var(--dark);
}
img.empty-image-placeholder:before {
  background-color: rgba(255, 0, 0, 0.5);
  display: block;
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100px;
  height: 100px;
  unicode-bidi: normal;
}

.image-with-copyright {
  position: relative;
}
.image-with-copyright .copyright {
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: var(--bg-color, var(--body-bg));
  padding: 0.25rem 0.5rem;
}
.image-with-copyright .copyright .media-copyright:not(:empty) {
  margin-left: 0.5rem;
}
.image-with-copyright .copyright .media-copyright:not(:empty):before {
  content: "©";
}

.image-with-text-overlay {
  position: relative;
  --text-font-size-small: 1.8rem;
  --text-font-size-normal:2rem;
  --text-font-size-large: 2.4rem;
  --headline-font-size-small: 2.4rem;
  --headline-font-size-default: 2.6rem;
  --headline-font-size-large: 2.8rem;
}
.image-with-text-overlay .text-container {
  position: absolute;
  bottom: 0;
  left: 0;
  top: 0;
  right: 0;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  background-color: color-mix(in srgb, var(--image-overlay-bg, transparent) 80%, transparent);
  backdrop-filter: blur(var(--image-overlay-blur, 0));
}
.image-with-text-overlay .text-container .text-content {
  width: 100%;
}
.image-with-text-overlay .image-select-btn {
  position: absolute;
  bottom: 4px;
  right: 4px;
  z-index: 5;
}

.image-with-text.image-item {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.image-with-text.image-item img {
  display: block;
  margin: 0 auto;
}
.image-with-text.image-item article.text {
  display: block;
  width: 100%;
  margin: 0 auto;
  text-align: center;
}

:root {
  --image-100: 1;
  --image-90: 0.9;
  --image-80: 0.8;
  --image-70: 0.7;
  --image-60: 0.6;
  --image-50: 0.5;
  --image-40: 0.4;
  --image-30: 0.3;
  --image-20: 0.2;
  --image-10: 0.1;
}

.image-layout-black-white img {
  filter: grayscale(100%);
}

.image-layout-sepia {
  filter: sepia(100%);
}

.image-layout-blur {
  filter: blur(4px);
}

.image-item {
  display: flex;
  position: relative;
  justify-content: var(--image-origin-x, center);
  align-items: var(--image-origin-y, start);
}
.image-item img {
  display: block;
  zoom: var(--image-size, 1);
}

.image-stretch img {
  max-width: calc(100% * var(--image-size, 1)) !important;
}

.image-object-fit-cover.image-stretch,
.image-object-fit-contain.image-stretch {
  height: 100%;
}
.image-object-fit-cover.image-stretch .image-item,
.image-object-fit-contain.image-stretch .image-item {
  height: 100%;
}

.image-object-fit-contain .image-item {
  overflow: hidden;
}
.image-object-fit-contain .image-item img {
  object-position: calc(var(--center-x, 50) * 1%) calc(var(--center-y, 50) * 1%);
  object-fit: contain;
  width: 100% !important;
  height: 100% !important;
}

.image-object-fit-cover .image-item {
  overflow: hidden;
}
.image-object-fit-cover .image-item img {
  object-position: calc(var(--center-x, 50) * 1%) calc(var(--center-y, 50) * 1%);
  object-fit: cover;
  width: 100% !important;
  height: 100% !important;
}

.pdf-frame {
  width: 100%;
  aspect-ratio: 1/1.414;
}

.content-bilder-gallery {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns, 5), 1fr);
  gap: var(--grid-gap, 1rem);
}
@media screen and (max-width: 1024px) {
  .content-bilder-gallery {
    grid-template-columns: repeat(calc(var(--grid-columns, 5) / 2), 1fr);
  }
}
@media screen and (max-width: 720px) {
  .content-bilder-gallery {
    grid-template-columns: 1fr;
  }
}
.content-bilder-gallery.lightbox-enable .image-item {
  cursor: pointer;
}
.content-bilder-gallery.fliesen .image-item {
  aspect-ratio: 1;
  overflow: hidden;
}
.content-bilder-gallery.fliesen .image-item img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: center center;
  max-width: 100% !important;
}
.content-bilder-gallery.spalten {
  display: block;
  column-count: var(--grid-columns, 5);
  column-gap: var(--grid-gap, 1rem);
}
@media screen and (max-width: 1024px) {
  .content-bilder-gallery.spalten {
    column-count: calc(var(--grid-columns, 5) / 2);
  }
}
@media screen and (max-width: 720px) {
  .content-bilder-gallery.spalten {
    column-count: 1;
  }
}
.content-bilder-gallery.spalten .image-item {
  margin-bottom: var(--grid-gap, 1rem);
}
.content-bilder-gallery.spalten .image-item img {
  max-width: 100% !important;
}

.content-bilder-gallery .slide-gallery-wrapper {
  grid-column: auto/span var(--grid-columns, 5);
  position: relative;
  overflow: hidden;
}
.content-bilder-gallery .slide-gallery-wrapper .slick-list {
  margin-left: calc(var(--grid-gap, 1rem) / -2);
  margin-right: calc(var(--grid-gap, 1rem) / -2);
}
.content-bilder-gallery .slide-gallery-wrapper .slide-arrow {
  position: absolute;
  color: var(--light);
  font-size: 4rem;
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1rem;
  top: 0;
  bottom: 0;
  opacity: 0;
  transition: opacity 0.4s;
}
.content-bilder-gallery .slide-gallery-wrapper:hover .slide-arrow {
  opacity: 1;
}
.content-bilder-gallery .slide-gallery-wrapper .slide-arrow-prev {
  left: 0;
}
.content-bilder-gallery .slide-gallery-wrapper .slide-arrow-next {
  right: 0;
}
.content-bilder-gallery .slide-gallery-wrapper .slick-dots {
  width: 100%;
  position: absolute;
  bottom: 0;
  padding: 1rem;
  display: flex;
  gap: 1rem;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.content-bilder-gallery .slide-gallery-wrapper .slick-dots li {
  width: 1rem;
  aspect-ratio: 1;
  overflow: hidden;
  background-color: var(--light);
  border-radius: 100%;
  cursor: pointer;
  padding: 0;
  box-shadow: 0 0 4px var(--primary);
}
.content-bilder-gallery .slide-gallery-wrapper .slick-dots li.slick-active {
  background-color: var(--primary);
}
.content-bilder-gallery .slide-gallery-wrapper .slick-dots li button {
  display: none;
}
.content-bilder-gallery .slide-gallery-wrapper:not(.slick-initialized) .image-item:not(:first-child) {
  display: none;
}
.content-bilder-gallery .slide-gallery-wrapper .image-item {
  padding-left: calc(var(--grid-gap, 1rem) / 2);
  padding-right: calc(var(--grid-gap, 1rem) / 2);
}
@media screen and (max-width: 1024px) {
  .content-bilder-gallery .slide-gallery-wrapper {
    grid-column: auto/span calc(var(--grid-columns, 5) / 2);
  }
}
@media screen and (max-width: 720px) {
  .content-bilder-gallery .slide-gallery-wrapper {
    grid-column: auto/span 1;
  }
}

body:has(.lightbox-overlay.show) {
  overflow: hidden;
}

.lightbox-overlay {
  --background-color: var(--body-bg);
  --text-color: var(--default-text);
  position: fixed;
  left: 0;
  bottom: 0;
  right: 0;
  top: 0;
  background-color: color-mix(in srgb, var(--background-color) 90%, transparent);
  backdrop-filter: blur(4px);
  z-index: 30;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.lightbox-overlay:not(.show) {
  display: none;
}
.lightbox-overlay .lightbox-header {
  background-color: color-mix(in srgb, var(--background-color) 90%, transparent);
  padding: 0.375rem;
  color: var(--text-color);
  font-size: 3rem;
  text-align: right;
  flex-grow: 0;
}
.lightbox-overlay .close-button {
  cursor: pointer;
}
.lightbox-overlay .lightbox-arrow-next,
.lightbox-overlay .lightbox-arrow-prev {
  cursor: pointer;
  background-color: color-mix(in srgb, var(--background-color) 90%, transparent);
  padding: 0.375rem;
  font-size: 3rem;
  position: fixed;
  top: calc(50% - 1.75rem);
  aspect-ratio: 1;
}
.lightbox-overlay .lightbox-arrow-next {
  right: 0;
}
.lightbox-overlay .lightbox-arrow-prev {
  left: 0;
}
.lightbox-overlay .lightbox-content {
  flex-grow: 1;
}
.lightbox-overlay .lightbox-content .slide-container {
  margin: 0 auto;
  overflow: hidden;
  height: 100%;
}
.lightbox-overlay .lightbox-content .slide-container .slide-item {
  display: flex;
  justify-content: start;
  align-items: center;
  width: 100%;
  height: 90vh;
  flex-direction: column;
}
.lightbox-overlay .lightbox-content .slide-container .slide-item .image-item-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  flex-grow: 1;
  flex-shrink: 1;
  max-height: 100%;
}
.lightbox-overlay .lightbox-content .slide-container .slide-item .image-item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex-grow: 1;
  flex-shrink: 1;
}
.lightbox-overlay .lightbox-content .slide-container .slide-item .alt-text {
  flex-shrink: 0;
  flex-grow: 0;
}
.lightbox-overlay .lightbox-content .slide-container .slide-item img {
  width: auto !important;
  height: auto !important;
  max-height: 100% !important;
  max-width: 100% !important;
}

article.text {
  color: var(--text-color, var(--body-color));
  font-size: var(--text-font-size, var(--text-font-size-default, 18px));
  line-height: var(--text-line-height, 1.4);
}
article.text .h {
  font-size: var(--headline-font-size, var(--headline-font-size-default, 1.4rem));
  color: var(--headline-color, var(--body-color));
  margin: 0 0 1rem 0;
  font-weight: var(--headline-weight, normal);
  text-transform: var(--headline-transform, none);
  text-align: var(--headline-align, start);
  line-height: var(--headline-line-height, 1.2);
}
article.text .h .subhead {
  display: block;
  font-size: var(--headline-font-size-xx-small, 1.2rem);
}
article.text .text-content {
  color: var(--text-color, var(--body-color));
  text-align: var(--text-align, start);
  line-height: var(--text-line-height, 1.4);
  font-size: var(--text-font-size, var(--text-font-size-default, 18px));
  font-weight: var(--text-font-weight, 100);
  /* UL List SETTINGS */
}
article.text .text-content > :not(:last-child) {
  margin: var(--paragraph-margin, 0);
}
article.text .text-content strong {
  font-size: 1em;
  font-weight: bold;
}
article.text .text-content a:not([class]), article.text .text-content a[class=""] {
  text-decoration: none;
  color: var(--text-link-color, inherit);
  font-size: 1em;
}
article.text .text-content ol li,
article.text .text-content ul li {
  margin-left: 1rem;
}
article.text .text-content ul > li {
  margin-bottom: 13px;
  list-style-position: outside;
  list-style-type: disc;
  line-height: calc(var(--text-line-height, 1.4) * 1);
}
article.text .text-content ul > li::marker {
  color: var(--primary);
}
article.text .text-content ul > li ul > li:before {
  display: none;
  content: "";
  margin-left: 0;
  margin-right: 0;
}
article.text .text-content table {
  border-collapse: collapse;
  border-spacing: 0;
  border: 0;
}
article.text .text-content table tr {
  gap: 0.4rem;
}
article.text .text-content table td, article.text .text-content table th {
  border: 0;
  padding-left: 0;
  padding-right: 0.8rem;
  text-align: left;
}

.text-image {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.text-image .text {
  align-self: start;
}
.image-right .text-image .text {
  order: 0;
}
.image-right .text-image .image-wrapper {
  order: 1;
}
.text-image-align-start .text-image .text {
  align-self: start;
}
.text-image-align-center .text-image .text {
  align-self: center;
}
.text-image-align-end .text-image .text {
  align-self: end;
}

.content_element[style*="--text-align: center"] article.text table {
  display: flex;
  justify-content: center;
}

.content_element[style*="--text-align: right"] article.text table {
  display: flex;
  justify-content: right;
}

.list-columns-active {
  --columns-1:1;
  --columns-2:2;
  --columns-3:3;
}
@media screen and (max-width: 1024px) {
  .list-columns-active {
    --columns-1:1;
    --columns-2:2;
    --columns-3:2;
  }
}
@media screen and (max-width: 720px) {
  .list-columns-active {
    --columns-1:1;
    --columns-2:1;
    --columns-3:1;
  }
}
.list-columns-active ul {
  column-count: var(--list-columns, 1);
}

.text-with-icon-container article.text {
  display: grid;
  gap: 1rem;
  grid-template-columns: auto 1fr;
  grid-template-areas: "icon headline" "none text";
}
@media screen and (max-width: 720px) {
  .text-with-icon-container article.text {
    grid-template-areas: "icon headline" "text text";
  }
}
.text-with-icon-container .text-icon {
  grid-area: icon;
  font-size: calc(var(--headline-font-size, 1.4rem) * 2);
  color: var(--headline-color, var(--default-text));
}
.text-with-icon-container .text-icon img {
  width: calc(var(--headline-font-size, 1.4rem) * 2);
  height: auto;
}
.text-with-icon-container .headline {
  grid-area: headline;
  align-self: center;
}
.text-with-icon-container .headline .h {
  margin: 0;
}
.text-with-icon-container .text-content {
  grid-area: text;
}

.icon-before .text-with-icon-container article.text {
  display: block;
}
.icon-before .text-with-icon-container article.text .text-icon {
  display: flex;
  justify-content: center;
  transform: translateY(calc((var(--container-pad, 0) + 50%) * -1));
}
.icon-before .text-with-icon-container article.text .text-icon i,
.icon-before .text-with-icon-container article.text .text-icon img {
  padding: 0.375rem;
  background-color: color-mix(in srgb, var(--container-bg-color, var(--row-bg-color, var(--body-bg))) var(--container-bg-opacity, 100%), transparent);
}

article.text .subtitle {
  color: var(--subtitle-color, var(--body-color));
  margin: 0 0 1rem 0;
  text-align: var(--subtitle-align, left);
  line-height: var(--subtitle-line-height, 1.4);
  font-size: var(--subtitle-font-size, 1rem);
  font-weight: var(--subtitle-weight, normal);
  text-transform: var(--subtitle-transform, none);
}

article.text.accordion {
  margin-bottom: 30px;
}
article.text.accordion .headline {
  display: grid;
  grid-template-columns: 60px 1fr;
  grid-template-areas: "opener head";
  border: 1px solid var(--primary);
  cursor: pointer;
}
article.text.accordion .headline .h {
  margin-bottom: 0px;
  padding-bottom: 0px;
}
article.text.accordion .headline .opener {
  grid-area: opener;
  background-color: var(--primary);
  display: grid;
  justify-content: center;
  justify-items: center;
  align-content: center;
  align-items: center;
  min-height: 50px;
}
article.text.accordion .headline .opener span {
  width: 25px;
  height: 3px;
  background-color: var(--primary-contrast);
  position: relative;
}
article.text.accordion .headline .opener span:after {
  width: 100%;
  height: 3px;
  background-color: var(--primary-contrast);
  display: block;
  position: absolute;
  left: 0;
  rotation-point: center;
  transform: rotate(90deg);
  content: " ";
  transition: transform 1s;
}
article.text.accordion .headline .h {
  grid-area: head;
  color: var(--primary);
  font-weight: 100;
  font-size: 1.2rem;
  display: flex;
  justify-content: start;
  align-items: center;
  padding: 0 10px;
  border-left: 1px solid var(--light);
}
article.text.accordion .accordion-content {
  display: none;
  padding: 30px 30px 30px 60px;
}
@media screen and (max-width: 1500px) {
  article.text.accordion .accordion-content { /* tablet */
    padding: 20px;
  }
}
@media screen and (max-width: 1024px) {
  article.text.accordion .accordion-content { /* mobile */
    padding: 10px;
    padding-left: 0px;
    padding-right: 0px;
  }
}
article.text.accordion.open > .accordion-headline {
  background-color: var(--primary);
}
article.text.accordion.open > .accordion-headline > .h {
  color: var(--primary-contrast);
}
article.text.accordion.open > .accordion-headline .opener span:after {
  transform: rotate(0deg);
}
.no-border-accordion article.text.accordion .headline {
  border: none;
  cursor: pointer;
  grid-template-columns: 40px 1fr;
}
.no-border-accordion article.text.accordion .headline .h {
  color: var(--headline-color, var(--default-text));
  padding-left: 0;
}
.no-border-accordion article.text.accordion .headline .opener {
  background-color: transparent;
  color: var(--primary);
  min-height: 40px;
}
.no-border-accordion article.text.accordion .headline .opener span {
  background-color: var(--primary);
  width: 15px;
}
.no-border-accordion article.text.accordion .headline .opener span:after {
  background-color: var(--primary);
  width: 100%;
}
.no-border-accordion article.text.accordion .headline .h {
  border-left: none;
}
.no-border-accordion article.text.accordion.open > .accordion-headline {
  background-color: transparent;
}
.no-border-accordion article.text.accordion.open > .accordion-headline > .h {
  color: var(--default-text);
}

/*
Samples
.btn {
  border-radius: 4px;
}
*/

/*# sourceMappingURL=base.css.map */
