/* ****************
     FONTS 
**************** */

@import "../fonts/icons/57t-icons.css";

@font-face {
  font-family: "57t-icons";
  src: url("../fonts/icons/57t-icons.eot?nltho0");
  src:
    url("../fonts/icon/s57t-icons.eot?nltho0#iefix") format("embedded-opentype"),
    url("../fonts/icons/57t-icons.ttf?nltho0") format("truetype"),
    url("../fonts/icons/57t-icons.woff?nltho0") format("woff"),
    url("../fonts/icons/57t-icons.svg?nltho0#57t-icons") 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: "57t-icons" !important;
  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;
}

/* roboto-regular - latin */

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto";
  src:
    url("../fonts/roboto-regular.woff2") format("woff2"),
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
      url("../fonts/roboto-regular.woff") format("woff"); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
  font-weight: normal;
  font-style: normal;
}

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Roboto Bold";
  src:
    url("../fonts/roboto-bold.woff2") format("woff2"),
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
      url("../fonts/roboto-bold.woff") format("woff"); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
  font-weight: 700;
  font-style: normal;
}

/* geist-bold - latin */

@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Geist Bold";
  src:
    url("../../fonts/geist-bold.woff2") format("woff2"),
    /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
      url("../../fonts/geist-bold.woff") format("woff"); /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
  font-weight: normal;
  font-style: normal;
}

* {
  hyphens: manual;
}

/* ********************
     GENERAL STYLING
*********************** */

:root {
  --color-primary: oklch(68% 50% 43deg);
  --color-secondary: oklch(45% 78% 265deg);
  --color-custom1: oklch(99% 0% 90deg);
  --color-custom2: oklch(96% 0% 90deg);
  --color-white: var(--color-custom1);
  --color-black: oklch(0% 0% 0deg);

  --trans-speed: 0.3s;
  --border-radius-5: 5px;
  --border-radius-10: 10px;
  --border-radius-20: 20px;
  --border-radius-25: 25px;
  --border-radius-30: 30px;
  --border-radius-40: 40px;
  --border-radius-50: 50px;

  --icon-arrow-right-primary: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='oklch(68% 50% 43deg)' viewBox='0 -0.33 1108.29 1024.38'%3E%3Cpath d='M470.62 1016.08s-.07.05-.11.08h0s.11-.08.11-.08Z'/%3E%3Cpath d='M1092.61 479h0S470.5 7.84 470.5 7.84c-6.63-5.1-15.04-8.17-24.18-8.17-22.02 0-39.86 17.85-39.86 39.86 0 .12 0 .23 0 .35v252.88H0v438.48h406.46v252.9c0 15.03 8.49 28.75 22.22 35.94 5.16 2.51 11.22 3.97 17.62 3.97 9.05 0 17.42-2.93 24.2-7.9l622.11-473.12c9.8-7.84 15.68-19.6 15.68-32.02s-5.88-24.18-15.68-32.02Z'/%3E%3C/svg%3E");
  --icon-arrow-right-white: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='oklch(100% 0% 90deg)' viewBox='0 -0.33 1108.29 1024.38'%3E%3Cpath d='M470.62 1016.08s-.07.05-.11.08h0s.11-.08.11-.08Z'/%3E%3Cpath d='M1092.61 479h0S470.5 7.84 470.5 7.84c-6.63-5.1-15.04-8.17-24.18-8.17-22.02 0-39.86 17.85-39.86 39.86 0 .12 0 .23 0 .35v252.88H0v438.48h406.46v252.9c0 15.03 8.49 28.75 22.22 35.94 5.16 2.51 11.22 3.97 17.62 3.97 9.05 0 17.42-2.93 24.2-7.9l622.11-473.12c9.8-7.84 15.68-19.6 15.68-32.02s-5.88-24.18-15.68-32.02Z'/%3E%3C/svg%3E");

  --icon-arrow-left-primary: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='oklch(68% 50% 43deg)' viewBox='0 0 35 32'%3E%3Cpath d='M14.7,31.75s0,0,0,0h0Z'/%3E%3Cpath d='M0,15.97c0,.39.18.75.49,1l19.43,14.78c.21.16.47.25.76.25.2,0,.39-.05.55-.12.43-.22.69-.65.69-1.12v-7.9h12.7s0-13.7,0-13.7h-12.7V1.26h0c0-.7-.56-1.26-1.24-1.26-.28,0-.55.1-.76.25L.49,14.97H.49C.18,15.22,0,15.58,0,15.97Z'/%3E%3C/svg%3E");
  --icon-arrow-left-white: url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='oklch(100% 0% 90deg)' viewBox='0 0 35 32'%3E%3Cpath d='M14.7,31.75s0,0,0,0h0Z'/%3E%3Cpath d='M0,15.97c0,.39.18.75.49,1l19.43,14.78c.21.16.47.25.76.25.2,0,.39-.05.55-.12.43-.22.69-.65.69-1.12v-7.9h12.7s0-13.7,0-13.7h-12.7V1.26h0c0-.7-.56-1.26-1.24-1.26-.28,0-.55.1-.76.25L.49,14.97H.49C.18,15.22,0,15.58,0,15.97Z'/%3E%3C/svg%3E");

  --transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1);
}
@media (prefers-reduced-motion: reduce) {
  #sidebar .column {
    transition: none;
  }
}

