/* =========================================================
   Zentrale Variablensammlung
   - Design-Tokens (Farben, Typo, Buttons)
   - Skalen/Breakpoints
   - Helper-Mixins fuer gestufte CSS-Variablen
   ========================================================= */
/* ---------- Helper: gestufte Scales ---------- */
/* ---------- Globale Parameter ---------- */
/* ---------- Grundfarben & Transitions ---------- */
@import "../../node_modules/swiper/swiper-bundle.css";
:root {
  --color-black: #1a1a1a;
  --color-dark: #1a1a1a;
  --color-white: #ffffff;
  --color-grey: #666666;
  --color-lightgrey: #f5f5f5;
  --color-gradient: linear-gradient(76deg, #ED804F -1.67%, #ECA547 44.02%, #B3C4DB 88.72%, #B3C4DB 97.66%);
  --color-accent: #0066cc;
  --color-accent-dark: #004c99;
  --color-accent-light: #3399ff;
  --color-text: var(--color-black);
  --color-body: var(--color-black);
  --color-sitebg: var(--color-white);
  --logocolor: var(--color-black);
  --color-h1: var(--color-black);
  --color-h2: var(--color-black);
  --color-h2-b: var(--color-accent);
  --color-h3: var(--color-black);
  --color-h4: var(--color-accent);
  --color-button: var(--color-text);
  --var-buttonborderraduis: 4px;
  --var-ease: cubic-bezier(0.4, 0, 0.2, 1);
  /* ---------- Typo Tokens ---------- */
  --font-sans: "ABC Diatype", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --font-serif: Georgia, "Times New Roman", serif;
  --font-mono: ui-monospace, "SF Mono", Consolas, monospace;
  --font-body: var(--font-sans);
  --font-headings: var(--font-sans);
  --font-code: var(--font-mono);
  --weight-light: 300;
  --weight-regular: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;
  --fs-body-lh: 160%;
  --fs-eyebrow-lh: 1.3;
  --fs-subtitle-lh: 1.3;
  --fs-lead-lh: 1.4;
  --fs-imagecaption-lh: 105%;
  --fs-h3-lh: 1.15;
  --fs-bigtext-lh: 120%;
  --fs-h2-lh: 1.1;
  --fs-h1-lh: 1;
  --fs-button-lh: 1;
  --outline-width: 1px;
  --fs-body: 1.55rem;
  --fs-imagecaption: 1.25rem;
  --fs-h3: 2.1rem;
  --fs-bigtext: 2.4rem;
  --fs-h2: 2.6rem;
  --fs-h1: 4rem;
  --fs-eyebrow: 1.1rem;
  --fs-subtitle: 1.2rem;
  --fs-lead: 1.8rem;
  --fs-button: 1.4rem;
  /* ---------- Spacing Tokens ---------- */
  --var-margin-default: 12rem;
  --var-margin-small: 5rem;
  --var-margin-medium: 12rem;
  --var-margin-negative: -5rem;
  --var-margin-row: 2rem;
  --var-row-gap: 2rem;
  --var-grid-gap: 1rem;
  --var-bodymargin: 2.4rem;
  --var-margin-left: 1rem;
  --var-borderradius: 1rem;
  /* ---------- Button Tokens ---------- */
  --button-radius: var(--var-borderradius, 15px);
  --button-ease: var(--var-ease, cubic-bezier(0.2, 0.8, 0.2, 1));
  --btn-gap: 0.6rem;
  --btn-py: 1rem;
  --btn-px: 2rem;
  --btn-bg: transparent;
  --btn-fg: var(--color-text);
  --btn-bg-light: transparent;
  --btn-fg-light: var(--color-text);
}
@media (min-width: 800px) {
  :root {
    --fs-body: 1.6375rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-body: 1.725rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-body: 1.8125rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-body: 1.9rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-imagecaption: 1.3375rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-imagecaption: 1.425rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-imagecaption: 1.5125rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-imagecaption: 1.6rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-h3: 2.325rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-h3: 2.55rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-h3: 2.775rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-h3: 3rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-bigtext: 2.65rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-bigtext: 2.9rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-bigtext: 3.15rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-bigtext: 3.4rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-h2: 3rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-h2: 3.4rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-h2: 3.8rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-h2: 4.2rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-h1: 4.7rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-h1: 5.4rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-h1: 6.1rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-h1: 6.8rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-eyebrow: 1.175rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-eyebrow: 1.25rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-eyebrow: 1.325rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-eyebrow: 1.4rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-subtitle: 1.3rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-subtitle: 1.4rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-subtitle: 1.5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-subtitle: 1.6rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-lead: 1.95rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-lead: 2.1rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-lead: 2.25rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-lead: 2.4rem;
  }
}
@media (min-width: 800px) {
  :root {
    --fs-button: 1.475rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --fs-button: 1.55rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --fs-button: 1.625rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --fs-button: 1.7rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-default: 16.5rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-default: 21rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-default: 25.5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-default: 30rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-small: 7.5rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-small: 10rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-small: 12.5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-small: 15rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-medium: 14.5rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-medium: 17rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-medium: 19.5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-medium: 22rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-negative: -7.5rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-negative: -10rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-negative: -12.5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-negative: -15rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-row: 3rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-row: 4rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-row: 5rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-row: 6rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-row-gap: 2.75rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-row-gap: 3.5rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-row-gap: 4.25rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-row-gap: 5rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-grid-gap: 1.25rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-grid-gap: 1.5rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-grid-gap: 1.75rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-grid-gap: 2rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-bodymargin: 3.3rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-bodymargin: 4.2rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-bodymargin: 5.1rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-bodymargin: 6rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-margin-left: 1.75rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-margin-left: 2.5rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-margin-left: 3.25rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-margin-left: 4rem;
  }
}
@media (min-width: 800px) {
  :root {
    --var-borderradius: 1.6rem;
  }
}
@media (min-width: 1100px) {
  :root {
    --var-borderradius: 2.2rem;
  }
}
@media (min-width: 1400px) {
  :root {
    --var-borderradius: 2.8rem;
  }
}
@media (min-width: 1700px) {
  :root {
    --var-borderradius: 3.4rem;
  }
}
@media screen and (max-width: 800px) {
  :root {
    --btn-py: 0.71rem;
    --btn-px: 1.4rem;
  }
}
.bg-is-light {
  --color-text: var(--color-black);
  --color-body: var(--color-black);
  --logocolor: var(--color-accent);
  --color-h1: var(--color-black);
  --color-h2: var(--color-accent);
  --color-h3: var(--color-text);
  --color-h4: var(--color-text);
  --color-button: var(--color-text);
  --btn-fg: var(--color-black);
  --btn-bg-light: transparent;
  --btn-fg-light: var(--color-accent);
}
/* ==========================================================
   Modern Reset (cmart)
   - Vereinheitlicht Browser Defaults
   - Barrierefrei (keine Focus-Styles entfernt)
   - Kompatibel mit Fluid Typography & Grid System
   ========================================================== */
/* 1. Box-Modell */
*,
*::before,
*::after {
  box-sizing: border-box;
}
/* 2. Entferne Default Margin */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}
/* 3. Basiswerte */
html,
body {
  min-height: 100%;
  padding: 0;
  border: 0;
  line-height: 1.5;
  font-family: var(--font-body, system-ui, sans-serif);
  color: var(--color-text, #111);
  background: var(--color-bg, #fff);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
/* 4. Listen */
ul[role="list"],
ol[role="list"] {
  list-style: none;
  margin: 0;
  padding: 0;
}
/* 5. Links */
a {
  color: inherit;
  text-decoration: none;
}
a:hover,
a:focus-visible {
  text-decoration: underline;
}
/* 6. Medien */
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}
img {
  height: auto;
}
/* 7. Tabellen */
table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}
th,
td {
  text-align: left;
  vertical-align: middle;
}
/* 8. Formulare */
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
  margin: 0;
  border: none;
  background: none;
}
/* 9. Fokus sichtbar lassen */
:focus-visible {
  outline: 2px solid var(--color-accent, #3a6cf4);
  outline-offset: 2px;
}
/* 10. Root Block Elements */
:where(article, aside, nav, section, header, footer, main) {
  display: block;
}
/* 11. Utility: smoother scroll + motion respect */
html {
  scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
.hide {
  display: none;
}
#loading,
#successmessage,
#errormessage {
  display: none;
}
.slidearrow-prev,
.slidearrow-next {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  font: inherit;
}
#navshow {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  font: inherit;
}
.cm-accordion__title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  font: inherit;
  text-align: left;
}
.skip-to-content {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 9999;
  padding: 0.75em 1.5em;
  background: var(--color-primary, #000);
  color: #fff;
  font-weight: 600;
  text-decoration: none;
}
.skip-to-content:focus {
  left: 0;
}
@keyframes bounceOut {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(1.2);
  }
}
@keyframes slideInShort {
  from {
    transform: rotateX(-15deg) translateY(100px);
  }
  to {
    transform: rotateX(0) translateY(0px);
  }
}
@keyframes slideMeIn {
  from {
    transform: rotateX(-60deg) translateY(300px);
  }
  to {
    transform: rotateX(0) translateY(0px);
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
ul {
  list-style-type: none;
}
ul {
  margin: 0px;
  padding: 0px;
}
a:focus {
  outline: none;
}
/* ===================================
   COLOR SYSTEM — Utilities
   (Variablen sind in variables.less)
   =================================== */
/* ---------- BACKGROUND UTILITY MIXIN ---------- */
/* Generierte Utility-Klassen */
.bg--black {
  background-color: var(--color-black);
}
.bg--dark {
  background-color: var(--color-dark);
}
.bg--white {
  background-color: var(--color-white);
}
.bg--grey {
  background-color: var(--color-grey);
}
.bg--lightgrey {
  background-color: var(--color-lightgrey);
}
.bg--accent {
  background-color: var(--color-accent);
}
.bg--accent-dark {
  background-color: var(--color-accent-dark);
}
.bg--sitebg {
  background-color: var(--color-sitebg);
}
/* ===================================
   TYPOGRAPHY SYSTEM
   - .fs(@name) Mixin mit automatischen Options
   (Variablen & Tokens sind in variables.less)
   =================================== */
/* ---------- html font-size ---------- */
html {
  font-size: 10px;
}
/* ---------- UPSCALE > 1700 ---------- */
@media (min-width: 1900px) {
  html {
    font-size: 11px;
  }
}
@media (min-width: 2556px) {
  html {
    font-size: 12px;
  }
}
@media (min-width: 2884px) {
  html {
    font-size: 13px;
  }
}
@media (min-width: 3212px) {
  html {
    font-size: 14px;
  }
}
@media (min-width: 3540px) {
  html {
    font-size: 15px;
  }
}
/* ---------- .fs() MIXIN ---------- */
/* Default options */
/* Heading options */
/* ---------- BASE STYLES ---------- */
html {
  font-family: var(--font-body);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  font-kerning: normal;
  font-variant-ligatures: common-ligatures contextual;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
#wrap {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
}
/* ---------- SEMANTIC ELEMENTS ---------- */
h1 {
  font-size: var(--fs-h1);
  line-height: var(--fs-h1-lh);
  color: var(--color-h1, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  font-weight: bold;
}
h1 strong,
h1 b {
  font-weight: inherit;
  color: var(--color-accent);
}
h2 {
  font-size: var(--fs-h2);
  line-height: var(--fs-h2-lh);
  color: var(--color-h2, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
}
h2 strong,
h2 b {
  font-weight: inherit;
  color: var(--color-accent);
}
h3 {
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
}
h3 strong,
h3 b {
  font-weight: inherit;
  color: var(--color-accent);
}
h4 {
  font-size: var(--fs-subtitle);
  line-height: var(--fs-subtitle-lh);
  color: var(--color-subtitle, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
/* ---------- ROLE MIXINS ---------- */
/* ---------- UTILITY CLASSES ---------- */
.eyebrow,
.cm-eyebrow {
  font-size: var(--fs-eyebrow);
  line-height: var(--fs-eyebrow-lh);
  color: var(--color-eyebrow, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.subtitle,
.cm-subtitle {
  font-size: var(--fs-subtitle);
  line-height: var(--fs-subtitle-lh);
  color: var(--color-subtitle, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.lead,
.cm-lead {
  font-size: var(--fs-lead);
  line-height: var(--fs-lead-lh);
  color: var(--color-lead, inherit);
  font-weight: var(--weight-regular);
}
.btn-text,
.cm-btn-text {
  font-size: var(--fs-button);
  line-height: var(--fs-button-lh);
  color: var(--color-button, inherit);
  font-family: var(--font-sans);
  font-weight: var(--weight-regular);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.bigtext,
.cm-bigtext {
  font-size: var(--fs-bigtext);
  line-height: var(--fs-bigtext-lh);
  color: var(--color-bigtext, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
}
/* =========================================================
   LAYOUT SYSTEM (cm-)
   - Grid mit benannten Linien (m, c, m-end)
   - Spacing Utilities (margin/padding Mods)
   (Spacing-Tokens sind in variables.less)
   ========================================================= */
/* ---------- Grid Basis ---------- */
/* ---------- SPACING UTILITIES ---------- */
/* Oeffentliche Utilities */
.cm-mt,
.margintop {
  margin-top: var(--var-margin-default);
}
.cm-mt--50vh,
.margintop--50vh {
  margin-top: 50vh;
}
.cm-mt--small,
.margintop--small {
  margin-top: var(--var-margin-small);
}
.cm-mt--negative,
.margintop--negative {
  margin-top: var(--var-margin-negative);
}
.cm-mt--medium,
.margintop--medium {
  margin-top: var(--var-margin-medium);
}
.cm-mt--row,
.margintop--row {
  margin-top: var(--var-margin-row);
}
.cm-mt--none,
.margintop--none {
  margin-top: 0;
}
.cm-pt,
.paddingtop {
  padding-top: var(--var-margin-default);
}
.cm-pt--50vh,
.paddingtop--50vh {
  padding-top: 50vh;
}
.cm-pt--small,
.paddingtop--small {
  padding-top: var(--var-margin-small);
}
.cm-pt--negative,
.paddingtop--negative {
  padding-top: var(--var-margin-negative);
}
.cm-pt--medium,
.paddingtop--medium {
  padding-top: var(--var-margin-medium);
}
.cm-pt--row,
.paddingtop--row {
  padding-top: var(--var-margin-row);
}
.cm-pt--none,
.paddingtop--none {
  padding-top: 0;
}
.cm-mb,
.marginbottom {
  margin-bottom: var(--var-margin-default);
}
.cm-mb--50vh,
.marginbottom--50vh {
  margin-bottom: 50vh;
}
.cm-mb--small,
.marginbottom--small {
  margin-bottom: var(--var-margin-small);
}
.cm-mb--negative,
.marginbottom--negative {
  margin-bottom: var(--var-margin-negative);
}
.cm-mb--medium,
.marginbottom--medium {
  margin-bottom: var(--var-margin-medium);
}
.cm-mb--row,
.marginbottom--row {
  margin-bottom: var(--var-margin-row);
}
.cm-mb--none,
.marginbottom--none {
  margin-bottom: 0;
}
.cm-pb,
.paddingbottom {
  padding-bottom: var(--var-margin-default);
}
.cm-pb--50vh,
.paddingbottom--50vh {
  padding-bottom: 50vh;
}
.cm-pb--small,
.paddingbottom--small {
  padding-bottom: var(--var-margin-small);
}
.cm-pb--negative,
.paddingbottom--negative {
  padding-bottom: var(--var-margin-negative);
}
.cm-pb--medium,
.paddingbottom--medium {
  padding-bottom: var(--var-margin-medium);
}
.cm-pb--row,
.paddingbottom--row {
  padding-bottom: var(--var-margin-row);
}
.cm-pb--none,
.paddingbottom--none {
  padding-bottom: 0;
}
/* Legacy Utilities (margintop, marginbottom, etc.) */
.margintop {
  margin-top: var(--var-margin-default);
}
.margintop--50vh {
  margin-top: 50vh;
}
.margintop--small {
  margin-top: var(--var-margin-small);
}
.margintop--negative {
  margin-top: var(--var-margin-negative);
}
.margintop--medium {
  margin-top: var(--var-margin-medium);
}
.margintop--row {
  margin-top: var(--var-margin-row);
}
.margintop--none {
  margin-top: 0;
}
.marginbottom {
  margin-bottom: var(--var-margin-default);
}
.marginbottom--50vh {
  margin-bottom: 50vh;
}
.marginbottom--small {
  margin-bottom: var(--var-margin-small);
}
.marginbottom--negative {
  margin-bottom: var(--var-margin-negative);
}
.marginbottom--medium {
  margin-bottom: var(--var-margin-medium);
}
.marginbottom--row {
  margin-bottom: var(--var-margin-row);
}
.marginbottom--none {
  margin-bottom: 0;
}
.paddingtop {
  padding-top: var(--var-margin-default);
}
.paddingtop--50vh {
  padding-top: 50vh;
}
.paddingtop--small {
  padding-top: var(--var-margin-small);
}
.paddingtop--negative {
  padding-top: var(--var-margin-negative);
}
.paddingtop--medium {
  padding-top: var(--var-margin-medium);
}
.paddingtop--row {
  padding-top: var(--var-margin-row);
}
.paddingtop--none {
  padding-top: 0;
}
.paddingbottom {
  padding-bottom: var(--var-margin-default);
}
.paddingbottom--50vh {
  padding-bottom: 50vh;
}
.paddingbottom--small {
  padding-bottom: var(--var-margin-small);
}
.paddingbottom--negative {
  padding-bottom: var(--var-margin-negative);
}
.paddingbottom--medium {
  padding-bottom: var(--var-margin-medium);
}
.paddingbottom--row {
  padding-bottom: var(--var-margin-row);
}
.paddingbottom--none {
  padding-bottom: 0;
}
/* ---------- CONTENT SPACING (mit :has()) ---------- */
li.content + li.content,
#content > div + div {
  margin-top: var(--var-margin-default);
}
/* Cover gefolgt von Content: kein Abstand */
/* ---------- ABSOLUTE MEDIA MIXIN ---------- */
/* ---------- VIDEO PLAY INDICATOR ---------- */
.has-video {
  position: relative;
}
.has-video::after {
  content: "\25B6";
  /* Play Symbol */
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 5rem;
  color: white;
  text-shadow: 0px 4px 15px rgba(0, 0, 0, 0.2);
  opacity: 1;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.has-video.is-playing::after {
  opacity: 0;
}
/* Cover: Play-Button unten */
div.cover .has-video::after {
  align-items: end;
  justify-items: center;
  padding-bottom: 1.5rem;
}
/* ---------- CENTERING UTILITIES ---------- */
.cm-center {
  text-align: center;
}
.cm-text-center,
.textcentering {
  text-align: center;
}
.cm-text-center p,
.textcentering p {
  text-align: center;
}
@font-face {
  font-family: 'icomoon';
  src: url('/public/fonts/icomoon.eot?u8ox1g');
  src: url('/public/fonts/icomoon.eot?u8ox1g#iefix') format('embedded-opentype'), url('/public/fonts/icomoon.ttf?u8ox1g') format('truetype'), url('/public/fonts/icomoon.woff?u8ox1g') format('woff'), url('/public/fonts/icomoon.svg?u8ox1g#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-gondola:before {
  content: "\e920";
}
.icon-phone:before {
  content: "\e967";
}
.icon-link:before {
  content: "\e980";
}
.icon-house:before {
  content: "\e90c";
}
.icon-home:before {
  content: "\e90e";
}
.icon-glass:before {
  content: "\e985";
}
.icon-glass-whiskey:before {
  content: "\e987";
}
.icon-facebook:before {
  content: "\e905";
}
.icon-instagram:before {
  content: "\e907";
}
.icon-spotify:before {
  content: "\e90a";
}
.icon-tripadvisor:before {
  content: "\e970";
}
.icon-youtube:before {
  content: "\e90d";
}
.icon-arrow-down:before {
  content: "\e914";
}
.icon-arrow-left:before {
  content: "\e915";
}
.icon-arrow-right:before {
  content: "\e916";
}
.icon-arrow-up:before {
  content: "\e917";
}
.icon-comment:before {
  content: "\e92a";
}
.icon-comments:before {
  content: "\e92b";
}
.icon-envelope:before {
  content: "\e92d";
}
.icon-external-link:before {
  content: "\e902";
}
.icon-external-link-square:before {
  content: "\e903";
}
.icon-map-marker:before {
  content: "\e93e";
}
.icon-map:before {
  content: "\e940";
}
.icon-money-bill:before {
  content: "\e904";
}
.icon-newspaper:before {
  content: "\e943";
}
.icon-print:before {
  content: "\e948";
}
.icon-quote-right:before {
  content: "\e906";
}
.icon-snowflake:before {
  content: "\e974";
}
.icon-tag:before {
  content: "\e950";
}
.icon-tags:before {
  content: "\e951";
}
.icon-thumbs-down:before {
  content: "\e953";
}
.icon-thumbs-up:before {
  content: "\e954";
}
.icon-toggle-off:before {
  content: "\e908";
}
.icon-toggle-on:before {
  content: "\e909";
}
.icon-trash:before {
  content: "\e90b";
}
.icon-eat:before {
  content: "\e95b";
}
/* =================================
   HEADER - Basis-Styles
   ================================= */
#header {
  position: relative;
  z-index: 100;
  width: 100%;
  padding: 5rem var(--var-bodymargin);
  display: flex;
  align-items: center;
  justify-content: center;
}
#header #logo {
  display: block;
  height: 12rem;
  width: auto;
}
#header #logo img,
#header #logo svg {
  height: 100%;
  width: auto;
}
/* =================================
   FOOTER - Basis-Styles
   ================================= */
#footer {
  width: calc(100% - 2 * var(--var-bodymargin));
  border-radius: var(--var-borderradius);
  background: hsl(0, 0%, 13%);
  color: #fff;
  box-sizing: border-box;
  padding: var(--vimeos-padding-v) var(--vimeos-padding-h);
  margin: 4rem var(--var-bodymargin, 2rem);
  min-height: 80vh;
  justify-content: space-between;
  display: flex;
  flex-direction: column;
  align-items: start;
}
#footer svg {
  height: 8rem;
  width: auto;
}
#footer > div {
  width: 100%;
  margin-top: 4rem;
}
#footer #footer__content {
  margin-bottom: 3rem;
  width: 100%;
  gap: 3rem;
  display: flex;
  flex-direction: column;
}
#footer #footer__content .footer--left,
#footer #footer__content .footer--right {
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  color: #fff;
}
#footer #footer__content .footer--left strong,
#footer #footer__content .footer--right strong,
#footer #footer__content .footer--left b,
#footer #footer__content .footer--right b {
  font-weight: inherit;
  color: var(--color-accent);
}
#footer #footer__content .footer--right-- {
  text-align: right;
}
#footer #footer__imprint {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  font-size: 1.4rem;
}
#footer #footer__imprint a {
  color: var(--color-grey);
  transition: 0.2s color var(--var-ease);
}
#footer #footer__imprint a:hover {
  color: #fff;
  text-decoration: none;
}
#footer #footer__imprint a.zmart {
  margin-left: auto;
}
/* ===========================
   BUTTON SYSTEM (cm-)
   Beispiel-Markup:

   <a href="/kontakt" class="cm-button">
     <span class="cm-button__icon" aria-hidden="true">→</span>
     <span class="cm-button__label">Kontakt aufnehmen</span>
   </a>

   <a href="/mehr" class="cm-button cm-button--text">
     <span class="cm-button__label">Mehr erfahren</span>
   </a>

   <button type="button" class="cm-button cm-button--light cm-button--lg">
     <span class="cm-button__label">Eintrag erstellen</span>
   </button>
   =========================== */
