/* [project]/node_modules/.pnpm/swiper@12.2.0/node_modules/swiper/swiper.css [app-client] (css) */
:root {
  --swiper-theme-color: #007aff;
}

:host {
  z-index: 1;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: relative;
}

.swiper {
  z-index: 1;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  list-style: none;
  display: block;
  position: relative;
  overflow: hidden;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  z-index: 1;
  width: 100%;
  height: 100%;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
  display: flex;
  position: relative;
}

.swiper-android .swiper-slide, .swiper-ios .swiper-slide, .swiper-wrapper {
  transform: translate3d(0, 0, 0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  transition-property: transform;
  display: block;
  position: relative;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  backface-visibility: hidden;
  transform: translateZ(0);
}

.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
}

.swiper-3d .swiper-slide, .swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}

.swiper-css-mode > .swiper-wrapper {
  scrollbar-width: none;
  -ms-overflow-style: none;
  overflow: auto;
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-slides-offset-before);
  scroll-margin-inline-start: var(--swiper-slides-offset-before);
}

.swiper-css-mode.swiper-horizontal > .swiper-wrapper > .swiper-slide:last-child {
  margin-inline-end: var(--swiper-slides-offset-after);
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-slides-offset-before);
  scroll-margin-block-start: var(--swiper-slides-offset-before);
}

.swiper-css-mode.swiper-vertical > .swiper-wrapper > .swiper-slide:last-child {
  margin-block-end: var(--swiper-slides-offset-after);
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none;
}

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper:before {
  content: "";
  flex-shrink: 0;
  order: 9999;
}

.swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper:before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper:before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-slide-shadow-bottom {
  pointer-events: none;
  z-index: 10;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.swiper-3d .swiper-slide-shadow {
  background: #00000026;
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, #00000080, #0000);
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, #00000080, #0000);
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, #00000080, #0000);
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(#00000080, #0000);
}

.swiper-lazy-preloader {
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-top-color: #0000;
  border-radius: 50%;
  width: 42px;
  height: 42px;
  margin-top: -21px;
  margin-left: -21px;
  position: absolute;
  top: 50%;
  left: 50%;
}

:is(.swiper:not(.swiper-watch-progress), .swiper-watch-progress .swiper-slide-visible) .swiper-lazy-preloader {
  animation: 1s linear infinite swiper-preloader-spin;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

/* [project]/node_modules/.pnpm/swiper@12.2.0/node_modules/swiper/modules/navigation.css [app-client] (css) */
:root {
  --swiper-navigation-size: 44px;
}

.swiper-button-prev, .swiper-button-next {
  width: var(--swiper-navigation-size);
  height: var(--swiper-navigation-size);
  z-index: 10;
  cursor: pointer;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
}

:is(.swiper-button-prev, .swiper-button-next).swiper-button-disabled {
  opacity: .35;
  cursor: auto;
  pointer-events: none;
}

:is(.swiper-button-prev, .swiper-button-next).swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled :is(.swiper-button-prev, .swiper-button-next) {
  display: none !important;
}

:is(.swiper-button-prev, .swiper-button-next) ::slotted(svg), :is(.swiper-button-prev, .swiper-button-next) svg {
  object-fit: contain;
  transform-origin: center;
  fill: currentColor;
  pointer-events: none;
  width: 100%;
  height: 100%;
}

.swiper-button-lock {
  display: none;
}

.swiper-button-prev, .swiper-button-next {
  top: var(--swiper-navigation-top-offset, 50%);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
}

.swiper-button-prev {
  left: var(--swiper-navigation-sides-offset, 4px);
  right: auto;
}

.swiper-button-prev ::slotted(.swiper-navigation-icon), .swiper-button-prev .swiper-navigation-icon {
  transform: rotate(180deg);
}

.swiper-button-next {
  right: var(--swiper-navigation-sides-offset, 4px);
  left: auto;
}

.swiper-horizontal .swiper-button-prev, .swiper-horizontal .swiper-button-next, .swiper-horizontal ~ .swiper-button-prev, .swiper-horizontal ~ .swiper-button-next {
  top: var(--swiper-navigation-top-offset, 50%);
  margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
  margin-left: 0;
}

.swiper-horizontal .swiper-button-prev, .swiper-horizontal ~ .swiper-button-prev, .swiper-horizontal.swiper-rtl .swiper-button-next, .swiper-horizontal.swiper-rtl ~ .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 4px);
  right: auto;
}

.swiper-horizontal .swiper-button-next, .swiper-horizontal ~ .swiper-button-next, .swiper-horizontal.swiper-rtl .swiper-button-prev, .swiper-horizontal.swiper-rtl ~ .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 4px);
  left: auto;
}