body {
  font-family: "Roboto", sans-serif;
  font-size: clamp(1.025rem, 1.0815rem + 0.2174vw, 1.15rem);

  line-height: 12px;
  line-height: clamp(1.125rem, 1.18rem + 0.2174vw, 1.25rem);
  background-color: var(--color-black);
}

h1,
h2,
h3,
h4,
h5,
h6,
.h1,
.h2,
.h3,
.h4,
.h5,
.h6 {
  font-family: "Geist Bold", sans-serif;
  color: black;
  text-transform: uppercase;
}

h2,
.h2 {
  margin-bottom: 5px;
}

/* General  */

@media screen and (max-width: 768px) {
  .mod_article.fullwidth .column :is(.ce_wrap, .ce_videoplayer_desktop_mobile) {
    margin-inline: 3vw;
  }
}
@media screen and (min-width: 768px) {
  .mod_article.fullwidth {
    .column {
      &:first-of-type:has(img):has([class*="border-radius"]) img,
      &:first-of-type:has(video):has([class*="border-radius"]) video,
      &:first-child .ce_wrap[class*="border-radius"] {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
      }

      &:last-of-type:has(img):has([class*="border-radius"]) img,
      &:last-of-type:has(video):has([class*="border-radius"]) video,
      &:last-child .ce_wrap[class*="border-radius"] {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
      }
    }
  }
}

/* Off Grid */

.ce_wrap.offgrid {
  overflow: initial;
}

/* Social Icons */
#top,
#footer {
  .socials {
    font-size: 1.25rem;
    display: flex;
    gap: 0.5rem;
    a {
      display: block;

      &:hover,
      &:focus {
        color: var(--color-primary);
      }
    }
  }
}

.mod_socials i.fa-facebook:hover,
.mod_socials i.fa-instagram:hover,
.mod_socials i.fa-linkedin:hover {
  background: var(--color-secondary) !important;
}

#footer .socials {
  justify-content: flex-end;
}

#footer .attributes .p1 {
  font-size: 1.15rem;
}

/* Mobile Menü */

#mmenu {
  top: 100px;
}

/* Footer Nav */

#footer .mod_customnav {
  .vlist {
    font-size: 1.15rem;
    li {
      padding-left: 0;
      &::before {
        display: none;
      }
    }
  }
}

.top-link i::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: var(--color-primary);
  -webkit-mask: var(--icon-arrow-right-primary) no-repeat center / contain;
  mask: var(--icon-arrow-right-primary) no-repeat center / contain;
  transform: rotate(-90deg);
}