/* Tokens in variables.less */
/* Mixins */
/* Hover mit Fuell-Effekt */
/* Hauptklasse: cm-button (+ Alias: c-button) */
.cm-button,
.c-button {
  display: inline-flex;
  gap: var(--btn-gap);
  position: relative;
  text-decoration: none;
  cursor: pointer;
  padding: var(--btn-py) var(--btn-px);
  border-radius: var(--button-radius);
  border: 1px solid var(--btn-fg);
  background: var(--btn-bg);
  color: var(--btn-fg);
  -webkit-tap-highlight-color: transparent;
  font-size: var(--fs-button);
  line-height: var(--fs-button-lh);
  color: var(--color-button, inherit);
  font-family: var(--font-sans);
  font-weight: var(--weight-regular);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  transition: 0.2s all var(--button-ease);
}
.cm-button > span,
.c-button > span {
  display: inline-block;
  position: relative;
}
.cm-button:focus-visible,
.c-button:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}
.cm-button .cm-button__title,
.c-button .cm-button__title {
  position: relative;
}
.cm-button:hover,
.c-button:hover {
  text-decoration: none;
  background: #222;
}
.cm-button:hover .cm-button__title,
.c-button:hover .cm-button__title {
  color: #fff;
}
.cm-button:hover .cm-button__icon,
.c-button:hover .cm-button__icon {
  color: #fff;
}
.cm-button:active,
.c-button:active {
  transform: translateY(1px) scale(0.98);
}
.cm-button--light,
.c-button--light {
  --btn-bg: var(--btn-bg-light);
  --btn-fg: var(--btn-fg-light);
}
.cm-button--text,
.c-button--text {
  background: none;
  padding: 0;
  border-radius: 0;
  border: none;
  --btn-bg: transparent;
  --btn-fg: var(--color-accent);
  gap: 0.4rem;
  padding-right: 0;
}
@media (hover: hover) {
  .cm-button--text:hover,
  .c-button--text:hover {
    text-decoration: underline;
    filter: none;
    transform: none;
  }
}
.cm-button--text .cm-button__icon,
.c-button--text .cm-button__icon {
  display: none;
}
.cm-button:disabled,
.c-button:disabled,
.cm-button[aria-disabled="true"],
.c-button[aria-disabled="true"] {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}
/* Button Spacing */
a.cm-button + a.cm-button,
a.cm-button + span.cm-button,
span.cm-button + a.cm-button,
span.cm-button + span.cm-button {
  margin-left: 2rem;
}
@media (hover: hover) {
  a.cm-button,
  span.cm-button {
    transition: 0.2s all var(--button-ease);
  }
  a.cm-button:hover,
  span.cm-button:hover {
    text-decoration: none;
    background: #222;
  }
  a.cm-button:hover .cm-button__title,
  span.cm-button:hover .cm-button__title {
    color: #fff;
  }
  a.cm-button:hover .cm-button__icon,
  span.cm-button:hover .cm-button__icon {
    color: #fff;
  }
  a.cm-button:active,
  span.cm-button:active {
    transform: translateY(1px) scale(0.98);
  }
}
/* Alias-Mixins */
/* Button in Listen */
ul.button {
  text-align: center;
}
ul.button li.button {
  display: inline-block;
}
ul.button li.button + li.button {
  margin-left: 1rem;
}
/* ===========================
   cm-card — Karten-Komponente
   =========================== */
.cm-card {
  position: relative;
  display: flex;
  overflow: hidden;
  border-radius: var(--var-borderradius);
  /* Fullpic */
}
.cm-card--vertical {
  flex-direction: column;
}
.cm-card--horizontal {
  flex-direction: row;
}
@media screen and (max-width: 768px) {
  .cm-card--horizontal {
    flex-direction: column;
  }
}
.cm-card__image {
  overflow: hidden;
}
.cm-card__image picture,
.cm-card__image img {
  transition: transform 0.4s ease;
}
.cm-card--horizontal .cm-card__image {
  flex: 0 0 50%;
}
@media screen and (max-width: 768px) {
  .cm-card--horizontal .cm-card__image {
    flex: none;
  }
}
.cm-card__content {
  padding: 2rem 0;
}
.cm-card__content .cm-button {
  align-self: flex-start;
}
.cm-card--horizontal .cm-card__content {
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cm-card--fullpic {
  flex-direction: column;
  min-height: 40rem;
}
.cm-card--fullpic .cm-card__image {
  position: absolute;
  inset: 0;
  z-index: 1;
  height: 100%;
}
.cm-card--fullpic .cm-card__image picture,
.cm-card--fullpic .cm-card__image video,
.cm-card--fullpic .cm-card__image img {
  opacity: 0.8;
}
.cm-card--fullpic .cm-card__image .singlefileconnectionform .picconnection .editpanel {
  margin-left: 0;
  left: auto;
  right: 2em;
}
.cm-card--fullpic .cm-card__content {
  position: relative;
  z-index: 30;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  text-align: center;
  pointer-events: none;
  padding: 3rem;
  color: #fff;
}
.cm-card--fullpic .cm-card__content > * {
  pointer-events: auto;
}
.cm-card--fullpic .cm-card__content .cm-button {
  align-self: center;
}
@media (hover: hover) {
  .cm-card:hover .cm-card__image picture,
  .cm-card:hover .cm-card__image img {
    transform: scale(1.05);
  }
}
a.cm-card {
  text-decoration: none;
  color: inherit;
}
a.cm-card:hover {
  text-decoration: none;
}
/* ===========================
   Legacy: .card (fuer listinfos/infobox)
   =========================== */
.card {
  position: relative;
}
.card .cmartbge {
  z-index: 0;
}
/* --- Standalone Card (div.card / a.card) --- */
div.card,
a.card {
  overflow: hidden;
  display: flex;
  border-radius: var(--var-borderradius);
  /* Horizontal (default) */
  flex-direction: row;
  width: 40rem;
  max-width: 100%;
  /* Vertical */
}
div.card .card__image,
a.card .card__image {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--var-borderradius);
  /* Container muss position:relative haben */
}
div.card .card__image picture,
a.card .card__image picture,
div.card .card__image video,
a.card .card__image video,
div.card .card__image img.img,
a.card .card__image img.img {
  border-radius: var(--var-borderradius);
}
div.card .card__image img,
a.card .card__image img,
div.card .card__image video,
a.card .card__image video,
div.card .card__image picture,
a.card .card__image picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.card .card__image picture img,
a.card .card__image picture img {
  position: relative;
}
div.card .card__image > video,
a.card .card__image > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.card .card__image > picture,
a.card .card__image > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.card .card__image > picture > img,
a.card .card__image > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.card .card__image .filedropbox,
a.card .card__image .filedropbox {
  height: 100%;
}
div.card .card__content,
a.card .card__content {
  position: relative;
  display: block;
  width: 100%;
  padding: 3rem 4rem 4rem 4rem;
  box-sizing: border-box;
}
div.card .card__content .card__title,
a.card .card__content .card__title,
div.card .card__content h3,
a.card .card__content h3 {
  margin-bottom: 2rem;
  display: inline-block;
}
div.card .card__image,
a.card .card__image {
  flex: 0 0 50%;
  height: auto;
}
@media screen and (max-width: 768px) {
  div.card,
  a.card {
    flex-direction: column;
  }
  div.card .card__image,
  a.card .card__image {
    flex: none;
    height: 25rem;
  }
}
div.card.card--vertical,
a.card.card--vertical {
  flex-direction: column;
  width: 50%;
  max-width: 70rem;
}
div.card.card--vertical .card__image,
a.card.card--vertical .card__image {
  flex: none;
  height: 25rem;
}
@media screen and (max-width: 1000px) {
  div.card.card--vertical,
  a.card.card--vertical {
    width: 100%;
    max-width: 70rem;
    margin: 0 auto;
  }
}
a.card {
  text-decoration: none;
  color: inherit;
}
a.card:hover {
  text-decoration: none;
}
/* --- Card-Liste (ul.card > li.card) --- */
#content ul.card {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--var-grid-gap);
}
#content ul.card > li.card {
  flex: 0 0 40rem;
  max-width: 100%;
}
#content ul.card > li.card a.card,
#content ul.card > li.card div.card {
  width: 100%;
}
.editing.cmart .card.cmart-editmode {
  display: flex !important;
}
/* --- Card Slider (cm-cardslider) --- */
.cm-cardslider .swiper-slide .cm-card {
  width: 100%;
  height: 100%;
}
.cm-cardslider--horizontal .swiper-slide {
  width: 60rem;
}
.cm-cardslider--fullpic .swiper-slide {
  width: 60rem;
}
div.singleheadline {
  position: relative;
  float: none;
  margin: 0 auto;
  clear: left;
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
}
div.singleheadline h1,
div.singleheadline h2,
div.singleheadline h3 {
  grid-column: 2 / span 12;
  max-width: 30ch;
  margin: 0 auto;
}
@media screen and (max-width: 900px) {
  div.singleheadline.longtext h1 {
    font-size: var(--fs-h3);
  }
}
div.singleheadline h3 {
  max-width: 42ch;
}
#content {
  /* Haupttextbereiche */
  /* Abstand zwischen aufeinanderfolgenden Blöcken */
}
#content .cm-text-center,
#content .textcentering {
  text-align: center;
}
#content .cm-text-center p,
#content .textcentering p {
  text-align: center;
}
#content .cm-text,
#content .textobj {
  /* Basis-Elemente */
  /* Abstände zwischen Elementen */
  /* Verhindere zusätzliche p-Margins in verschachtelten Strukturen */
  /* Unordered Lists mit einfachem Bullet */
  /* Bilder im Fließtext */
}
#content .cm-text p,
#content .textobj p,
#content .cm-text li,
#content .textobj li,
#content .cm-text td,
#content .textobj td {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
  color: var(--color-body, inherit);
  font-weight: var(--weight-regular);
  max-width: 65ch;
}
#content .cm-text p i,
#content .textobj p i,
#content .cm-text p em,
#content .textobj p em {
  font-style: normal;
}
#content .cm-text p + ul,
#content .textobj p + ul,
#content .cm-text p + p,
#content .textobj p + p,
#content .cm-text ul + p,
#content .textobj ul + p,
#content .cm-text ul + h2,
#content .textobj ul + h2,
#content .cm-text ul + h3,
#content .textobj ul + h3,
#content .cm-text ul + h4,
#content .textobj ul + h4,
#content .cm-text p + h2,
#content .textobj p + h2,
#content .cm-text p + h3,
#content .textobj p + h3 {
  margin-top: 1em;
}
#content .cm-text h2 + p,
#content .textobj h2 + p,
#content .cm-text h3 + p,
#content .textobj h3 + p,
#content .cm-text h4 + p,
#content .textobj h4 + p,
#content .cm-text h2 + ul,
#content .textobj h2 + ul,
#content .cm-text h3 + ul,
#content .textobj h3 + ul,
#content .cm-text h4 + ul,
#content .textobj h4 + ul {
  margin-top: 3rem;
}
#content .cm-text h1 p,
#content .textobj h1 p,
#content .cm-text h2 p,
#content .textobj h2 p,
#content .cm-text h3 p,
#content .textobj h3 p,
#content .cm-text h4 p,
#content .textobj h4 p,
#content .cm-text p p,
#content .textobj p p,
#content .cm-text ul p,
#content .textobj ul p {
  margin-bottom: 0;
}
#content .cm-text ul,
#content .textobj ul {
  list-style: none;
  position: relative;
  width: 100%;
  margin-left: 0;
}
#content .cm-text ul li,
#content .textobj ul li {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 0;
  padding: 0.3em 0.5em 0.3em 1.4em;
  line-height: 1.4;
}
#content .cm-text ul li::before,
#content .textobj ul li::before {
  content: "•";
  position: absolute;
  top: 0.3em;
  left: 0;
  width: 1.4em;
  height: 1.6em;
  font-size: 1.2em;
  color: var(--color-accent);
}
#content .cm-text img,
#content .textobj img {
  position: relative;
  max-width: 100%;
  height: auto;
}
#content .textblock + .textblock {
  margin-top: 1.5em;
}
#content .cm-text + .cm-text,
#content .textobj + .textobj {
  margin-top: 1.5em;
}
#content div.textblock {
  position: relative;
  width: 100%;
  z-index: 2;
}
#content div.textblock.style--columns.style--columns {
  max-width: 80ch;
  margin: 0 auto;
}
@media screen and (max-width: 700px) {
  #content div.textblock.style--columns.style--columns {
    max-width: 90%;
  }
}
#content div.textblock.style--columns div.cm-text,
#content div.textblock.style--columns div.textobj {
  column-count: 2;
  column-gap: 4em;
}
@media screen and (max-width: 900px) {
  #content div.textblock.style--columns div.cm-text,
  #content div.textblock.style--columns div.textobj {
    column-gap: 3em;
  }
}
@media screen and (max-width: 700px) {
  #content div.textblock.style--columns div.cm-text,
  #content div.textblock.style--columns div.textobj {
    column-count: 1;
  }
}
#content div.textblock.style--bigtext .textblockwrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
}
#content div.textblock.style--bigtext .textblockwrap .textobj,
#content div.textblock.style--bigtext .textblockwrap h4 {
  grid-column: 4 / span 9;
}
@media screen and (max-width: 1100px) {
  #content div.textblock.style--bigtext .textblockwrap .textobj,
  #content div.textblock.style--bigtext .textblockwrap h4 {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 900px) {
  #content div.textblock.style--bigtext .textblockwrap .textobj,
  #content div.textblock.style--bigtext .textblockwrap h4 {
    grid-column: 3 / span 11;
  }
}
@media screen and (max-width: 700px) {
  #content div.textblock.style--bigtext .textblockwrap .textobj,
  #content div.textblock.style--bigtext .textblockwrap h4 {
    grid-column: 2 / span 12;
  }
}
#content div.textblock.style--bigtext .textblockwrap h4 {
  margin-bottom: 3rem;
}
#content div.textblock.style--bigtext .textblockwrap h4 strong {
  font-weight: inherit;
  display: inline-block;
  background: var(--color-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
#content div.textblock.style--bigtext .textblockwrap h4 strong span div {
  -webkit-text-fill-color: #111;
}
#content div.textblock.style--bigtext .textblockwrap .textobj p {
  font-size: var(--fs-bigtext);
  line-height: var(--fs-bigtext-lh);
  color: var(--color-bigtext, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
}
#content div.textblock.default .textblockwrap,
#content div.textblock.style-- .textblockwrap,
#content div.textblock.style--default .textblockwrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  row-gap: var(--var-row-gap);
}
#content div.textblock.default .textblockwrap .textobj,
#content div.textblock.style-- .textblockwrap .textobj,
#content div.textblock.style--default .textblockwrap .textobj {
  grid-column: 5 / span 6;
}
#content div.textblock.default .textblockwrap .textblockbutton,
#content div.textblock.style-- .textblockwrap .textblockbutton,
#content div.textblock.style--default .textblockwrap .textblockbutton {
  grid-column: 8 / span 6;
}
#content div.textblock.centering {
  text-align: center;
}
.textblock .textblockwrap > * {
  will-change: transform, opacity;
}
#content .cm-columns div.textblock.style--bigtext .textblockwrap,
#content .cm-columns div.textblock.style--default .textblockwrap,
#content .cm-columns div.textblock.default .textblockwrap,
#content .cm-columns div.textblock.bigtext .textblockwrap {
  display: block;
}
/* =================================
   SEARCH - Frontend-Suche
   ================================= */
