/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/***
 * Remove browser's margins, paddings and list style rules
 */
/***
 * Hide native browser's scrollbar
 */
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
.cs-slider-navigation {
  display: none; }
  @media (hover: hover) and (pointer: fine) {
    .cs-slider-navigation {
      position: absolute;
      z-index: 11;
      top: 50%;
      transform: translate3d(0, -50%, 0);
      display: flex;
      align-items: center;
      justify-content: center;
      width: 4.4rem;
      height: 5.2rem;
      border: 0;
      border-radius: 7px;
      background: #fff;
      box-shadow: 1px 1px 2px 0 rgba(0, 0, 0, 0.25);
      padding: 0;
      color: #7e57c2;
      cursor: pointer;
      transition: all 0.3s; }
      .cs-slider-navigation--prev {
        left: 1.5rem; }
      .cs-slider-navigation--next {
        right: 1.5rem; }
      .cs-slider-navigation[disabled] {
        opacity: 0.25;
        cursor: not-allowed; }
        .cs-slider-navigation[disabled] svg {
          filter: grayscale(1); }
      .cs-slider-navigation:not([disabled]):hover {
        box-shadow: 1px 1px 10px 0 rgba(0, 0, 0, 0.25); }
      .cs-slider-navigation__icon {
        width: 1.4rem;
        height: 2.7rem;
        fill: currentColor; } }

/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
/**
 * Breakpoint component used by include-media vendor library.
 */
@use 'sass:map';
/**
 * Extracts nested keys from given map.
 * Example: deep-get($some-map, some, nested, keys);
 */