/* Header */
#top-wrapper {
  margin-top: 2rem;
  #header > .inside {
    display: grid;
    gap: 0.5em;
    grid-template-columns: 1fr 2fr;
    grid-template-rows: 1.25fr 1fr;
    grid-template-areas:
      "logo top"
      "logo nav";
  }
  .logo {
    grid-area: logo;
    margin-bottom: 0;
  }
  #top {
    line-height: initial;
    grid-area: top;
    .inside {
      padding-block: 0;
      margin-block: 0;
      margin-right: 0;
      padding-right: 0;
      display: flex;
      align-items: center;

      justify-content: end;
      gap: 1.5rem;

      & > *:first-child {
        margin-left: auto;
      }
    }
  }
  .smartmenu,
  nav.mainmenu {
    grid-area: nav;
    align-content: center;
    justify-content: flex-end;

    ul {
      display: flex;
      justify-content: flex-end;
      gap: 4rem;
      li {
        margin: 0;
      }
      &::after {
        display: none;
      }
    }
  }

  .smartmenu {
    display: flex;
    color: var(--color-white);
  }

  .header.original {
    line-height: initial;
  }
  .header,
  #header .inside {
    background: var(--color-black);
    column-gap: 2rem;
  }

  #header .mainmenu a {
    font-weight: bold;

    &.active,
    &:hover,
    &:focus {
      color: var(--color-primary);
    }
  }
}
section {
  background: var(--color-white);
}

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

/* Topbar / Footer Pills */

#top {
  padding-top: 1rem;
}

#footer {
  color: white;
  background: linear-gradient(
    to bottom,
    var(--color-white) 0px,
    var(--color-white) 150px,
    var(--color-black) 150px,
    var(--color-black) 100%
  );
}
.mod_customnav a {
  color: var(--color-white);
  &:hover {
    color: var(--color-primary);
  }
}

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

  .inside .left a {
    margin-right: 0;
  }
}
#footer .mod_customnav li {
  font-weight: bold;
  margin-block: 0;
  padding-block: 0;

  &:after {
    border-bottom: 0;
  }
}

#footer .footer-pill a,
#top .topbar_teaser a,
#top .topbar_mail a {
  transition: All 0.3s ease;
  -webkit-transition: All 0.3s ease;
  background: var(--color-secondary);
  border-radius: var(--border-radius-20);
  font-weight: bold;
  display: inline-block;
  padding: 0.3rem 1rem;
  &:hover:not(.ce_hyperlink a),
  &:focus:not(.ce_hyperlink a) {
    background: var(--color-primary);
    color: currentColor;
  }
  p {
    line-height: 1.5rem;
  }
}

#footer .footer-pill a:hover,
#footer .footer-pill a:focus {
  color: var(--color-white);
}

/* Tabs */

.ce_tabs {
  .panes.vertical {
    width: 50%;
    border-left: 4px solid var(--color-primary);
    min-height: 13rem;
    @media screen and (max-width: 768px) {
      width: 100%;
      border-left: 0;
      border-right: 4px solid var(--color-primary);
    }
  }

  .tabs.vertical {
    width: 50%;
    @media screen and (max-width: 768px) {
      width: 100%;
    }
    ul {
      @media screen and (max-width: 768px) {
        border-right: 4px solid var(--color-primary);
      }
      li {
        overflow: hidden;
        position: relative;
        text-transform: uppercase;
        font-size: 4rem;
        font-weight: bold;
        padding-block: 0.5rem;
        margin-bottom: 2rem;

        span {
          transition:
            transform 0.3s ease,
            color 0.3s ease;
          position: relative;
          transition: left 0.3s ease;
          left: 0;
          font-family: "Geist Bold", sans-serif;
          font-size: clamp(1.875rem, 1.4837rem + 1.9565vw, 3rem);
          border: 0px solid var(--color-primary);
          margin-right: 3rem;
          display: inline-block;
          width: auto;
          background: var(--color-white);
          hyphens: auto;
          white-space: normal;
          overflow-wrap: break-word;
          word-break: break-word;
          z-index: 1;
          padding: 0.5rem;
        }
        &.active {
          span {
            left: -0.5rem;
          }
          color: var(--color-primary);
          z-index: 0;
          &::after {
            z-index: 1;
          }
          &:hover::after,
          &.active::after {
            content: "";
            position: absolute;
            z-index: -1;
            top: 50%;
            right: 0;
            transform: translateY(-50%);
            height: 4px;
            width: 100%;
            background-color: var(--color-primary);
          }
          &:not(.active) {
            transform: translateX(0);
          }
        }
      }
    }
  }
}