:is(.swiper-horizontal .swiper-button-prev, .swiper-horizontal ~ .swiper-button-prev, .swiper-horizontal.swiper-rtl .swiper-button-next, .swiper-horizontal.swiper-rtl ~ .swiper-button-next) ::slotted(.swiper-navigation-icon), :is(.swiper-horizontal .swiper-button-prev, .swiper-horizontal ~ .swiper-button-prev, .swiper-horizontal.swiper-rtl .swiper-button-next, .swiper-horizontal.swiper-rtl ~ .swiper-button-next) .swiper-navigation-icon {
  transform: rotate(180deg);
}

:is(.swiper-horizontal.swiper-rtl .swiper-button-prev, .swiper-horizontal.swiper-rtl ~ .swiper-button-prev) ::slotted(.swiper-navigation-icon), :is(.swiper-horizontal.swiper-rtl .swiper-button-prev, .swiper-horizontal.swiper-rtl ~ .swiper-button-prev) .swiper-navigation-icon {
  transform: rotate(0);
}

.swiper-vertical .swiper-button-prev, .swiper-vertical .swiper-button-next, .swiper-vertical ~ .swiper-button-prev, .swiper-vertical ~ .swiper-button-next {
  left: var(--swiper-navigation-top-offset, 50%);
  margin-left: calc(0px - (var(--swiper-navigation-size) / 2));
  margin-top: 0;
  right: auto;
}

.swiper-vertical .swiper-button-prev, .swiper-vertical ~ .swiper-button-prev {
  top: var(--swiper-navigation-sides-offset, 4px);
  bottom: auto;
}

:is(.swiper-vertical .swiper-button-prev, .swiper-vertical ~ .swiper-button-prev) ::slotted(.swiper-navigation-icon), :is(.swiper-vertical .swiper-button-prev, .swiper-vertical ~ .swiper-button-prev) .swiper-navigation-icon {
  transform: rotate(-90deg);
}

.swiper-vertical .swiper-button-next, .swiper-vertical ~ .swiper-button-next {
  bottom: var(--swiper-navigation-sides-offset, 4px);
  top: auto;
}

:is(.swiper-vertical .swiper-button-next, .swiper-vertical ~ .swiper-button-next) ::slotted(.swiper-navigation-icon), :is(.swiper-vertical .swiper-button-next, .swiper-vertical ~ .swiper-button-next) .swiper-navigation-icon {
  transform: rotate(90deg);
}

/* [project]/node_modules/.pnpm/swiper@12.2.0/node_modules/swiper/modules/pagination.css [app-client] (css) */
.swiper-pagination {
  text-align: center;
  z-index: 10;
  transition: opacity .3s;
  position: absolute;
  transform: translate3d(0, 0, 0);
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

.swiper-pagination-fraction, .swiper-pagination-custom, .swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  width: 100%;
  left: 0;
}

.swiper-pagination-bullets-dynamic {
  font-size: 0;
  overflow: hidden;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  position: relative;
  transform: scale(.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active, .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, .2);
  display: inline-block;
}