/**
* Default project breakpoints - [em]
*/
.cs-slider-pagination {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.8rem;
  min-height: 3rem; }
  .cs-slider-pagination--fraction {
    gap: 0;
    white-space: pre-wrap;
    color: inherit;
    font-weight: 600; }
    .cs-slider-pagination--fraction span {
      color: #11a099; }
  .cs-slider-pagination__bullet {
    position: relative;
    border-radius: 2px;
    background: #fff;
    border: 0;
    inline-size: 2.2rem;
    block-size: 0.9rem;
    transition: all 0.15s;
    overflow: hidden;
    text-indent: -99rem; }
    .cs-slider-pagination__bullet.current {
      background-color: #11a099; }
    .cs-slider-pagination__bullet:only-child {
      display: none; }

/*
 * Function to get value from a list of values, based on side
 * @param {string} $variable: variable with a list of values (like paddings, margins etc.);
 * @param {string} $side: side (up / right / down / left) for which we want to get value
 * Example:
 * $component_padding: 1rem 2rem 3rem;
 * get-value-from-list($component_padding, 'right') // 2rem
 * get-value-from-list($component_padding, 'bottom') // 3rem
 */
/* stylelint-disable block-no-empty */
/* stylelint-enable */
/**
 * This components is sort of unique because it's items-per-row configuration is only available for tablet+
 * This map adds possibility to 'force' provied columns configuration up to laptop resolutions.
 */
.cs-image-teaser {
  --slogan-font-size: 3.8rem;
  --description-font-size: 1.5rem;
  --gap: 0.8rem;
  /*
     * Keep CTA separated from text-content for all scenarios
     * "!important" added due to fallback from --scheme-* with button() mixin that resets margins
     */
  /**
     * Contrast Optimizers
     */ }
  .cs-image-teaser:not(.cs-container--use-whole-width) .cs-image-teaser.cs-image-teaser--container-width .cs-image-teaser__slides-wrapper {
    max-width: 128rem;
    margin-left: auto;
    margin-right: auto; }
  .cs-image-teaser__slides {
    --columns: 1;
    display: grid;
    gap: var(--gap);
    grid-template-columns: repeat(var(--columns), minmax(0, 1fr));
    margin: 0;
    padding: 0; }
    .cs-image-teaser--items-in-row-mobile-2 .cs-image-teaser__slides {
      --columns: 2; }
  .cs-image-teaser__slide {
    display: inline-block;
    margin: 0; }
  .cs-image-teaser__link {
    outline-offset: calc(var(--gap) / 2 + 2); }
    .cs-image-teaser__link:focus {
      outline-offset: 0.4rem; }
    @media (prefers-reduced-motion: no-preference) {
      .cs-image-teaser__link {
        transition: outline-offset 0.25s ease; } }
  .cs-image-teaser__picture {
    display: block;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    overflow: hidden;
    width: 100%;
    height: auto;
    /* stylelint-disable -- stylelint doesn't know this media query yet. */
    /* stylelint-enable */ }
    @media (prefers-reduced-data: reduce) {
      .cs-image-teaser__picture {
        display: none; } }
  .cs-image-teaser__image {
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    background-color: #f0f0f0; }
  @media (min-width: 48em) {
    .cs-image-teaser {
      --gap: 0.8rem; }
      .cs-image-teaser--items-in-row-2 .cs-image-teaser__slides {
        --columns: 2; }
      .cs-image-teaser--items-in-row-3 .cs-image-teaser__slides {
        --columns: 3; }
      .cs-image-teaser--items-in-row-4 .cs-image-teaser__slides {
        --columns: 4; }
      .cs-image-teaser--items-in-row-5 .cs-image-teaser__slides {
        --columns: 5; }
      .cs-image-teaser--items-in-row-6 .cs-image-teaser__slides {
        --columns: 6; }
      .cs-image-teaser--items-in-row-7 .cs-image-teaser__slides {
        --columns: 7; }
      .cs-image-teaser--items-in-row-8 .cs-image-teaser__slides {
        --columns: 8; } }

@media (min-width: 48em) and (max-width: 63.99em) {
  .cs-image-teaser--items-in-row-4:not(.cs-image-teaser--icon) .cs-image-teaser__slides {
    --columns: 2; } }
  .cs-image-teaser--slider {
    --gap: 0.8rem;
    --base-size: calc(100% - 0px);
    --size: var(--base-size);
    /**
     * class-based columns config relates to classnames, like '--items-in-row-4'
     * which are added to elements, depending on the CC Components configuration.
     */
    /*  container padding fix  */ }
    @media (min-width: 81.875em) {
      .cs-image-teaser--slider.cs-image-teaser--container-width {
        --base-size: calc(128rem - 0px); }
      .cs-image-teaser--slider.cs-image-teaser--use-whole-screen:not(.cs-image-teaser--full-width-slider) {
        --base-size: 100%;
        max-width: 100%; }
        .cs-image-teaser--slider.cs-image-teaser--use-whole-screen:not(.cs-image-teaser--full-width-slider) .cs-image-teaser__slides {
          scroll-snap-type: x proximity;
          padding-left: calc((100% - 128rem) / 2);
          padding-right: calc((100% - 128rem) / 2);
          scroll-padding-left: calc((100% - 128rem) / 2);
          scroll-padding-right: calc((100% - 128rem) / 2);
          scroll-margin-left: calc((100vw - 128rem) / 2);
          scroll-margin-right: calc((100vw - 128rem) / 2); } }
    @media (hover: hover) and (pointer: fine) and (min-width: 81.875em) {
      .cs-image-teaser--slider.cs-image-teaser--container-width {
        --base-size: 128rem; } }
    @media (min-width: 48em) {
      .cs-image-teaser--slider {
        --gap: 0.8rem; } }
    @media (min-width: 48em) {
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-2 {
        --size: calc(
                        var(--base-size) /
                            2 -
                            ((1 * var(--gap)) / 2)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-3 {
        --size: calc(
                        var(--base-size) /
                            3 -
                            ((2 * var(--gap)) / 3)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-4 {
        --size: calc(
                        var(--base-size) /
                            4 -
                            ((3 * var(--gap)) / 4)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-5 {
        --size: calc(
                        var(--base-size) /
                            5 -
                            ((4 * var(--gap)) / 5)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-6 {
        --size: calc(
                        var(--base-size) /
                            6 -
                            ((5 * var(--gap)) / 6)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-7 {
        --size: calc(
                        var(--base-size) /
                            7 -
                            ((6 * var(--gap)) / 7)
                    ); }
      .cs-image-teaser--slider.cs-image-teaser--items-in-row-8 {
        --size: calc(
                        var(--base-size) /
                            8 -
                            ((7 * var(--gap)) / 8)
                    ); } }

@media (min-width: 48em) and (max-width: 63.99em) {
  .cs-image-teaser--slider.cs-image-teaser--items-in-row-4:not(.cs-image-teaser--icon) {
    --size: calc(var(--base-size) / 2 - (1 * var(--gap) / 2)); } }
    @media (max-width: 81.8125em) {
      .cs-image-teaser--slider.cs-image-teaser--container-width .cs-image-teaser__slides {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        scroll-padding-left: 1.5rem;
        scroll-padding-right: 1.5rem; } }
    @media (prefers-reduced-motion: no-preference) {
      .cs-image-teaser--slider .cs-image-teaser__slides {
        scroll-behavior: smooth; } }
    .cs-image-teaser--slider .cs-image-teaser__slides-wrapper {
      position: relative; }
    .cs-image-teaser--slider .cs-image-teaser__slides {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      flex: 0 0 100%;
      gap: 0;
      flex-wrap: nowrap;
      padding: var(--gap) 0;
      overflow-x: auto;
      overscroll-behavior-inline: contain;
      scrollbar-width: thin; }
      @supports (scroll-behavior: smooth) {
        .cs-image-teaser--slider .cs-image-teaser__slides {
          scroll-snap-type: x mandatory; } }
      @media (min-width: 48em) {
        .cs-image-teaser--slider .cs-image-teaser__slides {
          overflow: -moz-scrollbars-none;
          scrollbar-width: none; }
          .cs-image-teaser--slider .cs-image-teaser__slides::-webkit-scrollbar {
            display: none;
            width: 0;
            height: 0;
            background: transparent; }
          .cs-image-teaser--slider .cs-image-teaser__slides::-webkit-scrollbar-thumb {
            background: transparent;
            width: 0;
            height: 0; } }
    .cs-image-teaser--slider .cs-image-teaser__slide {
      margin: 0;
      padding: 0;
      list-style: none;
      display: inline-block;
      flex: 0 0 var(--size);
      margin-right: var(--gap);
      scroll-snap-align: start;
      min-width: 0; }
      .cs-image-teaser--slider .cs-image-teaser__slide:last-of-type {
        margin-right: 0; }
    .cs-image-teaser--slider .cs-image-teaser__image {
      display: block; }
  @media (max-width: 47.99em) {
    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) {
      --gap: 0.8rem;
      --base-size: calc(100% - 0px);
      --size: var(--base-size); }
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider).cs-image-teaser--container-width {
        margin-left: -1.5rem;
        margin-right: -1.5rem; }
        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider).cs-image-teaser--container-width .cs-image-teaser__slides {
          padding-left: 1.5rem;
          padding-right: 1.5rem;
          scroll-padding-left: 1.5rem;
          scroll-padding-right: 1.5rem; } }
  @media (max-width: 47.99em) and (prefers-reduced-motion: no-preference) {
    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {
      scroll-behavior: smooth; } }
  @media (max-width: 47.99em) {
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides-wrapper {
        position: relative; }
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {
        margin: 0;
        padding: 0;
        list-style: none;
        display: flex;
        flex: 0 0 100%;
        gap: 0;
        flex-wrap: nowrap;
        padding: var(--gap) 0;
        overflow-x: auto;
        overscroll-behavior-inline: contain;
        scrollbar-width: thin; }
        @supports (scroll-behavior: smooth) {
          .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {
            scroll-snap-type: x mandatory; } } }
    @media (max-width: 47.99em) and (min-width: 48em) {
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {
        overflow: -moz-scrollbars-none;
        scrollbar-width: none; }
        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides::-webkit-scrollbar {
          display: none;
          width: 0;
          height: 0;
          background: transparent; }
        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides::-webkit-scrollbar-thumb {
          background: transparent;
          width: 0;
          height: 0; } }
  @media (max-width: 47.99em) {
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slide {
        margin: 0;
        padding: 0;
        list-style: none;
        display: inline-block;
        flex: 0 0 var(--size);
        margin-right: var(--gap);
        scroll-snap-align: start;
        min-width: 0; }
        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slide:last-of-type {
          margin-right: 0; }
      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__image {
        display: block; } }
  @media (min-width: 48em) {
    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__nav,
    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__pagination {
      display: none; } }
  .cs-image-teaser__slide--scheme-light {
    --scheme-color: #fff;
    --scheme-background: #212121; }
  .cs-image-teaser__slide--scheme-dark {
    --scheme-color: #455a64;
    --scheme-background: #fff; }
  .cs-image-teaser__slide:not(.cs-image-teaser__slide--image-uploaded) {
    background: var(--scheme-background); }
  @media (max-width: 47.99em) {
    .cs-image-teaser__slides--mobile_text-image .cs-image-teaser__slide--image-uploaded {
      order: 1; }
    .cs-image-teaser__slides--mobile_image-text .cs-image-teaser__slide--image-uploaded {
      order: -1; } }
  @media (max-width: 47.99em) {
    .cs-image-teaser--as-list-mobile .cs-image-teaser__slides {
      flex-wrap: wrap; }
    .cs-image-teaser--as-list-mobile .cs-image-teaser__slide {
      margin: 0 0 0.8rem; }
    .cs-image-teaser--as-list-mobile .cs-image-teaser__pagination,
    .cs-image-teaser--as-list-mobile .cs-image-teaser__nav {
      display: none; } }
  .cs-image-teaser__link {
    display: block;
    height: 100%; }
    .cs-image-teaser__link, .cs-image-teaser__link:hover, .cs-image-teaser__link:visited, .cs-image-teaser__link:active, .cs-image-teaser__link:focus {
      text-decoration: none; }
  .cs-image-teaser__figure {
    height: 100%;
    position: relative; }
  .cs-image-teaser__content-wrapper {
    color: var(--scheme-color); }
    .cs-image-teaser__content-wrapper--under {
      position: relative;
      z-index: 1;
      margin: -2rem 2rem 0;
      padding: 2rem;
      background-color: var(--scheme-background);
      text-align: center; }
    .cs-image-teaser__content-wrapper--over {
      width: 100%;
      height: 100%;
      display: flex;
      padding: 2rem;
      overflow: hidden;
      align-items: flex-start; }
      .cs-image-teaser__picture + .cs-image-teaser__content-wrapper--over,
      .cs-image-teaser--teaser-and-text .cs-image-teaser__slide--image-uploaded .cs-image-teaser__content-wrapper--over {
        position: absolute;
        top: 0;
        left: 0; }
    .cs-image-teaser__content-wrapper--content-align-x-2 {
      justify-content: center;
      text-align: center; }
    .cs-image-teaser__content-wrapper--content-align-x-3 {
      justify-content: flex-end;
      text-align: right; }
    .cs-image-teaser__content-wrapper--content-align-y-2 {
      align-items: center; }
    .cs-image-teaser__content-wrapper--content-align-y-3 {
      align-items: flex-end; }
  .cs-image-teaser__content {
    position: relative; }
  .cs-image-teaser__text-content + .cs-image-teaser__cta {
    margin-top: 1em !important; }
  .cs-image-teaser__slogan {
    margin: 0;
    line-height: 1.1;
    font-size: var(--slogan-font-size);
    font-weight: 900;
    overflow-wrap: break-word;
    word-wrap: break-word;
    word-break: break-word;
    -webkit-hyphens: auto;
            hyphens: auto; }
  .cs-image-teaser__description {
    margin: 1em 0 0;
    line-height: 1.1;
    font-size: var(--description-font-size); }
  .cs-image-teaser__cta {
    display: none; }
    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta {
      display: inline-block;
      font-size: 1.8rem;
      font-weight: 700;
      text-align: center;
      position: relative;
      line-height: 1.275em;
      margin: 0;
      text-transform: none;
      padding: 0.75em 1em;
      box-sizing: border-box;
      transition: background-color 0.5s, border-color 0.5s, fill 0.5s, color 0.5s;
      vertical-align: middle;
      z-index: 5; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active {
        background-color: #7e57c2 !important; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:before, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:after {
        content: '';
        position: absolute;
        top: -1px;
        bottom: -1px;
        right: -1px; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:before {
        width: 3.4em;
        border-radius: 0 200px 200px 0;
        z-index: -1;
        background: linear-gradient(0deg, transparent 0%, transparent 0%, #4d2c91 0%, #4d2c91 100%); }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:after {
        width: 3em;
        min-width: auto;
        background-color: #4d2c91;
        transition: width 0.25s linear;
        z-index: -2;
        border-radius: 200px; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:after {
        width: calc(100% + 2px); }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta::-moz-focus-inner {
        border: 0;
        padding: 0;
        margin: 0; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:visited {
        cursor: pointer;
        border-radius: 200px;
        outline-offset: 1px;
        text-decoration: none;
        box-shadow: none;
        border: 1px solid transparent;
        color: #fff;
        background-color: #7e57c2; }
        .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:visited * {
          color: #fff;
          fill: #fff; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:not([disabled]), .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus:not([disabled]), .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active:not([disabled]) {
        box-shadow: none;
        outline: none;
        text-decoration: none;
        border: 1px solid transparent;
        color: #fff;
        background-color: #4d2c91; }
        .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:not([disabled]) *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus:not([disabled]) *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active:not([disabled]) * {
          color: #fff;
          fill: #fff; }
      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta[disabled] {
        opacity: 0.65;
        cursor: auto; }
    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta {
      display: inline-block;
      font-size: 1.8rem;
      font-weight: 700;
      text-align: center;
      position: relative;
      line-height: 1.275em;
      margin: 0;
      text-transform: none;
      padding: 0.75em 1em;
      box-sizing: border-box;
      transition: background-color 0.5s, border-color 0.5s, fill 0.5s, color 0.5s;
      vertical-align: middle;
      z-index: 5; }
      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::before, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::after {
        content: none; }
      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::-moz-focus-inner {
        border: 0;
        padding: 0;
        margin: 0; }
      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:visited {
        cursor: pointer;
        border-radius: 200px;
        outline-offset: 1px;
        text-decoration: none;
        box-shadow: none;
        border: 1px solid #7e57c2;
        color: #7e57c2;
        background-color: #fff; }
        .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:visited * {
          color: #7e57c2;
          fill: #7e57c2; }
      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:hover:not([disabled]), .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:focus:not([disabled]), .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:active:not([disabled]) {
        box-shadow: none;
        outline: none;
        text-decoration: none;
        border: 1px solid #4d2c91;
        color: #fff;
        background-color: #4d2c91; }
        .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:hover:not([disabled]) *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:focus:not([disabled]) *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:active:not([disabled]) * {
          color: #fff;
          fill: #fff; }
      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta[disabled] {
        opacity: 0.65;
        cursor: auto; }
    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta-span {
      margin-top: 0;
      z-index: 1;
      font-weight: 700;
      vertical-align: baseline;
      display: inline-block;
      line-height: 1.275em;
      letter-spacing: normal;
      padding-left: 0;
      padding-right: 4em; }
    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta-span {
      margin-top: 0;
      z-index: 1;
      font-weight: 700;
      vertical-align: baseline;
      display: inline-block;
      line-height: 1.275em;
      letter-spacing: normal;
      padding-left: 0;
      padding-right: 4em; }
    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta-icon {
      max-width: 1em;
      max-height: 1.8rem;
      z-index: 2;
      height: auto;
      width: 100%;
      position: absolute;
      top: 50%;
      transform: translate3d(0, -50%, 0);
      margin-right: 0;
      right: 1em; }
    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta-icon {
      max-width: 1em;
      max-height: 1.8rem;
      z-index: 2;
      height: auto;
      width: 100%;
      position: absolute;
      top: 50%;
      transform: translate3d(0, -50%, 0);
      margin-right: 0;
      right: 1em; }
    @media (min-width: 30em) {
      .cs-image-teaser__cta {
        display: inline-flex;
        z-index: 1;
        margin: 1.2em 0 0;
        align-items: center;
        font-size: 1.2rem; }
        .cs-image-teaser__cta-icon {
          width: 1.2rem;
          height: 1.4rem; } }
  .cs-image-teaser__overlay, .cs-image-teaser__gradient {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__overlay, .cs-image-teaser__slide--scheme-light .cs-image-teaser__optimizer-container {
    background-color: #212121; }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__overlay, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__optimizer-container {
    background-color: #fff; }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(135deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(135deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(45deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(45deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(180deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(180deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(0deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(-135deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-1 {
    background: linear-gradient(-135deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(-90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-2 {
    background: linear-gradient(-90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(-45deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-3 {
    background: linear-gradient(-45deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }
  .cs-image-teaser__image--mirror {
    transform: scaleX(-1); }
  .cs-image-teaser__content--container {
    position: relative;
    z-index: 1;
    padding: 2em; }
  .cs-image-teaser__optimizer-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1; }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-0 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-5 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.05); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-10 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.1); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-15 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.15); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-20 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.2); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-25 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.25); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-30 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.3); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-35 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.35); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-40 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.4); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-45 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.45); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-50 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.5); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-55 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.55); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-60 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.6); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-65 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.65); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-70 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.7); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-75 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.75); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-80 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.8); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-85 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.85); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-90 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.9); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-95 {
    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.95); }
  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-100 {
    text-shadow: 0 0 2.5rem white; }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-0 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-5 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.05); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-10 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.1); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-15 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.15); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-20 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.2); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-25 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.25); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-30 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.3); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-35 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.35); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-40 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.4); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-45 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.45); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-50 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.5); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-55 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.55); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-60 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.6); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-65 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.65); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-70 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.7); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-75 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.75); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-80 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.8); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-85 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.85); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-90 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.9); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-95 {
    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.95); }
  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-100 {
    text-shadow: 0 0 2.5rem #212121; }

@media (min-width: 48em) and (max-width: 63.99em) {
  .cs-image-teaser--icon {
    --gap: 0.8rem;
    --base-size: calc(100% - 0px);
    --size: var(--base-size); }
    .cs-image-teaser--icon.cs-image-teaser--container-width {
      margin-left: -1.5rem;
      margin-right: -1.5rem; }
      .cs-image-teaser--icon.cs-image-teaser--container-width .cs-image-teaser__slides {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        scroll-padding-left: 1.5rem;
        scroll-padding-right: 1.5rem; } }
  @media (min-width: 48em) and (max-width: 63.99em) and (prefers-reduced-motion: no-preference) {
    .cs-image-teaser--icon .cs-image-teaser__slides {
      scroll-behavior: smooth; } }

@media (min-width: 48em) and (max-width: 63.99em) {
    .cs-image-teaser--icon .cs-image-teaser__slides-wrapper {
      position: relative; }
    .cs-image-teaser--icon .cs-image-teaser__slides {
      margin: 0;
      padding: 0;
      list-style: none;
      display: flex;
      flex: 0 0 100%;
      gap: 0;
      flex-wrap: nowrap;
      padding: var(--gap) 0;
      overflow-x: auto;
      overscroll-behavior-inline: contain;
      scrollbar-width: thin; }
      @supports (scroll-behavior: smooth) {
        .cs-image-teaser--icon .cs-image-teaser__slides {
          scroll-snap-type: x mandatory; } } }
    @media (min-width: 48em) and (max-width: 63.99em) and (min-width: 48em) {
      .cs-image-teaser--icon .cs-image-teaser__slides {
        overflow: -moz-scrollbars-none;
        scrollbar-width: none; }
        .cs-image-teaser--icon .cs-image-teaser__slides::-webkit-scrollbar {
          display: none;
          width: 0;
          height: 0;
          background: transparent; }
        .cs-image-teaser--icon .cs-image-teaser__slides::-webkit-scrollbar-thumb {
          background: transparent;
          width: 0;
          height: 0; } }

@media (min-width: 48em) and (max-width: 63.99em) {
    .cs-image-teaser--icon .cs-image-teaser__slide {
      margin: 0;
      padding: 0;
      list-style: none;
      display: inline-block;
      flex: 0 0 var(--size);
      margin-right: var(--gap);
      scroll-snap-align: start;
      min-width: 0; }
      .cs-image-teaser--icon .cs-image-teaser__slide:last-of-type {
        margin-right: 0; }
    .cs-image-teaser--icon .cs-image-teaser__image {
      display: block; } }

@media (min-width: 0px) and (max-width: 63.99em) {
  .cs-image-teaser--icon {
    --size: calc(
                    var(--base-size) / 2 - ((
                                    1 * var(--gap)
                                ) / 2)
                ) !important; } }

@media (min-width: 23.125em) and (max-width: 63.99em) {
  .cs-image-teaser--icon {
    --size: calc(
                    var(--base-size) / 2 - ((
                                    1 * var(--gap)
                                ) / 2)
                ) !important; } }

@media (min-width: 30em) and (max-width: 63.99em) {
  .cs-image-teaser--icon {
    --size: calc(
                    var(--base-size) / 2 - ((
                                    1 * var(--gap)
                                ) / 2)
                ) !important; } }

@media (min-width: 48em) and (max-width: 63.99em) {
  .cs-image-teaser--icon {
    --size: calc(
                    var(--base-size) / 3 - ((
                                    2 * var(--gap)
                                ) / 3)
                ) !important; } }

@media (min-width: 48em) and (max-width: 63.99em) and (hover: hover) and (pointer: fine) {
  .cs-image-teaser--icon.cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__nav {
    display: block; } }

@media (min-width: 48em) and (max-width: 63.99em) {
  .cs-image-teaser--icon.cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__pagination {
    display: flex; } }
  .cs-image-teaser--icon .cs-image-teaser__slogan {
    --slogan-font-size: 1.6rem; }
  .cs-image-teaser--icon .cs-image-teaser__description {
    margin-top: 0.5em; }
  .cs-image-teaser--icon .cs-image-teaser__cta {
    display: none; }
  .cs-image-teaser--icon .cs-image-teaser__content-wrapper--under {
    margin-top: 0;
    padding: 1rem; }
  .cs-image-teaser--icon .cs-image-teaser__content-wrapper--cta-only {
    display: none; }
  @media (min-width: 48em) {
    .cs-image-teaser--mosaic .cs-image-teaser__slides--mosaic-scenario-1 {
      grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }
    .cs-image-teaser--mosaic .cs-image-teaser__slides--mosaic-scenario-2 {
      grid-template-columns: minmax(0, 1fr) minmax(0, 2fr); } }
  @media (max-width: 47.99em) {
    .cs-image-teaser--teaser-and-text .cs-image-teaser__slides {
      display: flex;
      flex-wrap: wrap; }
    .cs-image-teaser--teaser-and-text .cs-image-teaser__slide {
      flex: 0 0 100%; } }

.cs-container--image-teaser {
  margin: 0 0 3rem; }
  @media (min-width: 48em) {
    .cs-container--image-teaser {
      margin: 0 0 4rem; } }
  .cs-container--image-teaser--skip-spacing {
    margin: 0; }

.cs-container--grid-teaser {
  margin: 0; }

.cs-container--image-teaser-window-width {
  padding-left: 0;
  padding-right: 0; }
  .cs-container--image-teaser-window-width .cs-container__inner {
    max-width: 100%; }

.cs-container--image-teaser-slider {
  padding-left: 0;
  padding-right: 0; }


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"css/image-teaser.css","sources":["webpack://[name]/./src/config/breakpoints.scss","webpack://[name]/image-teaser.scss","webpack://[name]/../theme-creativeshop/src/utils/deep-get/deep-get.scss","webpack://[name]/../theme-creativeshop/src/utils/reset-list-style.scss","webpack://[name]/../theme-creativeshop/src/utils/hide-scrollbar.scss","webpack://[name]/../theme-creativeshop/src/components/_slider/navigation/navigation.scss","webpack://[name]/../theme-creativeshop/src/components/_slider/navigation/mixin.scss","webpack://[name]/../theme-creativeshop/src/components/_slider/pagination/pagination.scss","webpack://[name]/./src/components/_slider/pagination/mixin.scss","webpack://[name]/../theme-creativeshop/src/utils/get-value-from-list.scss","webpack://[name]/../theme-creativeshop/src/components/button/hook.scss","webpack://[name]/../theme-creativeshop/src/components/image-teaser/image-teaser.scss","webpack://[name]/../theme-creativeshop/src/components/_slider/mixin.scss","webpack://[name]/./node_modules/include-media/dist/_include-media.scss","webpack://[name]/./src/components/button/mixin.scss","webpack://[name]/../theme-creativeshop/src/components/button/animation.scss","webpack://[name]/../theme-creativeshop/src/components/image-teaser/mixins/contrast-optimizers/gradient.scss","webpack://[name]/../theme-creativeshop/src/components/image-teaser/mixins/contrast-optimizers/text-shadow.scss","webpack://[name]/../theme-creativeshop/src/utils/component-spacing.scss"],"sourcesContent":["/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n@import 'etc/view.scss';\n@import 'utils/deep-get/deep-get.scss';\n\n// Breakpoints import from view.xml [px]\n$breakpoints_px: deep-get($view-xml, vars, Magento_Theme, breakpoints);\n$breakpoints_em: ();\n\n@function calculate-breakpoints($breakpoints_em, $breakpoints_px) {\n    $result: $breakpoints_em;\n    @each $key, $value in $breakpoints_px {\n        $result: map-merge(\n            $result,\n            (\n                unquote($key): $value / 16 * 1em,\n            )\n        );\n    }\n\n    @return $result;\n}\n\n/**\n* Default project breakpoints - [em]\n*/\n\n$breakpoints: calculate-breakpoints($breakpoints_em, $breakpoints_px) !default;\n\n// phone: 23.125em - 370px\n// phoneLg: 30em - 480px,\n// tablet: 48em - 768px,\n// laptop: 64em - 1024px,\n// laptopLg: 80em - 1280px,\n// desktop: 90em - 1440px,\n// tv: 120em - 1920px,\n","/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/***\n * Remove browser's margins, paddings and list style rules\n */\n/***\n * Hide native browser's scrollbar\n */\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n.cs-slider-navigation {\n  display: none; }\n  @media (hover: hover) and (pointer: fine) {\n    .cs-slider-navigation {\n      position: absolute;\n      z-index: 11;\n      top: 50%;\n      transform: translate3d(0, -50%, 0);\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      width: 4.4rem;\n      height: 5.2rem;\n      border: 0;\n      border-radius: 7px;\n      background: #fff;\n      box-shadow: 1px 1px 2px 0 rgba(0, 0, 0, 0.25);\n      padding: 0;\n      color: #7e57c2;\n      cursor: pointer;\n      transition: all 0.3s; }\n      .cs-slider-navigation--prev {\n        left: 1.5rem; }\n      .cs-slider-navigation--next {\n        right: 1.5rem; }\n      .cs-slider-navigation[disabled] {\n        opacity: 0.25;\n        cursor: not-allowed; }\n        .cs-slider-navigation[disabled] svg {\n          filter: grayscale(1); }\n      .cs-slider-navigation:not([disabled]):hover {\n        box-shadow: 1px 1px 10px 0 rgba(0, 0, 0, 0.25); }\n      .cs-slider-navigation__icon {\n        width: 1.4rem;\n        height: 2.7rem;\n        fill: currentColor; } }\n\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n/**\n * Breakpoint component used by include-media vendor library.\n */\n@use 'sass:map';\n/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n/**\n* Default project breakpoints - [em]\n*/\n.cs-slider-pagination {\n  display: flex;\n  flex-wrap: wrap;\n  justify-content: center;\n  align-items: center;\n  gap: 0.8rem;\n  min-height: 3rem; }\n  .cs-slider-pagination--fraction {\n    gap: 0;\n    white-space: pre-wrap;\n    color: inherit;\n    font-weight: 600; }\n    .cs-slider-pagination--fraction span {\n      color: #11a099; }\n  .cs-slider-pagination__bullet {\n    position: relative;\n    border-radius: 2px;\n    background: #fff;\n    border: 0;\n    inline-size: 2.2rem;\n    block-size: 0.9rem;\n    transition: all 0.15s;\n    overflow: hidden;\n    text-indent: -99rem; }\n    .cs-slider-pagination__bullet.current {\n      background-color: #11a099; }\n    .cs-slider-pagination__bullet:only-child {\n      display: none; }\n\n/*\n * Function to get value from a list of values, based on side\n * @param {string} $variable: variable with a list of values (like paddings, margins etc.);\n * @param {string} $side: side (up / right / down / left) for which we want to get value\n * Example:\n * $component_padding: 1rem 2rem 3rem;\n * get-value-from-list($component_padding, 'right') // 2rem\n * get-value-from-list($component_padding, 'bottom') // 3rem\n */\n/* stylelint-disable block-no-empty */\n/* stylelint-enable */\n/**\n * This components is sort of unique because it's items-per-row configuration is only available for tablet+\n * This map adds possibility to 'force' provied columns configuration up to laptop resolutions.\n */\n.cs-image-teaser {\n  --slogan-font-size: 3.8rem;\n  --description-font-size: 1.5rem;\n  --gap: 0.8rem;\n  /*\n     * Keep CTA separated from text-content for all scenarios\n     * \"!important\" added due to fallback from --scheme-* with button() mixin that resets margins\n     */\n  /**\n     * Contrast Optimizers\n     */ }\n  .cs-image-teaser:not(.cs-container--use-whole-width) .cs-image-teaser.cs-image-teaser--container-width .cs-image-teaser__slides-wrapper {\n    max-width: 128rem;\n    margin-left: auto;\n    margin-right: auto; }\n  .cs-image-teaser__slides {\n    --columns: 1;\n    display: grid;\n    gap: var(--gap);\n    grid-template-columns: repeat(var(--columns), minmax(0, 1fr));\n    margin: 0;\n    padding: 0; }\n    .cs-image-teaser--items-in-row-mobile-2 .cs-image-teaser__slides {\n      --columns: 2; }\n  .cs-image-teaser__slide {\n    display: inline-block;\n    margin: 0; }\n  .cs-image-teaser__link {\n    outline-offset: calc(var(--gap) / 2 + 2); }\n    .cs-image-teaser__link:focus {\n      outline-offset: 0.4rem; }\n    @media (prefers-reduced-motion: no-preference) {\n      .cs-image-teaser__link {\n        transition: outline-offset 0.25s ease; } }\n  .cs-image-teaser__picture {\n    display: block;\n    user-select: none;\n    overflow: hidden;\n    width: 100%;\n    height: auto;\n    /* stylelint-disable -- stylelint doesn't know this media query yet. */\n    /* stylelint-enable */ }\n    @media (prefers-reduced-data: reduce) {\n      .cs-image-teaser__picture {\n        display: none; } }\n  .cs-image-teaser__image {\n    display: block;\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n    background-color: #f0f0f0; }\n  @media (min-width: 48em) {\n    .cs-image-teaser {\n      --gap: 0.8rem; }\n      .cs-image-teaser--items-in-row-2 .cs-image-teaser__slides {\n        --columns: 2; }\n      .cs-image-teaser--items-in-row-3 .cs-image-teaser__slides {\n        --columns: 3; }\n      .cs-image-teaser--items-in-row-4 .cs-image-teaser__slides {\n        --columns: 4; }\n      .cs-image-teaser--items-in-row-5 .cs-image-teaser__slides {\n        --columns: 5; }\n      .cs-image-teaser--items-in-row-6 .cs-image-teaser__slides {\n        --columns: 6; }\n      .cs-image-teaser--items-in-row-7 .cs-image-teaser__slides {\n        --columns: 7; }\n      .cs-image-teaser--items-in-row-8 .cs-image-teaser__slides {\n        --columns: 8; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n  .cs-image-teaser--items-in-row-4:not(.cs-image-teaser--icon) .cs-image-teaser__slides {\n    --columns: 2; } }\n  .cs-image-teaser--slider {\n    --gap: 0.8rem;\n    --base-size: calc(100% - 0px);\n    --size: var(--base-size);\n    /**\n     * class-based columns config relates to classnames, like '--items-in-row-4'\n     * which are added to elements, depending on the CC Components configuration.\n     */\n    /*  container padding fix  */ }\n    @media (min-width: 81.875em) {\n      .cs-image-teaser--slider.cs-image-teaser--container-width {\n        --base-size: calc(128rem - 0px); }\n      .cs-image-teaser--slider.cs-image-teaser--use-whole-screen:not(.cs-image-teaser--full-width-slider) {\n        --base-size: 100%;\n        max-width: 100%; }\n        .cs-image-teaser--slider.cs-image-teaser--use-whole-screen:not(.cs-image-teaser--full-width-slider) .cs-image-teaser__slides {\n          scroll-snap-type: x proximity;\n          padding-left: calc((100% - 128rem) / 2);\n          padding-right: calc((100% - 128rem) / 2);\n          scroll-padding-left: calc((100% - 128rem) / 2);\n          scroll-padding-right: calc((100% - 128rem) / 2);\n          scroll-margin-left: calc((100vw - 128rem) / 2);\n          scroll-margin-right: calc((100vw - 128rem) / 2); } }\n    @media (hover: hover) and (pointer: fine) and (min-width: 81.875em) {\n      .cs-image-teaser--slider.cs-image-teaser--container-width {\n        --base-size: 128rem; } }\n    @media (min-width: 48em) {\n      .cs-image-teaser--slider {\n        --gap: 0.8rem; } }\n    @media (min-width: 48em) {\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-2 {\n        --size: calc(\n                        var(--base-size) /\n                            2 -\n                            ((1 * var(--gap)) / 2)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-3 {\n        --size: calc(\n                        var(--base-size) /\n                            3 -\n                            ((2 * var(--gap)) / 3)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-4 {\n        --size: calc(\n                        var(--base-size) /\n                            4 -\n                            ((3 * var(--gap)) / 4)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-5 {\n        --size: calc(\n                        var(--base-size) /\n                            5 -\n                            ((4 * var(--gap)) / 5)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-6 {\n        --size: calc(\n                        var(--base-size) /\n                            6 -\n                            ((5 * var(--gap)) / 6)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-7 {\n        --size: calc(\n                        var(--base-size) /\n                            7 -\n                            ((6 * var(--gap)) / 7)\n                    ); }\n      .cs-image-teaser--slider.cs-image-teaser--items-in-row-8 {\n        --size: calc(\n                        var(--base-size) /\n                            8 -\n                            ((7 * var(--gap)) / 8)\n                    ); } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n  .cs-image-teaser--slider.cs-image-teaser--items-in-row-4:not(.cs-image-teaser--icon) {\n    --size: calc(var(--base-size) / 2 - (1 * var(--gap) / 2)); } }\n    @media (max-width: 81.8125em) {\n      .cs-image-teaser--slider.cs-image-teaser--container-width .cs-image-teaser__slides {\n        padding-left: 1.5rem;\n        padding-right: 1.5rem;\n        scroll-padding-left: 1.5rem;\n        scroll-padding-right: 1.5rem; } }\n    @media (prefers-reduced-motion: no-preference) {\n      .cs-image-teaser--slider .cs-image-teaser__slides {\n        scroll-behavior: smooth; } }\n    .cs-image-teaser--slider .cs-image-teaser__slides-wrapper {\n      position: relative; }\n    .cs-image-teaser--slider .cs-image-teaser__slides {\n      margin: 0;\n      padding: 0;\n      list-style: none;\n      display: flex;\n      flex: 0 0 100%;\n      gap: 0;\n      flex-wrap: nowrap;\n      padding: var(--gap) 0;\n      overflow-x: auto;\n      overscroll-behavior-inline: contain;\n      scrollbar-width: thin; }\n      @supports (scroll-behavior: smooth) {\n        .cs-image-teaser--slider .cs-image-teaser__slides {\n          scroll-snap-type: x mandatory; } }\n      @media (min-width: 48em) {\n        .cs-image-teaser--slider .cs-image-teaser__slides {\n          overflow: -moz-scrollbars-none;\n          scrollbar-width: none; }\n          .cs-image-teaser--slider .cs-image-teaser__slides::-webkit-scrollbar {\n            display: none;\n            width: 0;\n            height: 0;\n            background: transparent; }\n          .cs-image-teaser--slider .cs-image-teaser__slides::-webkit-scrollbar-thumb {\n            background: transparent;\n            width: 0;\n            height: 0; } }\n    .cs-image-teaser--slider .cs-image-teaser__slide {\n      margin: 0;\n      padding: 0;\n      list-style: none;\n      display: inline-block;\n      flex: 0 0 var(--size);\n      margin-right: var(--gap);\n      scroll-snap-align: start;\n      min-width: 0; }\n      .cs-image-teaser--slider .cs-image-teaser__slide:last-of-type {\n        margin-right: 0; }\n    .cs-image-teaser--slider .cs-image-teaser__image {\n      display: block; }\n  @media (max-width: 47.99em) {\n    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) {\n      --gap: 0.8rem;\n      --base-size: calc(100% - 0px);\n      --size: var(--base-size); }\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider).cs-image-teaser--container-width {\n        margin-left: -1.5rem;\n        margin-right: -1.5rem; }\n        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider).cs-image-teaser--container-width .cs-image-teaser__slides {\n          padding-left: 1.5rem;\n          padding-right: 1.5rem;\n          scroll-padding-left: 1.5rem;\n          scroll-padding-right: 1.5rem; } }\n  @media (max-width: 47.99em) and (prefers-reduced-motion: no-preference) {\n    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {\n      scroll-behavior: smooth; } }\n  @media (max-width: 47.99em) {\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides-wrapper {\n        position: relative; }\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {\n        margin: 0;\n        padding: 0;\n        list-style: none;\n        display: flex;\n        flex: 0 0 100%;\n        gap: 0;\n        flex-wrap: nowrap;\n        padding: var(--gap) 0;\n        overflow-x: auto;\n        overscroll-behavior-inline: contain;\n        scrollbar-width: thin; }\n        @supports (scroll-behavior: smooth) {\n          .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {\n            scroll-snap-type: x mandatory; } } }\n    @media (max-width: 47.99em) and (min-width: 48em) {\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides {\n        overflow: -moz-scrollbars-none;\n        scrollbar-width: none; }\n        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides::-webkit-scrollbar {\n          display: none;\n          width: 0;\n          height: 0;\n          background: transparent; }\n        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slides::-webkit-scrollbar-thumb {\n          background: transparent;\n          width: 0;\n          height: 0; } }\n  @media (max-width: 47.99em) {\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slide {\n        margin: 0;\n        padding: 0;\n        list-style: none;\n        display: inline-block;\n        flex: 0 0 var(--size);\n        margin-right: var(--gap);\n        scroll-snap-align: start;\n        min-width: 0; }\n        .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__slide:last-of-type {\n          margin-right: 0; }\n      .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__image {\n        display: block; } }\n  @media (min-width: 48em) {\n    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__nav,\n    .cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__pagination {\n      display: none; } }\n  .cs-image-teaser__slide--scheme-light {\n    --scheme-color: #fff;\n    --scheme-background: #212121; }\n  .cs-image-teaser__slide--scheme-dark {\n    --scheme-color: #455a64;\n    --scheme-background: #fff; }\n  .cs-image-teaser__slide:not(.cs-image-teaser__slide--image-uploaded) {\n    background: var(--scheme-background); }\n  @media (max-width: 47.99em) {\n    .cs-image-teaser__slides--mobile_text-image .cs-image-teaser__slide--image-uploaded {\n      order: 1; }\n    .cs-image-teaser__slides--mobile_image-text .cs-image-teaser__slide--image-uploaded {\n      order: -1; } }\n  @media (max-width: 47.99em) {\n    .cs-image-teaser--as-list-mobile .cs-image-teaser__slides {\n      flex-wrap: wrap; }\n    .cs-image-teaser--as-list-mobile .cs-image-teaser__slide {\n      margin: 0 0 0.8rem; }\n    .cs-image-teaser--as-list-mobile .cs-image-teaser__pagination,\n    .cs-image-teaser--as-list-mobile .cs-image-teaser__nav {\n      display: none; } }\n  .cs-image-teaser__link {\n    display: block;\n    height: 100%; }\n    .cs-image-teaser__link, .cs-image-teaser__link:hover, .cs-image-teaser__link:visited, .cs-image-teaser__link:active, .cs-image-teaser__link:focus {\n      text-decoration: none; }\n  .cs-image-teaser__figure {\n    height: 100%;\n    position: relative; }\n  .cs-image-teaser__content-wrapper {\n    color: var(--scheme-color); }\n    .cs-image-teaser__content-wrapper--under {\n      position: relative;\n      z-index: 1;\n      margin: -2rem 2rem 0;\n      padding: 2rem;\n      background-color: var(--scheme-background);\n      text-align: center; }\n    .cs-image-teaser__content-wrapper--over {\n      width: 100%;\n      height: 100%;\n      display: flex;\n      padding: 2rem;\n      overflow: hidden;\n      align-items: flex-start; }\n      .cs-image-teaser__picture + .cs-image-teaser__content-wrapper--over,\n      .cs-image-teaser--teaser-and-text .cs-image-teaser__slide--image-uploaded .cs-image-teaser__content-wrapper--over {\n        position: absolute;\n        top: 0;\n        left: 0; }\n    .cs-image-teaser__content-wrapper--content-align-x-2 {\n      justify-content: center;\n      text-align: center; }\n    .cs-image-teaser__content-wrapper--content-align-x-3 {\n      justify-content: flex-end;\n      text-align: right; }\n    .cs-image-teaser__content-wrapper--content-align-y-2 {\n      align-items: center; }\n    .cs-image-teaser__content-wrapper--content-align-y-3 {\n      align-items: flex-end; }\n  .cs-image-teaser__content {\n    position: relative; }\n  .cs-image-teaser__text-content + .cs-image-teaser__cta {\n    margin-top: 1em !important; }\n  .cs-image-teaser__slogan {\n    margin: 0;\n    line-height: 1.1;\n    font-size: var(--slogan-font-size);\n    font-weight: 900;\n    overflow-wrap: break-word;\n    word-wrap: break-word;\n    word-break: break-word;\n    hyphens: auto; }\n  .cs-image-teaser__description {\n    margin: 1em 0 0;\n    line-height: 1.1;\n    font-size: var(--description-font-size); }\n  .cs-image-teaser__cta {\n    display: none; }\n    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta {\n      display: inline-block;\n      font-size: 1.8rem;\n      font-weight: 700;\n      text-align: center;\n      position: relative;\n      line-height: 1.275em;\n      margin: 0;\n      text-transform: none;\n      padding: 0.75em 1em;\n      box-sizing: border-box;\n      transition: background-color 0.5s, border-color 0.5s, fill 0.5s, color 0.5s;\n      vertical-align: middle;\n      z-index: 5; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active {\n        background-color: #7e57c2 !important; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:before, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:after {\n        content: '';\n        position: absolute;\n        top: -1px;\n        bottom: -1px;\n        right: -1px; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:before {\n        width: 3.4em;\n        border-radius: 0 200px 200px 0;\n        z-index: -1;\n        background: linear-gradient(0deg, transparent 0%, transparent 0%, #4d2c91 0%, #4d2c91 100%); }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:after {\n        width: 3em;\n        min-width: auto;\n        background-color: #4d2c91;\n        transition: width 0.25s linear;\n        z-index: -2;\n        border-radius: 200px; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:after {\n        width: calc(100% + 2px); }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n        margin: 0; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:visited {\n        cursor: pointer;\n        border-radius: 200px;\n        outline-offset: 1px;\n        text-decoration: none;\n        box-shadow: none;\n        border: 1px solid transparent;\n        color: #fff;\n        background-color: #7e57c2; }\n        .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:visited * {\n          color: #fff;\n          fill: #fff; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:not([disabled]), .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus:not([disabled]), .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active:not([disabled]) {\n        box-shadow: none;\n        outline: none;\n        text-decoration: none;\n        border: 1px solid transparent;\n        color: #fff;\n        background-color: #4d2c91; }\n        .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:hover:not([disabled]) *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:focus:not([disabled]) *, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta:active:not([disabled]) * {\n          color: #fff;\n          fill: #fff; }\n      .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta[disabled] {\n        opacity: 0.65;\n        cursor: auto; }\n    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta {\n      display: inline-block;\n      font-size: 1.8rem;\n      font-weight: 700;\n      text-align: center;\n      position: relative;\n      line-height: 1.275em;\n      margin: 0;\n      text-transform: none;\n      padding: 0.75em 1em;\n      box-sizing: border-box;\n      transition: background-color 0.5s, border-color 0.5s, fill 0.5s, color 0.5s;\n      vertical-align: middle;\n      z-index: 5; }\n      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::before, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::after {\n        content: none; }\n      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n        margin: 0; }\n      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:visited {\n        cursor: pointer;\n        border-radius: 200px;\n        outline-offset: 1px;\n        text-decoration: none;\n        box-shadow: none;\n        border: 1px solid #7e57c2;\n        color: #7e57c2;\n        background-color: #fff; }\n        .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:visited * {\n          color: #7e57c2;\n          fill: #7e57c2; }\n      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:hover:not([disabled]), .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:focus:not([disabled]), .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:active:not([disabled]) {\n        box-shadow: none;\n        outline: none;\n        text-decoration: none;\n        border: 1px solid #4d2c91;\n        color: #fff;\n        background-color: #4d2c91; }\n        .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:hover:not([disabled]) *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:focus:not([disabled]) *, .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta:active:not([disabled]) * {\n          color: #fff;\n          fill: #fff; }\n      .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta[disabled] {\n        opacity: 0.65;\n        cursor: auto; }\n    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta-span {\n      margin-top: 0;\n      z-index: 1;\n      font-weight: 700;\n      vertical-align: baseline;\n      display: inline-block;\n      line-height: 1.275em;\n      letter-spacing: normal;\n      padding-left: 0;\n      padding-right: 4em; }\n    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta-span {\n      margin-top: 0;\n      z-index: 1;\n      font-weight: 700;\n      vertical-align: baseline;\n      display: inline-block;\n      line-height: 1.275em;\n      letter-spacing: normal;\n      padding-left: 0;\n      padding-right: 4em; }\n    .cs-image-teaser__slide--scheme-dark .cs-image-teaser__cta-icon {\n      max-width: 1em;\n      max-height: 1.8rem;\n      z-index: 2;\n      height: auto;\n      width: 100%;\n      position: absolute;\n      top: 50%;\n      transform: translate3d(0, -50%, 0);\n      margin-right: 0;\n      right: 1em; }\n    .cs-image-teaser__slide--scheme-light .cs-image-teaser__cta-icon {\n      max-width: 1em;\n      max-height: 1.8rem;\n      z-index: 2;\n      height: auto;\n      width: 100%;\n      position: absolute;\n      top: 50%;\n      transform: translate3d(0, -50%, 0);\n      margin-right: 0;\n      right: 1em; }\n    @media (min-width: 30em) {\n      .cs-image-teaser__cta {\n        display: inline-flex;\n        z-index: 1;\n        margin: 1.2em 0 0;\n        align-items: center;\n        font-size: 1.2rem; }\n        .cs-image-teaser__cta-icon {\n          width: 1.2rem;\n          height: 1.4rem; } }\n  .cs-image-teaser__overlay, .cs-image-teaser__gradient {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%; }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__overlay, .cs-image-teaser__slide--scheme-light .cs-image-teaser__optimizer-container {\n    background-color: #212121; }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__overlay, .cs-image-teaser__slide--scheme-dark .cs-image-teaser__optimizer-container {\n    background-color: #fff; }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(135deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(135deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(45deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-1.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(45deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(180deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(180deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(0deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-2.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(-135deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-1 {\n    background: linear-gradient(-135deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(-90deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-2 {\n    background: linear-gradient(-90deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(-45deg, #212121 0%, rgba(33, 33, 33, 0) 85%); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__gradient--direction-x-3.cs-image-teaser__gradient--direction-y-3 {\n    background: linear-gradient(-45deg, #fff 0%, rgba(255, 255, 255, 0) 85%); }\n  .cs-image-teaser__image--mirror {\n    transform: scaleX(-1); }\n  .cs-image-teaser__content--container {\n    position: relative;\n    z-index: 1;\n    padding: 2em; }\n  .cs-image-teaser__optimizer-container {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%;\n    z-index: -1; }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-0 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-5 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.05); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-10 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.1); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-15 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.15); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-20 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.2); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-25 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.25); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-30 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.3); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-35 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.35); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-40 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.4); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-45 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.45); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-50 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.5); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-55 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.55); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-60 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.6); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-65 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.65); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-70 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.7); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-75 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.75); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-80 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.8); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-85 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.85); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-90 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.9); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-95 {\n    text-shadow: 0 0 2.5rem rgba(255, 255, 255, 0.95); }\n  .cs-image-teaser__slide--scheme-dark .cs-image-teaser__text-content--text-shadow-100 {\n    text-shadow: 0 0 2.5rem white; }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-0 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-5 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.05); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-10 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.1); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-15 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.15); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-20 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.2); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-25 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.25); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-30 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.3); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-35 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.35); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-40 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.4); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-45 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.45); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-50 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.5); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-55 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.55); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-60 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.6); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-65 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.65); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-70 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.7); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-75 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.75); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-80 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.8); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-85 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.85); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-90 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.9); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-95 {\n    text-shadow: 0 0 2.5rem rgba(33, 33, 33, 0.95); }\n  .cs-image-teaser__slide--scheme-light .cs-image-teaser__text-content--text-shadow-100 {\n    text-shadow: 0 0 2.5rem #212121; }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n  .cs-image-teaser--icon {\n    --gap: 0.8rem;\n    --base-size: calc(100% - 0px);\n    --size: var(--base-size); }\n    .cs-image-teaser--icon.cs-image-teaser--container-width {\n      margin-left: -1.5rem;\n      margin-right: -1.5rem; }\n      .cs-image-teaser--icon.cs-image-teaser--container-width .cs-image-teaser__slides {\n        padding-left: 1.5rem;\n        padding-right: 1.5rem;\n        scroll-padding-left: 1.5rem;\n        scroll-padding-right: 1.5rem; } }\n  @media (min-width: 48em) and (max-width: 63.99em) and (prefers-reduced-motion: no-preference) {\n    .cs-image-teaser--icon .cs-image-teaser__slides {\n      scroll-behavior: smooth; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n    .cs-image-teaser--icon .cs-image-teaser__slides-wrapper {\n      position: relative; }\n    .cs-image-teaser--icon .cs-image-teaser__slides {\n      margin: 0;\n      padding: 0;\n      list-style: none;\n      display: flex;\n      flex: 0 0 100%;\n      gap: 0;\n      flex-wrap: nowrap;\n      padding: var(--gap) 0;\n      overflow-x: auto;\n      overscroll-behavior-inline: contain;\n      scrollbar-width: thin; }\n      @supports (scroll-behavior: smooth) {\n        .cs-image-teaser--icon .cs-image-teaser__slides {\n          scroll-snap-type: x mandatory; } } }\n    @media (min-width: 48em) and (max-width: 63.99em) and (min-width: 48em) {\n      .cs-image-teaser--icon .cs-image-teaser__slides {\n        overflow: -moz-scrollbars-none;\n        scrollbar-width: none; }\n        .cs-image-teaser--icon .cs-image-teaser__slides::-webkit-scrollbar {\n          display: none;\n          width: 0;\n          height: 0;\n          background: transparent; }\n        .cs-image-teaser--icon .cs-image-teaser__slides::-webkit-scrollbar-thumb {\n          background: transparent;\n          width: 0;\n          height: 0; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n    .cs-image-teaser--icon .cs-image-teaser__slide {\n      margin: 0;\n      padding: 0;\n      list-style: none;\n      display: inline-block;\n      flex: 0 0 var(--size);\n      margin-right: var(--gap);\n      scroll-snap-align: start;\n      min-width: 0; }\n      .cs-image-teaser--icon .cs-image-teaser__slide:last-of-type {\n        margin-right: 0; }\n    .cs-image-teaser--icon .cs-image-teaser__image {\n      display: block; } }\n\n@media (min-width: 0px) and (max-width: 63.99em) {\n  .cs-image-teaser--icon {\n    --size: calc(\n                    var(--base-size) / 2 - ((\n                                    1 * var(--gap)\n                                ) / 2)\n                ) !important; } }\n\n@media (min-width: 23.125em) and (max-width: 63.99em) {\n  .cs-image-teaser--icon {\n    --size: calc(\n                    var(--base-size) / 2 - ((\n                                    1 * var(--gap)\n                                ) / 2)\n                ) !important; } }\n\n@media (min-width: 30em) and (max-width: 63.99em) {\n  .cs-image-teaser--icon {\n    --size: calc(\n                    var(--base-size) / 2 - ((\n                                    1 * var(--gap)\n                                ) / 2)\n                ) !important; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n  .cs-image-teaser--icon {\n    --size: calc(\n                    var(--base-size) / 3 - ((\n                                    2 * var(--gap)\n                                ) / 3)\n                ) !important; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) and (hover: hover) and (pointer: fine) {\n  .cs-image-teaser--icon.cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__nav {\n    display: block; } }\n\n@media (min-width: 48em) and (max-width: 63.99em) {\n  .cs-image-teaser--icon.cs-image-teaser--slider-mobile:not(.cs-image-teaser--slider) .cs-image-teaser__pagination {\n    display: flex; } }\n  .cs-image-teaser--icon .cs-image-teaser__slogan {\n    --slogan-font-size: 1.6rem; }\n  .cs-image-teaser--icon .cs-image-teaser__description {\n    margin-top: 0.5em; }\n  .cs-image-teaser--icon .cs-image-teaser__cta {\n    display: none; }\n  .cs-image-teaser--icon .cs-image-teaser__content-wrapper--under {\n    margin-top: 0;\n    padding: 1rem; }\n  .cs-image-teaser--icon .cs-image-teaser__content-wrapper--cta-only {\n    display: none; }\n  @media (min-width: 48em) {\n    .cs-image-teaser--mosaic .cs-image-teaser__slides--mosaic-scenario-1 {\n      grid-template-columns: minmax(0, 2fr) minmax(0, 1fr); }\n    .cs-image-teaser--mosaic .cs-image-teaser__slides--mosaic-scenario-2 {\n      grid-template-columns: minmax(0, 1fr) minmax(0, 2fr); } }\n  @media (max-width: 47.99em) {\n    .cs-image-teaser--teaser-and-text .cs-image-teaser__slides {\n      display: flex;\n      flex-wrap: wrap; }\n    .cs-image-teaser--teaser-and-text .cs-image-teaser__slide {\n      flex: 0 0 100%; } }\n\n.cs-container--image-teaser {\n  margin: 0 0 3rem; }\n  @media (min-width: 48em) {\n    .cs-container--image-teaser {\n      margin: 0 0 4rem; } }\n  .cs-container--image-teaser--skip-spacing {\n    margin: 0; }\n\n.cs-container--grid-teaser {\n  margin: 0; }\n\n.cs-container--image-teaser-window-width {\n  padding-left: 0;\n  padding-right: 0; }\n  .cs-container--image-teaser-window-width .cs-container__inner {\n    max-width: 100%; }\n\n.cs-container--image-teaser-slider {\n  padding-left: 0;\n  padding-right: 0; }\n","/**\n * Extracts nested keys from given map.\n * Example: deep-get($some-map, some, nested, keys);\n */\n@function deep-get($map, $keys...) {\n    @each $key in $keys {\n        $map: map-get($map, $key);\n    }\n    @return $map;\n}\n","/***\n * Remove browser's margins, paddings and list style rules\n */\n\n@mixin reset-list-style {\n    margin: 0;\n    padding: 0;\n    list-style: none;\n}\n","/***\n * Hide native browser's scrollbar\n */\n\n@mixin hide-scrollbar {\n    overflow: -moz-scrollbars-none;\n    scrollbar-width: none;\n\n    &::-webkit-scrollbar {\n        display: none;\n        width: 0;\n        height: 0;\n        background: transparent;\n    }\n\n    &::-webkit-scrollbar-thumb {\n        background: transparent;\n        width: 0;\n        height: 0;\n    }\n}\n","@import 'config/variables';\n@import 'components/_slider/navigation/mixin';\n\n.#{$ns}slider-navigation {\n    display: none;\n\n    @media (hover: hover) and (pointer: fine) {\n        @include slider-navigation();\n    }\n}\n","@import 'config/variables';\n@import 'components/_slider/hooks';\n\n$trigger_width: 4.4rem !default;\n$trigger_height: 5.2rem !default;\n$trigger_edge-offset: 1.5rem !default;\n$trigger_border: 0 !default;\n$trigger_radius: $border-radius_base !default;\n$trigger_background: $color_background-200 !default;\n$trigger_shadow: 1px 1px 2px 0 rgba($color_black, 0.25) !default;\n$trigger_shadow--hover: 1px 1px 10px 0 rgba($color_black, 0.25) !default;\n$trigger_color: $color_primary-500 !default; // icon color inherits\n$trigger--disabled-opacity: 0.25 !default;\n$trigger--disabled-grayout: true !default;\n\n$trigger-icon_width: 1.4rem !default;\n$trigger-icon_height: 2.7rem !default;\n\n@mixin slider-navigation() {\n    position: absolute;\n    z-index: 11;\n    top: 50%;\n    transform: translate3d(0, -50%, 0);\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: $trigger_width;\n    height: $trigger_height;\n    border: $trigger_border;\n    border-radius: $trigger_radius;\n    background: $trigger_background;\n    box-shadow: $trigger_shadow;\n    padding: 0;\n    color: $trigger_color;\n    cursor: pointer;\n    transition: all $transition-default-time;\n\n    &--prev {\n        left: $trigger_edge-offset;\n    }\n\n    &--next {\n        right: $trigger_edge-offset;\n    }\n\n    &[disabled] {\n        opacity: $trigger--disabled-opacity;\n        cursor: not-allowed;\n\n        @if ($trigger--disabled-grayout == true) {\n            svg {\n                filter: grayscale(1);\n            }\n        }\n    }\n\n    &:not([disabled]):hover {\n        box-shadow: $trigger_shadow--hover;\n    }\n\n    &__icon {\n        width: $trigger-icon_width;\n        height: $trigger-icon_height;\n        fill: currentColor;\n    }\n\n    @include slider-navigation-hook();\n}\n","@import 'config/variables';\n@import 'components/_slider/pagination/mixin';\n\n.#{$ns}slider-pagination {\n    @include slider-pagination();\n}\n","@import 'config/variables';\n@import 'components/_slider/hooks';\n\n$slider-pagination_bullets-gap: 0.8rem !default;\n$slider-pagination_bullet-border: 0 !default;\n$slider-pagination_bullet-radius: 2px !default;\n$slider-pagination_bullet-bg: $color_white !default;\n$slider-pagination_bullet-bg--current: $color_secondary-500 !default;\n\n$slider-pagination_bullet-width: 2.2rem !default;\n$slider-pagination_bullet-height: 0.9rem !default;\n\n$slider-pagination--fraction_color: inherit !default;\n$slider-pagination--fraction_font-weight: 600 !default;\n$slider-pagination--fraction_current-color: $color_secondary-500 !default;\n\n@mixin slider-pagination() {\n    display: flex;\n    flex-wrap: wrap;\n    justify-content: center;\n    align-items: center;\n    gap: $slider-pagination_bullets-gap;\n    min-height: 3rem;\n\n    &--fraction {\n        gap: 0;\n        white-space: pre-wrap;\n        color: $slider-pagination--fraction_color;\n        font-weight: $slider-pagination--fraction_font-weight;\n\n        span {\n            color: $slider-pagination--fraction_current-color;\n        }\n    }\n\n    &__bullet {\n        position: relative;\n        border-radius: $slider-pagination_bullet-radius;\n        background: $slider-pagination_bullet-bg;\n        border: $slider-pagination_bullet-border;\n        inline-size: $slider-pagination_bullet-width;\n        block-size: $slider-pagination_bullet-height;\n        transition: all 0.15s;\n        overflow: hidden;\n        text-indent: -99rem;\n\n        &.current {\n            background-color: $slider-pagination_bullet-bg--current;\n        }\n\n        &:only-child {\n            display: none;\n        }\n    }\n\n    @include slider-pagination-hook();\n}","/*\n * Function to get value from a list of values, based on side\n * @param {string} $variable: variable with a list of values (like paddings, margins etc.);\n * @param {string} $side: side (up / right / down / left) for which we want to get value\n * Example:\n * $component_padding: 1rem 2rem 3rem;\n * get-value-from-list($component_padding, 'right') // 2rem\n * get-value-from-list($component_padding, 'bottom') // 3rem\n */\n\n@function get-value-from-list($variable, $side) {\n    $length: length($variable);\n\n    @if ($length == 1) {\n        @return nth($variable, 1);\n    } @else if ($length == 2) {\n        @if ($side == 'up') OR ($side == 'down') {\n            @return nth($variable, 1);\n        } @else if ($side == 'left') OR ($side == 'right') {\n            @return nth($variable, 2);\n        }\n    } @else if ($length == 3) {\n        @if ($side == 'left') OR ($side == 'right') {\n            @return nth($variable, 2);\n        } @else if ($side == 'up') {\n            @return nth($variable, 1);\n        } @else if ($side == 'down') {\n            @return nth($variable, 3);\n        }\n    } @else if ($length == 4) {\n        @if ($side == 'up') {\n            @return nth($variable, 1);\n        } @else if ($side == 'right') {\n            @return nth($variable, 2);\n        } @else if ($side == 'down') {\n            @return nth($variable, 3);\n        } @else if ($side == 'left') {\n            @return nth($variable, 4);\n        }\n    }\n}\n","/* stylelint-disable block-no-empty */\n@mixin button-hook($type, $icon_pos) {\n}\n\n@mixin button_span-hook($type, $icon_pos) {\n}\n\n@mixin button_icon-hook($type, $icon_pos) {\n}\n/* stylelint-enable */\n","@import 'config/variables';\n@import 'config/breakpoints';\n@import 'vendors/include-media';\n@import 'utils/component-spacing';\n@import 'etc/view.scss';\n@import 'utils/deep-get/deep-get.scss';\n\n@import 'components/image-teaser/mixins/contrast-optimizers/gradient';\n@import 'components/image-teaser/mixins/contrast-optimizers/text-shadow';\n\n@import 'components/_slider/mixin';\n@import 'components/_slider/navigation/navigation.scss'; // TMP\n@import 'components/_slider/pagination/pagination.scss'; // TMP\n\n@import 'components/button/mixin';\n\n$it_mobile-gap: 0.8rem !default;\n$it_desktop-gap: 0.8rem !default;\n\n$it--slider_mobile-gap: $it_mobile-gap !default;\n$it--slider_desktop-gap: $it_desktop-gap !default;\n\n// \"next-slide-visible\" will work on mobiles and browser-width desktop\n// For container-width desktop it doesn't make sense.\n// Please use 'use_whole_screen' option in etc/view to have next slides visible for content-width\n$it--slider_next-slide-visible: 0px !default; // must be with unit (any kind)\n\n$it_cta-type--light: 'secondary' !default;\n$it_cta-type--dark: 'primary' !default;\n$it_cta-font-size: 1.2rem !default;\n$it_cta-icon-position: 'right' !default;\n$it_cta-icon-width: 1.2rem !default;\n$it_cta-icon-height: 1.4rem !default;\n\n// contrast optimizers\n$it_container-background--light: $color_background-700 !default;\n$it_container-background--dark: $color_background-200 !default;\n$it_gradient-color--light: $color_background-700 !default;\n$it_gradient-color--dark: $color_background-200 !default;\n$it_text-shadow-color--light: $color_background-700 !default;\n$it_text-shadow-color--dark: $color_background-200 !default;\n$it_text-shadow-offset--light: 0 0 2.5rem !default;\n$it_text-shadow-offset--dark: 0 0 2.5rem !default;\n$it_text-shadow-step--light: 5 !default;\n$it_text-shadow-step--dark: 5 !default;\n\n// icon component\n/**\n * This components is sort of unique because it's items-per-row configuration is only available for tablet+\n * This map adds possibility to 'force' provied columns configuration up to laptop resolutions.\n */\n$it--icon_items-in-view-till-laptop: deep-get(\n    $view-xml,\n    vars,\n    MageSuite_ContentConstructorFrontend,\n    icon,\n    js,\n    columnsConfig\n) !default;\n\n.#{$ns}image-teaser {\n    $root: &;\n\n    --slogan-font-size: 3.8rem;\n    --description-font-size: 1.5rem;\n\n    @include it-grid($m-gap: $it_mobile-gap, $d-gap: $it_desktop-gap);\n\n    &--slider {\n        @include slider(\n            $m-gap: $it--slider_mobile-gap,\n            $d-gap: $it--slider_desktop-gap,\n            $next-visible: $it--slider_next-slide-visible,\n            $root: $root\n        );\n    }\n\n    &--slider-mobile:not(#{$root}--slider) {\n        @include media('<tablet') {\n            @include slider-mobile(\n                $m-gap: $it--slider_mobile-gap,\n                $next-visible: $it--slider_next-slide-visible,\n                $root: $root\n            );\n        }\n\n        @include media('>=tablet') {\n            #{$root}__nav,\n            #{$root}__pagination {\n                display: none;\n            }\n        }\n    }\n\n    &__slide {\n        &--scheme-light {\n            --scheme-color: #{$scheme--light_texts-color};\n            --scheme-background: #{$scheme--light_background};\n        }\n\n        &--scheme-dark {\n            --scheme-color: #{$scheme--dark_texts-color};\n            --scheme-background: #{$scheme--dark_background};\n        }\n\n        // teaser & text\n        &:not(#{$root}__slide--image-uploaded) {\n            background: var(--scheme-background);\n        }\n\n        @include media('<tablet') {\n            &--image-uploaded {\n                #{$root}__slides--mobile_text-image & {\n                    order: 1;\n                }\n\n                #{$root}__slides--mobile_image-text & {\n                    order: -1;\n                }\n            }\n        }\n    }\n\n    // Hero in mobile as 'Large Teaser' scenario\n    @include media('<tablet') {\n        &--as-list-mobile {\n            #{$root}__slides {\n                flex-wrap: wrap;\n            }\n\n            #{$root}__slide {\n                margin: 0 0 #{$it--slider_mobile-gap};\n            }\n\n            #{$root}__pagination,\n            #{$root}__nav {\n                display: none;\n            }\n        }\n    }\n\n    &__link {\n        display: block;\n        height: 100%;\n\n        &,\n        &:hover,\n        &:visited,\n        &:active,\n        &:focus {\n            text-decoration: none;\n        }\n    }\n\n    &__figure {\n        height: 100%;\n        position: relative;\n    }\n\n    &__content-wrapper {\n        color: var(--scheme-color);\n\n        &--under {\n            position: relative;\n            z-index: 1;\n            margin: -2rem 2rem 0;\n            padding: 2rem;\n            background-color: var(--scheme-background);\n            text-align: center;\n        }\n\n        &--over {\n            width: 100%;\n            height: 100%;\n            display: flex;\n            padding: 2rem;\n            overflow: hidden;\n            align-items: flex-start;\n\n            #{$root}__picture + &,\n            #{$root}--teaser-and-text #{$root}__slide--image-uploaded & {\n                position: absolute;\n                top: 0;\n                left: 0;\n            }\n        }\n\n        &--content-align-x {\n            &-2 {\n                justify-content: center;\n                text-align: center;\n            }\n\n            &-3 {\n                justify-content: flex-end;\n                text-align: right;\n            }\n        }\n\n        &--content-align-y {\n            &-2 {\n                align-items: center;\n            }\n\n            &-3 {\n                align-items: flex-end;\n            }\n        }\n    }\n\n    &__content {\n        position: relative;\n    }\n\n    /*\n     * Keep CTA separated from text-content for all scenarios\n     * \"!important\" added due to fallback from --scheme-* with button() mixin that resets margins\n     */\n    &__text-content + #{$root}__cta {\n        margin-top: 1em !important;\n    }\n\n    &__slogan {\n        margin: 0;\n        line-height: 1.1;\n        font-size: var(--slogan-font-size);\n        font-weight: 900;\n        overflow-wrap: break-word;\n        word-wrap: break-word;\n        word-break: break-word;\n        hyphens: auto;\n    }\n\n    &__description {\n        margin: 1em 0 0;\n        line-height: 1.1;\n        font-size: var(--description-font-size);\n    }\n\n    &__cta {\n        #{$root}__slide--scheme-dark & {\n            @include button(\n                $type: $it_cta-type--dark,\n                $icon_pos: $it_cta-icon-position\n            );\n        }\n\n        #{$root}__slide--scheme-light & {\n            @include button(\n                $type: $it_cta-type--light,\n                $icon_pos: $it_cta-icon-position\n            );\n        }\n\n        &-span {\n            #{$root}__slide--scheme-dark & {\n                @include button_span(\n                    $type: $it_cta-type--dark,\n                    $icon_pos: $it_cta-icon-position\n                );\n            }\n\n            #{$root}__slide--scheme-light & {\n                @include button_span(\n                    $type: $it_cta-type--light,\n                    $icon_pos: $it_cta-icon-position\n                );\n            }\n        }\n\n        &-icon {\n            #{$root}__slide--scheme-dark & {\n                @include button_icon(\n                    $type: $it_cta-type--dark,\n                    $icon_pos: $it_cta-icon-position\n                );\n            }\n\n            #{$root}__slide--scheme-light & {\n                @include button_icon(\n                    $type: $it_cta-type--light,\n                    $icon_pos: $it_cta-icon-position\n                );\n            }\n        }\n\n        display: none;\n\n        @include media('>=phoneLg') {\n            display: inline-flex;\n            z-index: 1;\n            margin: 1.2em 0 0;\n            align-items: center;\n            font-size: $it_cta-font-size;\n\n            &-icon {\n                width: $it_cta-icon-width;\n                height: $it_cta-icon-height;\n            }\n        }\n    }\n\n    /**\n     * Contrast Optimizers\n     */\n    // common for overlay amnd gradient\n    &__overlay,\n    &__gradient {\n        position: absolute;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 100%;\n    }\n\n    // overlay, container\n    &__overlay,\n    &__optimizer-container {\n        #{$root}__slide--scheme-light & {\n            background-color: $it_container-background--light;\n        }\n\n        #{$root}__slide--scheme-dark & {\n            background-color: $it_container-background--dark;\n        }\n    }\n\n    // gradient\n    &__gradient {\n        @for $x from 1 through 3 {\n            &--direction-x-#{$x} {\n                @for $y from 1 through 3 {\n                    &#{$root}__gradient--direction-y-#{$y} {\n                        #{$root}__slide--scheme-light & {\n                            @include teaser-gradient-overlay(\n                                $x,\n                                $y,\n                                $it_gradient-color--light,\n                                85%\n                            );\n                        }\n\n                        #{$root}__slide--scheme-dark & {\n                            @include teaser-gradient-overlay(\n                                $x,\n                                $y,\n                                $it_gradient-color--dark,\n                                85%\n                            );\n                        }\n                    }\n                }\n            }\n        }\n    }\n\n    // mirror image\n    &__image {\n        &--mirror {\n            transform: scaleX(-1);\n        }\n    }\n\n    // container\n    &__content--container {\n        position: relative;\n        z-index: 1;\n        padding: 2em;\n    }\n\n    &__optimizer-container {\n        position: absolute;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 100%;\n        z-index: -1;\n    }\n\n    // text shadow\n    &__text-content--text-shadow {\n        #{$root}__slide--scheme-dark & {\n            @include optimizer-text-shadow(\n                $color: $it_text-shadow-color--dark,\n                $text-shadow-offset: $it_text-shadow-offset--dark,\n                $step: $it_text-shadow-step--dark\n            );\n        }\n\n        #{$root}__slide--scheme-light & {\n            @include optimizer-text-shadow(\n                $color: $it_text-shadow-color--light,\n                $text-shadow-offset: $it_text-shadow-offset--light,\n                $step: $it_text-shadow-step--light\n            );\n        }\n    }\n\n    // Icon component\n    &--icon {\n        @include media('>=tablet', '<laptop') {\n            @include slider-mobile(\n                $m-gap: $it--slider_mobile-gap,\n                $next-visible: $it--slider_next-slide-visible,\n                $root: $root\n            );\n        }\n\n        @each $breakpoint, $itemsPerRow in $it--icon_items-in-view-till-laptop {\n            @include media('>=#{$breakpoint}', '<laptop') {\n                --size: calc(\n                    var(--base-size) / #{$itemsPerRow} - ((\n                                    #{$itemsPerRow - 1} * var(--gap)\n                                ) / #{$itemsPerRow})\n                ) !important;\n            }\n        }\n\n        @include media('>=tablet', '<laptop') {\n            &#{$root}--slider-mobile:not(#{$root}--slider) {\n                @media (hover: hover) and (pointer: fine) {\n                    #{$root}__nav {\n                        display: block;\n                    }\n                }\n\n                #{$root}__pagination {\n                    display: flex;\n                }\n            }\n        }\n\n        #{$root}__slogan {\n            --slogan-font-size: 1.6rem;\n        }\n\n        #{$root}__description {\n            margin-top: 0.5em;\n        }\n\n        #{$root}__cta {\n            display: none;\n        }\n\n        #{$root}__content-wrapper {\n            &--under {\n                margin-top: 0;\n                padding: 1rem;\n            }\n\n            &--cta-only {\n                display: none;\n            }\n        }\n    }\n\n    // Mosaic component\n    @include media('>=tablet') {\n        &--mosaic {\n            #{$root}__slides--mosaic-scenario {\n                &-1 {\n                    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);\n                }\n\n                &-2 {\n                    grid-template-columns: minmax(0, 1fr) minmax(0, 2fr);\n                }\n            }\n        }\n    }\n\n    // Teaser & Text component\n    @include media('<tablet') {\n        &--teaser-and-text {\n            #{$root}__slides {\n                display: flex;\n                flex-wrap: wrap;\n            }\n\n            #{$root}__slide {\n                flex: 0 0 100%;\n            }\n        }\n    }\n}\n\n.#{$ns}container--image-teaser {\n    @include component-spacing();\n}\n\n.#{$ns}container--grid-teaser {\n    margin: 0;\n}\n\n.#{$ns}container--image-teaser-window-width {\n    padding-left: 0;\n    padding-right: 0;\n\n    .#{$ns}container__inner {\n        max-width: 100%;\n    }\n}\n\n.#{$ns}container--image-teaser-slider {\n    padding-left: 0;\n    padding-right: 0;\n}\n","@import 'config/variables';\n@import 'utils/reset-list-style';\n@import 'utils/strip-unit';\n@import 'utils/hide-scrollbar';\n@import 'components/_slider/hooks';\n\n// Calculate container breakpoint + 2 * edge gutter and transform to 'em' unit for media query\n$containerBreakpointPx: (\n        strip-unit($page_max-width) + 2 * strip-unit($page_edge-gutter)\n    ) * 10;\n$containerBreakpointEm: $containerBreakpointPx / 16 * 1em;\n$toContainerBreakpointEm: ($containerBreakpointPx - 1) / 16 * 1em;\n\n@mixin it-grid($m-gap: 0.8rem, $d-gap: 0.8rem) {\n    $root: &;\n    --gap: #{$m-gap};\n\n    &:not(.#{$ns}container--use-whole-width) & {\n        &#{$root}--container-width {\n            #{$root}__slides-wrapper {\n                max-width: $page_max-width;\n                margin-left: auto;\n                margin-right: auto;\n            }\n        }\n    }\n\n    &__slides {\n        --columns: 1;\n\n        display: grid;\n        gap: var(--gap);\n        grid-template-columns: repeat(var(--columns), minmax(0, 1fr));\n        margin: 0;\n        padding: 0;\n\n        #{$root}--items-in-row-mobile-2 & {\n            --columns: 2;\n        }\n    }\n\n    &__slide {\n        display: inline-block;\n        margin: 0;\n    }\n\n    &__link {\n        outline-offset: calc(var(--gap) / 2 + 2);\n\n        &:focus {\n            outline-offset: 0.4rem;\n        }\n\n        @media (prefers-reduced-motion: no-preference) {\n            transition: outline-offset 0.25s ease;\n        }\n    }\n\n    &__picture {\n        display: block;\n        user-select: none;\n        overflow: hidden;\n        width: 100%;\n        height: auto;\n\n        /* stylelint-disable -- stylelint doesn't know this media query yet. */\n        @media (prefers-reduced-data: reduce) {\n            display: none;\n        }\n        /* stylelint-enable */\n    }\n\n    &__image {\n        display: block;\n        width: 100%;\n        height: 100%;\n        object-fit: cover;\n        background-color: $color_background-500;\n    }\n\n    @include media('>=tablet') {\n        --gap: #{$d-gap};\n\n        @for $i from 2 through 8 {\n            &--items-in-row-#{$i} #{$root}__slides {\n                --columns: #{$i};\n            }\n        }\n    }\n\n    @include media('>=tablet', '<laptop') {\n        &--items-in-row-4:not(#{$root}--icon) #{$root}__slides {\n            --columns: 2;\n        }\n    }\n\n    @include it-grid-hook($m-gap, $d-gap);\n}\n\n@mixin slider-essentials($root: $root) {\n    #{$root}__slides-wrapper {\n        position: relative;\n    }\n\n    #{$root}__slides {\n        @include reset-list-style();\n\n        display: flex;\n        flex: 0 0 100%;\n        gap: 0;\n        flex-wrap: nowrap;\n        padding: var(--gap) 0;\n        overflow-x: auto;\n        overscroll-behavior-inline: contain;\n        scrollbar-width: thin;\n\n        @supports (scroll-behavior: smooth) {\n            scroll-snap-type: x mandatory;\n        }\n\n        @include media('>=tablet') {\n            @include hide-scrollbar();\n        }\n    }\n\n    #{$root}__slide {\n        @include reset-list-style();\n\n        display: inline-block;\n        flex: 0 0 var(--size);\n        margin-right: var(--gap);\n        scroll-snap-align: start;\n        min-width: 0;\n\n        &:last-of-type {\n            margin-right: 0;\n        }\n    }\n\n    #{$root}__image {\n        display: block;\n    }\n\n    @include slider-essentials-hook($root);\n}\n\n@mixin slider(\n    $columns-config: 'class-based',\n    $m-gap: 0.8rem,\n    $d-gap: 0.8rem,\n    $next-visible: 3.2rem,\n    $root: '&'\n) {\n    --gap: #{$m-gap};\n    --base-size: calc(100% - #{$next-visible});\n\n    @media (min-width: #{$containerBreakpointEm}) {\n        &#{$root}--container-width {\n            --base-size: calc(#{$page_max-width} - #{$next-visible});\n        }\n\n        &#{$root}--use-whole-screen:not(#{$root}--full-width-slider) {\n            --base-size: 100%;\n\n            max-width: 100%;\n\n            #{$root}__slides {\n                scroll-snap-type: x proximity;\n                padding-left: calc((100% - #{$page_max-width}) / 2);\n                padding-right: calc((100% - #{$page_max-width}) / 2);\n                scroll-padding-left: calc((100% - #{$page_max-width}) / 2);\n                scroll-padding-right: calc((100% - #{$page_max-width}) / 2);\n                scroll-margin-left: calc((100vw - #{$page_max-width}) / 2);\n                scroll-margin-right: calc((100vw - #{$page_max-width}) / 2);\n            }\n        }\n    }\n\n    @media (hover: hover) and (pointer: fine) and (min-width: #{$containerBreakpointEm}) {\n        &#{$root}--container-width {\n            --base-size: #{$page_max-width};\n        }\n    }\n\n    --size: var(--base-size);\n\n    @include media('>=tablet') {\n        --gap: #{$d-gap};\n    }\n\n    /**\n     * class-based columns config relates to classnames, like '--items-in-row-4'\n     * which are added to elements, depending on the CC Components configuration.\n     */\n    @if $columns-config == 'class-based' {\n        @include media('>=tablet') {\n            @for $i from 2 through 8 {\n                &#{$root}--items-in-row-#{$i} {\n                    --size: calc(\n                        var(--base-size) /\n                            #{$i} -\n                            ((#{$i - 1} * var(--gap)) / #{$i})\n                    );\n                }\n            }\n        }\n\n        @include media('>=tablet', '<laptop') {\n            &#{$root}--items-in-row-4:not(#{$root}--icon) {\n                --size: calc(var(--base-size) / 2 - (1 * var(--gap) / 2));\n            }\n        }\n    } @else {\n        $baseItemsPerRow: map-get($columns-config, 'phone');\n        --size: calc(\n            var(--base-size) /\n                #{$baseItemsPerRow} -\n                #{$baseItemsPerRow -\n                1} *\n                var(--gap) /\n                #{$baseItemsPerRow}\n        );\n\n        @each $breakpoint, $itemsPerRow in $columns-config {\n            @include media('>=#{$breakpoint}') {\n                --size: calc(\n                    var(--base-size) / #{$itemsPerRow} - ((\n                                    #{$itemsPerRow - 1} * var(--gap)\n                                ) / #{$itemsPerRow})\n                );\n            }\n        }\n    }\n\n    /*  container padding fix  */\n    @media (max-width: #{$toContainerBreakpointEm}) {\n        &#{$root}--container-width {\n            #{$root}__slides {\n                padding-left: $page_edge-gutter;\n                padding-right: $page_edge-gutter;\n                scroll-padding-left: $page_edge-gutter;\n                scroll-padding-right: $page_edge-gutter;\n            }\n        }\n    }\n\n    @media (prefers-reduced-motion: no-preference) {\n        #{$root}__slides {\n            scroll-behavior: smooth;\n        }\n    }\n\n    @include slider-essentials($root);\n\n    @include slider-hook($columns-config, $m-gap, $d-gap, $next-visible, $root);\n}\n\n@mixin slider-mobile($m-gap: 0.8rem, $next-visible: 3.2rem, $root: '&') {\n    --gap: #{$m-gap};\n    --base-size: calc(100% - #{$next-visible});\n    --size: var(--base-size);\n\n    &#{$root}--container-width {\n        margin-left: -#{$page_edge-gutter};\n        margin-right: -#{$page_edge-gutter};\n\n        #{$root}__slides {\n            padding-left: $page_edge-gutter;\n            padding-right: $page_edge-gutter;\n            scroll-padding-left: $page_edge-gutter;\n            scroll-padding-right: $page_edge-gutter;\n        }\n    }\n\n    @media (prefers-reduced-motion: no-preference) {\n        #{$root}__slides {\n            scroll-behavior: smooth;\n        }\n    }\n\n    @include slider-essentials($root);\n\n    @include slider-mobile-hook($m-gap, $next-visible, $root);\n}\n","@charset \"UTF-8\";\n\n//     _            _           _                           _ _\n//    (_)          | |         | |                         | (_)\n//     _ _ __   ___| |_   _  __| | ___   _ __ ___   ___  __| |_  __ _\n//    | | '_ \\ / __| | | | |/ _` |/ _ \\ | '_ ` _ \\ / _ \\/ _` | |/ _` |\n//    | | | | | (__| | |_| | (_| |  __/ | | | | | |  __/ (_| | | (_| |\n//    |_|_| |_|\\___|_|\\__,_|\\__,_|\\___| |_| |_| |_|\\___|\\__,_|_|\\__,_|\n//\n//      Simple, elegant and maintainable media queries in Sass\n//                        v1.4.9\n//\n//        https://eduardoboucas.github.io/include-media\n//\n//         Authors: Eduardo Boucas (@eduardoboucas)\n//                  Kitty Giraudel (@kittygiraudel)\n//\n//      This project is licensed under the terms of the MIT license\n////\n/// include-media library public configuration\n/// @author Eduardo Boucas\n/// @access public\n////\n\n\n///\n/// Creates a list of global breakpoints\n///\n/// @example scss - Creates a single breakpoint with the label `phone`\n///  $breakpoints: ('phone': 320px);\n///\n$breakpoints: (\n  'phone': 320px,\n  'tablet': 768px,\n  'desktop': 1024px\n) !default;\n\n\n///\n/// Creates a list of static expressions or media types\n///\n/// @example scss - Creates a single media type (screen)\n///  $media-expressions: ('screen': 'screen');\n///\n/// @example scss - Creates a static expression with logical disjunction (OR operator)\n///  $media-expressions: (\n///    'retina2x': '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi)'\n///  );\n///\n$media-expressions: (\n  'screen': 'screen',\n  'print': 'print',\n  'handheld': 'handheld',\n  'landscape': '(orientation: landscape)',\n  'portrait': '(orientation: portrait)',\n  'retina2x': '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi), (min-resolution: 2dppx)',\n  'retina3x': '(-webkit-min-device-pixel-ratio: 3), (min-resolution: 350dpi), (min-resolution: 3dppx)'\n) !default;\n\n\n///\n/// Defines a number to be added or subtracted from each unit when declaring breakpoints with exclusive intervals\n///\n/// @example scss - Interval for pixels is defined as `1` by default\n///  @include media('>128px') {}\n///\n///  /* Generates: */\n///  @media (min-width: 129px) {}\n///\n/// @example scss - Interval for ems is defined as `0.01` by default\n///  @include media('>20em') {}\n///\n///  /* Generates: */\n///  @media (min-width: 20.01em) {}\n///\n/// @example scss - Interval for rems is defined as `0.1` by default, to be used with `font-size: 62.5%;`\n///  @include media('>2.0rem') {}\n///\n///  /* Generates: */\n///  @media (min-width: 2.1rem) {}\n///\n$unit-intervals: (\n  'px': 1,\n  'em': 0.01,\n  'rem': 0.1,\n  '': 0\n) !default;\n\n///\n/// Defines whether support for media queries is available, useful for creating separate stylesheets\n/// for browsers that don't support media queries.\n///\n/// @example scss - Disables support for media queries\n///  $im-media-support: false;\n///  @include media('>=tablet') {\n///    .foo {\n///      color: tomato;\n///    }\n///  }\n///\n///  /* Generates: */\n///  .foo {\n///    color: tomato;\n///  }\n///\n$im-media-support: true !default;\n\n///\n/// Selects which breakpoint to emulate when support for media queries is disabled. Media queries that start at or\n/// intercept the breakpoint will be displayed, any others will be ignored.\n///\n/// @example scss - This media query will show because it intercepts the static breakpoint\n///  $im-media-support: false;\n///  $im-no-media-breakpoint: 'desktop';\n///  @include media('>=tablet') {\n///    .foo {\n///      color: tomato;\n///    }\n///  }\n///\n///  /* Generates: */\n///  .foo {\n///    color: tomato;\n///  }\n///\n/// @example scss - This media query will NOT show because it does not intercept the desktop breakpoint\n///  $im-media-support: false;\n///  $im-no-media-breakpoint: 'tablet';\n///  @include media('>=desktop') {\n///    .foo {\n///      color: tomato;\n///    }\n///  }\n///\n///  /* No output */\n///\n$im-no-media-breakpoint: 'desktop' !default;\n\n///\n/// Selects which media expressions are allowed in an expression for it to be used when media queries\n/// are not supported.\n///\n/// @example scss - This media query will show because it intercepts the static breakpoint and contains only accepted media expressions\n///  $im-media-support: false;\n///  $im-no-media-breakpoint: 'desktop';\n///  $im-no-media-expressions: ('screen');\n///  @include media('>=tablet', 'screen') {\n///    .foo {\n///      color: tomato;\n///    }\n///  }\n///\n///   /* Generates: */\n///   .foo {\n///     color: tomato;\n///   }\n///\n/// @example scss - This media query will NOT show because it intercepts the static breakpoint but contains a media expression that is not accepted\n///  $im-media-support: false;\n///  $im-no-media-breakpoint: 'desktop';\n///  $im-no-media-expressions: ('screen');\n///  @include media('>=tablet', 'retina2x') {\n///    .foo {\n///      color: tomato;\n///    }\n///  }\n///\n///  /* No output */\n///\n$im-no-media-expressions: ('screen', 'portrait', 'landscape') !default;\n\n////\n/// Cross-engine logging engine\n/// @author Kitty Giraudel\n/// @access private\n////\n\n\n///\n/// Log a message either with `@error` if supported\n/// else with `@warn`, using `feature-exists('at-error')`\n/// to detect support.\n///\n/// @param {String} $message - Message to log\n///\n@function im-log($message) {\n  @if feature-exists('at-error') {\n    @error $message;\n  } @else {\n    @warn $message;\n    $_: noop();\n  }\n\n  @return $message;\n}\n\n\n///\n/// Wrapper mixin for the log function so it can be used with a more friendly\n/// API than `@if im-log('..') {}` or `$_: im-log('..')`. Basically, use the function\n/// within functions because it is not possible to include a mixin in a function\n/// and use the mixin everywhere else because it's much more elegant.\n///\n/// @param {String} $message - Message to log\n///\n@mixin log($message) {\n  @if im-log($message) {}\n}\n\n\n///\n/// Function with no `@return` called next to `@warn` in Sass 3.3\n/// to trigger a compiling error and stop the process.\n///\n@function noop() {}\n\n///\n/// Determines whether a list of conditions is intercepted by the static breakpoint.\n///\n/// @param {Arglist}   $conditions  - Media query conditions\n///\n/// @return {Boolean} - Returns true if the conditions are intercepted by the static breakpoint\n///\n@function im-intercepts-static-breakpoint($conditions...) {\n  $no-media-breakpoint-value: map-get($breakpoints, $im-no-media-breakpoint);\n\n  @if not $no-media-breakpoint-value {\n    @if im-log('`#{$im-no-media-breakpoint}` is not a valid breakpoint.') {}\n  }\n\n  @each $condition in $conditions {\n    @if not map-has-key($media-expressions, $condition) {\n      $operator: get-expression-operator($condition);\n      $prefix: get-expression-prefix($operator);\n      $value: get-expression-value($condition, $operator);\n\n      @if ($prefix == 'max' and $value <= $no-media-breakpoint-value) or\n          ($prefix == 'min' and $value > $no-media-breakpoint-value) {\n        @return false;\n      }\n    } @else if not index($im-no-media-expressions, $condition) {\n      @return false;\n    }\n  }\n\n  @return true;\n}\n\n////\n/// Parsing engine\n/// @author Kitty Giraudel\n/// @access private\n////\n\n\n///\n/// Get operator of an expression\n///\n/// @param {String} $expression - Expression to extract operator from\n///\n/// @return {String} - Any of `>=`, `>`, `<=`, `<`, `≥`, `≤`\n///\n@function get-expression-operator($expression) {\n  @each $operator in ('>=', '>', '<=', '<', '≥', '≤') {\n    @if str-index($expression, $operator) {\n      @return $operator;\n    }\n  }\n\n  // It is not possible to include a mixin inside a function, so we have to\n  // rely on the `im-log(..)` function rather than the `log(..)` mixin. Because\n  // functions cannot be called anywhere in Sass, we need to hack the call in\n  // a dummy variable, such as `$_`. If anybody ever raise a scoping issue with\n  // Sass 3.3, change this line in `@if im-log(..) {}` instead.\n  $_: im-log('No operator found in `#{$expression}`.');\n}\n\n\n///\n/// Get dimension of an expression, based on a found operator\n///\n/// @param {String} $expression - Expression to extract dimension from\n/// @param {String} $operator - Operator from `$expression`\n///\n/// @return {String} - `width` or `height` (or potentially anything else)\n///\n@function get-expression-dimension($expression, $operator) {\n  $operator-index: str-index($expression, $operator);\n  $parsed-dimension: str-slice($expression, 0, $operator-index - 1);\n  $dimension: 'width';\n\n  @if str-length($parsed-dimension) > 0 {\n    $dimension: $parsed-dimension;\n  }\n\n  @return $dimension;\n}\n\n\n///\n/// Get dimension prefix based on an operator\n///\n/// @param {String} $operator - Operator\n///\n/// @return {String} - `min` or `max`\n///\n@function get-expression-prefix($operator) {\n  @return if(index(('<', '<=', '≤'), $operator), 'max', 'min');\n}\n\n\n///\n/// Get value of an expression, based on a found operator\n///\n/// @param {String} $expression - Expression to extract value from\n/// @param {String} $operator - Operator from `$expression`\n///\n/// @return {Number} - A numeric value\n///\n@function get-expression-value($expression, $operator) {\n  $operator-index: str-index($expression, $operator);\n  $value: str-slice($expression, $operator-index + str-length($operator));\n\n  @if map-has-key($breakpoints, $value) {\n    $value: map-get($breakpoints, $value);\n  } @else {\n    $value: to-number($value);\n  }\n\n  $interval: map-get($unit-intervals, unit($value));\n\n  @if not $interval {\n    // It is not possible to include a mixin inside a function, so we have to\n    // rely on the `im-log(..)` function rather than the `log(..)` mixin. Because\n    // functions cannot be called anywhere in Sass, we need to hack the call in\n    // a dummy variable, such as `$_`. If anybody ever raise a scoping issue with\n    // Sass 3.3, change this line in `@if im-log(..) {}` instead.\n    $_: im-log('Unknown unit `#{unit($value)}`.');\n  }\n\n  @if $operator == '>' {\n    $value: $value + $interval;\n  } @else if $operator == '<' {\n    $value: $value - $interval;\n  }\n\n  @return $value;\n}\n\n\n///\n/// Parse an expression to return a valid media-query expression\n///\n/// @param {String} $expression - Expression to parse\n///\n/// @return {String} - Valid media query\n///\n@function parse-expression($expression) {\n  // If it is part of $media-expressions, it has no operator\n  // then there is no need to go any further, just return the value\n  @if map-has-key($media-expressions, $expression) {\n    @return map-get($media-expressions, $expression);\n  }\n\n  $operator: get-expression-operator($expression);\n  $dimension: get-expression-dimension($expression, $operator);\n  $prefix: get-expression-prefix($operator);\n  $value: get-expression-value($expression, $operator);\n\n  @return '(#{$prefix}-#{$dimension}: #{$value})';\n}\n\n///\n/// Slice `$list` between `$start` and `$end` indexes\n///\n/// @access private\n///\n/// @param {List} $list - List to slice\n/// @param {Number} $start [1] - Start index\n/// @param {Number} $end [length($list)] - End index\n///\n/// @return {List} Sliced list\n///\n@function slice($list, $start: 1, $end: length($list)) {\n  @if length($list) < 1 or $start > $end {\n    @return ();\n  }\n\n  $result: ();\n\n  @for $i from $start through $end {\n    $result: append($result, nth($list, $i));\n  }\n\n  @return $result;\n}\n\n////\n/// String to number converter\n/// @author Kitty Giraudel\n/// @access private\n////\n\n\n///\n/// Casts a string into a number\n///\n/// @param {String | Number} $value - Value to be parsed\n///\n/// @return {Number}\n///\n@function to-number($value) {\n  @if type-of($value) == 'number' {\n    @return $value;\n  } @else if type-of($value) != 'string' {\n    $_: im-log('Value for `to-number` should be a number or a string.');\n  }\n\n  $first-character: str-slice($value, 1, 1);\n  $result: 0;\n  $digits: 0;\n  $minus: ($first-character == '-');\n  $numbers: ('0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9);\n\n  // Remove +/- sign if present at first character\n  @if ($first-character == '+' or $first-character == '-') {\n    $value: str-slice($value, 2);\n  }\n\n  @for $i from 1 through str-length($value) {\n    $character: str-slice($value, $i, $i);\n\n    @if not (index(map-keys($numbers), $character) or $character == '.') {\n      @return to-length(if($minus, -$result, $result), str-slice($value, $i))\n    }\n\n    @if $character == '.' {\n      $digits: 1;\n    } @else if $digits == 0 {\n      $result: $result * 10 + map-get($numbers, $character);\n    } @else {\n      $digits: $digits * 10;\n      $result: $result + map-get($numbers, $character) / $digits;\n    }\n  }\n\n  @return if($minus, -$result, $result);\n}\n\n\n///\n/// Add `$unit` to `$value`\n///\n/// @param {Number} $value - Value to add unit to\n/// @param {String} $unit - String representation of the unit\n///\n/// @return {Number} - `$value` expressed in `$unit`\n///\n@function to-length($value, $unit) {\n  $units: ('px': 1px, 'cm': 1cm, 'mm': 1mm, '%': 1%, 'ch': 1ch, 'pc': 1pc, 'in': 1in, 'em': 1em, 'rem': 1rem, 'pt': 1pt, 'ex': 1ex, 'vw': 1vw, 'vh': 1vh, 'vmin': 1vmin, 'vmax': 1vmax);\n\n  @if not index(map-keys($units), $unit) {\n    $_: im-log('Invalid unit `#{$unit}`.');\n  }\n\n  @return $value * map-get($units, $unit);\n}\n\n///\n/// This mixin aims at redefining the configuration just for the scope of\n/// the call. It is helpful when having a component needing an extended\n/// configuration such as custom breakpoints (referred to as tweakpoints)\n/// for instance.\n///\n/// @author Kitty Giraudel\n///\n/// @param {Map} $tweakpoints [()] - Map of tweakpoints to be merged with `$breakpoints`\n/// @param {Map} $tweak-media-expressions [()] - Map of tweaked media expressions to be merged with `$media-expression`\n///\n/// @example scss - Extend the global breakpoints with a tweakpoint\n///  @include media-context(('custom': 678px)) {\n///    .foo {\n///      @include media('>phone', '<=custom') {\n///       // ...\n///      }\n///    }\n///  }\n///\n/// @example scss - Extend the global media expressions with a custom one\n///  @include media-context($tweak-media-expressions: ('all': 'all')) {\n///    .foo {\n///      @include media('all', '>phone') {\n///       // ...\n///      }\n///    }\n///  }\n///\n/// @example scss - Extend both configuration maps\n///  @include media-context(('custom': 678px), ('all': 'all')) {\n///    .foo {\n///      @include media('all', '>phone', '<=custom') {\n///       // ...\n///      }\n///    }\n///  }\n///\n@mixin media-context($tweakpoints: (), $tweak-media-expressions: ()) {\n  // Save global configuration\n  $global-breakpoints: $breakpoints;\n  $global-media-expressions: $media-expressions;\n\n  // Update global configuration\n  $breakpoints: map-merge($breakpoints, $tweakpoints) !global;\n  $media-expressions: map-merge($media-expressions, $tweak-media-expressions) !global;\n\n  @content;\n\n  // Restore global configuration\n  $breakpoints: $global-breakpoints !global;\n  $media-expressions: $global-media-expressions !global;\n}\n\n////\n/// include-media public exposed API\n/// @author Eduardo Boucas\n/// @access public\n////\n\n\n///\n/// Generates a media query based on a list of conditions\n///\n/// @param {Arglist}   $conditions  - Media query conditions\n///\n/// @example scss - With a single set breakpoint\n///  @include media('>phone') { }\n///\n/// @example scss - With two set breakpoints\n///  @include media('>phone', '<=tablet') { }\n///\n/// @example scss - With custom values\n///  @include media('>=358px', '<850px') { }\n///\n/// @example scss - With set breakpoints with custom values\n///  @include media('>desktop', '<=1350px') { }\n///\n/// @example scss - With a static expression\n///  @include media('retina2x') { }\n///\n/// @example scss - Mixing everything\n///  @include media('>=350px', '<tablet', 'retina3x') { }\n///\n@mixin media($conditions...) {\n  @if ($im-media-support and length($conditions) == 0) or\n      (not $im-media-support and im-intercepts-static-breakpoint($conditions...)) {\n    @content;\n  } @else if ($im-media-support and length($conditions) > 0) {\n    @media #{unquote(parse-expression(nth($conditions, 1)))} {\n      // Recursive call\n      @include media(slice($conditions, 2)...) {\n        @content;\n      }\n    }\n  }\n}\n","@import 'utils/get-value-from-list';\n@import 'components/button/animation';\n@import 'components/button/hook';\n\n// Define default type for buttons. You can override it individually per button in each component\n// Variants: primary | secondary | link | success | error\n$button_default-type: 'primary' !default;\n\n// Define default position for icons in button. You can override it individually per button in each component\n// Variants: left | right | no-icon | only-icon\n$button_default-icon-pos: 'right' !default;\n\n// General styles for buttons\n$button_font-size: 1.8rem !default;\n$button_font-weight: 700 !default;\n$button_border-size: 1px !default;\n$button_padding: 0.75em 1em !default;\n$button_padding-when-icon: 3em !default;\n$button_line-height: 1.275em !default;\n$button_border-radius: 200px !default;\n$button_animation-time: 0.5s !default;\n$button_animation-before-width: 3.4em !default;\n$button_animation-after-width: 3em !default;\n$button_text-transform: none !default;\n$button_text-letter-spacing: normal !default;\n$button_text-align: center !default;\n\n// Styles for `primary` button type\n$button_primary-border: $button_border-size solid transparent !default;\n$button_primary--hover-border: $button_border-size solid transparent !default;\n$button_primary-background: $color_primary-500 !default;\n$button_primary--hover-background: $color_primary-800 !default;\n$button_primary-color: $color_text-200 !default;\n$button_primary--hover-color: $color_text-200 !default;\n$button_primary-fill: $color_text-200 !default;\n$button_primary--hover-fill: $color_text-200 !default;\n$button_primary-enable-animation: true !default;\n\n// Styles for `secondary` button type\n$button_secondary-border: $button_border-size solid $color_primary-500 !default;\n$button_secondary--hover-border: $button_border-size solid $color_primary-800 !default;\n$button_secondary-background: $color_white !default;\n$button_secondary--hover-background: $color_primary-800 !default;\n$button_secondary-color: $color_primary-500 !default;\n$button_secondary--hover-color: $color_text-200 !default;\n$button_secondary-fill: $color_primary-500 !default;\n$button_secondary--hover-fill: $color_text-200 !default;\n$button_secondary-enable-animation: false !default;\n\n// Style for `link` button type\n$button_link-color: $color_primary-500 !default;\n$button_link--hover-color: $color_primary-800 !default;\n$button_link-icon-padding: 2rem !default;\n\n// Styles for `success` button type\n$button_success-border: $button_border-size solid transparent !default;\n$button_success--hover-border: $button_border-size solid transparent !default;\n$button_success-background: $color_success-500 !default;\n$button_success--hover-background: $color_success-600 !default;\n$button_success-color: $color_text-200 !default;\n$button_success--hover-color: $color_text-200 !default;\n$button_success-fill: $color_text-200 !default;\n$button_success--hover-fill: $color_text-200 !default;\n$button_success-enable-animation: false !default;\n\n// Styles for `error` button type\n$button_error-border: $button_border-size solid transparent !default;\n$button_error--hover-border: $button_border-size solid transparent !default;\n$button_error-background: $color_error-500 !default;\n$button_error--hover-background: $color_error-600 !default;\n$button_error-color: $color_text-200 !default;\n$button_error--hover-color: $color_text-200 !default;\n$button_error-fill: $color_text-200 !default;\n$button_error--hover-fill: $color_text-200 !default;\n$button_error-enable-animation: false !default;\n\n// Defines how much button icon should be pulled vertically to center it.\n// Should be defined in em to make it relative to button's font size.\n$button_span-font-offset: 0 !default;\n\n// Defines how much button icon should be pulled vertically to center it on icon button.\n// Should be defined in em to make it relative to button's font size.\n$button_icon-offset: 0.1em !default;\n\n// stylelint-disable function-calc-no-unspaced-operator\n\n@mixin button($type: $button_default-type,\n    $icon_pos: $button_default-icon-pos) {\n    display: inline-block;\n    font-size: $button_font-size;\n    font-weight: $button_font-weight;\n    text-align: $button_text-align;\n    position: relative;\n    line-height: $button_line-height;\n    margin: 0;\n    text-transform: $button_text-transform;\n\n    @if ($type !='link') {\n        padding: $button_padding;\n        box-sizing: border-box;\n        transition: background-color $button_animation-time,\n            border-color $button_animation-time, fill $button_animation-time,\n            color $button_animation-time;\n        vertical-align: middle;\n        z-index: 5;\n    }\n\n    @if ($type =='primary') {\n        @if ($button_primary-enable-animation) {\n            @include button_animation($type: 'primary',\n                $color_start: $button_primary-background,\n                $color_end: $button_primary--hover-background,\n                $icon_pos: $icon_pos );\n        }\n\n        @else {\n            @if ($icon_pos =='right') or ($icon_pos =='left') {\n\n                &::before,\n                &::after {\n                    content: none;\n                }\n            }\n        }\n    }\n\n    @if ($type =='secondary') {\n        @if ($button_secondary-enable-animation) {\n            @include button_animation($type: 'secondary',\n                $color_start: $button_secondary-background,\n                $color_end: $button_secondary--hover-background,\n                $icon_pos: $icon_pos );\n        }\n\n        @else {\n            @if ($icon_pos =='right') or ($icon_pos =='left') {\n\n                &::before,\n                &::after {\n                    content: none;\n                }\n            }\n        }\n    }\n\n    @if ($type =='link') {\n        transition: color $button_animation-time, fill $button_animation-time;\n\n        * {\n            transition: color $button_animation-time,\n                fill $button_animation-time;\n        }\n    }\n\n    @if ($type =='success') {\n        @if ($button_success-enable-animation) {\n            @include button_animation($type: 'success',\n                $color_start: $button_success-background,\n                $color_end: $button_success--hover-background,\n                $icon_pos: $icon_pos );\n        }\n    }\n\n    @if ($type =='error') {\n        @if ($button_error-enable-animation) {\n            @include button_animation($type: 'error',\n                $color_start: $button_error-background,\n                $color_end: $button_error--hover-background,\n                $icon_pos: $icon_pos );\n        }\n    }\n\n    // stylelint-disable no-descending-specificity\n    &::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n        margin: 0;\n    }\n\n    &,\n    &:visited {\n        @if ($type !='link') {\n            cursor: pointer;\n            border-radius: $button_border-radius;\n            outline-offset: 1px;\n            text-decoration: none;\n            box-shadow: none;\n        }\n\n        @if ($type =='primary') {\n            border: $button_primary-border;\n            color: $button_primary-color;\n            background-color: $button_primary-background;\n\n            * {\n                color: $button_primary-color;\n                fill: $button_primary-fill;\n            }\n        }\n\n        @if ($type =='secondary') {\n            border: $button_secondary-border;\n            color: $button_secondary-color;\n            background-color: $button_secondary-background;\n\n            * {\n                color: $button_secondary-color;\n                fill: $button_secondary-fill;\n            }\n        }\n\n        @if ($type =='link') {\n            color: $button_link-color;\n\n            * {\n                color: $button_link-color;\n                fill: $button_link-color;\n            }\n        }\n\n        @if ($type =='success') {\n            border: $button_success-border;\n            color: $button_success-color;\n            background-color: $button_success-background;\n\n            * {\n                color: $button_success-color;\n                fill: $button_success-fill;\n            }\n        }\n\n        @if ($type =='error') {\n            border: $button_error-border;\n            color: $button_error-color;\n            background-color: $button_error-background;\n\n            * {\n                color: $button_error-color;\n                fill: $button_error-fill;\n            }\n        }\n    }\n\n    // stylelint-enable no-descending-specificity\n\n    &:hover,\n    &:focus,\n    &:active {\n        &:not([disabled]) {\n            @if ($type !='link') {\n                box-shadow: none;\n                outline: none;\n                text-decoration: none;\n            }\n\n            @if ($type =='primary') {\n                border: $button_primary--hover-border;\n                color: $button_primary--hover-color;\n                background-color: $button_primary--hover-background;\n\n                * {\n                    color: $button_primary--hover-color;\n                    fill: $button_primary--hover-fill;\n                }\n            }\n\n            @if ($type =='secondary') {\n                border: $button_secondary--hover-border;\n                color: $button_secondary--hover-color;\n                background-color: $button_secondary--hover-background;\n\n                * {\n                    color: $button_secondary--hover-color;\n                    fill: $button_secondary--hover-fill;\n                }\n            }\n\n            @if ($type =='link') {\n                color: $button_link--hover-color;\n\n                * {\n                    color: $button_link--hover-color;\n                    fill: $button_link--hover-color;\n                }\n            }\n\n            @if ($type =='success') {\n                border: $button_success--hover-border;\n                color: $button_success--hover-color;\n                background-color: $button_success--hover-background;\n\n                * {\n                    color: $button_success--hover-color;\n                    fill: $button_success--hover-fill;\n                }\n            }\n\n            @if ($type =='error') {\n                border: $button_error--hover-border;\n                color: $button_error--hover-color;\n                background-color: $button_error--hover-background;\n\n                * {\n                    color: $button_error--hover-color;\n                    fill: $button_error--hover-fill;\n                }\n            }\n        }\n    }\n\n    &[disabled] {\n        opacity: 0.65;\n        cursor: auto;\n    }\n\n    @include button-hook($type, $icon_pos);\n}\n\n@mixin button_span($type: $button_default-type,\n    $icon_pos: $button_default-icon-pos) {\n    margin-top: $button_span-font-offset;\n    z-index: 1;\n    font-weight: $button_font-weight;\n    vertical-align: baseline;\n    display: inline-block;\n    line-height: $button_line-height;\n    letter-spacing: $button_text-letter-spacing;\n\n    @if ($icon_pos =='right') {\n        padding-left: 0;\n\n        @if ($type =='link') {\n            padding-right: $button_link-icon-padding;\n        }\n\n        @else {\n\n            @if (unit($button_padding-when-icon)==unit(get-value-from-list($variable: $button_padding,\n                        $side: $icon_pos ))) {\n                padding-right: $button_padding-when-icon + get-value-from-list($variable: $button_padding,\n                        $side: $icon_pos );\n            }\n\n            @else {\n                padding-right: calc(#{$button_padding-when-icon} + #{get-value-from-list(\n $variable: $button_padding,\n                    $side: $icon_pos )\n            });\n        }\n    }\n}\n\n@else if ($icon_pos =='left') {\n    padding-right: 0;\n\n    @if ($type =='link') {\n        padding-left: $button_link-icon-padding;\n    }\n\n    @else {\n\n        @if (unit($button_padding-when-icon)==unit(get-value-from-list($variable: $button_padding,\n                    $side: $icon_pos ))) {\n            padding-left: $button_padding-when-icon + get-value-from-list($variable: $button_padding,\n                    $side: $icon_pos );\n        }\n\n        @else {\n            padding-left: calc(#{$button_padding-when-icon} + #{get-value-from-list(\n $variable: $button_padding,\n                $side: $icon_pos )\n        });\n    }\n}\n}\n\n@else if ($icon_pos =='only-icon') {\n    display: none;\n}\n\n@include button_span-hook($type, $icon_pos);\n}\n\n@mixin button_icon($type: $button_default-type,\n    $icon_pos: $button_default-icon-pos) {\n    max-width: 1em;\n    max-height: $button_font-size;\n    z-index: 2;\n    height: auto;\n    width: 100%;\n\n    @if ($icon_pos =='right') or ($icon_pos =='left') {\n        position: absolute;\n        top: 50%;\n        transform: translate3d(0, -50%, 0);\n    }\n\n    @if ($icon_pos =='only-icon') {\n        position: relative;\n        top: $button_icon-offset;\n\n        @if ($type =='link') {\n            margin-left: $button_link-icon-padding / 2;\n            margin-right: $button_link-icon-padding / 2;\n        }\n    }\n\n    @else if ($icon_pos =='right') {\n        @if ($type =='link') {\n            right: 0;\n        }\n\n        @else {\n            margin-right: 0;\n            right: get-value-from-list($variable: $button_padding,\n                    $side: $icon_pos );\n        }\n    }\n\n    @else if ($icon_pos =='left') {\n        @if ($type =='link') {\n            left: 0;\n        }\n\n        @else {\n            margin-left: 0;\n            left: get-value-from-list($variable: $button_padding,\n                    $side: $icon_pos );\n        }\n    }\n\n    @else {\n        display: none;\n    }\n\n    @include button_icon-hook($type, $icon_pos);\n}","// In this mixin you can define your custom animation for buttons\n// You can check examples of animations in http://ianlunn.github.io/Hover/ library\n\n@mixin button_animation(\n    $type: $button_default-type,\n    $color_start: $button_primary-background,\n    $color_end: $button_primary--hover-background,\n    $icon_pos: $button_default-icon-pos\n) {\n    @if ($type == 'primary') and\n        (($icon_pos == 'right') or ($icon_pos == 'left'))\n    {\n        &:hover,\n        &:focus,\n        &:active {\n            background-color: $color_start !important;\n        }\n    }\n\n    &:before,\n    &:after {\n        @if ($icon_pos == 'right') or ($icon_pos == 'left') {\n            content: '';\n            position: absolute;\n            top: -#{$button_border-size};\n            bottom: -#{$button_border-size};\n        }\n\n        @if ($icon_pos == 'right') {\n            right: -#{$button_border-size};\n        }\n\n        @if ($icon_pos == 'left') {\n            left: -#{$button_border-size};\n        }\n    }\n\n    &:before {\n        @if ($icon_pos == 'right') or ($icon_pos == 'left') {\n            width: $button_animation-before-width;\n            border-radius: 0 $button_border-radius $button_border-radius 0;\n            z-index: -1;\n        }\n\n        @if ($icon_pos == 'right') {\n            background: linear-gradient(\n                0deg,\n                transparent 0%,\n                transparent 0%,\n                $color_end 0%,\n                $color_end 100%\n            );\n        }\n\n        @if ($icon_pos == 'left') {\n            background: linear-gradient(\n                0deg,\n                $color_end 0%,\n                $color_end 85%,\n                transparent 100%,\n                transparent 100%\n            );\n        }\n    }\n\n    &:after {\n        @if ($icon_pos == 'right') or ($icon_pos == 'left') {\n            width: $button_animation-after-width;\n            min-width: auto;\n            background-color: $color_end;\n            transition: width 0.25s linear;\n            z-index: -2;\n            border-radius: $button_border-radius;\n        }\n    }\n\n    &:hover {\n        @if ($icon_pos == 'right') or ($icon_pos == 'left') {\n            &:after {\n                @if ($button_border-size > 0) {\n                    width: calc(100% + #{2 * $button_border-size});\n                } @else {\n                    width: 100%;\n                }\n            }\n        }\n    }\n}\n","@import 'config/variables';\n@import 'components/image-teaser/functions/get-gradient-angle';\n\n@mixin teaser-gradient-overlay(\n    $x: 1,\n    $y: 1,\n    $color: $color_background-700,\n    $gradient-range: 85%\n) {\n    background: linear-gradient(\n        get-gradient-angle($x, $y),\n        $color 0%,\n        rgba($color, 0) $gradient-range\n    );\n}\n","@mixin optimizer-text-shadow(\n    $color: $color_background-200,\n    $text-shadow-offset: 0 0 25px,\n    $step: 5\n) {\n    @for $i from 0 through ceil(100 / $step) {\n        $value: $i * $step;\n\n        &-#{$value} {\n            text-shadow: #{$text-shadow-offset} rgba($color, ($value / 100));\n        }\n    }\n}\n","@import 'config/variables';\n@import 'config/breakpoints';\n@import 'vendors/include-media';\n\n@mixin component-spacing($margins-config: $component-spacing-configuration) {\n    @if map-has-key($margins-config, default) {\n        margin: map-get($margins-config, default);\n    } @else {\n        // Default component margin value\n        margin: 0 0 3rem;\n    }\n\n    @if map-has-key($margins-config, responsive) {\n        // Adding margin rules for each passed breakpoint\n        @each $breakpoint, $margin in map-get($margins-config, responsive) {\n            @include media(#{$breakpoint}) {\n                margin: $margin;\n            }\n        }\n    }\n\n    &--skip-spacing {\n        margin: 0;\n    }\n}\n"],"mappings":"AAAA;;ACEA;ADCA;AEHA;;;ADOA;ADkBA;;ACfA;ADVA;;ACaA;ADVA;AEHA;;;ADkBA;ADOA;;ACJA;ADrBA;;ACwBA;ADrBA;AEHA;;;AD6BA;ADJA;;ACOA;ADhCA;;ACmCA;ADhCA;AEHA;;;ADwCA;ADfA;;ACkBA;AD3CA;;AC8CA;AD3CA;AEHA;;;ADmDA;AD1BA;;AC6BA;ADtDA;;ACyDA;ADtDA;AEHA;;;AD8DA;ADrCA;;ACwCA;ACjEA;;;ADqEA;ADrEA;;ACwEA;ADrEA;AEHA;;;AD6EA;ADpDA;;ACuDA;ADhFA;;ACmFA;ADhFA;AEHA;;;ADwFA;AD/DA;;ACkEA;AE3FA;;AF8FA;AG9FA;;AHiGA;ADjGA;;ACoGA;ADjGA;AEHA;;;ADyGA;ADhFA;;ACmFA;AD5GA;;AC+GA;AD5GA;AEHA;;;ADoHA;AD3FA;;AC8FA;AIpHA;AACA;AAEA;AAHA;ACgBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AAGA;AACA;ADvCA;AC2CA;AACA;AD5CA;ACgDA;ADhDA;ACsDA;AAGA;AACA;AACA;AACA;AACA;ANhEA;;AC+JA;AD5JA;AEHA;;;ADoKA;AD3IA;;AC8IA;ADvKA;;AC0KA;ADvKA;AEHA;;;AD+KA;ADtJA;;ACyJA;AM/KA;ACcA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AAJA;AAOA;AAIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AATA;AAYA;AAZA;AAgBA;AACA;ACpDA;;;;;;;;ARwNA;ASxNA;AASA;ACsCA;;;AV+KA;AUlKA;AAGA;AACA;ACjDA;ADuMA;;;AVgBA;AUwEA;;AVrEA;AU7KA;ACxCA;AACA;AACA;AAKA;AACA;AAEA;AACA;AACA;AACA;AACA;AAEA;AACA;AAIA;AACA;AACA;AAGA;AACA;AADA;AAIA;AAGA;AAPA;AAQA;AAIA;AACA;AACA;AAAA;AAAA;AACA;AACA;AACA;AAEA;AAIA;AAHA;AARA;AASA;AAKA;AACA;AACA;AACA;AACA;AAAA;AACA;ACgeA;AFjfA;ACqBA;AAGA;AACA;AADA;AACA;AADA;AACA;AADA;AACA;AADA;AACA;AADA;AACA;AADA;AACA;AACA;ACudA;ADldA;AACA;ADxBA;ACqFA;AACA;AA8BA;AAMA;;;AXgHA;AWpEA;AA9EA;ADxFA;AC0FA;AD1FA;AC8FA;AAEA;ADhGA;ACmGA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AD9GA;ACgHA;ACyXA;AFzeA;ACuHA;ACkXA;AFzeA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;ADlIA;ACkIA;;;;AAAA;AACA;ACsWA;AFzeA;AC6IA;AA0BA;ADvKA;AC0KA;AACA;AACA;AACA;AAKA;ADlLA;ACoLA;ADpLA;ACiCA;ADjCA;AR/DA;AACA;AACA;ASoGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;ADhDA;ACiDA;ACwbA;AFzeA;AP/DA;AACA;AO8DA;AP3DA;AACA;AACA;AACA;AOwDA;APpDA;AACA;AACA;AOkDA;AR/DA;AACA;AACA;ASyHA;AACA;AACA;AACA;AACA;ADhEA;ACmEA;ADnEA;ACwEA;ACiaA;AFheA;ACqLA;AACA;AACA;ADvLA;AC0LA;AACA;AD3LA;AC8LA;AACA;AACA;AACA;AAIA;ADrMA;ACuMA;ACyRA;AFheA;ACwBA;ADxBA;ARxEA;AACA;AACA;ASoGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;ADvCA;ACwCA;ACwbA;AFheA;APxEA;AACA;AOuEA;APpEA;AACA;AACA;AACA;AOiEA;AP7DA;AACA;AACA;AS2hBA;AFheA;ARxEA;AACA;AACA;ASyHA;AACA;AACA;AACA;AACA;ADvDA;AC0DA;AD1DA;AC+DA;ACiaA;AFheA;;AAYA;AAMA;AACA;AACA;AAGA;AACA;AACA;AARA;AAaA;AEkcA;AF7bA;AACA;AAGA;AACA;AEwbA;AFhbA;AAEA;AAFA;AAMA;AANA;;AAWA;AAKA;AACA;AACA;AAFA;AASA;AAIA;AACA;AACA;AAGA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;;AAEA;AACA;AACA;AAKA;AACA;AACA;AAGA;AACA;AACA;AAKA;AACA;AAGA;AACA;AAKA;AACA;AAOA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAGA;AACA;AACA;AACA;AAGA;AA+CA;AA9CA;AGxJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAGA;AACA;AHwIA;AIjOA;AJiOA;AI1NA;AACA;AACA;AACA;AAIA;AJmNA;AIzMA;AACA;AACA;AAIA;AJmMA;AI7KA;AACA;AACA;AACA;AACA;AACA;AJwKA;AIhKA;AJgKA;AGlEA;AACA;AACA;AHgEA;AG1DA;AACA;AACA;AACA;AACA;AAIA;AACA;AACA;AHgDA;AG7CA;AACA;AH4CA;AGUA;AACA;AACA;AAIA;AACA;AACA;AHlBA;AGqBA;AACA;AHtBA;AGuEA;AACA;AHjEA;AG/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAGA;AACA;AH+IA;AG5GA;AH4GA;AGzEA;AACA;AACA;AHuEA;AGjEA;AACA;AACA;AACA;AACA;AAeA;AACA;AACA;AH4CA;AGzCA;AACA;AHwCA;AGGA;AACA;AACA;AAeA;AACA;AACA;AHtBA;AGyBA;AACA;AH1BA;AGgEA;AACA;AHzDA;AGiEA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AAUA;AH7EA;AG0DA;AACA;AACA;AACA;AACA;AACA;AACA;AAGA;AAUA;AHpEA;AGkHA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAmBA;AACA;AHxIA;AG2GA;AACA;AACA;AACA;AACA;AAGA;AACA;AACA;AAmBA;AACA;AD+IA;AF9TA;AAkDA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AASA;AAEA;AACA;AACA;AACA;AACA;AAMA;AACA;AAGA;AACA;AAUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;ALoUA;AKpUA;AL6UA;AK7UA;AL6VA;AACA;AAKA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;ANoXA;AMpXA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AN4XA;AM5XA;AACA;AJmiBA;AF9JA;AC7IA;AACA;AACA;AD2IA;ACxIA;AACA;ADuIA;ACpIA;AACA;AACA;AACA;AAIA;AD6HA;AC3HA;AACA;ACwRA;AF9JA;AC1SA;AD0SA;AR1YA;AACA;AACA;ASoGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AD2RA;AC1RA;ACwbA;AF9JA;AP1YA;AACA;AOyYA;APtYA;AACA;AACA;AACA;AOmYA;AP/XA;AACA;AACA;AACA;AS0hBA;AF9JA;AR1YA;AACA;AACA;ASyHA;AACA;AACA;AACA;AACA;AD2QA;ACxQA;ADwQA;ACnQA;AACA;ACgaA;AF9JA;AAWA;;;;AAAA;AACA;AEkJA;AF9JA;AAWA;;;;AAAA;AACA;AEkJA;AF9JA;AAWA;;;;AAAA;AACA;AEkJA;AF9JA;AAWA;;;;AAAA;AACA;AASA;AArBA;AAuBA;AACA;AEsIA;AF9JA;AA4BA;AA5BA;AAkCA;AAlCA;AAsCA;AAtCA;AA0CA;AA1CA;AA+CA;AACA;AAhDA;AAoDA;AE0GA;AFnGA;AAGA;AAHA;AAOA;AE4FA;AFpFA;AAEA;AACA;AAHA;AAOA;AACA;AAKA;AOheA;ALuiBA;AFvEA;AOtdA;AAKA;AACA;AACA;APmdA;AACA;AACA;AAEA;AACA;AACA;AAFA;AAKA;AACA;AAGA;AACA;AACA;;","sourceRoot":""}*/