/* Buttons .ce_customlink */

form.style5 button.submit,
.widget button.submit,
.ce_customlink[data-style="style1"] a {
  appearance: none;
  font-size: 1rem;
  background: var(--color-secondary);
  color: var(--color-white);
  border-radius: var(--border-radius-30);
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.25rem 0.4rem 1rem;
  margin-bottom: 0.5rem;
  font-weight: bold;
  text-decoration: none;
  border: 0;
  transition:
    all var(--trans-speed) ease,
    color var(--trans-speed) ease;

  &::after {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    margin-left: 0.5rem;
    margin-right: 0.15rem;
    background: var(--color-primary);
    border-radius: var(--border-radius-50);
    content: "";
    background-image: var(--icon-arrow-right-white);
    background-position: center;
    color: var(--color-white);
    fill: var(--color-white);
    background-repeat: no-repeat;
    background-size: 40%;
    transition:
      all var(--trans-speed) ease,
      transform var(--trans-speed) ease;
  }
  &:hover,
  &:focus {
    background: var(--color-primary);

    &::after {
      background: var(--color-secondary);
      content: "";
      background-image: var(--icon-arrow-right-white);
      color: var(--color-white);
      fill: var(--color-white);
      background-position: center;
      background-repeat: no-repeat;
      background-size: 40%;
      pointer-events: none;
    }
  }
}

.widget button.submit {
  padding: 1.65rem 0.3rem 1.65rem 1.25rem;
}

/* Galerie Rounded */

.autogrid_row.inner-rounded img,
.autogrid_row.inner-rounded video {
  border-radius: 30px;
}

@media screen and (min-width: 767px) {
  /* Wenn Video in rechter Spalte steht → rechte Ecken weg */
  .autogrid_row.same_height .column:last-child video {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
  }

  /* Wenn Video in linker Spalte steht → linke Ecken weg */
  .autogrid_row.same_height .column:first-child video {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }
}

/* 1) Die Spalte/Wrap muss die Höhe „durchreichen“ */
.autogrid_row.same_height .column .attributes,
.autogrid_row.same_height .column .same-height-wrap {
  height: 100%;
}

/* 2) Video-Element (ce_player) soll auch strecken */
.autogrid_row.same_height .ce_videoplayer_desktop_mobile,
.autogrid_row.same_height .ce_player {
  height: 100%;
}

/* 3) Wrapper wird Flex-Container und nimmt volle Höhe */
.ce_videoplayer_desktop_mobile .video-wrapper {
  display: flex;
  width: 100%;
  height: 100%;
}

/* 4) Video füllt die Fläche, object-fit greift */
.ce_videoplayer_desktop_mobile .video-wrapper > video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Gegen Videohüpfer wegen fehlender Breitenangabe */

.ce_videoplayer_desktop_mobile .video-wrapper {
  display: block;
  width: 100%;
  max-width: 100%;
}
.ce_videoplayer_desktop_mobile video {
  display: block;
  width: 100%;
  height: auto;
}

/* Video rounded Thumbnail */

.ce_videoplayer_desktop_mobile video,
.ce_image.rounded img,
.ce_player video {
  border-radius: var(--border-radius-30);
}

.btn-circle {
  background-color: var(--color-black) !important;
}

/* FIX */

/* 2) Video-Wrapper muss block + volle Höhe */
.ce_videoplayer_desktop_mobile .video-wrapper {
  position: relative;
  display: block;
  width: 100%;
  height: 100%; /* wichtig: nimmt die Höhe vom same-height-wrap */
}

