/**
 * 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]
*/
/**
 * 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
 */
/**
 * It is intended, to not use the same config pattern (js/conlumnsConfig) as for other slider-based componets,
 * because Products Carousels should have the same config as product grid for consistency.
 * If custom columns config is needed, redefine it.
 */
.cs-products-carousel {
  margin: 0 0 3rem;
  --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.
     */
  --size: calc(
            var(--base-size) /
                2 -
                1 *
                var(--gap) /
                2
        );
  /*  container padding fix  */ }
  @media (min-width: 48em) {
    .cs-products-carousel {
      margin: 0 0 4rem; } }
  .cs-products-carousel--skip-spacing {
    margin: 0; }
  @media (min-width: 81.875em) {
    .cs-products-carousel.cs-products-carousel--container-width {
      --base-size: calc(128rem - 0px); }
    .cs-products-carousel.cs-products-carousel--use-whole-screen:not(.cs-products-carousel--full-width-slider) {
      --base-size: 100%;
      max-width: 100%; }
      .cs-products-carousel.cs-products-carousel--use-whole-screen:not(.cs-products-carousel--full-width-slider) .cs-products-carousel__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-products-carousel.cs-products-carousel--container-width {
      --base-size: 128rem; } }
  @media (min-width: 48em) {
    .cs-products-carousel {
      --gap: 0.8rem; } }
  @media (min-width: 23.125em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 2 - ((
                                    1 * var(--gap)
                                ) / 2)
                ); } }
  @media (min-width: 30em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 2 - ((
                                    1 * var(--gap)
                                ) / 2)
                ); } }
  @media (min-width: 48em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 3 - ((
                                    2 * var(--gap)
                                ) / 3)
                ); } }
  @media (min-width: 64em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 3 - ((
                                    2 * var(--gap)
                                ) / 3)
                ); } }
  @media (min-width: 80em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 4 - ((
                                    3 * var(--gap)
                                ) / 4)
                ); } }
  @media (min-width: 90em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 4 - ((
                                    3 * var(--gap)
                                ) / 4)
                ); } }
  @media (min-width: 120em) {
    .cs-products-carousel {
      --size: calc(
                    var(--base-size) / 4 - ((
                                    3 * var(--gap)
                                ) / 4)
                ); } }
  @media (max-width: 81.8125em) {
    .cs-products-carousel.cs-products-carousel--container-width .cs-products-carousel__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-products-carousel .cs-products-carousel__slides {
      scroll-behavior: smooth; } }
  .cs-products-carousel .cs-products-carousel__slides-wrapper {
    position: relative; }
  .cs-products-carousel .cs-products-carousel__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-products-carousel .cs-products-carousel__slides {
        scroll-snap-type: x mandatory; } }
    @media (min-width: 48em) {
      .cs-products-carousel .cs-products-carousel__slides {
        overflow: -moz-scrollbars-none;
        scrollbar-width: none; }
        .cs-products-carousel .cs-products-carousel__slides::-webkit-scrollbar {
          display: none;
          width: 0;
          height: 0;
          background: transparent; }
        .cs-products-carousel .cs-products-carousel__slides::-webkit-scrollbar-thumb {
          background: transparent;
          width: 0;
          height: 0; } }
  .cs-products-carousel .cs-products-carousel__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-products-carousel .cs-products-carousel__slide:last-of-type {
      margin-right: 0; }
  .cs-products-carousel .cs-products-carousel__image {
    display: block; }
  .cs-products-carousel__wrapper {
    position: relative;
    z-index: 2; }


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"css/products-carousel.css","sources":["webpack://[name]/./src/config/breakpoints.scss","webpack://[name]/products-carousel.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/products-carousel/products-carousel.scss","webpack://[name]/../theme-creativeshop/src/utils/component-spacing.scss","webpack://[name]/../theme-creativeshop/src/components/_slider/mixin.scss","webpack://[name]/./node_modules/include-media/dist/_include-media.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 * 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 * 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 * It is intended, to not use the same config pattern (js/conlumnsConfig) as for other slider-based componets,\n * because Products Carousels should have the same config as product grid for consistency.\n * If custom columns config is needed, redefine it.\n */\n.cs-products-carousel {\n  margin: 0 0 3rem;\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  --size: calc(\n            var(--base-size) /\n                2 -\n                1 *\n                var(--gap) /\n                2\n        );\n  /*  container padding fix  */ }\n  @media (min-width: 48em) {\n    .cs-products-carousel {\n      margin: 0 0 4rem; } }\n  .cs-products-carousel--skip-spacing {\n    margin: 0; }\n  @media (min-width: 81.875em) {\n    .cs-products-carousel.cs-products-carousel--container-width {\n      --base-size: calc(128rem - 0px); }\n    .cs-products-carousel.cs-products-carousel--use-whole-screen:not(.cs-products-carousel--full-width-slider) {\n      --base-size: 100%;\n      max-width: 100%; }\n      .cs-products-carousel.cs-products-carousel--use-whole-screen:not(.cs-products-carousel--full-width-slider) .cs-products-carousel__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-products-carousel.cs-products-carousel--container-width {\n      --base-size: 128rem; } }\n  @media (min-width: 48em) {\n    .cs-products-carousel {\n      --gap: 0.8rem; } }\n  @media (min-width: 23.125em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 2 - ((\n                                    1 * var(--gap)\n                                ) / 2)\n                ); } }\n  @media (min-width: 30em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 2 - ((\n                                    1 * var(--gap)\n                                ) / 2)\n                ); } }\n  @media (min-width: 48em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 3 - ((\n                                    2 * var(--gap)\n                                ) / 3)\n                ); } }\n  @media (min-width: 64em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 3 - ((\n                                    2 * var(--gap)\n                                ) / 3)\n                ); } }\n  @media (min-width: 80em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 4 - ((\n                                    3 * var(--gap)\n                                ) / 4)\n                ); } }\n  @media (min-width: 90em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 4 - ((\n                                    3 * var(--gap)\n                                ) / 4)\n                ); } }\n  @media (min-width: 120em) {\n    .cs-products-carousel {\n      --size: calc(\n                    var(--base-size) / 4 - ((\n                                    3 * var(--gap)\n                                ) / 4)\n                ); } }\n  @media (max-width: 81.8125em) {\n    .cs-products-carousel.cs-products-carousel--container-width .cs-products-carousel__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-products-carousel .cs-products-carousel__slides {\n      scroll-behavior: smooth; } }\n  .cs-products-carousel .cs-products-carousel__slides-wrapper {\n    position: relative; }\n  .cs-products-carousel .cs-products-carousel__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-products-carousel .cs-products-carousel__slides {\n        scroll-snap-type: x mandatory; } }\n    @media (min-width: 48em) {\n      .cs-products-carousel .cs-products-carousel__slides {\n        overflow: -moz-scrollbars-none;\n        scrollbar-width: none; }\n        .cs-products-carousel .cs-products-carousel__slides::-webkit-scrollbar {\n          display: none;\n          width: 0;\n          height: 0;\n          background: transparent; }\n        .cs-products-carousel .cs-products-carousel__slides::-webkit-scrollbar-thumb {\n          background: transparent;\n          width: 0;\n          height: 0; } }\n  .cs-products-carousel .cs-products-carousel__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-products-carousel .cs-products-carousel__slide:last-of-type {\n      margin-right: 0; }\n  .cs-products-carousel .cs-products-carousel__image {\n    display: block; }\n  .cs-products-carousel__wrapper {\n    position: relative;\n    z-index: 2; }\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 'config/breakpoints';\n@import 'vendors/include-media';\n@import 'etc/view.scss';\n@import 'utils/deep-get/deep-get.scss';\n@import 'utils/component-spacing';\n\n@import 'components/_slider/mixin';\n\n/**\n * It is intended, to not use the same config pattern (js/conlumnsConfig) as for other slider-based componets,\n * because Products Carousels should have the same config as product grid for consistency.\n * If custom columns config is needed, redefine it.\n */\n$products-carousel_item-per-row: deep-get(\n    $view-xml,\n    vars,\n    MageSuite_ContentConstructor,\n    columns,\n    one-column\n) !default;\n\n$products-carousel_mobile-gap: 0.8rem !default;\n$products-carousel_desktop-gap: 0.8rem !default;\n$products-carousel_next-slide-visible: 0px !default; // it will be this value + page-gutter\n\n.#{$ns}products-carousel {\n    $root: &;\n\n    @include component-spacing();\n\n    @include slider(\n        $columns-config: $products-carousel_item-per-row,\n        $m-gap: $products-carousel_mobile-gap,\n        $d-gap: $products-carousel_desktop-gap,\n        $next-visible: $products-carousel_next-slide-visible,\n        $root: $root\n    );\n\n    &__wrapper {\n        position: relative;\n        z-index: 2;\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","@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"],"mappings":"AAAA;;ACEA;ADCA;AEHA;;;ADOA;ADkBA;;ACfA;ADVA;;ACaA;ADVA;AEHA;;;ADkBA;ADOA;;ACJA;ADrBA;;ACwBA;ADrBA;AEHA;;;AD6BA;ADJA;;ACOA;AChCA;;;ADoCA;ADpCA;;ACuCA;ADpCA;AEHA;;;AD4CA;ADnBA;;ACsBA;AD/CA;;ACkDA;AD/CA;AEHA;;;ADuDA;AD9BA;;ACiCA;AD1DA;;AC6DA;AD1DA;AEHA;;;ADkEA;ADzCA;;AC4CA;ADrEA;;ACwEA;ADrEA;AEHA;;;AD6EA;ADpDA;;ACuDA;AEhFA;;AFmFA;AGnFA;;AHsFA;AI7EA;;;;AJkFA;AIjEA;ACpBA;ACmJA;AACA;AA8BA;AAMA;;;AN1FA;AMkHA;;;;;;AAAA;AAoBA;ACmUA;AHnhBA;ACVA;AAKA;AACA;ACsIA;AFlIA;AEoIA;AFpIA;AEwIA;AAEA;AF1IA;AE6IA;AACA;AACA;AACA;AACA;AACA;AACA;AAKA;AFxJA;AE0JA;ACyXA;AHnhBA;AEiKA;ACkXA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AC4UA;AHnhBA;AEuMA;;;;AAAA;AAUA;AFjNA;AEoNA;AACA;AACA;AACA;AAKA;AF5NA;AE8NA;AF9NA;AE2EA;AF3EA;AFrBA;AACA;AACA;AIoGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AF1FA;AE2FA;ACwbA;AHnhBA;ADrBA;AACA;ACoBA;ADjBA;AACA;AACA;AACA;ACcA;ADVA;AACA;AACA;ACQA;AFrBA;AACA;AACA;AIyHA;AACA;AACA;AACA;AACA;AF1GA;AE6GA;AF7GA;AEkHA;AFrGA;AACA;AACA;;","sourceRoot":""}*/