button.swiper-pagination-bullet {
  box-shadow: none;
  appearance: none;
  border: none;
  margin: 0;
  padding: 0;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-vertical > .swiper-pagination-bullets, .swiper-pagination-vertical.swiper-pagination-bullets {
  right: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  top: 50%;
  transform: translate3d(0, -50%, 0);
}

:is(.swiper-vertical > .swiper-pagination-bullets, .swiper-pagination-vertical.swiper-pagination-bullets) .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

:is(.swiper-vertical > .swiper-pagination-bullets, .swiper-pagination-vertical.swiper-pagination-bullets).swiper-pagination-bullets-dynamic {
  width: 8px;
  top: 50%;
  transform: translateY(-50%);
}

:is(.swiper-vertical > .swiper-pagination-bullets, .swiper-pagination-vertical.swiper-pagination-bullets).swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: transform .2s, top .2s;
  display: inline-block;
}

:is(.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets) .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

:is(.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets).swiper-pagination-bullets-dynamic {
  white-space: nowrap;
  left: 50%;
  transform: translateX(-50%);
}

:is(.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-horizontal.swiper-pagination-bullets).swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: transform .2s, left .2s;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: transform .2s, right .2s;
}

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, #00000040);
  position: absolute;
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(0);
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: 100% 0;
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: var(--swiper-pagination-progressbar-size, 4px);
  top: 0;
  left: 0;
}

.swiper-vertical > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  top: 0;
  left: 0;
}

.swiper-pagination-lock {
  display: none;
}

/* [project]/src/features/hero/components/layout/HeroCarousel/style.module.css [app-client] (css) */
.style-module__JQG5Vq__carousel {
  width: 100%;
  height: 70vh;
  min-height: 28em;
  max-height: 52em;
  position: relative;
  overflow: hidden;
}

.style-module__JQG5Vq__swiper {
  height: 100%;
}

:is(.style-module__JQG5Vq__swiper .swiper-button-next, .style-module__JQG5Vq__swiper .swiper-button-prev) {
  color: var(--white-1);
  -webkit-backdrop-filter: blur(.5em) saturate(1.2);
  backdrop-filter: blur(.5em) saturate(1.2);
  background: #00000040;
  border: .0625em solid #ffffff26;
  border-radius: 50%;
  width: 2.75em;
  height: 2.75em;
  transition: all .25s;
}

:is(.style-module__JQG5Vq__swiper .swiper-button-next:hover, .style-module__JQG5Vq__swiper .swiper-button-prev:hover) {
  background: #0006;
  border-color: #ffffff40;
  transform: scale(1.05);
}

.style-module__JQG5Vq__swiper .swiper-button-next:after {
  font-size: 1.1em;
  font-weight: 700;
}

.style-module__JQG5Vq__swiper .swiper-button-prev:after {
  font-size: 1.1em;
  font-weight: 700;
}

.style-module__JQG5Vq__swiper .swiper-pagination-bullet {
  opacity: 1;
  background: #ffffff80;
  width: .5em;
  height: .5em;
  transition: all .3s;
}

.style-module__JQG5Vq__swiper .swiper-pagination-bullet-active {
  background: var(--white-1);
  border-radius: .25em;
  width: 1.75em;
  box-shadow: 0 0 .5em #ffffff80;
}