/* 3) Video füllt den verfügbaren Platz */
.ce_videoplayer_desktop_mobile .video-wrapper video {
  width: 100%;
  height: 100%; /* wichtig */
  object-fit: cover; /* wie background-size: cover */
  display: block;
}

/* 4) Overlay-Buttons bleiben korrekt positioniert */
.ce_videoplayer_desktop_mobile .btn-circle {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
}

/* Slider */

.ce_swiper-slider-start.style3_dark {
  .swiper-buttons {
    margin-top: 0;
    .swiper-button-prev {
      background: var(--color-primary);
      background-image: var(--icon-arrow-left-white);
      background-position: center;
      background-repeat: no-repeat;
      background-size: 40%;
      &::after {
        content: "";
      }
    }

    .swiper-button-next {
      background: var(--color-primary);
      background-image: var(--icon-arrow-right-white);
      background-position: center;
      background-repeat: no-repeat;
      background-size: 40%;
      &::after {
        content: "";
      }
    }
  }
}

/* ACCORDION */
.content-accordion {
  border-bottom: 0;

  h4.handorgel__header button.handorgel__header__button {
    padding: 0.5em 0.5em 0.5em 1.5em;
  }
  h5.handorgel__header button.handorgel__header__button {
    padding: 1em 1em 1em 1.5em;
  }

  .handorgel__header {
    display: flex;
    align-items: center;
    margin-bottom: 0;
    padding-bottom: 0;
    justify-content: space-between;
    background: var(--color-custom2);
    border-radius: var(--border-radius-40);
    &:not(.handorgel__header--opened) {
      margin-bottom: 1rem;
    }

    button.handorgel__header__button {
      display: flex;
      gap: 1rem;
      justify-content: space-between;
      align-items: center;
      align-content: center;
      background: transparent;
      font-weight: bold;
      line-height: 1.4;
      border-top: 0;
      padding: inherit;
      cursor: pointer;
      border-radius: inherit;
      transition: background-color 0.3s ease;

      &::after {
        content: "";
        display: block;
        height: 1lh;
        aspect-ratio: 1 / 1;
        border-radius: 50%;
        flex-shrink: 0;
        transform: rotate(-270deg);
        background-color: var(--color-primary);
        background-image: var(--icon-arrow-right-white);
        background-position: center;
        background-repeat: no-repeat;
        background-size: 40% auto;
        transition:
          background-color 0.2s ease,
          transform 0.2s ease;
      }

      &:hover,
      &:focus-visible {
        border-top: 0;
        background-color: var(--color-primary);
        color: var(--color-white);
      }

      &:hover::after,
      &:focus-visible::after {
        background-color: var(--color-white);
        background-image: var(--icon-arrow-right-primary);
        transform: rotate(-90deg);
      }

      &[aria-expanded="true"] {
        background: black;
        color: var(--color-white);
        border-top-left-radius: var(--border-radius-25);
        border-top-right-radius: var(--border-radius-25);
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        padding-bottom: 0;
        &::after {
          transform: rotate(-90deg);
        }
      }
    }
  }

  .handorgel__content {
    border-top: 0;
  }
  .handorgel__content--opened {
    background: black;
    color: var(--color-white);
    border-radius: 0 0 var(--border-radius-25) var(--border-radius-25);
    margin-bottom: 1rem;
  }
}

/*.uppercase > button.handorgel__header__button {
  text-transform: uppercase;
}*/

/* Count Up */

.ce_countup {
  color: var(--color-white);
  border-radius: var(--border-radius-30);
  display: inline-block;
  padding-inline: clamp(0.3rem, 1vw, 2rem);
  padding-block-start: clamp(0.25rem, 3vw, 2rem); /* oben */
  padding-block-end: clamp(0.15rem, 1vw, 1.5rem); /* unten */
  .h3 {
    font-size: clamp(0.75rem, 1rem + 0.9vw, 3rem);
    color: var(--color-white);
    margin-bottom: 0.25em;
    line-height: 20px;
  }
  .text p {
    font-size: clamp(0.25rem, 0.65rem + 0.9vw, 1rem);
    white-space: pre;
  }
}