.cmart-search {
  position: relative;
}
.cmart-search__results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid #ddd;
  border-top: none;
  border-radius: 0 0 8px 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  z-index: 100;
  max-height: 400px;
  overflow-y: auto;
}
.cmart-search__item {
  display: flex;
  flex-direction: column;
  padding: 10px 14px;
  text-decoration: none;
  color: #333;
  border-bottom: 1px solid #eee;
  transition: background 0.15s;
}
.cmart-search__item:last-child {
  border-bottom: none;
}
.cmart-search__item:hover {
  background: #f5f7fa;
}
.cmart-search__type {
  font-size: 0.7em;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #888;
  margin-bottom: 2px;
}
.cmart-search__title {
  font-size: 0.95em;
  font-weight: 600;
  color: #222;
}
.cmart-search__desc {
  font-size: 0.8em;
  color: #666;
  margin-top: 3px;
  line-height: 1.4;
}
.cmart-search__empty {
  padding: 12px 14px;
  color: #888;
  font-size: 0.9em;
}
/* cm-mediabox — wiederverwendbare Media-Komponente */
.cm-mediabox {
  position: relative;
  overflow: hidden;
  width: 100%;
  /* Default: Bild fließt proportional */
  /* Container muss position:relative haben */
  /* Cover-Shapes: Bild füllt Container absolut */
  /* Contain: Bild passt in Container ohne Crop */
  /* Aspect-Ratios */
}
.cm-mediabox > video {
  width: 100%;
  height: auto;
}
.cm-mediabox > picture {
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: auto;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
.cm-mediabox > picture > img {
  width: 100%;
  height: auto;
}
.cm-mediabox.cm-mediabox--cover,
.cm-mediabox.cm-mediabox--landscape,
.cm-mediabox.cm-mediabox--portrait,
.cm-mediabox.cm-mediabox--square {
  /* Container muss position:relative haben */
}
.cm-mediabox.cm-mediabox--cover img,
.cm-mediabox.cm-mediabox--landscape img,
.cm-mediabox.cm-mediabox--portrait img,
.cm-mediabox.cm-mediabox--square img,
.cm-mediabox.cm-mediabox--cover video,
.cm-mediabox.cm-mediabox--landscape video,
.cm-mediabox.cm-mediabox--portrait video,
.cm-mediabox.cm-mediabox--square video,
.cm-mediabox.cm-mediabox--cover picture,
.cm-mediabox.cm-mediabox--landscape picture,
.cm-mediabox.cm-mediabox--portrait picture,
.cm-mediabox.cm-mediabox--square picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.cm-mediabox.cm-mediabox--cover picture img,
.cm-mediabox.cm-mediabox--landscape picture img,
.cm-mediabox.cm-mediabox--portrait picture img,
.cm-mediabox.cm-mediabox--square picture img {
  position: relative;
}
.cm-mediabox.cm-mediabox--cover > video,
.cm-mediabox.cm-mediabox--landscape > video,
.cm-mediabox.cm-mediabox--portrait > video,
.cm-mediabox.cm-mediabox--square > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.cm-mediabox.cm-mediabox--cover > picture,
.cm-mediabox.cm-mediabox--landscape > picture,
.cm-mediabox.cm-mediabox--portrait > picture,
.cm-mediabox.cm-mediabox--square > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
.cm-mediabox.cm-mediabox--cover > picture > img,
.cm-mediabox.cm-mediabox--landscape > picture > img,
.cm-mediabox.cm-mediabox--portrait > picture > img,
.cm-mediabox.cm-mediabox--square > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cm-mediabox.cm-mediabox--contain picture,
.cm-mediabox.cm-mediabox--contain picture img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.cm-mediabox.cm-mediabox--cover {
  aspect-ratio: 16 / 9;
}
@media screen and (max-width: 768px) {
  .cm-mediabox.cm-mediabox--cover {
    aspect-ratio: 2 / 3;
  }
}
.cm-mediabox.cm-mediabox--landscape {
  aspect-ratio: 3 / 2;
}
.cm-mediabox.cm-mediabox--portrait {
  aspect-ratio: 2 / 3;
}
.cm-mediabox.cm-mediabox--square {
  aspect-ratio: 1 / 1;
}
/* cm-eyebrow — Dachzeile */
.cm-eyebrow {
  display: block;
  font-size: var(--fs-eyebrow);
  line-height: var(--fs-eyebrow-lh);
  color: var(--color-eyebrow, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-accent);
  margin-bottom: 1rem;
}
/* cm-titlegroup — Text-Einheit (eyebrow + headline + text + button) */
.cm-titlegroup > * + * {
  margin-top: 1.5rem;
}
.cm-titlegroup > .cm-eyebrow + * {
  margin-top: 0.8rem;
}
.cm-titlegroup .textobj {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
  color: var(--color-body, inherit);
  font-weight: var(--weight-regular);
}
.cm-titlegroup--center {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .cm-titlegroup > * + * {
    margin-top: 1rem;
  }
}
/* cm-icontext — Icon/Bild mit Text */
.cm-icontext {
  display: flex;
  align-items: flex-start;
  gap: 2rem;
}
.cm-icontext--horizontal {
  flex-direction: row;
}
.cm-icontext--vertical {
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.cm-icontext__icon {
  flex-shrink: 0;
  overflow: hidden;
  border-radius: var(--var-borderradius);
}
.cm-icontext--small .cm-icontext__icon {
  width: 4rem;
  height: 4rem;
}
.cm-icontext--medium .cm-icontext__icon {
  width: 6rem;
  height: 6rem;
}
.cm-icontext--large .cm-icontext__icon {
  width: 10rem;
  height: 10rem;
}
.cm-icontext__content {
  flex: 1;
}
.cm-icontext__content strong {
  display: block;
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  margin-bottom: 0.5rem;
}
.cm-icontext__content strong strong,
.cm-icontext__content strong b {
  font-weight: inherit;
  color: var(--color-accent);
}
.cm-icontext__content .textobj {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
  color: var(--color-body, inherit);
  font-weight: var(--weight-regular);
}
@media screen and (max-width: 768px) {
  .cm-icontext--small .cm-icontext__icon {
    width: 3rem;
    height: 3rem;
  }
  .cm-icontext--large .cm-icontext__icon {
    width: 7rem;
    height: 7rem;
  }
}
/* ===========================
   cm-faq — FAQ Akkordeon
   =========================== */
.cm-faqs {
  display: flex;
  flex-direction: column;
  gap: 1px;
  width: 80%;
  margin: 0 auto;
}
.cm-faq {
  border-bottom: 1px solid var(--var-color-border, #e0e0e0);
  position: relative;
}
.cm-faq__question {
  padding: 2rem 0;
  cursor: pointer;
  font-weight: 600;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cm-faq__question::after {
  content: '+';
  font-size: 1.6em;
  font-weight: 300;
  transition: transform 0.3s ease;
}
.cm-faq__question::-webkit-details-marker {
  display: none;
}
.cm-faq[open] > .cm-faq__question::after {
  transform: rotate(45deg);
}
.cm-faq__answer {
  padding: 0 0 2rem;
}
/**
 * CMART Popup Styles
 *
 * Styles für das dynamisch geladene Popup-System.
 * Unterstützt verschiedene Style-Varianten:
 * - default: Rechts positioniert
 * - centered: Zentriert mit Overlay
 * - fullscreen: Vollbild
 * - banner: Unten fixiert
 */
.cmart-popup-open {
  overflow: hidden;
}
.cmart-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  pointer-events: none;
}
.cmart-popup--visible {
  opacity: 1;
  visibility: visible;
}
.cmart-popup--visible .cmart-popup__container {
  transform: translateY(0);
}
.cmart-popup__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  pointer-events: none;
}
.cmart-popup__container {
  position: relative;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.25);
  max-width: 90%;
  max-height: 90vh;
  overflow: auto;
  transform: translateY(20px);
  transition: transform 0.3s ease;
  pointer-events: auto;
}
.cmart-popup__close {
  position: absolute;
  top: -0.5em;
  right: -0.5em;
  width: 2.5em;
  height: 2.5em;
  border-radius: 50%;
  background: #fff;
  border: none;
  font-size: 1.5em;
  line-height: 1;
  cursor: pointer;
  z-index: 10;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
  transition: background 0.2s, color 0.2s;
}
.cmart-popup__close:hover {
  background: #333;
  color: #fff;
}
.cmart-popup__image img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 10px 10px 0 0;
}
.cmart-popup__content {
  padding: 2em;
  text-align: center;
}
.cmart-popup__title {
  margin: 0 0 0.5em;
  font-size: 1.5em;
  font-weight: 600;
  color: #222;
}
.cmart-popup__text {
  margin-bottom: 1.5em;
  color: #555;
  line-height: 1.5;
}
.cmart-popup__text p {
  margin: 0 0 0.5em;
}
.cmart-popup__text p:last-child {
  margin-bottom: 0;
}
.cmart-popup__button {
  display: inline-block;
  padding: 0.8em 2em;
  background: var(--cmart-color, #333);
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
  font-weight: 500;
  transition: background 0.2s, transform 0.2s;
}
.cmart-popup__button:hover {
  background: var(--cmart-color-hover, #111);
  transform: translateY(-2px);
}
.cmart-popup--default {
  align-items: center;
  justify-content: flex-end;
  padding: 2em;
}
.cmart-popup--default .cmart-popup__overlay {
  background: transparent;
  pointer-events: none;
}
.cmart-popup--default .cmart-popup__container {
  width: 22em;
  max-width: 100%;
  pointer-events: auto;
}
@media screen and (max-width: 600px) {
  .cmart-popup--default {
    padding: 1em;
  }
  .cmart-popup--default .cmart-popup__container {
    width: 100%;
  }
}
.cmart-popup--centered .cmart-popup__overlay {
  background: rgba(0, 0, 0, 0.5);
  pointer-events: auto;
  cursor: pointer;
}
.cmart-popup--centered .cmart-popup__container {
  width: 500px;
  max-width: 90%;
}
.cmart-popup--fullscreen .cmart-popup__overlay {
  background: rgba(0, 0, 0, 0.8);
  pointer-events: auto;
  cursor: pointer;
}
.cmart-popup--fullscreen .cmart-popup__container {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  border-radius: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cmart-popup--fullscreen .cmart-popup__close {
  top: 1em;
  right: 1em;
  width: 3em;
  height: 3em;
  font-size: 1.5em;
}
.cmart-popup--fullscreen .cmart-popup__image {
  max-height: 50vh;
  overflow: hidden;
}
.cmart-popup--fullscreen .cmart-popup__image img {
  border-radius: 0;
  object-fit: cover;
  height: 100%;
}
.cmart-popup--fullscreen .cmart-popup__content {
  padding: 3em;
}
.cmart-popup--fullscreen .cmart-popup__title {
  font-size: 2em;
}
.cmart-popup--fullscreen .cmart-popup__text {
  font-size: 1.2em;
}
.cmart-popup--banner {
  align-items: flex-end;
  justify-content: center;
}
.cmart-popup--banner .cmart-popup__overlay {
  background: transparent;
  pointer-events: none;
}
.cmart-popup--banner .cmart-popup__container {
  width: 100%;
  max-width: 100%;
  border-radius: 10px 10px 0 0;
  transform: translateY(100%);
  pointer-events: auto;
}
.cmart-popup--banner.cmart-popup--visible .cmart-popup__container {
  transform: translateY(0);
}
.cmart-popup--banner .cmart-popup__close {
  top: 0.5em;
  right: 1em;
}
.cmart-popup--banner .cmart-popup__content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2em;
  padding: 1.5em 2em;
  text-align: left;
}
@media screen and (max-width: 600px) {
  .cmart-popup--banner .cmart-popup__content {
    flex-direction: column;
    text-align: center;
  }
}
.cmart-popup--banner .cmart-popup__title {
  margin: 0;
  font-size: 1.2em;
}
.cmart-popup--banner .cmart-popup__text {
  margin: 0;
  flex: 1;
}
.cmart-popup--banner .cmart-popup__text p {
  margin: 0;
}
.cmart-popup--banner .cmart-popup__button {
  white-space: nowrap;
}
.cmart-popup--banner .cmart-popup__image {
  display: none;
}
#cmart-contentpopup {
  position: fixed;
  top: 50%;
  display: none;
  right: 5em;
  float: left;
  transform: translate(0, -50%);
  width: 21em;
  max-width: 70%;
  z-index: 200;
}
@media screen and (max-width: 800px) {
  #cmart-contentpopup {
    right: 3em;
    width: 19em;
  }
}
#cmart-contentpopup #cmart-contentpopupbg {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  display: block;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.25);
  border-radius: 10px;
}
#cmart-contentpopup > a {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: 220;
}
#cmart-contentpopupcloser {
  position: absolute;
  display: block;
  right: -1em;
  top: -1em;
  z-index: 230;
  width: 4em;
  height: 4em;
  border-radius: 30px;
  background: #fff;
}
#cmart-contentpopupcloser span {
  position: absolute;
  display: block;
  top: 50%;
  left: 0;
  width: 100%;
  text-align: center;
  font-size: 2em;
  line-height: normal;
  transform: translate(0, -50%);
}
#cmart-contentpopupicon {
  width: 100%;
  display: block;
  position: relative;
  font-size: 4.4em;
  color: #fff;
  margin-bottom: 0.4em;
}
#cmart-contentpopuplink {
  width: calc(100% - 2em);
  margin-left: 1em;
  margin-bottom: 1em;
  border-radius: 8px;
  color: #fff;
  padding: 1em 0;
  box-sizing: border-box;
  position: relative;
  text-align: center;
}
#cmart-contentpopuplink span {
  line-height: normal;
  text-transform: uppercase;
}
#cmart-contentpopupcontent {
  padding: 3em 1.5em;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  display: block;
  position: relative;
  z-index: 205;
}
#cmart-contentpopupcontent p,
#cmart-contentpopupcontent h1,
#cmart-contentpopupcontent h2,
#cmart-contentpopupcontent h3,
#cmart-contentpopupcontent h4 {
  color: #fff;
}
#cmart-contentpopupcontent p {
  margin-bottom: 0;
  line-height: 130%;
}
#cmart-contentpopupcontent p + p {
  margin-top: 0.5em;
}
.js.no-touch #cmart-contentpopup.haslink #cmart-contentpopupcloser,
.js.no-touch #cmart-contentpopup.haslink #cmart-contentpopuplink {
  transition: 0.13s all ease;
}
.js.no-touch #cmart-contentpopup.haslink:hover #cmart-contentpopupcloser {
  background: #111;
  color: #fff;
}
.js.no-touch #cmart-contentpopup.haslink:hover #cmart-contentpopuplink {
  background: #fff;
}
/**
 * Accordion Module - Modern BEM with cm-prefix
 * CMS-specific classes (listinfos, infobox) kept for editor functionality
 */
.cm-accordion {
  position: relative;
  width: 80%;
  margin: 0 auto;
  max-width: 100rem;
}
.cm-accordion__item {
  position: relative;
  clear: left;
  display: block;
  box-sizing: border-box;
  border: 2px solid #e0e0e0;
  border-radius: 12px;
  background: #fff;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}
.cm-accordion__item + .cm-accordion__item {
  margin-top: 1.5rem;
}
.cm-accordion__item:not(.active):hover {
  border-color: #d0d0d0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  transform: translateY(-2px);
}
.cm-accordion__item.active {
  border-color: var(--color-accent, #333);
  background: #fafafa;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}
.cm-accordion__item.active .cm-accordion__title .cm-accordion__icon {
  transform: translateY(-50%) rotate(180deg);
  color: var(--color-accent, #333);
}
.cm-accordion__item.active .cm-accordion__content {
  display: block;
  animation: accordion-expand 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.cm-accordion__title {
  display: block;
  width: 100%;
  box-sizing: border-box;
  text-decoration: none;
  padding: 2rem 6rem 2rem 2.5rem;
  position: relative;
  font-weight: 500;
  font-size: 1.8rem;
  color: #333;
  line-height: 1.4;
  clear: left;
  cursor: pointer;
  user-select: none;
  transition: all 0.2s ease;
}
.cm-accordion__title strong {
  width: 80%;
  font-weight: 500;
  line-height: 1.4;
  display: block;
}
.cm-accordion__title:hover {
  color: var(--color-accent, #333);
}
.cm-accordion__icon {
  position: absolute;
  top: 50%;
  right: 2.5rem;
  line-height: 100%;
  transform: translateY(-50%);
  font-size: 2rem;
  color: #999;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.cm-accordion__icon .icon-arrow-down {
  display: block;
}
.cm-accordion__content {
  display: none;
  clear: left;
  width: 100%;
  box-sizing: border-box;
  padding: 0 2.5rem 2.5rem 2.5rem;
  min-height: 0;
  color: #666;
  font-size: 1.6rem;
  line-height: 1.6;
}
.cm-accordion__content p {
  margin-bottom: 1.5rem;
}
.cm-accordion__content p:last-child {
  margin-bottom: 0;
}
.cm-accordion__content .textblockwrap {
  display: block;
}
@keyframes accordion-expand {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/**
 * Tabs Module - Modern BEM with cm-prefix
 * CMS-specific classes (listinfos, infobox) kept for editor functionality
 */
#content .cm-tabs .cmart-listinfos {
  margin-bottom: 0;
  position: absolute;
  z-index: 20;
  width: auto;
  text-align: center;
  left: 50%;
  top: -3em;
  transform: translate(-50%, 0);
}
#content .cm-tabs .cmart-listinfos .cmart-infobox a.infoboxtitle,
#content .cm-tabs .cmart-listinfos li.cms_add_item {
  display: inline-block;
  font-size: 1.8rem !important;
  line-height: normal;
  padding: 0.7rem 0.9rem !important;
  background: var(--cmart-color);
  color: #fff;
  border-radius: var(--cmart-borderradius);
  text-decoration: none;
  clear: none;
}
#content .cm-tabs .cmart-listinfos .cmart-infobox a.infoboxtitle:hover,
#content .cm-tabs .cmart-listinfos li.cms_add_item:hover {
  background: var(--cmart-color-dark);
}
#content .cm-tabs .cmart-listinfos .cmart-infobox {
  position: relative;
  clear: none;
  width: auto;
  display: inline-block;
}
#content .cm-tabs .cmart-listinfos .cmart-infobox + li {
  margin-left: 1rem;
}
#content .cm-tabs .cmart-listinfos .cmart-infobox.active a.infoboxtitle {
  color: var(--cmart-color);
  border: 2px solid var(--cmart-color);
  background: transparent;
}
#content .cm-tabs .cmart-listinfos .cmart-infobox:hover .cms_editbox .cms_editbox_title {
  display: block;
}
#content .cm-tabs .cmart-listinfos li.cms_add_item {
  margin-top: 0;
  width: auto;
}
#content .cm-tabs div.cmart-infobox.tabnav .cms_editbox .cms_editbox_title {
  display: none;
}
.cm-tabs {
  clear: left;
  position: relative;
  width: 100%;
  margin: 0 auto;
  max-width: 90rem;
  box-sizing: border-box;
  padding: 0 4rem;
  min-height: 15rem;
}
.cm-tabs__title {
  margin-bottom: 2rem;
}
.cm-tabs__navigation {
  position: relative;
  width: 100%;
  margin-bottom: 2rem;
  border-bottom: 2px solid #e0e0e0;
}
.cm-tabs__navigation > div {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.cm-tabs__nav {
  display: inline-flex;
  align-items: center;
  position: relative;
  text-decoration: none;
  padding: 1rem 2rem;
  background: transparent;
  border: 2px solid transparent;
  border-bottom: none;
  border-radius: 8px 8px 0 0;
  font-weight: 500;
  color: #666;
  transition: all 0.2s ease;
  margin-bottom: -2px;
}
.cm-tabs__nav:hover {
  text-decoration: none;
  color: #333;
  background: #f5f5f5;
}
.cm-tabs__nav.active {
  color: #333;
  background: #fff;
  border-color: #e0e0e0;
  border-bottom-color: #fff;
  font-weight: 600;
}
.cm-tabs__content {
  width: 100%;
  box-sizing: border-box;
  padding: 2rem 0;
  position: relative;
  clear: left;
  display: none;
  animation: tab-fade-in 0.3s ease;
}
.cm-tabs__content.active {
  display: block;
}
.cm-tabs__inner {
  width: 100%;
  clear: left;
}
.cm-tabs__inner .tabcontentbox {
  width: 100%;
  box-sizing: border-box;
}
@keyframes tab-fade-in {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/**
 * Slider Module - Modern BEM with cm-prefix
 * Uses Swiper.js for slider functionality
 * CMS-specific classes (listinfos, infobox) kept for editor functionality
 */
.cm-slider {
  position: relative;
  width: 100%;
  clear: left;
}
.cm-slider__title {
  margin-bottom: 2rem;
}
.cm-slider__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  cursor: pointer;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  transition: all 0.2s ease;
}
.cm-slider__nav:hover {
  background: #ffffff;
}
.cm-slider__nav--prev {
  left: 2rem;
}
.cm-slider__nav--next {
  right: 2rem;
}
.cm-slider__nav .arrow {
  display: block;
  font-size: 2rem;
  line-height: 1;
}
.cm-slider__container {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.cm-slider__item {
  position: relative;
  width: 100%;
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cm-slider__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 2rem;
}
.cm-slider__heading {
  margin-bottom: 1rem;
  color: #fff;
}
.cm-slider__heading span {
  display: inline-block;
}
.cm-slider__subheading {
  color: #fff;
}
.cm-slider__subheading span {
  display: inline-block;
}
.cm-slider__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  z-index: 1;
}
li.content.slider > div.cms_editbox {
  top: 50% !important;
}
li.content.slider .cmart_list_editor {
  padding: 15em 5em;
  background: #444;
}
li.content.slider .cmart_list_editor .cmart-listinfos {
  z-index: 100;
}
li.content.slider .cmart_list_editor .cmart-listinfos .cmart-infobox {
  padding: 2em;
  box-sizing: border-box;
  position: relative;
  border-bottom: 1px solid #ddd;
  margin-bottom: 2em;
  width: 100%;
  clear: left;
  background: #fff;
}
li.content.slider .cmart_list_editor .cmart-listinfos .cmart-infobox p {
  font-size: 1.5em;
  line-height: 130%;
}
li.content.slider .cmart_list_editor .cmart-listinfos .cmart-infobox .picconnection {
  position: relative;
}
.cmart-listinfos.slider .cmart-infobox {
  clear: left;
  position: relative;
  width: 100%;
  box-sizing: border-box;
  padding: 4em;
  border: 1px solid #ddd;
  margin: 0 0 1em 0;
}
.cm-slider {
  position: relative;
  overflow: hidden;
  width: 100%;
}
.cm-slider .swiper-wrapper {
  align-items: stretch;
}
.cm-slider .swiper-slide {
  width: 35rem;
  max-width: 80vw;
  height: auto;
}
.cm-slider .swiper-slide .cms_editbox {
  transform: translateY(0);
  top: 0;
  left: 0;
  border-radius: 0 0 var(--cmart-borderradius) 0;
}
.cm-slider .swiper-slide .cms_sortHandler {
  cursor: grab;
}
.cm-slider .swiper-slide.cms_add_item {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: var(--var-borderradius);
  font-size: 2.6rem;
  color: #fff;
  cursor: pointer;
  background: var(--cmart-color);
  transition: background-color 0.2s, transform 0.2s, color 0.2s;
}
.cm-slider .swiper-slide.cms_add_item:hover {
  background: var(--cmart-color-dark);
  color: #fff;
  transform: translate(0, -2px);
  font-size: 3.4rem;
}
.cm-slider .slidearrow-prev,
.cm-slider .slidearrow-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}
.cm-slider .slidearrow-prev {
  left: 1rem;
}
.cm-slider .slidearrow-next {
  right: 1rem;
}
/* ===========================
   cm-table — Tabellen-Komponente (div-basiert mit display:table)
   =========================== */