.style-module__JQG5Vq__slide {
  background-position: center;
  background-size: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.style-module__JQG5Vq__overlay {
  z-index: 1;
  background: radial-gradient(#0000 30%, #0006 100%), linear-gradient(105deg, #000000bf 0%, #00000073 40%, #00000026 70%, #0000 100%);
  position: absolute;
  inset: 0;
}

.style-module__JQG5Vq__content {
  z-index: 2;
  text-align: start;
  color: var(--white-1);
  max-width: 42em;
  margin-inline: 8% auto;
  padding: 2.5em;
  position: relative;
}

.style-module__JQG5Vq__title {
  letter-spacing: -.02em;
  text-shadow: 0 .0625em .25em #0000004d;
  margin: 0 0 .35em;
  font-size: clamp(2.25em, 5vw, 3.5em);
  font-weight: 800;
  line-height: 1.1;
}

.style-module__JQG5Vq__subtitle {
  opacity: .92;
  text-shadow: 0 .0625em .125em #00000040;
  max-width: 36em;
  margin: 0 0 1.75em;
  font-size: clamp(1em, 2vw, 1.25em);
  font-weight: 450;
  line-height: 1.6;
}

.style-module__JQG5Vq__button {
  background: linear-gradient(180deg, var(--primary-5), var(--primary-4));
  color: var(--white-1);
  border-radius: var(--border-radius-2);
  border: .0625em solid #ffffff1a;
  align-items: center;
  gap: .5em;
  padding: .875em 1.75em;
  font-size: .95em;
  font-weight: 650;
  text-decoration: none;
  transition: all .25s cubic-bezier(.2, 0, 0, 1);
  display: inline-flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 .25em .75em #3014ff4d, 0 .125em .25em #0003, inset 0 .0625em #ffffff26;
}

.style-module__JQG5Vq__button:before {
  content: "";
  opacity: 0;
  background: linear-gradient(#ffffff26, #0000 60%);
  transition: opacity .25s;
  position: absolute;
  inset: 0;
}

.style-module__JQG5Vq__button:hover {
  background: linear-gradient(180deg, var(--primary-4), var(--primary-3));
  transform: translateY(-.125em);
  box-shadow: 0 .5em 1.25em #3014ff66, 0 .25em .5em #00000040, inset 0 .0625em #fff3;
}

.style-module__JQG5Vq__button:hover:before {
  opacity: 1;
}

.style-module__JQG5Vq__button:active {
  transform: translateY(0);
}

@media (max-width: 48em) {
  .style-module__JQG5Vq__carousel {
    height: 60vh;
    min-height: 22em;
  }

  .style-module__JQG5Vq__content {
    text-align: center;
    max-width: 90%;
    margin-inline: auto;
    padding: 1.5em;
  }

  .style-module__JQG5Vq__overlay {
    background: radial-gradient(#0000 20%, #00000080 100%), linear-gradient(to top, #000c 0%, #0006 50%, #0000 100%);
  }

  :is(.style-module__JQG5Vq__swiper .swiper-button-next, .style-module__JQG5Vq__swiper .swiper-button-prev) {
    display: none;
  }
}

/* [project]/src/features/products/components/CategoryFilter/style.module.css [app-client] (css) */
.style-module__xHO5iG__wrapper {
  width: 100%;
  position: relative;
}

.style-module__xHO5iG__root {
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--primary-5) transparent;
  align-items: center;
  gap: .6em;
  padding: 1em 1.5em;
  scroll-padding-inline: 1.5em;
  display: flex;
  overflow: auto hidden;
  -webkit-mask-image: linear-gradient(to right, #0000 0, #000 1.5em calc(100% - 1.5em), #0000 100%);
  mask-image: linear-gradient(to right, #0000 0, #000 1.5em calc(100% - 1.5em), #0000 100%);
}

.style-module__xHO5iG__root::-webkit-scrollbar {
  height: .35em;
}

.style-module__xHO5iG__root::-webkit-scrollbar-track {
  background: none;
  margin: 0 1.5em;
}

.style-module__xHO5iG__root::-webkit-scrollbar-thumb {
  background: var(--white-4);
  border-radius: var(--border-radius-pill);
  transition: background .15s;
}

.style-module__xHO5iG__root:hover::-webkit-scrollbar-thumb {
  background: var(--primary-5);
}

.style-module__xHO5iG__root::-webkit-scrollbar-thumb:hover {
  background: var(--primary-6);
}

.style-module__xHO5iG__pill {
  all: unset;
  color: var(--text-4);
  background: var(--white-1);
  border: .07em solid var(--white-3);
  border-radius: var(--border-radius-pill);
  cursor: pointer;
  white-space: nowrap;
  scroll-snap-align: start;
  box-shadow: var(--shadow-1);
  flex-shrink: 0;
  align-items: center;
  gap: .45em;
  padding: .55em 1.1em;
  font-size: .9em;
  font-weight: 500;
  transition: all .18s;
  display: inline-flex;
  position: relative;
}

.style-module__xHO5iG__pill svg {
  opacity: .8;
  width: 1em;
  height: 1em;
}

.style-module__xHO5iG__pill:hover {
  border-color: var(--primary-8);
  color: var(--primary-2);
  background: var(--primary-light-7);
  transform: translateY(-.08em);
}

.style-module__xHO5iG__pill:active {
  transform: translateY(0);
}

.style-module__xHO5iG__active {
  background: linear-gradient(135deg, var(--primary-1) 0%, var(--primary-3) 100%);
  color: #fff;
  border-color: #0000;
  font-weight: 600;
}

.style-module__xHO5iG__active svg {
  opacity: 1;
}

.style-module__xHO5iG__count {
  border-radius: var(--border-radius-pill);
  background: color-mix(in srgb, var(--black-1), transparent 88%);
  color: var(--text-5);
  transition: var(--transition-2);
  text-align: center;
  min-width: 1.4em;
  padding: .15em .5em;
  font-size: .75em;
  font-weight: 600;
}

.style-module__xHO5iG__pill:hover .style-module__xHO5iG__count {
  background: color-mix(in srgb, var(--primary-1), transparent 85%);
  color: var(--primary-2);
}

.style-module__xHO5iG__active .style-module__xHO5iG__count {
  color: #fff;
  -webkit-backdrop-filter: blur(.2em);
  backdrop-filter: blur(.2em);
  background: #fff3;
}

.style-module__xHO5iG__rtl .style-module__xHO5iG__root {
  direction: rtl;
}

/* [project]/src/features/products/components/ProductCard/style.module.css [app-client] (css) */
.style-module__yS3l1q__root {
  background: var(--white-1);
  border: var(--border-line-2);
  border-radius: var(--border-radius-2);
  box-shadow: var(--shadow-1);
  isolation: isolate;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.style-module__yS3l1q__root:hover {
  border-color: var(--primary-6);
  transform: translateY(-.12em);
  box-shadow: 0 .4em 1.2em #00000014;
}

.style-module__yS3l1q__cardLink {
  color: inherit;
  outline: none;
  flex-direction: column;
  flex: 1;
  text-decoration: none;
  display: flex;
}

.style-module__yS3l1q__cardLink:focus-visible {
  box-shadow: var(--focus-ring-shadow-2);
}

.style-module__yS3l1q__imageWrapper {
  aspect-ratio: 1;
  background: var(--cold-white-2);
  position: relative;
  overflow: hidden;
}

.style-module__yS3l1q__image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  transition: transform .5s;
  display: block;
}

.style-module__yS3l1q__root:hover .style-module__yS3l1q__image {
  transform: scale(1.05);
}

.style-module__yS3l1q__hoverLayer {
  color: var(--white-1);
  opacity: 0;
  pointer-events: none;
  z-index: 5;
  background: linear-gradient(to top, #000000bf 0%, #0000 100%);
  padding: 1em;
  transition: all .25s;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  transform: translateY(.4em);
}

.style-module__yS3l1q__root:hover .style-module__yS3l1q__hoverLayer, .style-module__yS3l1q__root:focus-within .style-module__yS3l1q__hoverLayer {
  opacity: 1;
  transform: translateY(0);
}

.style-module__yS3l1q__shortDesc {
  -webkit-line-clamp: 2;
  opacity: .95;
  -webkit-box-orient: vertical;
  margin: 0 0 .5em;
  font-size: .85em;
  line-height: 1.4;
  display: -webkit-box;
  overflow: hidden;
}

.style-module__yS3l1q__stockRow {
  align-items: center;
  gap: .4em;
  font-size: .75em;
  display: flex;
}

.style-module__yS3l1q__stockDot {
  border-radius: 50%;
  flex-shrink: 0;
  width: .45em;
  height: .45em;
}

.style-module__yS3l1q__stockDot.style-module__yS3l1q__inStock {
  background: var(--positive-3);
}

.style-module__yS3l1q__stockDot.style-module__yS3l1q__outOfStock {
  background: var(--color-red-4);
}

.style-module__yS3l1q__info {
  box-sizing: border-box;
  flex-direction: column;
  justify-content: space-between;
  height: 4.6em;
  padding: .8em 1em;
  display: flex;
}

.style-module__yS3l1q__productTitle {
  font-size: .95em;
  font-weight: var(--weight-bold);
  color: var(--black-3);
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin: 0;
  line-height: 1.3;
  transition: color .2s;
  display: -webkit-box;
  overflow: hidden;
}

.style-module__yS3l1q__root:hover .style-module__yS3l1q__productTitle {
  color: var(--primary-4);
}

.style-module__yS3l1q__priceRow {
  align-items: baseline;
  gap: .5em;
  display: flex;
}

.style-module__yS3l1q__price {
  font-size: 1.1em;
  font-weight: var(--weight-bold);
  color: var(--black-3);
}

.style-module__yS3l1q__oldPrice {
  color: var(--text-6);
  font-size: .8em;
  text-decoration: line-through;
}

.style-module__yS3l1q__addToCart {
  background: var(--primary-4);
  color: var(--white-1);
  border-radius: var(--border-radius-1);
  font-size: .85em;
  font-weight: var(--weight-bold);
  cursor: pointer;
  box-shadow: var(--shadow-1);
  border: none;
  justify-content: center;
  align-items: center;
  gap: .5em;
  margin: 0 .75em .75em;
  padding: .6em 1em;
  transition: background .2s, transform .1s;
  display: flex;
}

.style-module__yS3l1q__addToCart:hover:not(:disabled) {
  background: var(--primary-6);
  transform: translateY(-.05em);
}

.style-module__yS3l1q__addToCart:active:not(:disabled) {
  transform: translateY(0);
}

.style-module__yS3l1q__addToCart:disabled {
  background: var(--white-3);
  color: var(--black-4);
  cursor: not-allowed;
}

.style-module__yS3l1q__addToCart:focus-visible {
  box-shadow: var(--focus-ring-shadow-2);
  outline: none;
}

.style-module__yS3l1q__icon {
  flex-shrink: 0;
  width: 1em;
  height: 1em;
}

.style-module__yS3l1q__badge {
  background: var(--primary-5);
  color: var(--white-1);
  font-size: .75em;
  font-weight: var(--weight-bold);
  border-radius: var(--border-radius-1);
  z-index: 3;
  box-shadow: var(--shadow-2);
  align-items: center;
  gap: .3em;
  padding: .3em .6em;
  display: flex;
  position: absolute;
  top: .75em;
  right: .75em;
}

.style-module__yS3l1q__badgeIcon {
  width: .9em;
  height: .9em;
}

.style-module__yS3l1q__outOfStockOverlay {
  -webkit-backdrop-filter: blur(.1em);
  backdrop-filter: blur(.1em);
  color: var(--white-1);
  font-weight: var(--weight-bold);
  z-index: 3;
  background: #0009;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: .5em;
  font-size: .95em;
  transition: background .2s;
  display: flex;
  position: absolute;
  inset: 0;
}

.style-module__yS3l1q__root:hover .style-module__yS3l1q__outOfStockOverlay {
  background: #00000073;
}

.style-module__yS3l1q__overlayIcon {
  opacity: .9;
  width: 1.5em;
  height: 1.5em;
}

@media (hover: none) {
  .style-module__yS3l1q__hoverLayer {
    opacity: 1;
    pointer-events: auto;
    background: linear-gradient(to top, #000000a6, #0000 70%);
    transform: none;
  }

  .style-module__yS3l1q__root:hover {
    transform: none;
  }
}

/* [project]/src/features/products/components/ProductGrid/style.module.css [app-client] (css) */
.style-module__zmpYsG__root {
  box-sizing: border-box;
  grid-template-columns: repeat(auto-fit, minmax(12em, 13em));
  justify-content: center;
  gap: 2em;
  width: 100%;
  display: grid;
}

@media (min-width: 40em) {
  .style-module__zmpYsG__root {
    grid-template-columns: repeat(auto-fit, minmax(13em, 14em));
    gap: 1.5em;
  }
}

@media (min-width: 64em) {
  .style-module__zmpYsG__root {
    grid-template-columns: repeat(auto-fit, minmax(16rem, 18rem));
    gap: 2rem;
  }
}

/* [project]/src/features/products/pages/CatalogPage/style.module.css [app-client] (css) */
.style-module__UT-i6q__root {
  background: var(--background-color);
  flex-direction: column;
  min-height: 100vh;
  display: flex;
}

.style-module__UT-i6q__filterWrap {
  z-index: 10;
  background: color-mix(in srgb, var(--background-color), transparent 12%);
  -webkit-backdrop-filter: blur(.7em);
  border-bottom: .07em solid var(--white-3);
  box-shadow: 0 .1em .8em color-mix(in srgb, var(--black-1), transparent 94%);
  top: 0;
}

.style-module__UT-i6q__filterInner {
  width: 100%;
  max-width: 75em;
  margin: 0 auto;
}

.style-module__UT-i6q__content {
  box-sizing: border-box;
  flex: 1;
  width: 100%;
  max-width: 75em;
  margin: 0 auto;
  padding: 1.8em 2em 4em;
}

@media (max-width: 48em) {
  .style-module__UT-i6q__content {
    padding: 1.2em 1em 3em;
  }

  .style-module__UT-i6q__filterWrap {
    top: -.01em;
  }
}

@media (min-width: 48.01em) and (max-width: 64em) {
  .style-module__UT-i6q__content {
    padding: 1.5em 1.5em 3.5em;
  }
}

/* [project]/src/components/ui/ErrorDisplay/style.module.css [app-client] (css) */
.style-module__302rhG__container {
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 2em;
  display: flex;
}

.style-module__302rhG__card {
  text-align: center;
  background: #fff;
  border: .0625em solid #eaeaea;
  border-radius: 1.25em;
  width: 100%;
  max-width: 34.375em;
  padding: 2.5em;
  box-shadow: 0 .625em 1.875em #00000014;
}

.style-module__302rhG__iconCircle {
  color: #e53e3e;
  background: #fff5f5;
  border-radius: 1.125em;
  justify-content: center;
  align-items: center;
  width: 3.75em;
  height: 3.75em;
  margin-bottom: 1.25em;
  display: inline-flex;
}

.style-module__302rhG__title {
  color: #1a202c;
  margin-bottom: .5em;
  font-size: 1.5em;
  font-weight: 800;
}

.style-module__302rhG__message {
  color: #4a5568;
  margin-bottom: 1.5em;
  font-size: 1em;
  line-height: 1.5;
}

.style-module__302rhG__actions {
  flex-direction: column;
  gap: .75em;
  display: flex;
}

.style-module__302rhG__retryButton {
  color: #fff;
  cursor: pointer;
  background: #1a202c;
  border: none;
  border-radius: .625em;
  padding: .75em 1.5em;
  font-weight: 600;
}

.style-module__302rhG__detailsToggle {
  color: #718096;
  cursor: pointer;
  background: none;
  border: none;
  font-size: .85em;
  text-decoration: underline;
}

.style-module__302rhG__detailsArea {
  text-align: left;
  background: #f8fafc;
  border: .0625em solid #e2e8f0;
  border-radius: .75em;
  margin-top: 1.5em;
  padding: 1em;
  animation: .3s ease-out style-module__302rhG__slideDown;
}

.style-module__302rhG__digestRow {
  color: #64748b;
  justify-content: space-between;
  margin-bottom: .5em;
  font-size: .75em;
  display: flex;
}

.style-module__302rhG__stackTrace {
  color: #475569;
  white-space: pre-wrap;
  max-height: 12.5em;
  font-family: ui-monospace, monospace;
  font-size: .7em;
  line-height: 1.4;
  overflow: auto;
}

@keyframes style-module__302rhG__slideDown {
  from {
    opacity: 0;
    transform: translateY(-.625em);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/*# sourceMappingURL=_0q-jav1._.css.map*/