.ce_wrap.countup-image {
  aspect-ratio: 1/1;
  position: relative;
  overflow: initial;
  align-content: center;

  container-type: size; /* aktiviert cqw/cqh */
  & > .inside {
    position: static;
  }
}

.box--blue {
  background: var(--color-secondary);
  position: absolute;
  top: 17cqw;
  right: 5cqw;
}
.box--orange {
  background: var(--color-primary);
  position: absolute;
  bottom: 0cqw;
  left: -12cqw;
}
.box--black {
  background: var(--color-black);
  position: absolute;
  bottom: 5cqw;
  right: 6cqw;
}

/* Vertical Iconbox */
.ce_iconbox_vertical {
  .headline {
    margin-bottom: 0;
    &.h3 {
      hyphens: auto;
      font-size: clamp(1.45rem, 1vw, 2rem);
    }
  }
  a {
    text-decoration: none;
  }
  &[data-style="style2"] p {
    color: rgba(255, 255, 255, 1);
  }
  &[data-size="small"] {
    .icon {
      .icon_inside {
        font-size: 2rem;
        i {
          position: relative;
          left: -0.4rem;
        }
      }
    }
    .content {
      font-weight: bold;
    }
  }
  &[data-size="medium"] {
    gap: 1.5rem;
    .icon {
      .icon_inside {
        width: clamp(100px, 1.5vw, 200px);
        padding-inline: clamp(1rem, 2vw, 1.5rem);
        padding-block: clamp(0.7rem, 1vw, 1rem);
        background: var(--color-primary);
        border-radius: var(--border-radius-20);
        border: 0;
        display: flex;
        height: auto;
        justify-content: center;
        align-items: center;

        i {
          display: block;
          font-size: clamp(1.75rem, 2vw, 2rem);
          min-width: 4rem;
          text-align: center;
          line-height: 1;
          height: auto;
          place-items: center;
          color: var(--color-white);
        }
        figure {
          top: 1.25rem;
        }
      }
    }
  }
  &[data-size="large"] {
    gap: 4rem;
    margin-bottom: 2rem;
    .icon {
      flex: 1;
      .icon_inside {
        background: var(--color-primary);
        border-radius: var(--border-radius-30);
        border: 0;
        width: 100%;
        display: flex;
        height: auto;
        padding-inline: clamp(1rem, 2vw, 1.5rem);
        padding-block: clamp(0.7rem, 1vw, 1rem);
        i {
          font-size: clamp(3rem, 5vw, 5rem);
          padding: clamp(1rem, 1vw, 3rem);
          display: block;
          height: auto;
          place-items: center;
          color: var(--color-white);
        }
        figure {
          top: 0.5rem;
          img {
            min-width: clamp(100px, 14vw + 1rem, 300px);
          }
        }
      }
    }
    .content {
      align-content: center;
      flex: 3.5;
    }
  }
  &::after {
    width: 0;
  }
}

/* Desktop beibehalten (Icon links, Text rechts) */
@media screen and (max-width: 767px) {
  .ce_iconbox_vertical[data-size="medium"],
  .ce_iconbox_vertical[data-size="large"] {
    flex-direction: column;
    align-items: center;
  }
}

/* Dashed Path */

@media screen and (max-width: 1400px) {
  .ce_wrap.dashedbg {
    background-image: none !important;
  }
}

/* Gallery */

.ce_gallery .gallery-margin {
  justify-content: center;
  padding: 0;
  margin: 0;
  list-style: none;
  .image_container {
    margin: 1rem 1rem 0 0;
  }
}

/* Forms */