.cm-table {
  width: 100%;
  position: relative;
  /* Desktop: Tabellen-Layout via display:table */
  /* Mobile: Karten-Layout */
}
.cm-table__title {
  margin-top: 1.4em;
  margin-bottom: 0.4em;
}
.cm-table__desktop {
  display: table;
  width: 100%;
  border-collapse: collapse;
}
@media screen and (max-width: 800px) {
  .cm-table__desktop {
    display: none;
  }
}
.cm-table__head {
  display: table-row;
}
.cm-table__head .cm-table__cell {
  padding: 0.8em;
  text-align: center;
  font-weight: bold;
  color: #222;
  border-bottom: 2px solid #ddd;
}
.cm-table__head .cm-table__cell:first-child {
  text-align: left;
}
.cm-table__row {
  display: table-row;
  position: relative;
}
.cm-table__row:nth-child(even) {
  background: #f5f5f5;
}
.cm-table__cell {
  display: table-cell;
  padding: 0.8em;
  text-align: center;
  vertical-align: middle;
  border-top: 1px solid #eee;
}
.cm-table__cell--head {
  text-align: left;
}
.cm-table__cell--head strong {
  display: block;
  font-size: 1.1em;
  line-height: 1.3;
}
.cm-table__cell--head em {
  display: block;
  color: #999;
  font-style: normal;
}
.cm-table__mobile {
  display: none;
}
@media screen and (max-width: 800px) {
  .cm-table__mobile {
    display: block;
  }
}
/* Mobiletable (innerhalb cm-table__mobile) */
.mobiletable__body {
  width: 100%;
  position: relative;
  margin-bottom: 0.5em;
}
.mobiletable__body.active {
  background: #f2f2f2;
}
.mobiletable__body.active .mobiletable__row {
  display: flex;
}
.mobiletable__body.active .mobiletable__head {
  background: transparent;
  color: #232222;
}
.mobiletable__head {
  text-align: center;
  padding: 0.7em;
}
.mobiletable__head strong {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: bold;
}
.mobiletable__head em {
  display: block;
  font-size: 0.85em;
  font-style: normal;
}
.mobiletable__row {
  display: none;
  border-top: 1px solid #ddd;
}
.mobiletable__row > div {
  flex: 1;
  padding: 1em;
  text-align: center;
  box-sizing: border-box;
}
.mobiletable__row--title {
  font-weight: bold;
}
/* Pricetable Variante */
.cm-table.pricetable .cm-table__cell--head {
  width: 20em;
}
/* Editor: cms_add_item absolut unten positionieren, ausserhalb des Table-Layouts */
.cm-table__row.cms_add_item {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  background: var(--cmart-color);
  border: 0px solid #fff;
  width: 100%;
  height: 5rem;
  line-height: 3rem;
  opacity: 0;
}
.cm-table__row.cms_add_item .cm-table__cell {
  display: block;
  border: 0px solid #fff;
}
/* Editor: Editbox hover */
.cmart.editing {
  /* Editor: Editbox aus table-row rausnehmen */
}
.cmart.editing .cm-table__row:hover .cms_editbox {
  visibility: visible;
  opacity: 1;
}
.cmart.editing .cm-table__desktop:hover > .cm-table__row.cms_add_item {
  opacity: 1;
}
.cmart.editing .cm-table__row > .cms_editbox {
  display: block;
  position: absolute;
}
.cmart.editing .cm-table:hover {
  padding-bottom: 5rem;
}
.cmartbge {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.cmartbge.cmartbge--picture {
  background-repeat: no-repeat;
}
.cmartbge {
  z-index: -1;
}
/* Contentblocks — alle Block-Styles zentral */
/* hero.less (cmart) */
.editing div.cm-hero {
  overflow: visible;
}
div.cm-hero {
  width: 100%;
  position: relative;
  clear: left;
  min-height: 75rem;
  height: 100vh;
  height: 100svh;
  overflow: hidden;
  background: var(--color-accent-dark);
}
div.cm-hero .cm-hero__image,
div.cm-hero .cm-hero__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
  opacity: 0.8;
  /* Container muss position:relative haben */
}
div.cm-hero .cm-hero__image img,
div.cm-hero .cm-hero__video img,
div.cm-hero .cm-hero__image video,
div.cm-hero .cm-hero__video video,
div.cm-hero .cm-hero__image picture,
div.cm-hero .cm-hero__video picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.cm-hero .cm-hero__image picture img,
div.cm-hero .cm-hero__video picture img {
  position: relative;
}
div.cm-hero .cm-hero__image > video,
div.cm-hero .cm-hero__video > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.cm-hero .cm-hero__image > picture,
div.cm-hero .cm-hero__video > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-hero .cm-hero__image > picture > img,
div.cm-hero .cm-hero__video > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-hero .filedropbox {
  height: 100%;
}
div.cm-hero .cm-hero__image .singlefileconnectionform .picconnection .editpanel {
  margin-left: 0;
  left: auto;
  right: 2em;
}
div.cm-hero.cm-hero--slideshow .swiper {
  opacity: 0.8;
}
div.cm-hero.cm-hero--slideshow picture {
  height: 100%;
}
div.cm-hero.cm-hero--slideshow .sliderarrows {
  position: absolute;
  z-index: 20;
  top: 50%;
  left: 1%;
  width: 98%;
  display: flex;
  justify-content: space-between;
  transform: translate(0, 0%);
}
div.cm-hero.cm-hero--slideshow .sliderarrows > div {
  padding: 2rem;
  color: #fff;
}
div.cm-hero.cm-hero--slideshow .swiper,
div.cm-hero.cm-hero--slideshow .cm-hero__slider {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
div.cm-hero.cm-hero--slideshow .swiper .swiper-slide,
div.cm-hero.cm-hero--slideshow .cm-hero__slider .swiper-slide {
  height: 100%;
}
div.cm-hero .cm-hero__video {
  opacity: 0.8;
}
div.cm-hero.cm-hero--default .cm-hero__content {
  position: absolute;
  z-index: 30;
  left: 50%;
  top: 58%;
  transform: translate(-50%, -50%);
  width: 80%;
  text-align: center;
}
div.cm-hero.cm-hero--default .cm-hero__content h1,
div.cm-hero.cm-hero--default .cm-hero__content h2 {
  margin-top: 0;
  margin-bottom: 0;
}
li.content.hero > div.cms_editbox {
  top: 50% !important;
}
/* cm-fullpic — Vollbild + Text */
.editing div.cm-fullpic {
  overflow: visible;
}
div.cm-fullpic {
  width: 100%;
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  overflow: hidden;
}
div.cm-fullpic .cm-fullpic__image,
div.cm-fullpic .cm-fullpic__video {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
  /* Container muss position:relative haben */
}
div.cm-fullpic .cm-fullpic__image img,
div.cm-fullpic .cm-fullpic__video img,
div.cm-fullpic .cm-fullpic__image video,
div.cm-fullpic .cm-fullpic__video video,
div.cm-fullpic .cm-fullpic__image picture,
div.cm-fullpic .cm-fullpic__video picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.cm-fullpic .cm-fullpic__image picture img,
div.cm-fullpic .cm-fullpic__video picture img {
  position: relative;
}
div.cm-fullpic .cm-fullpic__image > video,
div.cm-fullpic .cm-fullpic__video > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.cm-fullpic .cm-fullpic__image > picture,
div.cm-fullpic .cm-fullpic__video > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-fullpic .cm-fullpic__image > picture > img,
div.cm-fullpic .cm-fullpic__video > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-fullpic .cm-fullpic__image picture,
div.cm-fullpic .cm-fullpic__video picture,
div.cm-fullpic .cm-fullpic__image video,
div.cm-fullpic .cm-fullpic__video video,
div.cm-fullpic .cm-fullpic__image img,
div.cm-fullpic .cm-fullpic__video img {
  opacity: 0.8;
}
@media screen and (max-width: 768px) {
  div.cm-fullpic .cm-fullpic__image picture,
  div.cm-fullpic .cm-fullpic__video picture,
  div.cm-fullpic .cm-fullpic__image video,
  div.cm-fullpic .cm-fullpic__video video,
  div.cm-fullpic .cm-fullpic__image img,
  div.cm-fullpic .cm-fullpic__video img {
    opacity: 0.6;
  }
}
div.cm-fullpic .filedropbox {
  height: 100%;
}
div.cm-fullpic .cm-fullpic__image .singlefileconnectionform .picconnection .editpanel {
  margin-left: 0;
  left: auto;
  right: 2em;
}
div.cm-fullpic.cm-fullpic--slideshow .swiper {
  opacity: 0.8;
}
div.cm-fullpic.cm-fullpic--slideshow picture {
  height: 100%;
}
div.cm-fullpic.cm-fullpic--slideshow .sliderarrows {
  position: absolute;
  z-index: 20;
  top: 50%;
  left: 1%;
  width: 98%;
  display: flex;
  justify-content: space-between;
  transform: translate(0, 0%);
}
div.cm-fullpic.cm-fullpic--slideshow .sliderarrows > div {
  padding: 2rem;
  color: #fff;
}
div.cm-fullpic.cm-fullpic--slideshow .swiper,
div.cm-fullpic.cm-fullpic--slideshow .cm-fullpic__slider {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
div.cm-fullpic.cm-fullpic--slideshow .swiper .swiper-slide,
div.cm-fullpic.cm-fullpic--slideshow .cm-fullpic__slider .swiper-slide {
  height: 100%;
}
div.cm-fullpic .cm-fullpic__content {
  position: absolute;
  z-index: 30;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--var-margin-row);
}
div.cm-fullpic .cm-fullpic__content > * + * {
  margin-top: 0;
}
div.cm-fullpic .cm-fullpic__content > .cm-eyebrow + * {
  margin-top: 0;
}
li.content.fullpic > div.cms_editbox {
  top: 50% !important;
}
/* cm-layout — Content Layouts */
/* Basis-Layout-Block */
div.cm-layout {
  width: 100%;
  clear: left;
  position: relative;
}
/* Dark/Accent Kontexte */
/* Wrapper: Grid aktivieren */
div.cm-layout--imageleft-textright .cm-layout__wrap,
div.cm-layout--imageright-textleft .cm-layout__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  gap: var(--var-grid-gap);
  grid-auto-flow: dense;
  align-items: center;
}
/* Gemeinsame Grundstruktur */
div.cm-layout--imageleft-textright .cm-layout__text,
div.cm-layout--imageright-textleft .cm-layout__text,
div.cm-layout--imageleft-textright .cm-layout__image,
div.cm-layout--imageright-textleft .cm-layout__image {
  position: relative;
}
div.cm-layout--imageleft-textright .cm-layout__text,
div.cm-layout--imageright-textleft .cm-layout__text {
  padding: 10rem 0;
}
@media screen and (max-width: 768px) {
  div.cm-layout--imageleft-textright .cm-layout__text,
  div.cm-layout--imageright-textleft .cm-layout__text {
    padding: 3rem 0;
  }
}
div.cm-layout--imageleft-textright .cm-layout__text > div,
div.cm-layout--imageright-textleft .cm-layout__text > div,
div.cm-layout--imageleft-textright .cm-layout__text > div > div,
div.cm-layout--imageright-textleft .cm-layout__text > div > div {
  margin-top: var(--var-row-gap);
}
div.cm-layout--imageleft-textright .cm-layout__slideshow,
div.cm-layout--imageright-textleft .cm-layout__slideshow {
  display: flex;
  align-items: center;
}
div.cm-layout--imageleft-textright .cm-layout__slideshow .swiper .sliderarrows,
div.cm-layout--imageright-textleft .cm-layout__slideshow .swiper .sliderarrows {
  left: 0;
}
@media screen and (max-width: 800px) {
  div.cm-layout--imageleft-textright .cm-layout__slideshow,
  div.cm-layout--imageright-textleft .cm-layout__slideshow {
    width: 100%;
    margin-bottom: 10rem;
  }
  div.cm-layout--imageleft-textright .cm-layout__slideshow .swiper .sliderarrows,
  div.cm-layout--imageright-textleft .cm-layout__slideshow .swiper .sliderarrows {
    left: 7%;
  }
  div.cm-layout--imageleft-textright .cm-layout__slideshow .swiper .swiper-slide picture,
  div.cm-layout--imageright-textleft .cm-layout__slideshow .swiper .swiper-slide picture {
    height: 40rem;
  }
}
div.cm-layout--imageleft-textright .cm-layout__image,
div.cm-layout--imageright-textleft .cm-layout__image {
  min-height: 90vh;
  min-height: 90svh;
  height: 100%;
}
div.cm-layout--imageleft-textright .cm-layout__image .filedropbox,
div.cm-layout--imageright-textleft .cm-layout__image .filedropbox {
  height: 100%;
}
@media screen and (max-width: 768px) {
  div.cm-layout--imageleft-textright .cm-layout__image,
  div.cm-layout--imageright-textleft .cm-layout__image {
    margin-bottom: 5rem;
    min-height: 60vh;
    min-height: 60svh;
    height: auto;
  }
}
div.cm-layout--imageleft-textright .cm-layout__image .image,
div.cm-layout--imageright-textleft .cm-layout__image .image {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 100%;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  /* Container muss position:relative haben */
}
div.cm-layout--imageleft-textright .cm-layout__image .image img,
div.cm-layout--imageright-textleft .cm-layout__image .image img,
div.cm-layout--imageleft-textright .cm-layout__image .image video,
div.cm-layout--imageright-textleft .cm-layout__image .image video,
div.cm-layout--imageleft-textright .cm-layout__image .image picture,
div.cm-layout--imageright-textleft .cm-layout__image .image picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.cm-layout--imageleft-textright .cm-layout__image .image picture img,
div.cm-layout--imageright-textleft .cm-layout__image .image picture img {
  position: relative;
}
div.cm-layout--imageleft-textright .cm-layout__image .image > video,
div.cm-layout--imageright-textleft .cm-layout__image .image > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.cm-layout--imageleft-textright .cm-layout__image .image > picture,
div.cm-layout--imageright-textleft .cm-layout__image .image > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-layout--imageleft-textright .cm-layout__image .image > picture > img,
div.cm-layout--imageright-textleft .cm-layout__image .image > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-layout--imageleft-textright .cm-layout__image .image img.img,
div.cm-layout--imageright-textleft .cm-layout__image .image img.img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* Variante: Bild links - Text rechts */
div.cm-layout.cm-layout--imageleft-textright .cm-layout__image {
  grid-column: 2 / span 6;
}
@media screen and (max-width: 768px) {
  div.cm-layout.cm-layout--imageleft-textright .cm-layout__image {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout.cm-layout--imageleft-textright .cm-layout__image {
    grid-column: 2 / span 12;
  }
}
div.cm-layout.cm-layout--imageleft-textright .cm-layout__text {
  grid-column: 9 / span 4;
}
@media screen and (max-width: 900px) {
  div.cm-layout.cm-layout--imageleft-textright .cm-layout__text {
    grid-column: 9 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout.cm-layout--imageleft-textright .cm-layout__text {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout.cm-layout--imageleft-textright .cm-layout__text {
    grid-column: 2 / span 12;
  }
}
/* Variante: Bild rechts - Text links */
div.cm-layout--imageright-textleft .cm-layout__image,
div.cm-layout--imageright-textleft .cm-layout__slideshow {
  grid-column: 8 / span 6;
}
@media screen and (max-width: 768px) {
  div.cm-layout--imageright-textleft .cm-layout__image,
  div.cm-layout--imageright-textleft .cm-layout__slideshow {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--imageright-textleft .cm-layout__image,
  div.cm-layout--imageright-textleft .cm-layout__slideshow {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--imageright-textleft .cm-layout__text {
  grid-column: 3 / span 4;
}
@media screen and (max-width: 900px) {
  div.cm-layout--imageright-textleft .cm-layout__text {
    grid-column: 2 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--imageright-textleft .cm-layout__text {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--imageright-textleft .cm-layout__text {
    grid-column: 2 / span 12;
  }
}
/* Variante: Text + 2 Bilder (ueberlappend) */
div.cm-layout--text2bilder {
  /* Gespiegeltes Layout */
}
div.cm-layout--text2bilder .cm-layout__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  grid-auto-rows: auto;
  row-gap: var(--var-row-gap);
}
div.cm-layout--text2bilder .cm-layout__image--large {
  grid-column: 3 / span 5;
  grid-row: 1;
  position: relative;
  z-index: 1;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  min-height: 60vh;
  /* Container muss position:relative haben */
}
@media screen and (min-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__image--large {
    margin-bottom: calc(-1 * (16rem + var(--var-row-gap)));
  }
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder .cm-layout__image--large {
    grid-column: 2 / span 6;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__image--large {
    grid-column: 2 / span 12;
    min-height: 60vh;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder .cm-layout__image--large {
    grid-column: 2 / span 12;
    min-height: 50vh;
  }
}
div.cm-layout--text2bilder .cm-layout__image--large img,
div.cm-layout--text2bilder .cm-layout__image--large video,
div.cm-layout--text2bilder .cm-layout__image--large picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.cm-layout--text2bilder .cm-layout__image--large picture img {
  position: relative;
}
div.cm-layout--text2bilder .cm-layout__image--large > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.cm-layout--text2bilder .cm-layout__image--large > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-layout--text2bilder .cm-layout__image--large > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-layout--text2bilder .cm-layout__subtitle {
  grid-column: 9 / span 4;
  grid-row: 1;
  align-self: end;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder .cm-layout__subtitle {
    grid-column: 9 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__subtitle {
    grid-column: 3 / span 10;
    grid-row: auto;
    align-self: start;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder .cm-layout__subtitle {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder .cm-layout__title {
  grid-column: 9 / span 4;
  grid-row: 1;
  align-self: end;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder .cm-layout__title {
    grid-column: 9 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__title {
    grid-column: 3 / span 10;
    grid-row: auto;
    align-self: start;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder .cm-layout__title {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder .cm-layout__image--small {
  grid-column: 6 / span 3;
  grid-row: 2;
  min-height: 20rem;
  align-self: start;
  position: relative;
  z-index: 2;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  /* Container muss position:relative haben */
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder .cm-layout__image--small {
    grid-column: 5 / span 4;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__image--small {
    grid-row: auto;
    min-height: 15rem;
    margin-top: -8rem;
    order: -1;
    grid-column: 5 / span 6;
  }
}
div.cm-layout--text2bilder .cm-layout__image--small > video {
  width: 100%;
  height: auto;
}
div.cm-layout--text2bilder .cm-layout__image--small > picture {
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: auto;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-layout--text2bilder .cm-layout__image--small > picture > img {
  width: 100%;
  height: auto;
}
div.cm-layout--text2bilder .cm-layout__content {
  grid-column: 10 / span 3;
  grid-row: 2;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder .cm-layout__content {
    grid-column: 10 / span 4;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .cm-layout__content {
    grid-column: 3 / span 10;
    grid-row: auto;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder .cm-layout__content {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder .cm-layout__buttons a + a {
  margin-left: 2rem;
}
div.cm-layout--text2bilder .rows3 .cm-layout__subtitle {
  grid-row: 1;
  align-self: end;
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .rows3 .cm-layout__subtitle {
    grid-row: auto;
    align-self: start;
  }
}
div.cm-layout--text2bilder .rows3 .cm-layout__title {
  grid-row: 1;
  align-self: end;
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder .rows3 .cm-layout__title {
    grid-row: auto;
    align-self: start;
  }
}
div.cm-layout--text2bilder .rows3 .cm-layout__image--small {
  grid-row: 2;
}
div.cm-layout--text2bilder .rows3 .cm-layout__content {
  grid-row: 2;
}
div.cm-layout--text2bilder.change .cm-layout__image--large {
  grid-column: 8 / span 5;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder.change .cm-layout__image--large {
    grid-column: 8 / span 6;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder.change .cm-layout__image--large {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder.change .cm-layout__subtitle {
  grid-column: 3 / span 4;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder.change .cm-layout__subtitle {
    grid-column: 2 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder.change .cm-layout__subtitle {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder.change .cm-layout__subtitle {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder.change .cm-layout__title {
  grid-column: 3 / span 4;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder.change .cm-layout__title {
    grid-column: 2 / span 5;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder.change .cm-layout__title {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder.change .cm-layout__title {
    grid-column: 2 / span 12;
  }
}
div.cm-layout--text2bilder.change .cm-layout__image--small {
  grid-column: 7 / span 3;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder.change .cm-layout__image--small {
    grid-column: 7 / span 4;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder.change .cm-layout__image--small {
    grid-column: 5 / span 6;
  }
}
div.cm-layout--text2bilder.change .cm-layout__content {
  grid-column: 3 / span 3;
}
@media screen and (max-width: 1200px) {
  div.cm-layout--text2bilder.change .cm-layout__content {
    grid-column: 2 / span 4;
  }
}
@media screen and (max-width: 768px) {
  div.cm-layout--text2bilder.change .cm-layout__content {
    grid-column: 3 / span 10;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text2bilder.change .cm-layout__content {
    grid-column: 2 / span 12;
  }
}
/* Tab-Korrektur */
@media screen and (min-width: 768px) {
  div.tab div.cm-layout--text2bilder .cm-layout__image--large {
    min-height: 80vh;
  }
}
/* 2-Spalten Text-Layout */
div.cm-layout--text-2cols .cm-layout__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  position: relative;
}
div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__headline {
  grid-column: 4 / span 4;
}
@media screen and (max-width: 800px) {
  div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__headline {
    grid-column: 3 / span 5;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__headline {
    grid-column: 2 / span 6;
  }
}
div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__text {
  grid-column: 8 / span 4;
}
@media screen and (max-width: 800px) {
  div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__text {
    grid-column: 8 / span 5;
  }
}
@media screen and (max-width: 500px) {
  div.cm-layout--text-2cols .cm-layout__wrap .cm-layout__text {
    grid-column: 8 / span 6;
  }
}
/* cm-linkgrid */
div.cm-linkgrid {
  position: relative;
  background: transparent;
  box-sizing: border-box;
}
div.cm-linkgrid .cm-linkgrid__headline {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  margin-bottom: var(--var-margin-row);
}
div.cm-linkgrid .cm-linkgrid__headline h2 {
  grid-column: 2 / span 12;
}
div.cm-linkgrid .cm-linkgrid__headline h4 {
  grid-column: 2 / span 12;
}
div.cm-linkgrid .cm-linkgrid__links {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  gap: clamp(8px, 1vw, 16px);
  align-items: start;
  grid-auto-flow: dense;
}
div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--var-borderradius);
  min-height: 5rem;
}
div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item img,
div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item picture,
div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(1) {
  grid-column: 1 / span 7;
  grid-row: 1 / span 3;
  height: 100%;
  min-height: 70rem;
  overflow: hidden;
}
div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(2) {
  grid-column: 9 / span 3;
  grid-row: 1;
}
div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(3) {
  grid-column: 11 / span 4;
  grid-row: 3;
}
div.cm-linkgrid .cm-linkgrid__links.has-4 .cm-linkgrid__item:nth-child(1) {
  grid-column: 2 / span 8;
  grid-row: 1 / span 2;
  aspect-ratio: 4 / 3;
}
div.cm-linkgrid .cm-linkgrid__links.has-4 .cm-linkgrid__item:nth-child(2) {
  grid-column: 10 / span 4;
  grid-row: 1;
  aspect-ratio: 16 / 10;
}
div.cm-linkgrid .cm-linkgrid__links.has-4 .cm-linkgrid__item:nth-child(3) {
  grid-column: 10 / span 2;
  grid-row: 2;
  aspect-ratio: 1 / 1;
}
div.cm-linkgrid .cm-linkgrid__links.has-4 .cm-linkgrid__item:nth-child(4) {
  grid-column: 12 / span 2;
  grid-row: 2;
  aspect-ratio: 1 / 1;
}
@media (max-width: 900px) {
  div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item {
    grid-row: auto !important;
  }
  div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(1) {
    height: auto;
    grid-column: 2 / span 12 !important;
    margin-bottom: 5rem;
    min-height: 0;
  }
  div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(2) {
    grid-column: 2 / span 4;
  }
  div.cm-linkgrid .cm-linkgrid__links.has-3 .cm-linkgrid__item:nth-child(3) {
    grid-column: 8 / span 6;
  }
}
@media (max-width: 600px) {
  div.cm-linkgrid .cm-linkgrid__links {
    gap: 10px;
  }
  div.cm-linkgrid .cm-linkgrid__links .cm-linkgrid__item {
    aspect-ratio: auto;
  }
}
/* cm-backgroundbox */
div.cm-backgroundbox,
div.cm-backgroundbox > .contentbox {
  width: 100%;
  clear: left;
  position: relative;
  min-height: 15em;
}
div.cm-backgroundbox.border::before,
div.cm-backgroundbox > .contentbox.border::before {
  content: ' ';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  border: 1px solid #ccc;
  z-index: -1;
}
div.cm-backgroundbox .cmartbge {
  z-index: 0;
}
body.cmart.editing div.cm-backgroundbox {
  box-sizing: border-box;
  border: 5px solid var(--cmart-color);
}
/* cm-columns */
div.cm-columns {
  width: 100%;
  clear: left;
  position: relative;
  min-height: 5em;
}
div.cm-columns .cm-columns__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 7rem;
  justify-content: center;
}
div.cm-columns .cm-columns__item {
  position: relative;
}
div.cm-columns .cm-columns__item .textblockwrap {
  width: 100%;
  display: block;
  margin: 0;
}
div.cm-columns--1 .cm-columns__item,
div.cm-columns-- .cm-columns__item {
  width: 100%;
}
@media screen and (max-width: 1000px) {
  div.cm-columns--2 .cm-columns__inner {
    justify-content: space-around;
    gap: 1rem;
  }
}
div.cm-columns--2 div.textblock {
  position: relative;
  clear: left;
  width: 100%;
}
div.cm-columns--2.centerpadding .cm-columns__inner {
  gap: 20rem;
}
@media screen and (max-width: 1000px) {
  div.cm-columns--2.centerpadding .cm-columns__inner {
    gap: 3rem;
  }
}
div.cm-columns--2.centerpadding .cm-columns__inner .cm-columns__item.col2 {
  margin-top: 10rem;
}
@media screen and (max-width: 1000px) {
  div.cm-columns--2.centerpadding .cm-columns__inner .cm-columns__item.col2 {
    margin-top: 5rem;
  }
}
div.cm-columns--2 .cm-columns__item {
  width: 58rem;
}
@media screen and (max-width: 1000px) {
  div.cm-columns--2 .cm-columns__item {
    width: 70%;
  }
}
@media screen and (max-width: 1000px) {
  div.cm-columns--2 .cm-columns__item.col2 {
    margin-top: 5rem;
  }
}
@media screen and (max-width: 800px) {
  div.cm-columns--3 .cm-columns__inner {
    justify-content: space-around;
    gap: 1rem;
  }
}
div.cm-columns--3 .cm-columns__item {
  width: 25%;
}
@media screen and (max-width: 1200px) {
  div.cm-columns--3 .cm-columns__item.col1 {
    width: 80%;
  }
  div.cm-columns--3 .cm-columns__item.col2,
  div.cm-columns--3 .cm-columns__item.col3 {
    width: 40%;
    margin-top: 5rem;
  }
}
@media screen and (max-width: 800px) {
  div.cm-columns--3 .cm-columns__item.col1,
  div.cm-columns--3 .cm-columns__item.col2,
  div.cm-columns--3 .cm-columns__item.col3 {
    width: 70%;
    margin-top: 4rem;
  }
}
/* cm-abstand */
.cm-abstand {
  clear: left;
  position: relative;
  width: 100%;
  box-sizing: border-box;
  margin-top: 0px !important;
}
.cm-abstand.cm-pt--row > img,
.cm-abstand.cm-pt--small > img,
.cm-abstand.paddingtop--row > img,
.cm-abstand.paddingtop--small > img {
  display: none;
}
li.content.abstand {
  margin-top: 0 !important;
}
.abstand + div,
.abstand + li.content,
.cm-abstand + div,
.abstand + ul,
.cm-abstand + ul {
  margin-top: 0 !important;
}
/* cm-biglink */
div.cm-biglink {
  text-align: center;
}
div.cm-biglink a {
  display: inline-block;
  transition: 0.2s all var(--var-ease);
}
div.cm-biglink a strong {
  font-weight: normal;
  font-size: var(--fs-bigtext);
  line-height: var(--fs-bigtext-lh);
  color: var(--color-bigtext, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  font-family: var(--font-serif);
}
div.cm-biglink a span,
div.cm-biglink a strong {
  display: block;
}
div.cm-biglink a .cm-biglink__eyebrow {
  margin-bottom: clamp(2rem, 3.5rem, 5.5rem);
}
div.cm-biglink a:hover {
  color: #fff;
  text-decoration: none;
}
/* cm-gmaplink */
#cm-gmaplink {
  min-height: 10rem;
}
#cm-gmaplink > a {
  display: block;
  width: 100%;
  position: relative;
  transition: 0.5s all ease;
}
#cm-gmaplink > a:hover #cm-gmaplink-image {
  opacity: 0.6;
}
#cm-gmaplink > a:hover strong {
  color: var(--color-accent);
  top: 46%;
}
#cm-gmaplink #cm-gmaplink-image {
  width: calc(100% - 2 * var(--var-margin-left));
  border-radius: var(--var-borderradius);
  left: var(--var-margin-left);
  height: 80vh;
  transition: 0.5s all ease;
}
#cm-gmaplink strong {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: var(--fs-h1);
  line-height: var(--fs-h1-lh);
  color: var(--color-h1, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-headings);
  color: #fff;
  transition: 0.5s all ease;
}
#cm-gmaplink strong strong,
#cm-gmaplink strong b {
  font-weight: inherit;
  color: var(--color-accent);
}
/**
 * Slideshow Module - Modern BEM with cm-prefix
 * Uses Swiper.js for slideshow functionality
 */
.cm-slideshow {
  position: relative;
  width: 100%;
  clear: left;
}
.cm-slideshow__container {
  position: relative;
  width: 100%;
}
.cm-slideshow .swiper {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.cm-slideshow__slide {
  position: relative;
  width: 100%;
}
.cm-slideshow__slide picture {
  width: 100%;
  display: block;
  height: 80vh;
  overflow: hidden;
}
@media screen and (max-width: 700px) {
  .cm-slideshow__slide picture {
    height: 50rem;
  }
}
@media screen and (max-width: 500px) {
  .cm-slideshow__slide picture {
    height: 35rem;
  }
}
.cm-slideshow__slide picture source,
.cm-slideshow__slide picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cm-slideshow__slide img {
  width: 100%;
  height: auto;
  display: block;
}
.cm-slideshow__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  cursor: pointer;
  display: inline-block;
  width: 6rem;
  height: 6rem;
  box-sizing: border-box;
  font-size: 2rem;
  border-radius: 100px;
  padding: 1.5rem;
  transition: 0.2s all ease;
  border: 1px solid var(--color-black);
  background: transparent;
  color: var(--color-black);
}
.cm-slideshow__nav:hover {
  color: var(--color-accent-dark);
  transform: translateY(-50%) scale(1.1);
}
.cm-slideshow__nav:active {
  background: var(--color-black);
  color: #fff;
}
.cm-slideshow__nav.swiper-button-disabled {
  opacity: 0.25;
}
.cm-slideshow__nav--prev {
  left: 3rem;
}
.cm-slideshow__nav--next {
  right: 3rem;
}
.cm-slideshow__nav .arrow,
.cm-slideshow__nav .icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  font-size: 2rem;
  line-height: 1;
}
.cm-slideshow .swiper-pagination {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}
.cm-slideshow--small .swiper-slide {
  width: auto;
  max-width: 80%;
}
.cm-slideshow--small .cm-slideshow__slide picture {
  width: auto;
  display: block;
  height: 60vh;
  overflow: hidden;
  max-width: 100%;
}
.cm-slideshow--small .cm-slideshow__slide picture source,
.cm-slideshow--small .cm-slideshow__slide picture img {
  max-width: 100%;
  width: auto;
  height: 100%;
  object-fit: cover;
}
.darkbg .cm-slideshow .cm-slideshow__nav,
.bgdark .cm-slideshow .cm-slideshow__nav,
.bg--dark .cm-slideshow .cm-slideshow__nav,
.bg--black .cm-slideshow .cm-slideshow__nav,
.bg--green .cm-slideshow .cm-slideshow__nav {
  border-color: rgba(255, 255, 255, 0.5);
  color: #fff;
}
.darkbg .cm-slideshow .cm-slideshow__nav:hover,
.bgdark .cm-slideshow .cm-slideshow__nav:hover,
.bg--dark .cm-slideshow .cm-slideshow__nav:hover,
.bg--black .cm-slideshow .cm-slideshow__nav:hover,
.bg--green .cm-slideshow .cm-slideshow__nav:hover {
  border-color: #fff;
  color: var(--color-accent-light, #fff);
}
.darkbg .cm-slideshow .cm-slideshow__nav:active,
.bgdark .cm-slideshow .cm-slideshow__nav:active,
.bg--dark .cm-slideshow .cm-slideshow__nav:active,
.bg--black .cm-slideshow .cm-slideshow__nav:active,
.bg--green .cm-slideshow .cm-slideshow__nav:active {
  background: #fff;
  color: var(--color-black);
}
.cmart-editmode .cm-slideshow {
  min-height: 20rem;
  border: 2px dashed #ddd;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* cm-textmedia — Text + Media */
div.cm-textmedia {
  /* Bild links, Text rechts */
  /* Text links, Bild rechts */
}
div.cm-textmedia .cm-textmedia__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  gap: var(--var-grid-gap);
  align-items: center;
}
div.cm-textmedia .cm-textmedia__media {
  border-radius: var(--var-borderradius);
}
div.cm-textmedia .cm-textmedia__content > * + * {
  margin-top: var(--var-margin-row);
}
div.cm-textmedia.cm-textmedia--imageleft .cm-textmedia__media {
  grid-column: 2 / span 6;
}
@media screen and (max-width: 768px) {
  div.cm-textmedia.cm-textmedia--imageleft .cm-textmedia__media {
    grid-column: 2 / span 12;
  }
}
div.cm-textmedia.cm-textmedia--imageleft .cm-textmedia__content {
  grid-column: 9 / span 4;
}
@media screen and (max-width: 768px) {
  div.cm-textmedia.cm-textmedia--imageleft .cm-textmedia__content {
    grid-column: 2 / span 12;
  }
}
div.cm-textmedia.cm-textmedia--imageright .cm-textmedia__content {
  grid-column: 3 / span 4;
  grid-row: 1;
}
@media screen and (max-width: 768px) {
  div.cm-textmedia.cm-textmedia--imageright .cm-textmedia__content {
    grid-column: 2 / span 12;
    grid-row: auto;
    order: 1;
  }
}
div.cm-textmedia.cm-textmedia--imageright .cm-textmedia__media {
  grid-column: 8 / span 6;
  grid-row: 1;
}
@media screen and (max-width: 768px) {
  div.cm-textmedia.cm-textmedia--imageright .cm-textmedia__media {
    grid-column: 2 / span 12;
    grid-row: auto;
    order: 2;
  }
}
/* cm-teaser-row — 3er/4er Teaser-Reihe */
div.cm-teaser-row {
  /* 3 Spalten */
  /* 4 Spalten */
}
div.cm-teaser-row .cm-teaser-row__header {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  margin-bottom: var(--var-margin-row);
}
div.cm-teaser-row .cm-teaser-row__header > * {
  grid-column: 2 / span 12;
}
div.cm-teaser-row .cm-teaser-row__grid {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  row-gap: var(--var-row-gap);
}
div.cm-teaser-row .cm-teaser-row__item {
  display: flex;
  flex-direction: column;
}
div.cm-teaser-row .cm-teaser-row__image {
  position: relative;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  aspect-ratio: 3 / 2;
  /* Container muss position:relative haben */
}
div.cm-teaser-row .cm-teaser-row__image img,
div.cm-teaser-row .cm-teaser-row__image video,
div.cm-teaser-row .cm-teaser-row__image picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
div.cm-teaser-row .cm-teaser-row__image picture img {
  position: relative;
}
div.cm-teaser-row .cm-teaser-row__image > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
div.cm-teaser-row .cm-teaser-row__image > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
div.cm-teaser-row .cm-teaser-row__image > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-teaser-row .cm-teaser-row__content {
  margin-top: var(--var-margin-row);
}
div.cm-teaser-row .cm-teaser-row__content > * + * {
  margin-top: 1rem;
}
div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item {
  grid-column: span 4;
}
div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(1) {
  grid-column: 2 / span 4;
}
div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(2) {
  grid-column: 6 / span 4;
}
div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(3) {
  grid-column: 10 / span 4;
}
@media screen and (max-width: 768px) {
  div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(1),
  div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(2),
  div.cm-teaser-row.cm-teaser-row--cols-3 .cm-teaser-row__item:nth-child(3) {
    grid-column: 2 / span 12;
  }
}
div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item {
  grid-column: span 3;
}
div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(1) {
  grid-column: 2 / span 3;
}
div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(2) {
  grid-column: 5 / span 3;
}
div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(3) {
  grid-column: 8 / span 3;
}
div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(4) {
  grid-column: 11 / span 3;
}
@media screen and (max-width: 768px) {
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(1),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(2),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(3),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(4) {
    grid-column: 2 / span 6;
  }
}
@media screen and (max-width: 500px) {
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(1),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(2),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(3),
  div.cm-teaser-row.cm-teaser-row--cols-4 .cm-teaser-row__item:nth-child(4) {
    grid-column: 2 / span 12;
  }
}
/* cm-cta — Call-to-Action Banner */
div.cm-cta {
  /* Varianten */
}
div.cm-cta .cm-cta__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
}
div.cm-cta .cm-cta__content {
  grid-column: 4 / span 8;
  text-align: center;
  padding: var(--var-margin-small) 0;
}
div.cm-cta .cm-cta__content > * + * {
  margin-top: var(--var-margin-row);
}
@media screen and (max-width: 768px) {
  div.cm-cta .cm-cta__content {
    grid-column: 2 / span 12;
  }
}
div.cm-cta.cm-cta--dark {
  background: var(--color-dark);
  color: var(--color-white);
}
div.cm-cta.cm-cta--dark h2,
div.cm-cta.cm-cta--dark p {
  color: var(--color-white);
}
div.cm-cta.cm-cta--light {
  background: var(--color-lightgrey);
}
div.cm-cta.cm-cta--accent {
  background: var(--color-accent);
  color: var(--color-white);
}
div.cm-cta.cm-cta--accent h2,
div.cm-cta.cm-cta--accent p {
  color: var(--color-white);
}
/* cm-numbers — Zahlen/Fakten */
div.cm-numbers {
  /* 3 Spalten */
  /* 4 Spalten */
}
div.cm-numbers .cm-numbers__header {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  margin-bottom: var(--var-margin-row);
}
div.cm-numbers .cm-numbers__header > * {
  grid-column: 2 / span 12;
}
div.cm-numbers .cm-numbers__grid {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  row-gap: var(--var-row-gap);
}
div.cm-numbers .cm-numbers__item {
  display: flex;
  flex-direction: column;
  text-align: center;
  gap: 1rem;
}
div.cm-numbers .cm-numbers__value {
  font-size: var(--fs-h1);
  line-height: var(--fs-h1-lh);
  color: var(--color-h1, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  color: var(--color-accent);
}
div.cm-numbers .cm-numbers__value strong,
div.cm-numbers .cm-numbers__value b {
  font-weight: inherit;
  color: var(--color-accent);
}
div.cm-numbers .cm-numbers__label {
  font-size: var(--fs-subtitle);
  line-height: var(--fs-subtitle-lh);
  color: var(--color-subtitle, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(1) {
  grid-column: 2 / span 4;
}
div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(2) {
  grid-column: 6 / span 4;
}
div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(3) {
  grid-column: 10 / span 4;
}
@media screen and (max-width: 768px) {
  div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(1),
  div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(2),
  div.cm-numbers.cm-numbers--cols-3 .cm-numbers__item:nth-child(3) {
    grid-column: 2 / span 12;
  }
}
div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(1) {
  grid-column: 2 / span 3;
}
div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(2) {
  grid-column: 5 / span 3;
}
div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(3) {
  grid-column: 8 / span 3;
}
div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(4) {
  grid-column: 11 / span 3;
}
@media screen and (max-width: 768px) {
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(1),
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(2) {
    grid-column: 2 / span 6;
  }
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(3),
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(4) {
    grid-column: 8 / span 6;
  }
}
@media screen and (max-width: 500px) {
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(1),
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(2),
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(3),
  div.cm-numbers.cm-numbers--cols-4 .cm-numbers__item:nth-child(4) {
    grid-column: 2 / span 12;
  }
}
/* cm-testimonial — Einzelne Bewertung */
div.cm-testimonial .cm-testimonial__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
}
div.cm-testimonial .cm-testimonial__content {
  grid-column: 4 / span 8;
  text-align: center;
  padding: var(--var-margin-small) 0;
}
@media screen and (max-width: 768px) {
  div.cm-testimonial .cm-testimonial__content {
    grid-column: 2 / span 12;
  }
}
div.cm-testimonial .cm-testimonial__quote {
  font-size: var(--fs-lead);
  line-height: var(--fs-lead-lh);
  color: var(--color-lead, inherit);
  font-weight: var(--weight-regular);
  font-style: italic;
  position: relative;
}
div.cm-testimonial .cm-testimonial__quote::before {
  content: "\201C";
  font-size: var(--fs-h1);
  line-height: var(--fs-h1-lh);
  color: var(--color-h1, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
  color: var(--color-accent);
  display: block;
  margin-bottom: 1rem;
}
div.cm-testimonial .cm-testimonial__quote::before strong,
div.cm-testimonial .cm-testimonial__quote::before b {
  font-weight: inherit;
  color: var(--color-accent);
}
div.cm-testimonial .cm-testimonial__author {
  margin-top: var(--var-margin-row);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
div.cm-testimonial .cm-testimonial__name {
  font-size: var(--fs-subtitle);
  line-height: var(--fs-subtitle-lh);
  color: var(--color-subtitle, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
div.cm-testimonial .cm-testimonial__role {
  font-size: var(--fs-eyebrow);
  line-height: var(--fs-eyebrow-lh);
  color: var(--color-eyebrow, inherit);
  font-weight: var(--weight-regular);
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.7;
}
/* cm-video — Video Block */
div.cm-video {
  /* Selfhosted */
  /* Embed */
}
div.cm-video .cm-video__wrap {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
}
div.cm-video .cm-video__player {
  grid-column: 2 / span 12;
  position: relative;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  aspect-ratio: 16 / 9;
}
div.cm-video .cm-video__source {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div.cm-video .cm-video__embed {
  position: relative;
  width: 100%;
  height: 100%;
}
div.cm-video .cm-video__embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
/* cm-iconlist — Icons/Bilder mit Text in Grid */
div.cm-iconlist {
  /* 3 Spalten */
  /* 4 Spalten */
}
div.cm-iconlist .cm-iconlist__header {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  margin-bottom: var(--var-margin-row);
}
div.cm-iconlist .cm-iconlist__header > * {
  grid-column: 2 / span 12;
}
div.cm-iconlist .cm-iconlist__grid {
  display: grid;
  width: 100%;
  column-gap: var(--var-grid-gap);
  grid-template-columns: [m] var(--var-bodymargin) repeat(12, [c] 1fr) [m-end] var(--var-bodymargin);
  row-gap: var(--var-row-gap);
}
div.cm-iconlist .cm-iconlist__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1rem;
}
div.cm-iconlist .cm-iconlist__icon {
  width: 6rem;
  height: 6rem;
  position: relative;
}
div.cm-iconlist .cm-iconlist__icon img,
div.cm-iconlist .cm-iconlist__icon picture,
div.cm-iconlist .cm-iconlist__icon picture img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
div.cm-iconlist .cm-iconlist__fonticon {
  font-size: 5rem;
  line-height: 1;
  color: var(--var-color, currentColor);
}
div.cm-iconlist .cm-iconlist__title {
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-family: var(--font-headings);
  font-weight: var(--weight-regular);
}
div.cm-iconlist .cm-iconlist__title strong,
div.cm-iconlist .cm-iconlist__title b {
  font-weight: inherit;
  color: var(--color-accent);
}
div.cm-iconlist .cm-iconlist__text {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
  color: var(--color-body, inherit);
  font-weight: var(--weight-regular);
}
div.cm-iconlist.cm-iconlist--cols-3 .cm-iconlist__item:nth-child(3n+1) {
  grid-column: 2 / span 4;
}
div.cm-iconlist.cm-iconlist--cols-3 .cm-iconlist__item:nth-child(3n+2) {
  grid-column: 6 / span 4;
}
div.cm-iconlist.cm-iconlist--cols-3 .cm-iconlist__item:nth-child(3n+3) {
  grid-column: 10 / span 4;
}
@media screen and (max-width: 768px) {
  div.cm-iconlist.cm-iconlist--cols-3 .cm-iconlist__item:nth-child(n) {
    grid-column: 2 / span 12;
  }
}
div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(4n+1) {
  grid-column: 2 / span 3;
}
div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(4n+2) {
  grid-column: 5 / span 3;
}
div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(4n+3) {
  grid-column: 8 / span 3;
}
div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(4n+4) {
  grid-column: 11 / span 3;
}
@media screen and (max-width: 768px) {
  div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(n) {
    grid-column: 2 / span 6;
  }
}
@media screen and (max-width: 500px) {
  div.cm-iconlist.cm-iconlist--cols-4 .cm-iconlist__item:nth-child(n) {
    grid-column: 2 / span 12;
  }
}
/* cm-marquee — Laufschrift / Ticker */
div.cm-marquee {
  position: relative;
  height: 6em;
  border-radius: 3em;
  overflow: hidden;
}
div.cm-marquee .cm-marquee__track {
  width: 100%;
}
div.cm-marquee .cm-marquee__item {
  height: 100%;
  width: auto;
  position: relative;
  flex-shrink: 0;
  overflow: hidden;
}
div.cm-marquee .cm-marquee__link {
  position: absolute;
  right: 0;
  top: 0;
  color: #fff;
  float: right;
  display: block;
  border-radius: 1.1em 0 0 1.1em;
  padding-left: 2em;
  padding-right: 2em;
  transition: 0.2s all ease;
}
div.cm-marquee .cm-marquee__link:hover {
  text-decoration: none;
  padding-left: 3em;
  padding-right: 3em;
}
/* =========================================
   Contentmodule: Vimeos
   ========================================= */
:root {
  --vimeos-padding-v: 6rem;
  --vimeos-padding-h: 4rem;
}
@media screen and (max-width: 900px) {
  :root {
    --vimeos-padding-v: 4rem;
    --vimeos-padding-h: 3rem;
  }
}
@media screen and (max-width: 600px) {
  :root {
    --vimeos-padding-v: 3rem;
    --vimeos-padding-h: 2rem;
  }
}
.cm-vimeos {
  width: calc(100% - 2 * var(--var-bodymargin));
  position: relative;
  margin-left: var(--var-bodymargin);
  margin-right: var(--var-bodymargin);
  /* ── Erste Reihe: Contentbox + 2 Portrait-Karten ── */
  /* ── Contentbox ── */
  /* ── Portrait-Karten (Hochformat) ── */
  /* ── Querformat-Karten (Landscape) ── */
  /* ── Mehr laden Button ── */
  /* ── Empty State ── */
  /* ── Responsive ── */
}
.cm-vimeos .cm-vimeos__row--top {
  display: flex;
  gap: var(--var-row-gap);
  margin-bottom: var(--var-row-gap);
}
.cm-vimeos .cm-vimeos__contentbox {
  flex: 0 0 25%;
  min-width: 200px;
  background: #eee;
  border-radius: var(--var-borderradius);
  padding: var(--vimeos-padding-v) var(--vimeos-padding-h);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
}
.cm-vimeos .cm-vimeos__contentbox-logo {
  position: absolute;
  top: var(--vimeos-padding-v);
  left: var(--vimeos-padding-h);
  width: 40px;
  height: 40px;
  color: #222;
}
.cm-vimeos .cm-vimeos__contentbox-logo svg {
  width: 100%;
  height: 100%;
}
.cm-vimeos .cm-vimeos__contentbox-text {
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-weight: var(--weight-regular);
  color: #222;
}
.cm-vimeos .cm-vimeos__card--portrait {
  flex: 1;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  background: #222;
  cursor: pointer;
  text-decoration: none;
  min-height: 420px;
  /* ── Hover ── */
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-thumb {
  position: absolute;
  inset: 0;
  height: 60%;
  overflow: hidden;
  transition: height 0.45s ease;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-thumb .cm-vimeos__card-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 3rem;
  height: 2.5rem;
  z-index: 3;
  color: #fff;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-thumb .cm-vimeos__card-play svg {
  width: 100%;
  height: 100%;
}
@media (hover: none) {
  .cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-thumb .cm-vimeos__card-play {
    opacity: 0.8;
  }
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-gradient {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60%;
  background: linear-gradient(to top, #222 0%, rgba(34, 34, 34, 0) 100%);
  pointer-events: none;
  transition: height 0.45s ease;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--vimeos-padding-v) var(--vimeos-padding-h);
  z-index: 2;
  transition: transform 0.35s ease;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-eyebrow {
  font-size: var(--fs-eyebrow);
  line-height: var(--fs-eyebrow-lh);
  color: var(--color-eyebrow, inherit);
  font-weight: var(--weight-regular);
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 0.5rem;
}
.cm-vimeos .cm-vimeos__card--portrait .cm-vimeos__card-title {
  font-size: var(--fs-h2);
  line-height: var(--fs-h2-lh);
  color: var(--color-h2, inherit);
  font-weight: var(--weight-regular);
  color: #fff;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cm-vimeos .cm-vimeos__card--portrait:hover {
  text-decoration: none;
}
.cm-vimeos .cm-vimeos__card--portrait:hover .cm-vimeos__card-thumb {
  height: 65%;
}
.cm-vimeos .cm-vimeos__card--portrait:hover .cm-vimeos__card-thumb .cm-vimeos__card-play {
  opacity: 0.8;
}
.cm-vimeos .cm-vimeos__card--portrait:hover .cm-vimeos__card-gradient {
  height: 65%;
}
.cm-vimeos .cm-vimeos__card--portrait:hover .cm-vimeos__card-content {
  transform: translateY(-0.5rem);
}
.cm-vimeos .cm-vimeos__row--bottom,
.cm-vimeos .cm-vimeos__row--extra {
  display: flex;
  gap: var(--var-row-gap);
  margin-bottom: var(--var-row-gap);
}
.cm-vimeos .cm-vimeos__card--landscape {
  flex: 1;
  border-radius: var(--var-borderradius);
  overflow: hidden;
  background: #eee;
  display: flex;
  align-items: stretch;
  cursor: pointer;
  text-decoration: none;
  min-height: 160px;
  transition: box-shadow 0.3s ease;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-info {
  flex: 1 1 0%;
  padding: var(--vimeos-padding-v) 2rem var(--vimeos-padding-v) var(--vimeos-padding-h);
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-eyebrow {
  font-size: var(--fs-eyebrow);
  line-height: var(--fs-eyebrow-lh);
  color: var(--color-eyebrow, inherit);
  font-weight: var(--weight-regular);
  color: #666;
  margin-bottom: 0.5rem;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-title {
  font-size: var(--fs-h3);
  line-height: var(--fs-h3-lh);
  color: var(--color-h3, inherit);
  font-weight: var(--weight-regular);
  color: #222;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb {
  flex: 0 0 40%;
  max-width: 40%;
  position: relative;
  overflow: hidden;
  margin: 5px 5px 5px 0;
  border-radius: calc(var(--var-borderradius) - 2px);
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb .cm-vimeos__card-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 3rem;
  height: 2.5rem;
  z-index: 3;
  color: #fff;
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb .cm-vimeos__card-play svg {
  width: 100%;
  height: 100%;
}
@media (hover: none) {
  .cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb .cm-vimeos__card-play {
    opacity: 0.8;
  }
}
.cm-vimeos .cm-vimeos__card--landscape:hover {
  text-decoration: none;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}
.cm-vimeos .cm-vimeos__card--landscape:hover .cm-vimeos__card-thumb .cm-vimeos__card-play {
  opacity: 0.8;
}
.cm-vimeos .cm-vimeos__card--landscape:hover .cm-vimeos__card-thumb img {
  transform: scale(1.05);
}
.cm-vimeos .cm-vimeos__loadmore {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-top: 1rem;
  cursor: pointer;
  font-size: var(--fs-button);
  line-height: var(--fs-button-lh);
  color: var(--color-button, inherit);
  font-weight: var(--weight-regular);
  transition: background 0.3s ease, transform 0.2s ease;
}
.cm-vimeos .cm-vimeos__loadmore:hover {
  transform: translateY(-2px);
}
.cm-vimeos .cm-vimeos__empty {
  padding: 3rem;
  text-align: center;
  color: #888;
}
@media screen and (max-width: 900px) {
  .cm-vimeos .cm-vimeos__row--top {
    flex-wrap: wrap;
  }
  .cm-vimeos .cm-vimeos__contentbox {
    flex: 0 0 100%;
    min-height: auto;
    padding-top: calc(3 * var(--vimeos-padding-v));
  }
  .cm-vimeos .cm-vimeos__card--portrait {
    flex: 0 0 calc(50% - (var(--var-row-gap) / 2));
    min-height: 350px;
  }
  .cm-vimeos .cm-vimeos__row--bottom,
  .cm-vimeos .cm-vimeos__row--extra {
    flex-wrap: wrap;
  }
  .cm-vimeos .cm-vimeos__card--landscape {
    flex: 0 0 100%;
  }
}
@media screen and (max-width: 600px) {
  .cm-vimeos .cm-vimeos__contentbox {
    padding-top: calc(3 * var(--vimeos-padding-v));
  }
  .cm-vimeos .cm-vimeos__card--portrait {
    flex: 0 0 100%;
    min-height: 300px;
  }
  .cm-vimeos .cm-vimeos__card--landscape {
    flex-direction: column;
  }
  .cm-vimeos .cm-vimeos__card--landscape .cm-vimeos__card-thumb {
    flex: none;
    max-width: 100%;
    height: 180px;
    margin: 0 5px 5px 5px;
    border-radius: 0 0 calc(var(--var-borderradius) - 2px) calc(var(--var-borderradius) - 2px);
  }
}
/* Contentblock Styles → contentblocks/index.less */
body.compensate-for-scrollbar {
  overflow: hidden;
}
.fancybox-active {
  height: auto;
}
.fancybox-is-hidden {
  left: -9999px;
  margin: 0;
  position: absolute !important;
  top: -9999px;
  visibility: hidden;
}
.fancybox-container {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
  height: 100%;
  left: 0;
  position: fixed;
  -webkit-tap-highlight-color: transparent;
  top: 0;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  width: 100%;
  z-index: 99992;
}
.fancybox-container * {
  box-sizing: border-box;
}
.fancybox-outer,
.fancybox-inner,
.fancybox-bg,
.fancybox-stage {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.fancybox-outer {
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
}
.fancybox-bg {
  background: #232222;
  opacity: 0;
  transition-duration: inherit;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.47, 0, 0.74, 0.71);
}
.fancybox-is-open .fancybox-bg {
  opacity: 0.87;
  transition-timing-function: cubic-bezier(0.22, 0.61, 0.36, 1);
}
.fancybox-infobar,
.fancybox-toolbar,
.fancybox-caption,
.fancybox-navigation .fancybox-button {
  direction: ltr;
  opacity: 0;
  position: absolute;
  transition: opacity 0.25s, visibility 0s linear 0.25s;
  visibility: hidden;
  z-index: 99997;
}
.fancybox-show-infobar .fancybox-infobar,
.fancybox-show-toolbar .fancybox-toolbar,
.fancybox-show-caption .fancybox-caption,
.fancybox-show-nav .fancybox-navigation .fancybox-button {
  opacity: 1;
  transition: opacity 0.25s, visibility 0s;
  visibility: visible;
}
.fancybox-infobar {
  color: #ccc;
  font-size: 13px;
  -webkit-font-smoothing: subpixel-antialiased;
  height: 44px;
  left: 0;
  line-height: 44px;
  min-width: 44px;
  mix-blend-mode: difference;
  padding: 0 10px;
  pointer-events: none;
  text-align: center;
  top: 0;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.fancybox-toolbar {
  right: 0;
  top: 0;
}
.fancybox-stage {
  direction: ltr;
  overflow: visible;
  -webkit-transform: translate3d(0, 0, 0);
  z-index: 99994;
}
.fancybox-is-open .fancybox-stage {
  overflow: hidden;
}
.fancybox-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  display: none;
  height: 100%;
  left: 0;
  outline: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 44px;
  position: absolute;
  text-align: center;
  top: 0;
  transition-property: opacity, -webkit-transform;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform;
  white-space: normal;
  width: 100%;
  z-index: 99994;
}
.fancybox-slide::before {
  content: '';
  display: inline-block;
  height: 100%;
  margin-right: -0.25em;
  vertical-align: middle;
  width: 0;
}
.fancybox-is-sliding .fancybox-slide,
.fancybox-slide--previous,
.fancybox-slide--current,
.fancybox-slide--next {
  display: block;
}
.fancybox-slide--next {
  z-index: 99995;
}
.fancybox-slide--image {
  overflow: visible;
  padding: 44px 0;
}
.fancybox-slide--image::before {
  display: none;
}
.fancybox-slide--html {
  padding: 6px 6px 0 6px;
}
.fancybox-slide--iframe {
  padding: 44px 44px 0;
}
.fancybox-content {
  background: #fff;
  display: inline-block;
  margin: 0 0 6px 0;
  max-width: 100%;
  overflow: auto;
  padding: 0;
  padding: 24px;
  position: relative;
  text-align: left;
  vertical-align: middle;
}
.fancybox-slide--image .fancybox-content {
  -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.14, 1);
  animation-timing-function: cubic-bezier(0.5, 0, 0.14, 1);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  background: transparent;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  left: 0;
  margin: 0;
  max-width: none;
  overflow: visible;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-transform-origin: top left;
  -ms-transform-origin: top left;
  transform-origin: top left;
  transition-property: opacity, -webkit-transform;
  transition-property: transform, opacity;
  transition-property: transform, opacity, -webkit-transform;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  z-index: 99995;
}
.fancybox-can-zoomOut .fancybox-content {
  cursor: -webkit-zoom-out;
  cursor: zoom-out;
}
.fancybox-can-zoomIn .fancybox-content {
  cursor: -webkit-zoom-in;
  cursor: zoom-in;
}
.fancybox-can-drag .fancybox-content {
  cursor: -webkit-grab;
  cursor: grab;
}
.fancybox-is-dragging .fancybox-content {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}
.fancybox-container [data-selectable='true'] {
  cursor: text;
}
.fancybox-image,
.fancybox-spaceball {
  background: transparent;
  border: 0;
  height: 100%;
  left: 0;
  margin: 0;
  max-height: none;
  max-width: none;
  padding: 0;
  position: absolute;
  top: 0;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width: 100%;
}
.fancybox-spaceball {
  z-index: 1;
}
.fancybox-slide--html .fancybox-content {
  margin-bottom: 6px;
}
.fancybox-slide--video .fancybox-content,
.fancybox-slide--map .fancybox-content,
.fancybox-slide--iframe .fancybox-content {
  height: 100%;
  margin: 0;
  overflow: visible;
  padding: 0;
  width: 100%;
}
.fancybox-slide--video .fancybox-content {
  background: #000;
}
.fancybox-slide--map .fancybox-content {
  background: #e5e3df;
}
.fancybox-slide--iframe .fancybox-content {
  background: #fff;
  height: 92%;
  margin-bottom: 44px;
  width: 99%;
}
.fancybox-video,
.fancybox-iframe {
  background: transparent;
  border: 0;
  height: 100%;
  margin: 0;
  overflow: hidden;
  padding: 0;
  width: 100%;
}
.fancybox-iframe {
  vertical-align: top;
}
.fancybox-error {
  background: #fff;
  cursor: default;
  max-width: 400px;
  padding: 40px;
  width: 100%;
}
.fancybox-error p {
  color: #444;
  font-size: 16px;
  line-height: 20px;
  margin: 0;
  padding: 0;
}
/* Buttons */
.fancybox-button {
  background: rgba(30, 30, 30, 0.6);
  border: 0;
  border-radius: 0;
  cursor: pointer;
  display: inline-block;
  height: 44px;
  margin: 0;
  outline: none;
  padding: 10px;
  transition: color 0.2s;
  vertical-align: top;
  width: 44px;
}
.fancybox-button,
.fancybox-button:visited,
.fancybox-button:link {
  color: #ccc;
}
.fancybox-button:focus,
.fancybox-button:hover {
  color: #fff;
}
.fancybox-button.disabled,
.fancybox-button.disabled:hover,
.fancybox-button[disabled],
.fancybox-button[disabled]:hover {
  color: #888;
  cursor: default;
}
.fancybox-button svg {
  display: block;
  overflow: visible;
  position: relative;
  shape-rendering: geometricPrecision;
}
.fancybox-button svg path {
  fill: transparent;
  stroke: currentColor;
  stroke-linejoin: round;
  stroke-width: 3;
}
.fancybox-button--play svg path:nth-child(2) {
  display: none;
}
.fancybox-button--pause svg path:nth-child(1) {
  display: none;
}
.fancybox-button--play svg path,
.fancybox-button--share svg path,
.fancybox-button--thumbs svg path {
  fill: currentColor;
}
.fancybox-button--share svg path {
  stroke-width: 1;
}
/* Navigation arrows */
.fancybox-navigation .fancybox-button {
  height: 70px;
  opacity: 0;
  padding: 6px;
  position: absolute;
  top: 50%;
  width: 70px;
}
.fancybox-navigation svg {
  width: 50%;
  margin-left: 21%;
  margin-top: 21%;
}
.fancybox-show-nav .fancybox-navigation .fancybox-button {
  transition: opacity 0.25s, visibility 0s, color 0.25s;
}
.fancybox-navigation .fancybox-button::after {
  content: '';
  left: -35px;
  padding: 50px;
  position: absolute;
  top: -35px;
}
.fancybox-navigation .fancybox-button--arrow_left {
  background: transparent;
  left: 6px;
}
.fancybox-navigation .fancybox-button--arrow_right {
  background: transparent;
  right: 6px;
}
/* Close button on the top right corner of html content */
.fancybox-close-small {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: #555;
  cursor: pointer;
  height: 44px;
  margin: 0;
  padding: 6px;
  position: absolute;
  right: 0;
  top: 0;
  width: 44px;
  z-index: 10;
}
.fancybox-close-small svg {
  fill: transparent;
  opacity: 0.8;
  stroke: currentColor;
  stroke-width: 1.5;
  transition: stroke 0.1s;
}
.fancybox-close-small:focus {
  outline: none;
}
.fancybox-close-small:hover svg {
  opacity: 1;
}
.fancybox-slide--image .fancybox-close-small,
.fancybox-slide--video .fancybox-close-small,
.fancybox-slide--iframe .fancybox-close-small {
  color: #ccc;
  padding: 5px;
  right: -12px;
  top: -44px;
}
.fancybox-slide--image .fancybox-close-small:hover svg,
.fancybox-slide--video .fancybox-close-small:hover svg,
.fancybox-slide--iframe .fancybox-close-small:hover svg {
  background: transparent;
  color: #fff;
}
.fancybox-is-scaling .fancybox-close-small,
.fancybox-is-zoomable.fancybox-can-drag .fancybox-close-small {
  display: none;
}
/* Caption */
.fancybox-caption {
  bottom: 0;
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  left: 0;
  line-height: 1.5;
  padding: 25px 44px 25px 44px;
  right: 0;
}
.fancybox-caption::before {
  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAEtCAQAAABjBcL7AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAHRJREFUKM+Vk8EOgDAIQ0vj/3+xBw8qIZZueFnIKC90MCAI8DlrkHGeqqGIU6lVigrBtpCWqeRWoHDNqs0F7VNVBVxmHRlvoVqjaYkdnDIaivH2HqZ5+oZj3JUzWB+cOz4G48Bg+tsJ/tqu4dLC/4Xb+0GcF5BwBC0AA53qAAAAAElFTkSuQmCC);
  background-repeat: repeat-x;
  background-size: contain;
  bottom: 0;
  content: '';
  display: block;
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: -25px;
  z-index: -1;
}
.fancybox-caption::after {
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  content: '';
  display: block;
  left: 44px;
  position: absolute;
  right: 44px;
  top: 0;
}
.fancybox-caption a,
.fancybox-caption a:link,
.fancybox-caption a:visited {
  color: #ccc;
  text-decoration: none;
}
.fancybox-caption a:hover {
  color: #fff;
  text-decoration: underline;
}
/* Loading indicator */
.fancybox-loading {
  -webkit-animation: fancybox-rotate 1s infinite linear;
  animation: fancybox-rotate 1s infinite linear;
  background: transparent;
  border: 5px solid rgba(100, 100, 100, 0.5);
  border-radius: 100%;
  border-top-color: #fff;
  height: 60px;
  left: 50%;
  margin: -30px 0 0 -30px;
  opacity: 0.6;
  padding: 0;
  position: absolute;
  top: 50%;
  width: 60px;
  z-index: 99999;
}
.fancybox-loading.fancybox-loading1 {
  margin: -30px 0 0 -30px;
}
@-webkit-keyframes fancybox-rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@keyframes fancybox-rotate {
  from {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  to {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
/* Transition effects */
.fancybox-animated {
  transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
}
/* transitionEffect: slide */
.fancybox-fx-slide.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: translate3d(-100%, 0, 0);
  transform: translate3d(-100%, 0, 0);
}
.fancybox-fx-slide.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: translate3d(100%, 0, 0);
  transform: translate3d(100%, 0, 0);
}
.fancybox-fx-slide.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
/* transitionEffect: fade */
.fancybox-fx-fade.fancybox-slide--previous,
.fancybox-fx-fade.fancybox-slide--next {
  opacity: 0;
  transition-timing-function: cubic-bezier(0.19, 1, 0.22, 1);
}
.fancybox-fx-fade.fancybox-slide--current {
  opacity: 1;
}
/* transitionEffect: zoom-in-out */
.fancybox-fx-zoom-in-out.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: scale3d(1.5, 1.5, 1.5);
  transform: scale3d(1.5, 1.5, 1.5);
}
.fancybox-fx-zoom-in-out.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: scale3d(0.5, 0.5, 0.5);
  transform: scale3d(0.5, 0.5, 0.5);
}
.fancybox-fx-zoom-in-out.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: scale3d(1, 1, 1);
  transform: scale3d(1, 1, 1);
}
/* transitionEffect: rotate */
.fancybox-fx-rotate.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: rotate(-360deg);
  -ms-transform: rotate(-360deg);
  transform: rotate(-360deg);
}
.fancybox-fx-rotate.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: rotate(360deg);
  -ms-transform: rotate(360deg);
  transform: rotate(360deg);
}
.fancybox-fx-rotate.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: rotate(0deg);
  -ms-transform: rotate(0deg);
  transform: rotate(0deg);
}
/* transitionEffect: circular */
.fancybox-fx-circular.fancybox-slide--previous {
  opacity: 0;
  -webkit-transform: scale3d(0, 0, 0) translate3d(-100%, 0, 0);
  transform: scale3d(0, 0, 0) translate3d(-100%, 0, 0);
}
.fancybox-fx-circular.fancybox-slide--next {
  opacity: 0;
  -webkit-transform: scale3d(0, 0, 0) translate3d(100%, 0, 0);
  transform: scale3d(0, 0, 0) translate3d(100%, 0, 0);
}
.fancybox-fx-circular.fancybox-slide--current {
  opacity: 1;
  -webkit-transform: scale3d(1, 1, 1) translate3d(0, 0, 0);
  transform: scale3d(1, 1, 1) translate3d(0, 0, 0);
}
/* transitionEffect: tube */
.fancybox-fx-tube.fancybox-slide--previous {
  -webkit-transform: translate3d(-100%, 0, 0) scale(0.1) skew(-10deg);
  transform: translate3d(-100%, 0, 0) scale(0.1) skew(-10deg);
}
.fancybox-fx-tube.fancybox-slide--next {
  -webkit-transform: translate3d(100%, 0, 0) scale(0.1) skew(10deg);
  transform: translate3d(100%, 0, 0) scale(0.1) skew(10deg);
}
.fancybox-fx-tube.fancybox-slide--current {
  -webkit-transform: translate3d(0, 0, 0) scale(1);
  transform: translate3d(0, 0, 0) scale(1);
}
/* Share */
.fancybox-share {
  background: #f4f4f4;
  border-radius: 3px;
  max-width: 90%;
  padding: 30px;
  text-align: center;
}
.fancybox-share h1 {
  color: #222;
  font-size: 35px;
  font-weight: 700;
  margin: 0 0 20px 0;
}
.fancybox-share p {
  margin: 0;
  padding: 0;
}
.fancybox-share__button {
  border: 0;
  border-radius: 3px;
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  line-height: 40px;
  margin: 0 5px 10px 5px;
  min-width: 130px;
  padding: 0 15px;
  text-decoration: none;
  transition: all 0.2s;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  white-space: nowrap;
}
.fancybox-share__button:visited,
.fancybox-share__button:link {
  color: #fff;
}
.fancybox-share__button:hover {
  text-decoration: none;
}
.fancybox-share__button--fb {
  background: #3b5998;
}
.fancybox-share__button--fb:hover {
  background: #344e86;
}
.fancybox-share__button--pt {
  background: #bd081d;
}
.fancybox-share__button--pt:hover {
  background: #aa0719;
}
.fancybox-share__button--tw {
  background: #1da1f2;
}
.fancybox-share__button--tw:hover {
  background: #0d95e8;
}
.fancybox-share__button svg {
  height: 25px;
  margin-right: 7px;
  position: relative;
  top: -1px;
  vertical-align: middle;
  width: 25px;
}
.fancybox-share__button svg path {
  fill: #fff;
}
.fancybox-share__input {
  background: transparent;
  border: 0;
  border-bottom: 1px solid #d7d7d7;
  border-radius: 0;
  color: #5d5b5b;
  font-size: 14px;
  margin: 10px 0 0 0;
  outline: none;
  padding: 10px 15px;
  width: 100%;
}
/* Thumbs */
.fancybox-thumbs {
  background: #fff;
  bottom: 0;
  display: none;
  margin: 0;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: -ms-autohiding-scrollbar;
  padding: 2px 2px 4px 2px;
  position: absolute;
  right: 0;
  -webkit-tap-highlight-color: transparent;
  top: 0;
  width: 212px;
  z-index: 99995;
}
.fancybox-thumbs-x {
  overflow-x: auto;
  overflow-y: hidden;
}
.fancybox-show-thumbs .fancybox-thumbs {
  display: block;
}
.fancybox-show-thumbs .fancybox-inner {
  right: 212px;
}
.fancybox-thumbs > ul {
  font-size: 0;
  height: 100%;
  list-style: none;
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 0;
  position: absolute;
  position: relative;
  white-space: nowrap;
  width: 100%;
}
.fancybox-thumbs-x > ul {
  overflow: hidden;
}
.fancybox-thumbs-y > ul::-webkit-scrollbar {
  width: 7px;
}
.fancybox-thumbs-y > ul::-webkit-scrollbar-track {
  background: #fff;
  border-radius: 10px;
  box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
}
.fancybox-thumbs-y > ul::-webkit-scrollbar-thumb {
  background: #2a2a2a;
  border-radius: 10px;
}
.fancybox-thumbs > ul > li {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  cursor: pointer;
  height: 75px;
  margin: 2px;
  max-height: calc(100% - 8px);
  max-width: calc(50% - 4px);
  outline: none;
  overflow: hidden;
  padding: 0;
  position: relative;
  -webkit-tap-highlight-color: transparent;
  width: 100px;
}
.fancybox-thumbs-loading {
  background: rgba(0, 0, 0, 0.1);
}
.fancybox-thumbs > ul > li {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}
.fancybox-thumbs > ul > li:before {
  border: 4px solid #4ea7f9;
  bottom: 0;
  content: '';
  left: 0;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
  transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 99991;
}
.fancybox-thumbs .fancybox-thumbs-active:before {
  opacity: 1;
}
/* Styling for Small-Screen Devices */
@media all and (max-width: 800px) {
  .fancybox-thumbs {
    width: 110px;
  }
  .fancybox-show-thumbs .fancybox-inner {
    right: 110px;
  }
  .fancybox-thumbs > ul > li {
    max-width: calc(100% - 10px);
  }
}
.flatpickr-calendar {
  background: transparent;
  opacity: 0;
  display: none;
  text-align: center;
  visibility: hidden;
  padding: 0;
  -webkit-animation: none;
  animation: none;
  direction: ltr;
  border: 0;
  font-size: 14px;
  line-height: 24px;
  border-radius: 5px;
  position: absolute;
  width: 307.875px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  background: #fff;
  -webkit-box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08);
  box-shadow: 1px 0 0 #e6e6e6, -1px 0 0 #e6e6e6, 0 1px 0 #e6e6e6, 0 -1px 0 #e6e6e6, 0 3px 13px rgba(0, 0, 0, 0.08);
}
.flatpickr-calendar.open,
.flatpickr-calendar.inline {
  opacity: 1;
  max-height: 640px;
  visibility: visible;
}
.flatpickr-calendar.open {
  display: inline-block;
  z-index: 99999;
}
.flatpickr-calendar.animate.open {
  -webkit-animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
  animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.flatpickr-calendar.inline {
  display: block;
  position: relative;
  top: 2px;
}
.flatpickr-calendar.static {
  position: absolute;
  top: calc(100% + 2px);
}
.flatpickr-calendar.static.open {
  z-index: 999;
  display: block;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
  -webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
  box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-calendar .hasWeeks .dayContainer,
.flatpickr-calendar .hasTime .dayContainer {
  border-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.flatpickr-calendar .hasWeeks .dayContainer {
  border-left: 0;
}
.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time {
  height: 40px;
  border-top: 1px solid #e6e6e6;
}
.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
  height: auto;
}
.flatpickr-calendar:before,
.flatpickr-calendar:after {
  position: absolute;
  display: block;
  pointer-events: none;
  border: solid transparent;
  content: '';
  height: 0;
  width: 0;
  left: 22px;
}
.flatpickr-calendar.rightMost:before,
.flatpickr-calendar.rightMost:after {
  left: auto;
  right: 22px;
}
.flatpickr-calendar:before {
  border-width: 5px;
  margin: 0 -5px;
}
.flatpickr-calendar:after {
  border-width: 4px;
  margin: 0 -4px;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
  bottom: 100%;
}
.flatpickr-calendar.arrowTop:before {
  border-bottom-color: #e6e6e6;
}
.flatpickr-calendar.arrowTop:after {
  border-bottom-color: #fff;
}
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
  top: 100%;
}
.flatpickr-calendar.arrowBottom:before {
  border-top-color: #e6e6e6;
}
.flatpickr-calendar.arrowBottom:after {
  border-top-color: #fff;
}
.flatpickr-calendar:focus {
  outline: 0;
}
.flatpickr-wrapper {
  position: relative;
  display: inline-block;
}
.flatpickr-months {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-months .flatpickr-month {
  background: transparent;
  color: rgba(0, 0, 0, 0.9);
  fill: rgba(0, 0, 0, 0.9);
  height: 28px;
  line-height: 1;
  text-align: center;
  position: relative;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  overflow: hidden;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  text-decoration: none;
  cursor: pointer;
  position: absolute;
  top: 0px;
  line-height: 16px;
  height: 28px;
  padding: 10px;
  z-index: 3;
  color: rgba(0, 0, 0, 0.9);
  fill: rgba(0, 0, 0, 0.9);
}
.flatpickr-months .flatpickr-prev-month.disabled,
.flatpickr-months .flatpickr-next-month.disabled {
  display: none;
}
.flatpickr-months .flatpickr-prev-month i,
.flatpickr-months .flatpickr-next-month i {
  position: relative;
}
.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
  /*
      /*rtl:begin:ignore*/
  /*
      */
  left: 0;
  /*
      /*rtl:end:ignore*/
  /*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,
.flatpickr-months .flatpickr-next-month.flatpickr-next-month {
  /*
      /*rtl:begin:ignore*/
  /*
      */
  right: 0;
  /*
      /*rtl:end:ignore*/
  /*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  color: #959ea9;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: #f64747;
}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 14px;
  height: 14px;
}
.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  -webkit-transition: fill 0.1s;
  transition: fill 0.1s;
  fill: inherit;
}
.numInputWrapper {
  position: relative;
  height: auto;
}
.numInputWrapper input,
.numInputWrapper span {
  display: inline-block;
}
.numInputWrapper input {
  width: 100%;
}
.numInputWrapper input::-ms-clear {
  display: none;
}
.numInputWrapper span {
  position: absolute;
  right: 0;
  width: 14px;
  padding: 0 4px 0 2px;
  height: 50%;
  line-height: 50%;
  opacity: 0;
  cursor: pointer;
  border: 1px solid rgba(57, 57, 57, 0.15);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.numInputWrapper span:hover {
  background: rgba(0, 0, 0, 0.1);
}
.numInputWrapper span:active {
  background: rgba(0, 0, 0, 0.2);
}
.numInputWrapper span:after {
  display: block;
  content: "";
  position: absolute;
}
.numInputWrapper span.arrowUp {
  top: 0;
  border-bottom: 0;
}
.numInputWrapper span.arrowUp:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 4px solid rgba(57, 57, 57, 0.6);
  top: 26%;
}
.numInputWrapper span.arrowDown {
  top: 50%;
}
.numInputWrapper span.arrowDown:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid rgba(57, 57, 57, 0.6);
  top: 40%;
}
.numInputWrapper span svg {
  width: inherit;
  height: auto;
}
.numInputWrapper span svg path {
  fill: rgba(0, 0, 0, 0.5);
}
.numInputWrapper:hover {
  background: rgba(0, 0, 0, 0.05);
}
.numInputWrapper:hover span {
  opacity: 1;
}
.flatpickr-current-month {
  font-size: 135%;
  line-height: inherit;
  font-weight: 300;
  color: inherit;
  position: absolute;
  width: 75%;
  left: 12.5%;
  padding: 6.16px 0 0 0;
  line-height: 1;
  height: 28px;
  display: inline-block;
  text-align: center;
  -webkit-transform: translate3d(0px, 0px, 0px);
  transform: translate3d(0px, 0px, 0px);
}
.flatpickr-current-month span.cur-month {
  font-family: inherit;
  font-weight: 700;
  color: inherit;
  display: inline-block;
  margin-left: 0.5ch;
  padding: 0;
}
.flatpickr-current-month span.cur-month:hover {
  background: rgba(0, 0, 0, 0.05);
}
.flatpickr-current-month .numInputWrapper {
  width: 6ch;
  width: 7ch\0;
  display: inline-block;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after {
  border-bottom-color: rgba(0, 0, 0, 0.9);
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
  border-top-color: rgba(0, 0, 0, 0.9);
}
.flatpickr-current-month input.cur-year {
  background: transparent;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: inherit;
  cursor: text;
  padding: 0 0 0 0.5ch;
  margin: 0;
  display: inline-block;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  line-height: inherit;
  height: auto;
  border: 0;
  border-radius: 0;
  vertical-align: initial;
}
.flatpickr-current-month input.cur-year:focus {
  outline: 0;
}
.flatpickr-current-month input.cur-year[disabled],
.flatpickr-current-month input.cur-year[disabled]:hover {
  font-size: 100%;
  color: rgba(0, 0, 0, 0.5);
  background: transparent;
  pointer-events: none;
}
.flatpickr-weekdays {
  background: transparent;
  text-align: center;
  overflow: hidden;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 28px;
}
.flatpickr-weekdays .flatpickr-weekdaycontainer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
span.flatpickr-weekday {
  cursor: default;
  font-size: 90%;
  background: transparent;
  color: rgba(0, 0, 0, 0.54);
  line-height: 1;
  margin: 0;
  text-align: center;
  display: block;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  font-weight: bolder;
}
.dayContainer,
.flatpickr-weeks {
  padding: 1px 0 0 0;
}
.flatpickr-days {
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  width: 307.875px;
}
.flatpickr-days:focus {
  outline: 0;
}
.dayContainer {
  padding: 0;
  outline: 0;
  text-align: left;
  width: 307.875px;
  min-width: 307.875px;
  max-width: 307.875px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline-block;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-around;
  justify-content: space-around;
  -webkit-transform: translate3d(0px, 0px, 0px);
  transform: translate3d(0px, 0px, 0px);
  opacity: 1;
}
.dayContainer + .dayContainer {
  -webkit-box-shadow: -1px 0 0 #e6e6e6;
  box-shadow: -1px 0 0 #e6e6e6;
}
.flatpickr-day {
  background: none;
  border: 1px solid transparent;
  border-radius: 150px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #393939;
  cursor: pointer;
  font-weight: 400;
  width: 14.2857143%;
  -webkit-flex-basis: 14.2857143%;
  -ms-flex-preferred-size: 14.2857143%;
  flex-basis: 14.2857143%;
  max-width: 39px;
  height: 39px;
  line-height: 39px;
  margin: 0;
  display: inline-block;
  position: relative;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
}
.flatpickr-day.inRange,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.today.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day:focus,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.nextMonthDay:focus {
  cursor: pointer;
  outline: 0;
  background: #e6e6e6;
  border-color: #e6e6e6;
}
.flatpickr-day.today {
  border-color: #959ea9;
}
.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  border-color: #959ea9;
  background: #959ea9;
  color: #fff;
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  background: #569ff7;
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #fff;
  border-color: #569ff7;
}
.flatpickr-day.selected.startRange,
.flatpickr-day.startRange.startRange,
.flatpickr-day.endRange.startRange {
  border-radius: 50px 0 0 50px;
}
.flatpickr-day.selected.endRange,
.flatpickr-day.startRange.endRange,
.flatpickr-day.endRange.endRange {
  border-radius: 0 50px 50px 0;
}
.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
  -webkit-box-shadow: -10px 0 0 #569ff7;
  box-shadow: -10px 0 0 #569ff7;
}
.flatpickr-day.selected.startRange.endRange,
.flatpickr-day.startRange.startRange.endRange,
.flatpickr-day.endRange.startRange.endRange {
  border-radius: 50px;
}
.flatpickr-day.inRange {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
  box-shadow: -5px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
  color: rgba(57, 57, 57, 0.3);
  background: transparent;
  border-color: transparent;
  cursor: default;
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover {
  cursor: not-allowed;
  color: rgba(57, 57, 57, 0.1);
}
.flatpickr-day.week.selected {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
  box-shadow: -5px 0 0 #569ff7, 5px 0 0 #569ff7;
}
.flatpickr-day.hidden {
  visibility: hidden;
}
.rangeMode .flatpickr-day {
  margin-top: 1px;
}
.flatpickr-weekwrapper {
  display: inline-block;
}
.flatpickr-weekwrapper .flatpickr-weeks {
  padding: 0 12px;
  -webkit-box-shadow: 1px 0 0 #e6e6e6;
  box-shadow: 1px 0 0 #e6e6e6;
}
.flatpickr-weekwrapper .flatpickr-weekday {
  float: none;
  width: 100%;
  line-height: 28px;
}
.flatpickr-weekwrapper span.flatpickr-day,
.flatpickr-weekwrapper span.flatpickr-day:hover {
  display: block;
  width: 100%;
  max-width: none;
  color: rgba(57, 57, 57, 0.3);
  background: transparent;
  cursor: default;
  border: none;
}
.flatpickr-innerContainer {
  display: block;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
}
.flatpickr-rContainer {
  display: inline-block;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.flatpickr-time {
  text-align: center;
  outline: 0;
  display: block;
  height: 0;
  line-height: 40px;
  max-height: 40px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-time:after {
  content: "";
  display: table;
  clear: both;
}
.flatpickr-time .numInputWrapper {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  width: 40%;
  height: 40px;
}
.flatpickr-time .numInputWrapper span.arrowUp:after {
  border-bottom-color: #393939;
}
.flatpickr-time .numInputWrapper span.arrowDown:after {
  border-top-color: #393939;
}
.flatpickr-time.hasSeconds .numInputWrapper {
  width: 26%;
}
.flatpickr-time.time24hr .numInputWrapper {
  width: 49%;
}
.flatpickr-time input {
  background: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: 0;
  border-radius: 0;
  text-align: center;
  margin: 0;
  padding: 0;
  height: inherit;
  line-height: inherit;
  color: #393939;
  font-size: 14px;
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.flatpickr-time input.flatpickr-hour {
  font-weight: bold;
}
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
  font-weight: 400;
}
.flatpickr-time input:focus {
  outline: 0;
  border: 0;
}
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
  height: inherit;
  display: inline-block;
  line-height: inherit;
  color: #393939;
  font-weight: bold;
  width: 2%;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-align-self: center;
  -ms-flex-item-align: center;
  align-self: center;
}
.flatpickr-time .flatpickr-am-pm {
  outline: 0;
  width: 18%;
  cursor: pointer;
  text-align: center;
  font-weight: 400;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #f3f3f3;
}
.flatpickr-input[readonly] {
  cursor: pointer;
}
@-webkit-keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
.flatpickr-calendar {
  background: transparent;
  opacity: 0;
  display: none;
  text-align: center;
  visibility: hidden;
  padding: 0;
  -webkit-animation: none;
  animation: none;
  direction: ltr;
  border: 0;
  font-size: 14px;
  line-height: 24px;
  border-radius: 5px;
  position: absolute;
  width: 307.875px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  -webkit-box-shadow: 0 3px 13px rgba(0, 0, 0, 0.08);
  box-shadow: 0 3px 13px rgba(0, 0, 0, 0.08);
}
.flatpickr-calendar.open,
.flatpickr-calendar.inline {
  opacity: 1;
  max-height: 640px;
  visibility: visible;
}
.flatpickr-calendar.open {
  display: inline-block;
  z-index: 99999;
}
.flatpickr-calendar.animate.open {
  -webkit-animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
  animation: fpFadeInDown 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.flatpickr-calendar.inline {
  display: block;
  position: relative;
  top: 2px;
}
.flatpickr-calendar.static {
  position: absolute;
  top: calc(100% + 2px);
}
.flatpickr-calendar.static.open {
  z-index: 999;
  display: block;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7) {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
}
.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1) {
  -webkit-box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
  box-shadow: -2px 0 0 #e6e6e6, 5px 0 0 #e6e6e6;
}
.flatpickr-calendar .hasWeeks .dayContainer,
.flatpickr-calendar .hasTime .dayContainer {
  border-bottom: 0;
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.flatpickr-calendar .hasWeeks .dayContainer {
  border-left: 0;
}
.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time {
  height: 40px;
  border-top: 1px solid #eceef1;
}
.flatpickr-calendar.showTimeInput.hasTime .flatpickr-innerContainer {
  border-bottom: 0;
}
.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time {
  border: 1px solid #eceef1;
}
.flatpickr-calendar.noCalendar.hasTime .flatpickr-time {
  height: auto;
}
.flatpickr-calendar:before,
.flatpickr-calendar:after {
  position: absolute;
  display: block;
  pointer-events: none;
  border: solid transparent;
  content: '';
  height: 0;
  width: 0;
  left: 22px;
}
.flatpickr-calendar.rightMost:before,
.flatpickr-calendar.rightMost:after {
  left: auto;
  right: 22px;
}
.flatpickr-calendar:before {
  border-width: 5px;
  margin: 0 -5px;
}
.flatpickr-calendar:after {
  border-width: 4px;
  margin: 0 -4px;
}
.flatpickr-calendar.arrowTop:before,
.flatpickr-calendar.arrowTop:after {
  bottom: 100%;
}
.flatpickr-calendar.arrowTop:before {
  border-bottom-color: #eceef1;
}
.flatpickr-calendar.arrowTop:after {
  border-bottom-color: #eceef1;
}
.flatpickr-calendar.arrowBottom:before,
.flatpickr-calendar.arrowBottom:after {
  top: 100%;
}
.flatpickr-calendar.arrowBottom:before {
  border-top-color: #eceef1;
}
.flatpickr-calendar.arrowBottom:after {
  border-top-color: #eceef1;
}
.flatpickr-calendar:focus {
  outline: 0;
}
.flatpickr-wrapper {
  position: relative;
  display: inline-block;
}
.flatpickr-months {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.flatpickr-months .flatpickr-month {
  border-radius: 5px 5px 0 0;
  background: #eceef1;
  color: #5a6171;
  fill: #5a6171;
  height: 28px;
  line-height: 1;
  text-align: center;
  position: relative;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  overflow: hidden;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month {
  text-decoration: none;
  cursor: pointer;
  position: absolute;
  top: 0px;
  line-height: 16px;
  height: 28px;
  padding: 10px;
  z-index: 3;
  color: #5a6171;
  fill: #5a6171;
}
.flatpickr-months .flatpickr-prev-month.disabled,
.flatpickr-months .flatpickr-next-month.disabled {
  display: none;
}
.flatpickr-months .flatpickr-prev-month i,
.flatpickr-months .flatpickr-next-month i {
  position: relative;
}
.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month.flatpickr-prev-month {
  /*
      /*rtl:begin:ignore*/
  /*
      */
  left: 0;
  /*
      /*rtl:end:ignore*/
  /*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,
.flatpickr-months .flatpickr-next-month.flatpickr-next-month {
  /*
      /*rtl:begin:ignore*/
  /*
      */
  right: 0;
  /*
      /*rtl:end:ignore*/
  /*
      */
}
/*
      /*rtl:begin:ignore*/
/*
      /*rtl:end:ignore*/
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover {
  color: #bbb;
}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: #f64747;
}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  width: 14px;
  height: 14px;
}
.flatpickr-months .flatpickr-prev-month svg path,
.flatpickr-months .flatpickr-next-month svg path {
  -webkit-transition: fill 0.1s;
  transition: fill 0.1s;
  fill: inherit;
}
.numInputWrapper {
  position: relative;
  height: auto;
}
.numInputWrapper input,
.numInputWrapper span {
  display: inline-block;
}
.numInputWrapper input {
  width: 100%;
}
.numInputWrapper input::-ms-clear {
  display: none;
}
.numInputWrapper span {
  position: absolute;
  right: 0;
  width: 14px;
  padding: 0 4px 0 2px;
  height: 50%;
  line-height: 50%;
  opacity: 0;
  cursor: pointer;
  border: 1px solid rgba(72, 72, 72, 0.15);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.numInputWrapper span:hover {
  background: rgba(0, 0, 0, 0.1);
}
.numInputWrapper span:active {
  background: rgba(0, 0, 0, 0.2);
}
.numInputWrapper span:after {
  display: block;
  content: "";
  position: absolute;
}
.numInputWrapper span.arrowUp {
  top: 0;
  border-bottom: 0;
}
.numInputWrapper span.arrowUp:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-bottom: 4px solid rgba(72, 72, 72, 0.6);
  top: 26%;
}
.numInputWrapper span.arrowDown {
  top: 50%;
}
.numInputWrapper span.arrowDown:after {
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid rgba(72, 72, 72, 0.6);
  top: 40%;
}
.numInputWrapper span svg {
  width: inherit;
  height: auto;
}
.numInputWrapper span svg path {
  fill: rgba(90, 97, 113, 0.5);
}
.numInputWrapper:hover {
  background: rgba(0, 0, 0, 0.05);
}
.numInputWrapper:hover span {
  opacity: 1;
}
.flatpickr-current-month {
  font-size: 135%;
  line-height: inherit;
  font-weight: 300;
  color: inherit;
  position: absolute;
  width: 75%;
  left: 12.5%;
  padding: 6.16px 0 0 0;
  line-height: 1;
  height: 28px;
  display: inline-block;
  text-align: center;
  -webkit-transform: translate3d(0px, 0px, 0px);
  transform: translate3d(0px, 0px, 0px);
}
.flatpickr-current-month span.cur-month {
  font-family: inherit;
  font-weight: 700;
  color: inherit;
  display: inline-block;
  margin-left: 0.5ch;
  padding: 0;
}
.flatpickr-current-month span.cur-month:hover {
  background: rgba(0, 0, 0, 0.05);
}
.flatpickr-current-month .numInputWrapper {
  width: 6ch;
  width: 7ch\0;
  display: inline-block;
}
.flatpickr-current-month .numInputWrapper span.arrowUp:after {
  border-bottom-color: #5a6171;
}
.flatpickr-current-month .numInputWrapper span.arrowDown:after {
  border-top-color: #5a6171;
}
.flatpickr-current-month input.cur-year {
  background: transparent;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: inherit;
  cursor: text;
  padding: 0 0 0 0.5ch;
  margin: 0;
  display: inline-block;
  font-size: inherit;
  font-family: inherit;
  font-weight: 300;
  line-height: inherit;
  height: auto;
  border: 0;
  border-radius: 0;
  vertical-align: initial;
}
.flatpickr-current-month input.cur-year:focus {
  outline: 0;
}
.flatpickr-current-month input.cur-year[disabled],
.flatpickr-current-month input.cur-year[disabled]:hover {
  font-size: 100%;
  color: rgba(90, 97, 113, 0.5);
  background: transparent;
  pointer-events: none;
}
.flatpickr-weekdays {
  background: #eceef1;
  text-align: center;
  overflow: hidden;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 28px;
}
.flatpickr-weekdays .flatpickr-weekdaycontainer {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
span.flatpickr-weekday {
  cursor: default;
  font-size: 90%;
  background: #eceef1;
  color: #5a6171;
  line-height: 1;
  margin: 0;
  text-align: center;
  display: block;
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  font-weight: bolder;
}
.dayContainer,
.flatpickr-weeks {
  padding: 1px 0 0 0;
}
.flatpickr-days {
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  width: 307.875px;
  border-left: 1px solid #eceef1;
  border-right: 1px solid #eceef1;
}
.flatpickr-days:focus {
  outline: 0;
}
.dayContainer {
  padding: 0;
  outline: 0;
  text-align: left;
  width: 307.875px;
  min-width: 307.875px;
  max-width: 307.875px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: inline-block;
  display: -ms-flexbox;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-around;
  justify-content: space-around;
  -webkit-transform: translate3d(0px, 0px, 0px);
  transform: translate3d(0px, 0px, 0px);
  opacity: 1;
}
.dayContainer + .dayContainer {
  -webkit-box-shadow: -1px 0 0 #eceef1;
  box-shadow: -1px 0 0 #eceef1;
}
.flatpickr-day {
  background: none;
  border: 1px solid transparent;
  border-radius: 150px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #484848;
  cursor: pointer;
  font-weight: 400;
  width: 14.2857143%;
  -webkit-flex-basis: 14.2857143%;
  -ms-flex-preferred-size: 14.2857143%;
  flex-basis: 14.2857143%;
  max-width: 39px;
  height: 39px;
  line-height: 39px;
  margin: 0;
  display: inline-block;
  position: relative;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
}
.flatpickr-day.inRange,
.flatpickr-day.prevMonthDay.inRange,
.flatpickr-day.nextMonthDay.inRange,
.flatpickr-day.today.inRange,
.flatpickr-day.prevMonthDay.today.inRange,
.flatpickr-day.nextMonthDay.today.inRange,
.flatpickr-day:hover,
.flatpickr-day.prevMonthDay:hover,
.flatpickr-day.nextMonthDay:hover,
.flatpickr-day:focus,
.flatpickr-day.prevMonthDay:focus,
.flatpickr-day.nextMonthDay:focus {
  cursor: pointer;
  outline: 0;
  background: #e2e2e2;
  border-color: #e2e2e2;
}
.flatpickr-day.today {
  border-color: #bbb;
}
.flatpickr-day.today:hover,
.flatpickr-day.today:focus {
  border-color: #bbb;
  background: #bbb;
  color: #fff;
}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected.inRange,
.flatpickr-day.startRange.inRange,
.flatpickr-day.endRange.inRange,
.flatpickr-day.selected:focus,
.flatpickr-day.startRange:focus,
.flatpickr-day.endRange:focus,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover,
.flatpickr-day.selected.prevMonthDay,
.flatpickr-day.startRange.prevMonthDay,
.flatpickr-day.endRange.prevMonthDay,
.flatpickr-day.selected.nextMonthDay,
.flatpickr-day.startRange.nextMonthDay,
.flatpickr-day.endRange.nextMonthDay {
  background: var(--color-accent);
  -webkit-box-shadow: none;
  box-shadow: none;
  color: #fff;
  border-color: var(--color-accent);
}
.flatpickr-day.selected.startRange,
.flatpickr-day.startRange.startRange,
.flatpickr-day.endRange.startRange {
  border-radius: 50px 0 0 50px;
}
.flatpickr-day.selected.endRange,
.flatpickr-day.startRange.endRange,
.flatpickr-day.endRange.endRange {
  border-radius: 0 50px 50px 0;
}
.flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)),
.flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
  -webkit-box-shadow: -10px 0 0 var(--color-accent);
  box-shadow: -10px 0 0 var(--color-accent);
}
.flatpickr-day.selected.startRange.endRange,
.flatpickr-day.startRange.startRange.endRange,
.flatpickr-day.endRange.startRange.endRange {
  border-radius: 50px;
}
.flatpickr-day.inRange {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 #e2e2e2, 5px 0 0 #e2e2e2;
  box-shadow: -5px 0 0 #e2e2e2, 5px 0 0 #e2e2e2;
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay,
.flatpickr-day.notAllowed,
.flatpickr-day.notAllowed.prevMonthDay,
.flatpickr-day.notAllowed.nextMonthDay {
  color: rgba(72, 72, 72, 0.3);
  background: transparent;
  border-color: transparent;
  cursor: default;
}
.flatpickr-day.disabled,
.flatpickr-day.disabled:hover {
  cursor: not-allowed;
  color: rgba(72, 72, 72, 0.1);
}
.flatpickr-day.week.selected {
  border-radius: 0;
  -webkit-box-shadow: -5px 0 0 var(--color-accent), 5px 0 0 var(--color-accent);
  box-shadow: -5px 0 0 var(--color-accent), 5px 0 0 var(--color-accent);
}
.flatpickr-day.hidden {
  visibility: hidden;
}
.rangeMode .flatpickr-day {
  margin-top: 1px;
}
.flatpickr-weekwrapper {
  display: inline-block;
}
.flatpickr-weekwrapper .flatpickr-weeks {
  padding: 0 12px;
  border-left: 1px solid #eceef1;
}
.flatpickr-weekwrapper .flatpickr-weekday {
  float: none;
  width: 100%;
  line-height: 28px;
}
.flatpickr-weekwrapper span.flatpickr-day,
.flatpickr-weekwrapper span.flatpickr-day:hover {
  display: block;
  width: 100%;
  max-width: none;
  color: rgba(72, 72, 72, 0.3);
  background: transparent;
  cursor: default;
  border: none;
}
.flatpickr-innerContainer {
  display: block;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  background: #fff;
  border-bottom: 1px solid #eceef1;
}
.flatpickr-rContainer {
  display: inline-block;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.flatpickr-time {
  text-align: center;
  outline: 0;
  display: block;
  height: 0;
  line-height: 40px;
  max-height: 40px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  background: #fff;
  border-radius: 0 0 5px 5px;
}
.flatpickr-time:after {
  content: "";
  display: table;
  clear: both;
}
.flatpickr-time .numInputWrapper {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
  width: 40%;
  height: 40px;
}
.flatpickr-time .numInputWrapper span.arrowUp:after {
  border-bottom-color: #484848;
}
.flatpickr-time .numInputWrapper span.arrowDown:after {
  border-top-color: #484848;
}
.flatpickr-time.hasSeconds .numInputWrapper {
  width: 26%;
}
.flatpickr-time.time24hr .numInputWrapper {
  width: 49%;
}
.flatpickr-time input {
  background: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: 0;
  border-radius: 0;
  text-align: center;
  margin: 0;
  padding: 0;
  height: inherit;
  line-height: inherit;
  color: #484848;
  font-size: 14px;
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.flatpickr-time input.flatpickr-hour {
  font-weight: bold;
}
.flatpickr-time input.flatpickr-minute,
.flatpickr-time input.flatpickr-second {
  font-weight: 400;
}
.flatpickr-time input:focus {
  outline: 0;
  border: 0;
}
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
  height: inherit;
  display: inline-block;
  line-height: inherit;
  color: #484848;
  font-weight: bold;
  width: 2%;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-align-self: center;
  -ms-flex-item-align: center;
  align-self: center;
}
.flatpickr-time .flatpickr-am-pm {
  outline: 0;
  width: 18%;
  cursor: pointer;
  text-align: center;
  font-weight: 400;
}
.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
  background: #efefef;
}
.flatpickr-input[readonly] {
  cursor: pointer;
}
@-webkit-keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
@keyframes fpFadeInDown {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, -20px, 0);
    transform: translate3d(0, -20px, 0);
  }
  to {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
  }
}
span.flatpickr-day.selected {
  font-weight: bold;
}
html,
body {
  margin: 0;
  padding: 0;
  min-height: 100%;
}
body {
  background: var(--color-darkred);
  color: var(--color-text);
  display: block;
  min-height: 100vh;
  padding-top: 0.1px;
}
#pageload {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2000;
  background: var(--color-accent);
}
.mobile {
  display: none;
}
@media screen and (max-width: 800px) {
  .mobile {
    display: block;
  }
}
.desktop {
  display: block;
}
@media screen and (max-width: 800px) {
  .desktop {
    display: none;
  }
}
sup {
  vertical-align: super;
  font-size: 0.7em;
  line-height: 0;
}
a {
  text-decoration: none;
  color: var(--color-accent);
}
a:hover {
  text-decoration: underline;
}
#wrap {
  min-height: 100%;
  text-align: left;
  position: relative;
  width: 100%;
}
#page_wrap {
  position: relative;
  width: 100%;
}
div#page {
  position: relative;
  width: 100%;
}
/* =========================================
   contents.less (cmart)
   - Media Helpers (absolute / cover)
   - Spacing Utilities (margin/padding Mods)
   - Centering Helpers
   - Background Helper + Dark Context
   - Text Blocks, Lists, Embeds
   ========================================= */
/* ========== MEDIA HELPERS ========== */
/* Vollflächiges Media (Video & Picture) in absolut positionierten Containern */
/* Als Klasse verwendbar, wenn du nur Background-Bilder nutzt */
.cm-bgimage,
.bgimage {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center center;
}
/* Absolut gefülltes Bild/Video (Alternative) */
.cm-text-center,
.textcentering {
  text-align: center;
}
/* ========== BACKGROUND HELPERS ========== */
.cm-bg--white {
  background: #fff;
}
.cm-bg--hellbeige {
  background: var(--color-lightgrey);
}
.cm-bg--black {
  background: var(--color-black);
}
.cm-bg--dark {
  background: var(--color-black);
}
.cm-bg--accent {
  background: var(--color-accent);
}
.cm-bg--transparent {
  background: transparent;
}
/* Dunkler Kontext – Typo auf hell setzen */
.cm-bg--dark h1,
.cm-bg--accent h1,
.cm-bg--black h1,
.darkbg h1,
.cm-bg--dark h2,
.cm-bg--accent h2,
.cm-bg--black h2,
.darkbg h2,
.cm-bg--dark h3,
.cm-bg--accent h3,
.cm-bg--black h3,
.darkbg h3,
.cm-bg--dark p,
.cm-bg--accent p,
.cm-bg--black p,
.darkbg p,
.cm-bg--dark ul li::before,
.cm-bg--accent ul li::before,
.cm-bg--black ul li::before,
.darkbg ul li::before {
  color: #fff;
}
.lightboxopener {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  cursor: pointer;
  z-index: 30;
}
body.cmart.editing .lightboxopener {
  display: none;
}
/* ========== CONTENT LISTS & TEXT ========== */
li.content {
  position: relative;
  width: 100%;
  clear: left;
}
#content {
  /* Haupttextbereiche */
  /* Abstand zwischen aufeinanderfolgenden Blöcken */
}
#content ul.pageContents {
  position: relative;
  width: 100%;
  clear: left;
}
#content .cm-text-center,
#content .textcentering {
  text-align: center;
}
#content .cm-text-center p,
#content .textcentering p {
  text-align: center;
}
#content .cm-text,
#content .textobj {
  /* Basis-Elemente */
  /* Abstände zwischen Elementen */
  /* Verhindere zusätzliche p-Margins in verschachtelten Strukturen */
  /* Unordered Lists mit Icon Marker */
  /* Bilder im Fließtext */
}
#content .cm-text p,
#content .textobj p,
#content .cm-text li,
#content .textobj li,
#content .cm-text td,
#content .textobj td {
  font-size: var(--fs-body);
  line-height: var(--fs-body-lh);
  color: var(--color-body, inherit);
  font-weight: var(--weight-regular);
  max-width: 65ch;
}
#content .cm-text li p,
#content .textobj li p {
  font-size: 1em;
}
#content .cm-text p i,
#content .textobj p i,
#content .cm-text p em,
#content .textobj p em {
  font-style: normal;
}
#content .cm-text p + ul,
#content .textobj p + ul,
#content .cm-text p + p,
#content .textobj p + p,
#content .cm-text ul + p,
#content .textobj ul + p,
#content .cm-text ul + h2,
#content .textobj ul + h2,
#content .cm-text ul + h3,
#content .textobj ul + h3,
#content .cm-text ul + h4,
#content .textobj ul + h4,
#content .cm-text p + h2,
#content .textobj p + h2,
#content .cm-text p + h3,
#content .textobj p + h3 {
  margin-top: 1em;
}
#content .cm-text h2 + p,
#content .textobj h2 + p,
#content .cm-text h3 + p,
#content .textobj h3 + p,
#content .cm-text h4 + p,
#content .textobj h4 + p,
#content .cm-text h2 + ul,
#content .textobj h2 + ul,
#content .cm-text h3 + ul,
#content .textobj h3 + ul,
#content .cm-text h4 + ul,
#content .textobj h4 + ul {
  margin-top: 3rem;
}
#content .cm-text h1 p,
#content .textobj h1 p,
#content .cm-text h2 p,
#content .textobj h2 p,
#content .cm-text h3 p,
#content .textobj h3 p,
#content .cm-text h4 p,
#content .textobj h4 p,
#content .cm-text p p,
#content .textobj p p,
#content .cm-text ul p,
#content .textobj ul p {
  margin-bottom: 0;
}
#content .cm-text ul,
#content .textobj ul {
  list-style: none;
  position: relative;
  width: 100%;
  margin-left: 0;
}
#content .cm-text ul li,
#content .textobj ul li {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  margin-bottom: 0;
  padding: 0.3em 0.5em 0.3em 1.4em;
  line-height: 1.4;
}
#content .cm-text ul li::before,
#content .textobj ul li::before {
  content: "\e916";
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* bleibt projekt-spezifisch */
  position: absolute;
  top: 0.8em;
  left: 0;
  width: 1.4em;
  height: 1.6em;
  font-size: 0.8em;
  color: var(--color-accent-light);
}
#content .cm-text img,
#content .textobj img {
  position: relative;
  max-width: 100%;
  height: auto;
}
#content .textblock + .textblock {
  margin-top: 1.5em;
}
#content .cm-text + .cm-text,
#content .textobj + .textobj {
  margin-top: 1.5em;
}
/* ========== RESPONSIVE EMBEDS ========== */
.cm-responsive-video {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  /* 16:9 */
  padding-top: 25px;
  height: 0;
  overflow: hidden;
}
.cm-responsive-video iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
/* ===== Aliases (falls alte Klassennamen noch im Markup sind) ===== */
/* Erlaubt sanften Umstieg ohne sofortiges Refactor aller Templates */
/* NEU (ohne Deprecation) */
.absoluteimage {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  /* nur direkte Medien-Kinder */
}
.absoluteimage > img,
.absoluteimage > picture,
.absoluteimage > picture > img,
.absoluteimage > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* echte Mixins → mit () aufrufen */
.absolutemedia {
  /* Container muss position:relative haben */
}
.absolutemedia img,
.absolutemedia video,
.absolutemedia picture {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.absolutemedia picture img {
  position: relative;
}
.absolutemedia > video {
  position: absolute;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.absolutemedia > picture {
  position: absolute;
  inset: 0;
  /* top:0; right:0; bottom:0; left:0 */
  width: 100%;
  height: 100%;
  /* source lässt sich nicht stylen – bewusst weggelassen */
}
.absolutemedia > picture > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* Grundlayout – z.B. am Ende des Hero-Bereichs */
.scroll-indicator {
  position: absolute;
  /* oder relative, je nach Layout */
  left: 3rem;
  bottom: 3rem;
  transform: translateX(-50%);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
/* Text */
.scroll-text {
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.75;
}
/* „Mouse“-Rahmen */
.mouse {
  width: 28px;
  height: 46px;
  border-radius: 999px;
  border: 2px solid currentColor;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 6px;
  box-sizing: border-box;
  opacity: 0.8;
}
/* Scroll-Rad */
.wheel {
  width: 4px;
  height: 8px;
  border-radius: 999px;
  background: currentColor;
  animation: wheel-move 1.4s infinite ease-in-out;
}
/* Pfeil unten */
.arrow {
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  margin-top: 4px;
  animation: arrow-bounce 1.4s infinite ease-in-out;
}
/* Animationen */
@keyframes wheel-move {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  60% {
    transform: translateY(10px);
    opacity: 0;
  }
  61% {
    transform: translateY(-4px);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes arrow-bounce {
  0%,
  100% {
    transform: translateY(0) rotate(45deg);
    opacity: 0.7;
  }
  50% {
    transform: translateY(4px) rotate(45deg);
    opacity: 1;
  }
}
/* Farbanpassung (z.B. auf dunklem Hintergrund) */
.scroll-indicator {
  color: #ffffff;
}
/* Hover-Effekt (optional) */
.scroll-indicator:hover {
  opacity: 0.9;
  transform: translateX(-50%) translateY(2px);
  transition: transform 0.2s ease, opacity 0.2s ease;
}