.ce_form .style10 {
  fieldset {
    border: 0;
  }
  input,
  textarea,
  select {
    border-radius: var(--border-radius-30);
    border-color: var(--color-black);
  }

  input[name="Datenschutz"] + label a {
    text-decoration: underline;
    line-height: 1.5rem;
  }

  /* Container-Label umstylen */
  .checkbox_container {
    overflow: visible;

    .checkbox + label {
      font-size: 0.9rem;
      position: relative;
      padding-left: 30px;
      cursor: pointer;
      display: inline-block;
      line-height: 1.5;
    }
  }
  .checkbox_container .checkbox {
    position: absolute;
    opacity: 0;
    inset: 0;
    width: 20px;
    height: 20px;
    margin: 0;
    cursor: pointer;
    }

  .checkbox_container .checkbox + label::before {
    content: "";
    position: absolute;
    left: 0;
    top: 2px;
    width: 20px;
    height: 20px;
    border: 1px solid var(--color-primary);
    border-radius: var(--border-radius-5);
    box-sizing: border-box;
  }

  .checkbox_container .checkbox:checked + label::after {
    content: "";
    position: absolute;
    left: 6px;
    top: 3px;
    width: 6px;
    height: 12px;
    border-style: solid;              
    border-width: 0 2px 2px 0;
    border-color: var(--color-primary); 
    transform: rotate(45deg);
  }

  .checkbox_container .checkbox:focus + label::before {
    outline: 2px solid var(--color-secondary);
    z-index: 9999;
    outline-offset: 1px;
  }
}

/**
#
# Sidebar Quickmenü
#
*/

#sidebar {
  pointer-events: none;
  position: fixed;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

#sidebar .inside {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

#sidebar .ce_iconbox_vertical {
  pointer-events: auto;
  align-items: center;
  border-radius: var(--border-radius-40) 0 0 var(--border-radius-40);
  gap: 0rem;
  position: relative;
  width: 17.5rem;
  transform: translateX(14rem); /* 3rem ragen rein */
  transition: transform 0.45s ease;
  cursor: pointer;
  padding: 0.25rem 0;
  background: var(--color-primary);
  .icon {
    .icon_inside {
      display: flex;
      border: 0;
      width: 100%;
      i {
        left: 1px;
      }
      figure {
        top: 0.2rem;
        align-items: center;
        position: static;
        img {
          min-width: 30px;
          max-width: 70%;
          width: 70%;
        }
      }
    }
  }
}

#sidebar .ce_iconbox_vertical:hover,
#sidebar .ce_iconbox_vertical:focus-within {
  transform: translateX(0);
}
#sidebar:has(.ce_iconbox_vertical:focus-within) .ce_iconbox_vertical {
  transform: translateX(0);
}

#sidebar .ce_iconbox_vertical::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -3rem;
  width: 3rem;
  pointer-events: auto; /* nur Griff ist klickbar */
}

/* wenn man über den Griff fährt oder Tab-Fokus ins Element kommt */
#sidebar .ce_iconbox_vertical:hover,
#sidebar .ce_iconbox_vertical:focus-within {
  transform: translateX(0); /* fährt langsam rein */
  pointer-events: auto; /* jetzt ist alles klickbar */
}

.format-p-small > h1,
.format-p-medium > h1,
.format-p-large > h1 {
  line-height: inherit;
  font-size: unset;
  font-weight: normal;
  text-transform: inherit;
}

/* Wrapper Breite mobil */

.fullwidth-boxed .ce_wrap {
  margin: 0px -1vw;
}

/* Mobile Anpassungen */

@media screen and (max-width: 767px) {
  h1, .h1 {
    line-height: 4rem;
    font-size: 4rem;
    .span {
      display: block;
    }
  }

   h2, .h2 {
    line-height: 2rem;
    font-size: 2rem;
  }

  .ce_iconbox_vertical[data-size="large"],
  .ce_iconbox_vertical[data-size="medium"] {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: 2rem;
  }

    .ce_split_words > * {
    line-height: 2.4rem;
  }

.ce_player {
  margin-inline: 3vw;
}

.mod_article:not(.fullwidth) > .container {
  padding-top: 15px;
}

/* Formular */

.ce_form .column[class*="col_"]:not([class*="_m"]){
  margin-bottom: inherit;
}

.widget-checkbox fieldset.checkbox_container {
  padding-block: 0;
  span {
    margin-bottom: 0;
  }
}


}

/* Slider */
#kundenstimmen .swiper-buttons {
  padding-top: 1rem;
}

