[class^=ais-] {
  box-sizing: border-box;
}

.ais-Breadcrumb-list,
.ais-Carousel-list,
.ais-CurrentRefinements-list,
.ais-HierarchicalMenu-list,
.ais-Hits-list,
.ais-FrequentlyBoughtTogether-list,
.ais-LookingSimilar-list,
.ais-RelatedProducts-list,
.ais-TrendingItems-list,
.ais-Results-list,
.ais-InfiniteHits-list,
.ais-InfiniteResults-list,
.ais-Menu-list,
.ais-NumericMenu-list,
.ais-Pagination-list,
.ais-RatingMenu-list,
.ais-RefinementList-list,
.ais-ToggleRefinement-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ais-Carousel-navigation,
.ais-ClearRefinements-button,
.ais-CurrentRefinements-delete,
.ais-CurrentRefinements-reset,
.ais-GeoSearch-redo,
.ais-GeoSearch-reset,
.ais-HierarchicalMenu-showMore,
.ais-InfiniteHits-loadPrevious,
.ais-InfiniteHits-loadMore,
.ais-InfiniteResults-loadMore,
.ais-Menu-showMore,
.ais-RangeInput-submit,
.ais-RefinementList-showMore,
.ais-SearchBox-submit,
.ais-SearchBox-reset,
.ais-VoiceSearch-button {
  padding: 0;
  overflow: visible;
  font: inherit;
  line-height: normal;
  color: inherit;
  background: none;
  border: 0;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.ais-Carousel-navigation::-moz-focus-inner,
.ais-ClearRefinements-button::-moz-focus-inner,
.ais-CurrentRefinements-delete::-moz-focus-inner,
.ais-CurrentRefinements-reset::-moz-focus-inner,
.ais-GeoSearch-redo::-moz-focus-inner,
.ais-GeoSearch-reset::-moz-focus-inner,
.ais-HierarchicalMenu-showMore::-moz-focus-inner,
.ais-InfiniteHits-loadPrevious::-moz-focus-inner,
.ais-InfiniteHits-loadMore::-moz-focus-inner,
.ais-InfiniteResults-loadMore::-moz-focus-inner,
.ais-Menu-showMore::-moz-focus-inner,
.ais-RangeInput-submit::-moz-focus-inner,
.ais-RefinementList-showMore::-moz-focus-inner,
.ais-SearchBox-submit::-moz-focus-inner,
.ais-SearchBox-reset::-moz-focus-inner,
.ais-VoiceSearch-button::-moz-focus-inner {
  padding: 0;
  border: 0;
}
.ais-Carousel-navigation[disabled],
.ais-ClearRefinements-button[disabled],
.ais-CurrentRefinements-delete[disabled],
.ais-CurrentRefinements-reset[disabled],
.ais-GeoSearch-redo[disabled],
.ais-GeoSearch-reset[disabled],
.ais-HierarchicalMenu-showMore[disabled],
.ais-InfiniteHits-loadPrevious[disabled],
.ais-InfiniteHits-loadMore[disabled],
.ais-InfiniteResults-loadMore[disabled],
.ais-Menu-showMore[disabled],
.ais-RangeInput-submit[disabled],
.ais-RefinementList-showMore[disabled],
.ais-SearchBox-submit[disabled],
.ais-SearchBox-reset[disabled],
.ais-VoiceSearch-button[disabled] {
  cursor: default;
}

.ais-InfiniteHits-loadPrevious,
.ais-InfiniteHits-loadMore,
.ais-HierarchicalMenu-showMore,
.ais-Menu-showMore,
.ais-RefinementList-showMore {
  overflow-anchor: none;
}

.ais-Breadcrumb-list,
.ais-Breadcrumb-item,
.ais-Pagination-list,
.ais-RangeInput-form,
.ais-RatingMenu-link,
.ais-PoweredBy {
  display: flex;
  align-items: center;
}

.ais-GeoSearch,
.ais-GeoSearch-map {
  height: 100%;
}

.ais-HierarchicalMenu-list .ais-HierarchicalMenu-list {
  margin-left: 1em;
}

.ais-PoweredBy-logo {
  display: block;
  height: 1.2em;
  width: auto;
}

.ais-PoweredBy-text {
  margin-right: 0.3rem;
}

.ais-RatingMenu-starIcon {
  display: block;
  width: 20px;
  height: 20px;
}

.ais-SearchBox-input::-ms-clear, .ais-SearchBox-input::-ms-reveal {
  display: none;
  width: 0;
  height: 0;
}
.ais-SearchBox-input::-webkit-search-decoration, .ais-SearchBox-input::-webkit-search-cancel-button, .ais-SearchBox-input::-webkit-search-results-button, .ais-SearchBox-input::-webkit-search-results-decoration {
  display: none;
}

.ais-RangeSlider .rheostat {
  overflow: visible;
  margin-top: 40px;
  margin-bottom: 40px;
}
.ais-RangeSlider .rheostat-background {
  height: 6px;
  top: 0px;
  width: 100%;
}
.ais-RangeSlider .rheostat-handle {
  margin-left: -12px;
  top: -7px;
}
.ais-RangeSlider .rheostat-background {
  position: relative;
  background-color: #ffffff;
  border: 1px solid #aaa;
}
.ais-RangeSlider .rheostat-progress {
  position: absolute;
  top: 1px;
  height: 4px;
  background-color: #333;
}

.rheostat-handle {
  position: relative;
  z-index: 1;
  width: 20px;
  height: 20px;
  background-color: #fff;
  border: 1px solid #333;
  border-radius: 50%;
  cursor: grab;
}

.rheostat-marker {
  margin-left: -1px;
  position: absolute;
  width: 1px;
  height: 5px;
  background-color: #aaa;
}

.rheostat-marker--large {
  height: 9px;
}

.rheostat-value {
  margin-left: 50%;
  padding-top: 15px;
  position: absolute;
  text-align: center;
  transform: translateX(-50%);
}

.rheostat-tooltip {
  margin-left: 50%;
  position: absolute;
  top: -22px;
  text-align: center;
  transform: translateX(-50%);
}

.ais-Carousel {
  position: relative;
}

.ais-Carousel-list {
  grid-auto-columns: 42%;
  display: grid;
  grid-auto-flow: column;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
}

@media (min-width: 999px) {
  .ais-Carousel-list {
    grid-auto-columns: 20%;
  }
}
.ais-Carousel-navigation {
  position: absolute;
  top: 35%;
  z-index: 1;
}

.ais-Carousel-navigation--previous {
  left: 0;
  transform: translateX(-25%);
}

.ais-Carousel-navigation--next {
  right: 0;
  transform: translateX(25%);
}

.ais-Carousel-item {
  scroll-snap-align: start;
}

:root {
  /* Text colors */
  --ais-text-color-rgb: 38, 38, 38;
  --ais-text-color-alpha: 1;
  --ais-primary-color-rgb: 30, 89, 255;
  --ais-primary-color-alpha: 1;
  --ais-muted-color-rgb: 82, 82, 82;
  --ais-muted-color-alpha: 1;
  --ais-button-text-color-rgb: 255, 255, 255;
  --ais-button-text-color-alpha: 1;
  /* Border color */
  --ais-border-color-rgb: 150, 150, 150;
  --ais-border-color-alpha: 1;
  /* Background color */
  --ais-background-color-rgb: 255, 255, 255;
  --ais-background-color-alpha: 1;
  /* Shadow color */
  --ais-shadow-color-rgb: 23, 23, 23;
  /* Size and spacing */
  --ais-base-unit: 16;
  --ais-spacing-factor: 1;
  --ais-spacing: calc(var(--ais-base-unit) * var(--ais-spacing-factor) * 1px);
  /* Shadows */
  --ais-shadow-sm: 0px 0px 0px 1px rgba(var(--ais-shadow-color-rgb), 0.05),
    0px 1px 3px 0px rgba(var(--ais-shadow-color-rgb), 0.25);
  --ais-shadow-md: 0px 0px 0px 1px rgba(var(--ais-shadow-color-rgb), 0.05),
    0px 4px 8px -2px rgba(var(--ais-shadow-color-rgb), 0.25);
  --ais-shadow-lg: 0 0 0 1px rgba(var(--ais-shadow-color-rgb), 0.05),
    0 6px 16px -4px rgba(var(--ais-shadow-color-rgb), 0.15);
  /* Border radius */
  --ais-border-radius-sm: 4px;
  --ais-border-radius-md: 8px;
  --ais-border-radius-lg: 16px;
  --ais-border-radius-full: 9999px;
  /* Typography */
  --ais-font-size: calc(var(--ais-base-unit) * 1px);
  --ais-font-weight-medium: 500;
  --ais-font-weight-semibold: 600;
  --ais-font-weight-bold: 700;
  /* Icons */
  --ais-icon-size: 20px;
  --ais-icon-stroke-width: 1.6;
  /* Transitions */
  --ais-transition-duration: 0.3s;
  --ais-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  /* Z-index layers */
  --ais-z-index-chat: 9999;
  --ais-z-index-autocomplete: 10000;
  /* Chat component */
  --ais-chat-width: 22.5rem;
  --ais-chat-height: 70%;
  --ais-chat-maximized-width: 70%;
  --ais-chat-maximized-height: 100%;
  --ais-chat-margin: 1.5rem;
  /* Chat carousel component */
  --ais-chat-carousel-item-width: calc(var(--ais-spacing) * 10);
  /* Autocomplete component */
  --ais-autocomplete-search-input-height: 44px;
  --ais-autocomplete-panel-max-height: 650px;
  /* Touch screens */
}
@media (hover: none) and (pointer: coarse) {
  :root {
    --ais-spacing-factor: 1.2;
  }
}

/* Dark Mode */
:root[data-theme=dark],
.dark {
  /* Text colors */
  --ais-text-color-rgb: 255, 255, 255;
  --ais-primary-color-rgb: 110, 160, 255;
  --ais-muted-color-rgb: 190, 190, 190;
  --ais-button-text-color-rgb: 255, 255, 255;
  /* Border color */
  --ais-border-color-rgb: 100, 100, 100;
  /* Background color */
  --ais-background-color-rgb: 38, 38, 38;
  /* Shadow color */
  --ais-shadow-color-rgb: 0, 0, 0;
}

.ais-Scrollbar, .ais-AutocompletePanelLayout, .ais-ChatMessage-message .ais-Carousel-list {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, rgb(var(--ais-muted-color-rgb)) 40%, rgb(var(--ais-background-color-rgb))) transparent;
}

.ais-Scrollbar::-webkit-scrollbar, .ais-AutocompletePanelLayout::-webkit-scrollbar, .ais-ChatMessage-message .ais-Carousel-list::-webkit-scrollbar {
  width: 6px;
}

.ais-Scrollbar::-webkit-scrollbar-track, .ais-AutocompletePanelLayout::-webkit-scrollbar-track, .ais-ChatMessage-message .ais-Carousel-list::-webkit-scrollbar-track {
  background-color: transparent;
}

.ais-Scrollbar::-webkit-scrollbar-thumb, .ais-AutocompletePanelLayout::-webkit-scrollbar-thumb, .ais-ChatMessage-message .ais-Carousel-list::-webkit-scrollbar-thumb {
  background-color: color-mix(in srgb, rgb(var(--ais-muted-color-rgb)) 40%, rgb(var(--ais-background-color-rgb)));
  border-radius: var(--ais-border-radius-sm);
}

.ais-ChatMessage-message .ais-Carousel-list:focus-visible, .ais-Button:focus-visible {
  outline: 2px solid rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
  outline-offset: 2px;
}

.ais-Button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: calc(var(--ais-spacing) * 0.25);
  margin: 0;
  background-color: transparent;
  border-radius: var(--ais-border-radius-sm);
  font-family: inherit;
  font-size: var(--ais-font-size);
  line-height: 1em;
}
.ais-Button svg {
  stroke-width: var(--ais-icon-stroke-width);
  width: var(--ais-icon-size);
  height: auto;
}
.ais-Button:disabled {
  cursor: not-allowed;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-Button {
    transition: background-color var(--ais-transition-duration) var(--ais-transition-timing-function), color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-Button--sm {
  padding: calc(var(--ais-spacing) * 0.25) calc(var(--ais-spacing) * 0.5);
}

.ais-Button--md {
  padding: calc(var(--ais-spacing) * 0.5) calc(var(--ais-spacing) * 1);
}

.ais-Button--icon-only.ais-Button--sm {
  padding: calc(var(--ais-spacing) * 0.25);
}

.ais-Button--icon-only.ais-Button--md {
  padding: calc(var(--ais-spacing) * 0.5);
}

.ais-Button--primary {
  background-color: rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
  color: rgba(var(--ais-button-text-color-rgb), var(--ais-button-text-color-alpha));
}
.ais-Button--primary:disabled {
  background-color: rgba(var(--ais-primary-color-rgb), calc(var(--ais-primary-color-alpha) * 0.5));
}
@media (hover: hover) {
  .ais-Button--primary:hover:not(:disabled) {
    background-color: color-mix(in srgb, rgb(var(--ais-primary-color-rgb)), rgb(var(--ais-background-color-rgb)) 20%);
  }
}
.ais-Button--primary:active:not(:disabled) {
  background-color: rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
}

.ais-Button--ghost {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
}
.ais-Button--ghost:disabled {
  color: rgba(var(--ais-muted-color-rgb), 0.5);
}
@media (hover: hover) {
  .ais-Button--ghost:hover:not(:disabled) {
    background-color: rgba(var(--ais-muted-color-rgb), 0.1);
  }
}
.ais-Button--ghost:active:not(:disabled) {
  background-color: rgba(var(--ais-muted-color-rgb), 0.2);
}

.ais-Button--outline {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  background-color: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  border: 1px solid color-mix(in srgb, rgb(var(--ais-muted-color-rgb)) 30%, rgb(var(--ais-background-color-rgb)));
}
.ais-Button--outline:disabled {
  color: rgba(var(--ais-text-color-rgb), 0.4);
}
@media (hover: hover) {
  .ais-Button--outline:hover:not(:disabled) {
    background-color: color-mix(in srgb, rgb(var(--ais-muted-color-rgb)) 10%, rgb(var(--ais-background-color-rgb)));
  }
}
.ais-Button--outline:active:not(:disabled) {
  background-color: color-mix(in srgb, rgb(var(--ais-muted-color-rgb)) 20%, rgb(var(--ais-background-color-rgb)));
}

.ais-Chat {
  position: fixed;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: var(--ais-spacing);
  align-items: flex-end;
  right: var(--ais-chat-margin);
  bottom: var(--ais-chat-margin);
  width: var(--ais-chat-width);
  height: var(--ais-chat-height);
  max-width: calc(100% - var(--ais-chat-margin) * 2);
  max-height: calc(100% - var(--ais-chat-margin) * 2);
  z-index: var(--ais-z-index-chat);
  pointer-events: none;
}
.ais-Chat--maximized {
  width: var(--ais-chat-maximized-width);
  height: var(--ais-chat-maximized-height);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-Chat {
    transition: width var(--ais-transition-duration) var(--ais-transition-timing-function), height var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-Chat-container {
  display: flex;
  flex-direction: column;
  background-color: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  border-radius: var(--ais-border-radius-lg);
  box-shadow: var(--ais-shadow-md);
  border: 1px solid rgba(var(--ais-border-color-rgb), 0.2);
  width: 100%;
  height: 100%;
  overflow: hidden;
  opacity: 0;
  transform-origin: bottom right;
  transform: scale(0.95) translateY(var(--ais-spacing));
}
@media (prefers-reduced-motion: no-preference) {
  .ais-Chat-container {
    transition: opacity var(--ais-transition-duration) var(--ais-transition-timing-function), transform var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
.ais-Chat-container--open {
  pointer-events: auto;
  opacity: 1;
  transform: scale(1) translateY(0);
}

.ais-Chat-toggleButtonWrapper {
  pointer-events: auto;
}

@media (max-width: 680px) {
  .ais-Chat {
    inset: 0;
    height: 100%;
    width: 100%;
    transition: none;
    max-width: initial;
    max-height: initial;
    gap: 0;
  }
  .ais-Chat-container {
    border-radius: 0;
    transition: none;
  }
}
.ais-ChatToggleButton {
  width: calc(var(--ais-spacing) * 3);
  height: calc(var(--ais-spacing) * 3);
  border-radius: var(--ais-border-radius-full);
  box-shadow: var(--ais-shadow-sm);
  flex-shrink: 0;
}
.ais-ChatToggleButton svg {
  width: calc(var(--ais-icon-size) * 1.4);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatToggleButton {
    transition: transform var(--ais-transition-duration) var(--ais-transition-timing-function), background-color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-ChatToggleButton--open {
  transform: rotate(180deg);
}

@media (max-width: 680px) {
  .ais-ChatToggleButton {
    position: relative;
    right: var(--ais-chat-margin);
    bottom: var(--ais-chat-margin);
  }
  .ais-ChatToggleButton.ais-ChatToggleButton--open {
    display: none;
  }
}
.ais-ChatHeader {
  display: flex;
  gap: calc(var(--ais-spacing) * 2);
  align-items: center;
  justify-content: space-between;
  padding: var(--ais-spacing);
  border-bottom: 1px solid rgba(var(--ais-border-color-rgb), 0.2);
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  position: relative;
}
.ais-ChatHeader::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  margin-top: 1px;
  height: calc(var(--ais-spacing) - 1px);
  background: linear-gradient(to bottom, rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha)), transparent);
  pointer-events: none;
  z-index: 1;
}

.ais-ChatHeader-title {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) / 2);
  font-weight: var(--ais-font-weight-semibold);
}

.ais-ChatHeader-titleIcon {
  display: inline-flex;
  align-items: center;
  color: rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
}
.ais-ChatHeader-titleIcon svg {
  width: var(--ais-icon-size);
  height: auto;
}

.ais-ChatHeader-actions {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) / 2);
}
.ais-ChatHeader-actions svg {
  width: calc(var(--ais-icon-size) * 0.8);
}

.ais-ChatHeader-clear {
  font-size: calc(var(--ais-spacing) * 0.875);
}

@media (max-width: 680px) {
  .ais-ChatHeader-maximize {
    display: none;
  }
}
.ais-ChatMessages {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  height: 100%;
}

.ais-ChatMessages-scroll {
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: none;
  width: 100%;
  height: 100%;
  padding: var(--ais-spacing);
}

.ais-ChatMessages-content {
  display: flex;
  flex-direction: column;
  gap: calc(var(--ais-spacing) * 1.5);
  width: 100%;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessages-content {
    transition: opacity var(--ais-transition-duration) var(--ais-transition-timing-function), filter var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-ChatMessages-content--clearing {
  opacity: 0;
  filter: blur(8px);
}

.ais-ChatMessages-scrollToBottom {
  position: absolute;
  bottom: var(--ais-spacing);
  left: 50%;
  transform: translateX(-50%);
  width: calc(var(--ais-spacing) * 1.5);
  height: calc(var(--ais-spacing) * 1.5);
  border-radius: var(--ais-border-radius-full);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessages-scrollToBottom {
    transition: background-color var(--ais-transition-duration) var(--ais-transition-timing-function), transform var(--ais-transition-duration) var(--ais-transition-timing-function), opacity var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-ChatMessages-scrollToBottom--hidden {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(var(--ais-spacing)) scale(0.95);
}

.ais-ChatMessage {
  position: relative;
  width: 100%;
  scroll-margin-top: var(--ais-spacing);
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
}

.ais-ChatMessage-container {
  display: flex;
  align-items: flex-start;
  gap: calc(var(--ais-spacing) * 0.75);
  position: relative;
}

.ais-ChatMessage[data-role=user] .ais-ChatMessage-container {
  max-width: 70%;
}

.ais-ChatMessage--left .ais-ChatMessage-container {
  justify-content: flex-start;
}

.ais-ChatMessage--right .ais-ChatMessage-container {
  margin-inline-start: auto;
  flex-direction: row-reverse;
}

.ais-ChatMessage-leading {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ais-ChatMessage-content {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  min-width: 0;
}

.ais-ChatMessage-message {
  position: relative;
  text-wrap: pretty;
  font-size: calc(var(--ais-spacing) * 0.875);
  line-height: calc(var(--ais-spacing) * 1.25);
}
.ais-ChatMessage-message img {
  max-width: 100%;
  height: auto;
}

.ais-ChatMessage-code {
  overflow-x: auto;
}

.ais-ChatMessage--neutral .ais-ChatMessage-message {
  background-color: rgba(var(--ais-muted-color-rgb), 0.1);
  padding: calc(var(--ais-spacing) * 0.75);
  border-radius: var(--ais-border-radius-md);
}

.ais-ChatMessage-actions {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) * 0.25);
  position: relative;
}
.ais-ChatMessage-actions svg {
  width: calc(var(--ais-icon-size) * 0.8);
}

.ais-ChatMessage--right .ais-ChatMessage-actions {
  justify-content: flex-end;
}

.ais-ChatMessage--auto-hide-actions .ais-ChatMessage-actions {
  opacity: 0;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessage--auto-hide-actions .ais-ChatMessage-actions {
    transition: opacity var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

@media (hover: hover) {
  .ais-ChatMessage:hover .ais-ChatMessage-actions {
    opacity: 1;
  }
}
.ais-ChatMessageLoader .ais-ChatMessage-content {
  width: 100%;
}
.ais-ChatMessageLoader .ais-ChatMessage-message {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: calc(var(--ais-spacing) * 0.5);
}
.ais-ChatMessageLoader .ais-ChatMessageLoader-spinner {
  width: calc(var(--ais-spacing) * 1.5);
  height: calc(var(--ais-spacing) * 1.5);
  color: rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessageLoader .ais-ChatMessageLoader-spinner {
    animation: ais-chat-loader-spinner 1.4s linear infinite;
  }
}
.ais-ChatMessageLoader .ais-ChatMessageLoader-text {
  text-fill-color: transparent;
  -webkit-text-fill-color: transparent;
  background: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha)) linear-gradient(to right, rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha)) 0%, rgba(255, 255, 255, 0.75) 40%, rgba(255, 255, 255, 0.75) 60%, rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha)) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  background-repeat: no-repeat;
  background-size: 50% 200%;
  display: inline-block;
  background-position: -100% 0;
  font-weight: var(--ais-font-weight-medium);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessageLoader .ais-ChatMessageLoader-text {
    animation-delay: 0.5s;
    animation-duration: 3s;
    animation-iteration-count: infinite;
    animation-name: ais-chat-loader-text;
  }
}
.ais-ChatMessageLoader .ais-ChatMessageLoader-skeletonWrapper {
  display: flex;
  flex-direction: column;
  gap: calc(var(--ais-spacing) * 0.25);
}
.ais-ChatMessageLoader .ais-ChatMessageLoader-skeletonItem {
  height: var(--ais-spacing);
  background-color: rgba(var(--ais-muted-color-rgb), 0.2);
  border-radius: var(--ais-border-radius-sm);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessageLoader .ais-ChatMessageLoader-skeletonItem {
    animation: ais-chat-loader-skeleton 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  }
}
.ais-ChatMessageLoader .ais-ChatMessageLoader-skeletonItem:nth-child(2) {
  width: 40%;
}

@keyframes ais-chat-loader-spinner {
  0% {
    transform: rotate(0deg);
    stroke-dasharray: 1px, 200px;
    stroke-dashoffset: 0px;
  }
  50% {
    stroke-dasharray: 100px, 200px;
    stroke-dashoffset: -15px;
  }
  100% {
    transform: rotate(360deg);
    stroke-dasharray: 100px, 200px;
    stroke-dashoffset: -125px;
  }
}
@keyframes ais-chat-loader-skeleton {
  50% {
    opacity: 0.5;
  }
}
@keyframes ais-chat-loader-text {
  from {
    background-position: -100% 0%;
  }
  to {
    background-position: 250% 0%;
  }
}
.ais-ChatPrompt {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: calc(var(--ais-spacing) * 0.5);
  width: 100%;
  position: relative;
  padding: 0 var(--ais-spacing) var(--ais-spacing) var(--ais-spacing);
}
.ais-ChatPrompt::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 0;
  right: 0;
  height: var(--ais-spacing);
  background: linear-gradient(to top, rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha)), transparent);
  pointer-events: none;
}

.ais-ChatPrompt-header {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) * 0.375);
}

.ais-ChatPrompt-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--ais-spacing) * 0.375);
}
.ais-ChatPrompt-footer .ais-ChatPrompt-disclaimer {
  font-size: calc(var(--ais-spacing) * 0.75);
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
}

.ais-ChatPrompt-body {
  display: flex;
  flex-direction: column;
  width: 100%;
  overflow: hidden;
  background-color: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  border-radius: var(--ais-border-radius-sm);
  border: 1px solid rgba(var(--ais-border-color-rgb), var(--ais-border-color-alpha));
  outline: 1px solid transparent;
  z-index: 1;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatPrompt-body {
    transition: border-color var(--ais-transition-duration) var(--ais-transition-timing-function), outline-color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}

.ais-ChatPrompt-body:focus-within {
  outline: 1px solid rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
  border-color: rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
}

.ais-ChatPrompt-textarea {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: transparent;
  border: none;
  outline: none;
  resize: none;
  padding: calc(var(--ais-spacing) * 0.75);
  padding-bottom: 0;
  caret-color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  font-family: inherit;
  line-height: inherit;
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  font-size: calc(var(--ais-spacing) * 0.875);
  line-height: 1.25rem;
}

.ais-ChatPrompt-textarea::-moz-placeholder {
  color: rgba(var(--ais-text-color-rgb), 0.7);
}

.ais-ChatPrompt-textarea::placeholder {
  color: rgba(var(--ais-text-color-rgb), 0.7);
}

.ais-ChatPrompt-textarea:disabled,
.ais-ChatPrompt-actions--disabled {
  background-color: rgba(var(--ais-muted-color-rgb), 0.1);
}

.ais-ChatPrompt-actions {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  padding: calc(var(--ais-spacing) * 0.75);
  padding-top: calc(var(--ais-spacing) * 0.5);
  cursor: text;
}
.ais-ChatPrompt-actions svg {
  width: calc(var(--ais-icon-size) * 0.8);
}

@media (max-width: 680px) {
  .ais-ChatPrompt .ais-ChatPrompt-textarea {
    font-size: var(--ais-spacing);
  }
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: calc(var(--ais-spacing) * 0.5);
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderResults {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) * 0.5);
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderCount {
  color: rgba(var(--ais-text-color-rgb), 0.8);
  font-weight: var(--ais-font-weight-semibold);
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderViewAll svg {
  width: calc(var(--ais-icon-size) * 0.8);
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderScrollButtons {
  display: flex;
  align-items: center;
  gap: calc(var(--ais-spacing) * 0.25);
}
.ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderScrollButtons svg {
  width: calc(var(--ais-icon-size) * 0.8);
}
.ais-ChatMessage-message .ais-Carousel {
  position: relative;
}
.ais-ChatMessage-message .ais-Carousel a {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  text-decoration: none;
}
.ais-ChatMessage-message .ais-Carousel::before, .ais-ChatMessage-message .ais-Carousel::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--ais-spacing);
  pointer-events: none;
  z-index: 1;
}
.ais-ChatMessage-message .ais-Carousel::before {
  left: calc(-1 * var(--ais-spacing));
  background: linear-gradient(to right, rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha)), transparent);
}
.ais-ChatMessage-message .ais-Carousel::after {
  right: calc(-1 * var(--ais-spacing));
  background: linear-gradient(to left, rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha)), transparent);
}
.ais-ChatMessage-message .ais-Carousel-list {
  gap: 0;
  grid-auto-columns: var(--ais-chat-carousel-item-width) !important;
  margin-left: calc(-1 * var(--ais-spacing));
  margin-right: calc(-1 * var(--ais-spacing));
  padding-left: calc(var(--ais-spacing) * 0.5);
  padding-right: calc(var(--ais-spacing) * 0.5);
  scroll-padding-left: calc(var(--ais-spacing) * 0.5);
  scroll-padding-right: calc(var(--ais-spacing) * 0.5);
  outline: none;
}
.ais-ChatMessage-message .ais-Carousel-list:has(.ais-Carousel-item:only-child) {
  grid-auto-columns: calc(var(--ais-chat-carousel-item-width) * 1.5) !important;
}
.ais-ChatMessage-message .ais-Carousel-hit {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: calc(var(--ais-spacing) * 0.5);
  border-radius: var(--ais-border-radius-md);
  padding: calc(var(--ais-spacing) * 0.5);
  height: 100%;
}
.ais-ChatMessage-message .ais-Carousel-hit::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: var(--ais-border-radius-md);
  background-color: rgba(var(--ais-muted-color-rgb), 0);
  pointer-events: none;
  z-index: -1;
  transform: scale(0.95);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessage-message .ais-Carousel-hit::before {
    transition: all var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
@media (hover: hover) {
  .ais-ChatMessage-message .ais-Carousel-hit:hover::before {
    background-color: rgba(var(--ais-muted-color-rgb), 0.1);
    transform: scale(1);
  }
  .ais-ChatMessage-message .ais-Carousel-hit:hover .ais-Carousel-hit-image img {
    transform: scale(1.05);
  }
}
.ais-ChatMessage-message .ais-Carousel-hit:active:not(:disabled)::before {
  background-color: rgba(var(--ais-muted-color-rgb), 0.2);
}
.ais-ChatMessage-message .ais-Carousel-hit:has(:focus-visible) {
  outline: 2px solid rgba(var(--ais-primary-color-rgb), var(--ais-primary-color-alpha));
  outline-offset: 2px;
}
.ais-ChatMessage-message .ais-Carousel-hit-title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.ais-ChatMessage-message .ais-Carousel-hit-link::before {
  content: "";
  position: absolute;
  inset: 0;
}
.ais-ChatMessage-message .ais-Carousel-hit-link:focus-visible {
  outline: none;
}
.ais-ChatMessage-message .ais-Carousel-hit-image {
  position: relative;
  display: flex;
  justify-content: center;
  border-radius: var(--ais-border-radius-md);
  overflow: hidden;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-ChatMessage-message .ais-Carousel-hit-image img {
    transition: transform var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
.ais-ChatMessage-message .ais-Carousel-hit-favorite {
  position: absolute;
  top: calc(var(--ais-spacing) * 0.5);
  right: calc(var(--ais-spacing) * 0.5);
  z-index: 1;
}
.ais-ChatMessage-message .ais-Carousel-hit-title {
  font-weight: normal;
}
.ais-ChatMessage-message .ais-Carousel-hit-title a {
  font-size: var(--ais-spacing);
}
.ais-ChatMessage-message .ais-Carousel-hit-title,
.ais-ChatMessage-message .ais-Carousel-hit-price {
  margin: 0;
}
.ais-ChatMessage-message .ais-Carousel-hit-price {
  font-weight: var(--ais-font-weight-semibold);
  margin-top: auto;
}
@media (max-width: 680px) {
  .ais-ChatMessage-message .ais-ChatToolSearchIndexCarouselHeaderScrollButtons {
    display: none;
  }
}

.ais-AutocompletePanel, .ais-Autocomplete,
.ais-DetachedFormContainer {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  font-family: inherit;
  font-size: var(--ais-font-size);
  font-weight: normal;
  line-height: 1em;
  margin: 0;
  padding: 0;
  text-align: left;
  position: relative;
}

.ais-AutocompleteForm {
  align-items: center;
  background-color: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  border: 1px solid rgba(var(--ais-border-color-rgb), 0.8);
  border-radius: var(--ais-border-radius-sm);
  display: flex;
  line-height: 1em;
  margin: 0;
  position: relative;
  width: 100%;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-AutocompleteForm {
    transition: border-color var(--ais-transition-duration) var(--ais-transition-timing-function), box-shadow var(--ais-transition-duration) var(--ais-transition-timing-function), outline-color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
.ais-AutocompleteForm:focus-within {
  border-color: rgba(var(--ais-primary-color-rgb), 1);
  box-shadow: rgba(var(--ais-primary-color-rgb), 0.2) 0 0 0 2px, inset rgba(var(--ais-primary-color-rgb), 0.2) 0 0 0 2px;
  outline: currentColor none medium;
}
.ais-AutocompleteInputWrapperPrefix {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  height: var(--ais-autocomplete-search-input-height);
  order: 1;
}
.ais-AutocompleteLabel,
.ais-AutocompleteLoadingIndicator {
  cursor: initial;
  flex-shrink: 0;
  height: 100%;
  padding: 0;
  text-align: left;
}
.ais-AutocompleteLabel svg,
.ais-AutocompleteLoadingIndicator svg {
  color: rgba(var(--ais-primary-color-rgb), 1);
  height: auto;
  max-height: var(--ais-icon-size);
  stroke-width: var(--ais-icon-stroke-width);
  width: var(--ais-icon-size);
}

.ais-AutocompleteSubmitButton,
.ais-AutocompleteLoadingIndicator {
  height: 100%;
  padding-left: calc(var(--ais-spacing) * 0.75 - 1px);
  padding-right: calc(var(--ais-spacing) / 2);
  width: calc(var(--ais-spacing) * 1.75 + var(--ais-icon-size) - 1px);
}
@media (hover: none) and (pointer: coarse) {
  .ais-AutocompleteSubmitButton,
  .ais-AutocompleteLoadingIndicator {
    padding-left: calc(var(--ais-spacing) / 2 / 2 - 1px);
    width: calc(var(--ais-icon-size) + var(--ais-spacing) * 1.25 - 1px);
  }
}

.ais-AutocompleteSubmitButton {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: 0;
  margin: 0;
}

.ais-AutocompleteLoadingIndicator {
  align-items: center;
  display: flex;
  justify-content: center;
}
.ais-AutocompleteLoadingIndicator[hidden] {
  display: none;
}

.ais-AutocompleteInputWrapper {
  order: 3;
  position: relative;
  width: 100%;
}
.ais-AutocompleteInput {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: 0;
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  font: inherit;
  height: var(--ais-autocomplete-search-input-height);
  padding: 0;
  width: 100%;
}
.ais-AutocompleteInput::-moz-placeholder {
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  opacity: 1;
}
.ais-AutocompleteInput::placeholder {
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  opacity: 1;
}
.ais-AutocompleteInput:focus {
  border-color: none;
  box-shadow: none;
  outline: none;
}
.ais-AutocompleteInput::-webkit-search-decoration, .ais-AutocompleteInput::-webkit-search-cancel-button, .ais-AutocompleteInput::-webkit-search-results-button, .ais-AutocompleteInput::-webkit-search-results-decoration {
  -webkit-appearance: none;
          appearance: none;
}

.ais-AutocompleteInputWrapperSuffix {
  align-items: center;
  display: flex;
  height: var(--ais-autocomplete-search-input-height);
  order: 4;
}
.ais-AutocompleteClearButton {
  align-items: center;
  background: none;
  border: 0;
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  cursor: pointer;
  display: flex;
  height: 100%;
  margin: 0;
  padding: 0 calc(var(--ais-spacing) * 0.8333333333 - 0.5px);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-AutocompleteClearButton {
    transition: color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
@media (hover: none) and (pointer: coarse) {
  .ais-AutocompleteClearButton {
    padding: 0 calc(var(--ais-spacing) * 0.6666666667 - 0.5px);
  }
}
@media (hover: hover) {
  .ais-AutocompleteClearButton:hover {
    color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  }
}
.ais-AutocompleteClearButton:focus {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
}
.ais-AutocompleteClearButton[hidden] {
  display: none;
}
.ais-AutocompleteClearButton svg {
  stroke-width: var(--ais-icon-stroke-width);
  width: var(--ais-icon-size);
}

.ais-AutocompletePanel {
  background-color: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  border-radius: var(--ais-border-radius-sm);
  box-shadow: var(--ais-shadow-lg);
  border: 1px solid rgba(var(--ais-border-color-rgb), 0.2);
  margin: 8px 0 0;
  position: absolute;
  width: 100%;
  z-index: var(--ais-z-index-autocomplete);
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transform-origin: top center;
  transform: scale(0.95) translateY(calc(var(--ais-spacing) * -1));
}
@media (prefers-reduced-motion: no-preference) {
  .ais-AutocompletePanel {
    transition: opacity var(--ais-transition-duration) var(--ais-transition-timing-function), transform var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
.ais-AutocompletePanel--open {
  opacity: 1;
  pointer-events: auto;
  transform: scale(1) translateY(0);
}
.ais-AutocompletePanel button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: 0;
  margin: 0;
  padding: 0;
}
.ais-AutocompletePanelLayout {
  height: 100%;
  margin: 0;
  max-height: var(--ais-autocomplete-panel-max-height);
  overflow-y: auto;
  padding: calc(var(--ais-spacing) / 2);
  position: relative;
  text-align: left;
}

.ais-AutocompleteIndex {
  margin: 0;
  padding: 0;
  position: relative;
  width: 100%;
}
.ais-AutocompleteIndex:empty {
  display: none;
}
.ais-AutocompleteIndexNoResults {
  font-size: 1em;
  margin: 0;
  padding: var(--ais-spacing);
}

.ais-AutocompleteIndexList {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.ais-AutocompleteIndexHeader {
  margin: calc(var(--ais-spacing) / 2) 0.5em calc(var(--ais-spacing) / 2) 0;
  padding: 0;
  position: relative;
}
.ais-AutocompleteIndexHeader:empty {
  display: none;
}

.ais-AutocompleteIndexHeaderTitle {
  background: rgba(var(--ais-background-color-rgb), var(--ais-background-color-alpha));
  color: rgba(var(--ais-primary-color-rgb), 1);
  display: inline-block;
  font-size: 0.8em;
  font-weight: var(--ais-font-weight-semibold);
  margin: 0;
  padding: 0 calc(var(--ais-spacing) / 2) 0 0;
  position: relative;
  z-index: 2;
}

.ais-AutocompleteIndexHeaderLine {
  border-bottom: solid 1px rgba(var(--ais-primary-color-rgb), 1);
  display: block;
  height: 2px;
  left: 0;
  margin: 0;
  opacity: 0.3;
  padding: 0;
  position: absolute;
  right: 0;
  top: calc(var(--ais-spacing) / 2);
  z-index: 1;
}

.ais-AutocompleteIndexItem {
  align-items: center;
  border-radius: var(--ais-border-radius-sm);
  cursor: pointer;
  display: grid;
  min-height: calc(var(--ais-spacing) * 2.5);
  padding: calc(var(--ais-spacing) / 2 / 2);
}
@media (prefers-reduced-motion: no-preference) {
  .ais-AutocompleteIndexItem {
    transition: background-color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
@media (hover: hover) {
  .ais-AutocompleteIndexItem:hover {
    background-color: rgba(var(--ais-primary-color-rgb), 0.1);
  }
}
.ais-AutocompleteIndexItem[aria-selected=true] {
  background-color: rgba(var(--ais-primary-color-rgb), 0.1);
}
.ais-AutocompleteItemWrapper {
  align-items: center;
  color: inherit;
  display: grid;
  gap: calc(var(--ais-spacing) / 2 / 2);
  grid-auto-flow: column;
  justify-content: space-between;
  width: 100%;
}

.ais-AutocompleteItemContent {
  align-items: center;
  cursor: pointer;
  display: grid;
  gap: calc(var(--ais-spacing) / 2);
  grid-auto-flow: column;
  line-height: 1.25em;
  overflow: hidden;
}
.ais-AutocompleteItemContent:empty {
  display: none;
}
.ais-AutocompleteItemContent mark {
  background: none;
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
  font-style: normal;
  font-weight: var(--ais-font-weight-bold);
}

.ais-AutocompleteItemIcon {
  align-items: center;
  border-radius: var(--ais-border-radius-sm);
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  display: flex;
  flex-shrink: 0;
  font-size: 0.7em;
  height: calc(var(--ais-icon-size) + var(--ais-spacing) / 2);
  justify-content: center;
  overflow: hidden;
  stroke-width: var(--ais-icon-stroke-width);
  text-align: center;
  width: calc(var(--ais-icon-size) + var(--ais-spacing) / 2);
}
.ais-AutocompleteItemIcon svg {
  height: var(--ais-icon-size);
  width: var(--ais-icon-size);
}

.ais-AutocompleteItemActions {
  display: grid;
  grid-auto-flow: column;
  height: 100%;
  justify-self: end;
}

.ais-AutocompleteItemActionButton {
  align-items: center;
  background: none;
  border: 0;
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  cursor: pointer;
  display: flex;
  flex-shrink: 0;
  padding: 0;
}
@media (prefers-reduced-motion: no-preference) {
  .ais-AutocompleteItemActionButton {
    transition: color var(--ais-transition-duration) var(--ais-transition-timing-function);
  }
}
.ais-AutocompleteItemActionButton:hover svg, .ais-AutocompleteItemActionButton:focus svg {
  color: rgba(var(--ais-text-color-rgb), var(--ais-text-color-alpha));
}
@media (hover: none) and (pointer: coarse) {
  .ais-AutocompleteItemActionButton:hover svg, .ais-AutocompleteItemActionButton:focus svg {
    color: inherit;
  }
}
.ais-AutocompleteItemActionButton svg {
  color: rgba(var(--ais-muted-color-rgb), var(--ais-muted-color-alpha));
  margin: 0;
  margin: calc(var(--ais-spacing) / 3);
  stroke-width: var(--ais-icon-stroke-width);
  width: var(--ais-icon-size);
}

[class^=ais-] {
  font-size: 1rem;
}

a[class^=ais-] {
  text-decoration: none;
}

.ais-Breadcrumb,
.ais-ClearRefinements,
.ais-CurrentRefinements,
.ais-GeoSearch,
.ais-FrequentlyBoughtTogether,
.ais-HierarchicalMenu,
.ais-Hits,
.ais-Results,
.ais-HitsPerPage,
.ais-ResultsPerPage,
.ais-InfiniteHits,
.ais-InfiniteResults,
.ais-LookingSimilar,
.ais-Menu,
.ais-MenuSelect,
.ais-NumericMenu,
.ais-NumericSelector,
.ais-Pagination,
.ais-Panel,
.ais-PoweredBy,
.ais-RangeInput,
.ais-RangeSlider,
.ais-RatingMenu,
.ais-RefinementList,
.ais-RelatedProducts,
.ais-SearchBox,
.ais-RelevantSort,
.ais-SortBy,
.ais-Stats,
.ais-TrendingItems,
.ais-ToggleRefinement {
  color: rgb(58, 69, 112);
}

.ais-Breadcrumb-item--selected,
.ais-HierarchicalMenu-item--selected,
.ais-Menu-item--selected {
  font-weight: bold;
}

.ais-Breadcrumb-separator {
  margin: 0 0.3em;
  font-weight: normal;
}

.ais-Breadcrumb-link,
.ais-HierarchicalMenu-link,
.ais-Menu-link,
.ais-Pagination-link,
.ais-RatingMenu-link {
  color: #0096db;
  transition: color 0.2s ease-out;
}
.ais-Breadcrumb-link:hover, .ais-Breadcrumb-link:focus,
.ais-HierarchicalMenu-link:hover,
.ais-HierarchicalMenu-link:focus,
.ais-Menu-link:hover,
.ais-Menu-link:focus,
.ais-Pagination-link:hover,
.ais-Pagination-link:focus,
.ais-RatingMenu-link:hover,
.ais-RatingMenu-link:focus {
  color: #0073a8;
}

.ais-ClearRefinements-button,
.ais-CurrentRefinements-reset,
.ais-GeoSearch-redo,
.ais-GeoSearch-reset,
.ais-HierarchicalMenu-showMore,
.ais-InfiniteHits-loadPrevious,
.ais-InfiniteHits-loadMore,
.ais-InfiniteResults-loadMore,
.ais-Menu-showMore,
.ais-RefinementList-showMore,
.ais-RelevantSort-button,
.ais-Carousel-navigation {
  padding: 0.3rem 0.5rem;
  font-size: 0.8rem;
  color: #fff;
  background-color: #0096db;
  border-radius: 5px;
  transition: background-color 0.2s ease-out;
  outline: none;
}
.ais-ClearRefinements-button:hover, .ais-ClearRefinements-button:focus,
.ais-CurrentRefinements-reset:hover,
.ais-CurrentRefinements-reset:focus,
.ais-GeoSearch-redo:hover,
.ais-GeoSearch-redo:focus,
.ais-GeoSearch-reset:hover,
.ais-GeoSearch-reset:focus,
.ais-HierarchicalMenu-showMore:hover,
.ais-HierarchicalMenu-showMore:focus,
.ais-InfiniteHits-loadPrevious:hover,
.ais-InfiniteHits-loadPrevious:focus,
.ais-InfiniteHits-loadMore:hover,
.ais-InfiniteHits-loadMore:focus,
.ais-InfiniteResults-loadMore:hover,
.ais-InfiniteResults-loadMore:focus,
.ais-Menu-showMore:hover,
.ais-Menu-showMore:focus,
.ais-RefinementList-showMore:hover,
.ais-RefinementList-showMore:focus,
.ais-RelevantSort-button:hover,
.ais-RelevantSort-button:focus,
.ais-Carousel-navigation:hover,
.ais-Carousel-navigation:focus {
  background-color: #0073a8;
}

.ais-ClearRefinements-button--disabled,
.ais-GeoSearch-redo--disabled,
.ais-GeoSearch-reset--disabled,
.ais-HierarchicalMenu-showMore--disabled,
.ais-InfiniteHits-loadMore--disabled,
.ais-InfiniteResults-loadMore--disabled,
.ais-Menu-showMore--disabled,
.ais-RefinementList-showMore--disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.ais-ClearRefinements-button--disabled:hover, .ais-ClearRefinements-button--disabled:focus,
.ais-GeoSearch-redo--disabled:hover,
.ais-GeoSearch-redo--disabled:focus,
.ais-GeoSearch-reset--disabled:hover,
.ais-GeoSearch-reset--disabled:focus,
.ais-HierarchicalMenu-showMore--disabled:hover,
.ais-HierarchicalMenu-showMore--disabled:focus,
.ais-InfiniteHits-loadMore--disabled:hover,
.ais-InfiniteHits-loadMore--disabled:focus,
.ais-InfiniteResults-loadMore--disabled:hover,
.ais-InfiniteResults-loadMore--disabled:focus,
.ais-Menu-showMore--disabled:hover,
.ais-Menu-showMore--disabled:focus,
.ais-RefinementList-showMore--disabled:hover,
.ais-RefinementList-showMore--disabled:focus {
  background-color: #0096db;
}

.ais-InfiniteHits-loadPrevious--disabled {
  display: none;
}

@media (hover: none) and (pointer: coarse) {
  .ais-Carousel-navigation {
    display: none;
  }
}
.ais-Carousel-navigation,
.ais-Carousel-navigation[hidden] {
  opacity: 0;
  visibility: hidden;
}

.ais-Carousel:hover .ais-Carousel-navigation:not([hidden]) {
  opacity: 1;
  visibility: visible;
}

.ais-Carousel-list {
  padding-bottom: 0.5rem;
  gap: 0.5rem;
  outline-color: #0096db;
  outline-offset: 0.5rem;
  scrollbar-color: rgb(58, 69, 112) rgb(196, 200, 216);
  scrollbar-width: thin;
}

.ais-Carousel-list::-webkit-scrollbar {
  height: 2px;
}

.ais-Carousel-list::-webkit-scrollbar-track {
  background-color: rgb(196, 200, 216);
}

.ais-Carousel-list::-webkit-scrollbar-thumb {
  background-color: rgb(58, 69, 112);
}

.ais-CurrentRefinements {
  margin-top: -0.3rem;
  display: flex;
  flex-wrap: wrap;
}

.ais-CurrentRefinements-list {
  display: flex;
  flex-wrap: wrap;
}

.ais-CurrentRefinements-item {
  margin-right: 0.3rem;
  margin-top: 0.3rem;
  padding: 0.3rem 0.5rem;
  display: flex;
  background-color: rgb(73, 85, 136);
  border-radius: 5px;
}

.ais-CurrentRefinements-category {
  margin-left: 0.3em;
  display: flex;
}

.ais-CurrentRefinements-delete {
  margin-left: 0.3rem;
}

.ais-CurrentRefinements-label,
.ais-CurrentRefinements-categoryLabel,
.ais-CurrentRefinements-delete {
  white-space: nowrap;
  font-size: 0.8rem;
  color: #fff;
}

.ais-CurrentRefinements-reset {
  margin-top: 0.3rem;
  white-space: nowrap;
}
.ais-CurrentRefinements-reset + .ais-CurrentRefinements-list {
  margin-left: 0.3rem;
}

.ais-GeoSearch {
  position: relative;
}

.ais-GeoSearch-control {
  position: absolute;
  top: 0.8rem;
  left: 3.75rem;
}

.ais-GeoSearch-label {
  display: block;
  padding: 0.3rem 0.5rem;
  font-size: 0.8rem;
  background-color: #fff;
  border-radius: 5px;
  transition: background-color 0.2s ease-out;
  box-shadow: rgba(0, 0, 0, 0.1) 0 1px 1px;
  outline: none;
}

.ais-GeoSearch-input {
  margin: 0 0.25rem 0 0;
}

.ais-GeoSearch-label,
.ais-GeoSearch-redo,
.ais-GeoSearch-reset {
  white-space: nowrap;
}

.ais-GeoSearch-reset {
  position: absolute;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
}

.ais-HierarchicalMenu-link,
.ais-Menu-link {
  display: block;
  line-height: 1.5;
}

.ais-HierarchicalMenu-list,
.ais-Menu-list,
.ais-NumericMenu-list,
.ais-RatingMenu-list,
.ais-RefinementList-list {
  font-weight: normal;
  line-height: 1.5;
}

.ais-HierarchicalMenu-link:after {
  margin-left: 0.3em;
  content: "";
  width: 10px;
  height: 10px;
  display: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27%3E%3Cpath d=%27M7.3 24l-2.8-2.8 9.3-9.2-9.3-9.2 2.8-2.8 12.2 12z%27 fill%3D%22%233A4570%22 /%3E%3C/svg%3E");
  background-size: 100% 100%;
}
.ais-HierarchicalMenu-item--parent > .ais-HierarchicalMenu-link:after {
  display: inline-block;
}
.ais-HierarchicalMenu-item--selected > .ais-HierarchicalMenu-link:after {
  transform: rotate(90deg);
}

.ais-CurrentRefinements-count,
.ais-RatingMenu-count {
  font-size: 0.8rem;
}
.ais-CurrentRefinements-count:before,
.ais-RatingMenu-count:before {
  content: "(";
}
.ais-CurrentRefinements-count:after,
.ais-RatingMenu-count:after {
  content: ")";
}

.ais-HierarchicalMenu-count,
.ais-Menu-count,
.ais-RefinementList-count,
.ais-ToggleRefinement-count {
  padding: 0.1rem 0.4rem;
  font-size: 0.8rem;
  color: rgb(58, 69, 112);
  background-color: #dfe2ee;
  border-radius: 8px;
}

.ais-HierarchicalMenu-showMore,
.ais-Menu-showMore,
.ais-RefinementList-showMore {
  margin-top: 0.5rem;
}

.ais-Highlight-highlighted,
.ais-Snippet-highlighted {
  background-color: rgb(255, 193, 104);
}

.ais-ReverseHighlight-highlighted,
.ais-ReverseSnippet-highlighted {
  font-weight: bold;
  font-style: normal;
  background: none;
}

.ais-InfiniteHits-list,
.ais-InfiniteResults-list,
.ais-Hits-list,
.ais-FrequentlyBoughtTogether-list,
.ais-LookingSimilar-list,
.ais-RelatedProducts-list,
.ais-TrendingItems-list,
.ais-Results-list {
  margin-top: -1rem;
  margin-left: -1rem;
  display: flex;
  flex-wrap: wrap;
}
.ais-Panel-body .ais-InfiniteHits-list,
.ais-Panel-body .ais-InfiniteResults-list,
.ais-Panel-body .ais-Hits-list,
.ais-Panel-body .ais-FrequentlyBoughtTogether-list,
.ais-Panel-body .ais-LookingSimilar-list,
.ais-Panel-body .ais-RelatedProducts-list,
.ais-Panel-body .ais-TrendingItems-list,
.ais-Panel-body .ais-Results-list {
  margin: 0.5rem 0 0 -1rem;
}

.ais-InfiniteHits-item,
.ais-InfiniteResults-item,
.ais-Hits-item,
.ais-FrequentlyBoughtTogether-item,
.ais-LookingSimilar-item,
.ais-RelatedProducts-item,
.ais-TrendingItems-item,
.ais-Results-item {
  margin-top: 1rem;
  margin-left: 1rem;
  padding: 1rem;
  width: calc(25% - 1rem);
  border: 1px solid rgb(196, 200, 216);
  box-shadow: 0 2px 5px 0px #e3e5ec;
}
.ais-Panel-body .ais-InfiniteHits-item,
.ais-Panel-body .ais-InfiniteResults-item,
.ais-Panel-body .ais-Hits-item,
.ais-Panel-body .ais-FrequentlyBoughtTogether-item,
.ais-Panel-body .ais-LookingSimilar-item,
.ais-Panel-body .ais-RelatedProducts-item,
.ais-Panel-body .ais-TrendingItems-item,
.ais-Panel-body .ais-Results-item {
  margin: 0.5rem 0 0.5rem 1rem;
}

.ais-InfiniteHits-loadMore,
.ais-InfiniteResults-loadMore {
  margin-top: 1rem;
}

.ais-InfiniteHits-loadPrevious {
  margin-bottom: 1rem;
}

.ais-Hits-banner,
.ais-InfiniteHits-banner {
  display: flex;
  justify-content: center;
}

.ais-Hits-banner-image .ais-InfiniteHits-banner-image {
  max-width: 100%;
}

.ais-MenuSelect-select,
.ais-NumericSelector-select,
.ais-HitsPerPage-select,
.ais-ResultsPerPage-select,
.ais-SortBy-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0.3rem 2rem 0.3rem 0.3rem;
  max-width: 100%;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27%3E%3Cpath d=%27M0 7.3l2.8-2.8 9.2 9.3 9.2-9.3 2.8 2.8-12 12.2z%27 fill%3D%22%233A4570%22 /%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 10px 10px;
  background-position: 92% 50%;
  border: 1px solid rgb(196, 200, 216);
  border-radius: 5px;
}

.ais-Panel--collapsible {
  position: relative;
}
.ais-Panel--collapsible.ais-Panel--collapsed .ais-Panel-body,
.ais-Panel--collapsible.ais-Panel--collapsed .ais-Panel-footer {
  display: none;
}
.ais-Panel--collapsible .ais-Panel-collapseButton {
  position: absolute;
  top: 0;
  right: 0;
  padding: 0;
  border: none;
  background: none;
}

.ais-Panel-header {
  margin-bottom: 0.5rem;
  padding-bottom: 0.5rem;
  font-size: 0.8rem;
  font-weight: bold;
  text-transform: uppercase;
  border-bottom: 1px solid rgb(196, 200, 216);
}

.ais-Panel-footer {
  margin-top: 0.5rem;
  font-size: 0.8rem;
}

.ais-RangeInput-input {
  padding: 0 0.2rem;
  width: 5rem;
  height: 1.5rem;
  line-height: 1.5rem;
}

.ais-RangeInput-separator {
  margin: 0 0.3rem;
}

.ais-RangeInput-submit {
  margin-left: 0.3rem;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0 0.5rem;
  height: 1.5rem;
  line-height: 1.5rem;
  font-size: 0.8rem;
  color: #fff;
  background-color: #0096db;
  border: none;
  border-radius: 5px;
  transition: 0.2s ease-out;
  outline: none;
}
.ais-RangeInput-submit:hover, .ais-RangeInput-submit:focus {
  background-color: #0073a8;
}

.ais-RatingMenu-count {
  color: rgb(58, 69, 112);
}

.ais-Pagination-list {
  justify-content: center;
}

.ais-Pagination-item + .ais-Pagination-item {
  margin-left: 0.3rem;
}

.ais-Pagination-link {
  padding: 0.3rem 0.6rem;
  display: block;
  border: 1px solid rgb(196, 200, 216);
  border-radius: 5px;
  transition: background-color 0.2s ease-out;
}
.ais-Pagination-link:hover, .ais-Pagination-link:focus {
  background-color: #e3e5ec;
}
.ais-Pagination-item--disabled .ais-Pagination-link {
  opacity: 0.6;
  cursor: not-allowed;
  color: #a5abc4;
}
.ais-Pagination-item--disabled .ais-Pagination-link:hover, .ais-Pagination-item--disabled .ais-Pagination-link:focus {
  color: #a5abc4;
  background-color: #fff;
}
.ais-Pagination-item--selected .ais-Pagination-link {
  color: #fff;
  background-color: #0096db;
  border-color: #0096db;
}
.ais-Pagination-item--selected .ais-Pagination-link:hover, .ais-Pagination-item--selected .ais-Pagination-link:focus {
  color: #fff;
}

.ais-PoweredBy-text,
.rheostat-tooltip,
.rheostat-value,
.ais-Stats-text,
.ais-RelevantSort-text {
  font-size: 0.8rem;
}

.ais-RangeSlider .rheostat-progress {
  background-color: rgb(73, 85, 136);
}
.ais-RangeSlider .rheostat-background {
  border-color: #878faf;
  box-sizing: border-box;
}
.ais-RangeSlider .rheostat-handle {
  border-color: #878faf;
}
.ais-RangeSlider .rheostat-marker {
  background-color: #878faf;
}
.ais-Panel-body .ais-RangeSlider {
  margin: 2rem 0;
}

.ais-RangeSlider-handle {
  width: 20px;
  height: 20px;
  position: relative;
  z-index: 1;
  background: #ffffff;
  border: 1px solid #46aeda;
  border-radius: 50%;
  cursor: pointer;
}

.ais-RangeSlider-tooltip {
  position: absolute;
  background: #ffffff;
  top: -22px;
  font-size: 0.8em;
}

.ais-RangeSlider-value {
  width: 40px;
  position: absolute;
  text-align: center;
  margin-left: -20px;
  padding-top: 15px;
  font-size: 0.8em;
}

.ais-RangeSlider-marker {
  position: absolute;
  background: #ddd;
  margin-left: -1px;
  width: 1px;
  height: 5px;
}

.ais-RatingMenu-item--disabled .ais-RatingMenu-count,
.ais-RatingMenu-item--disabled .ais-RatingMenu-label {
  color: rgb(196, 200, 216);
}

.ais-RatingMenu-item--selected {
  font-weight: bold;
}

.ais-RatingMenu-link {
  line-height: 1.5;
}
.ais-RatingMenu-link > * + * {
  margin-left: 0.3rem;
}

.ais-RatingMenu-starIcon {
  position: relative;
  top: -1px;
  width: 15px;
  fill: rgb(255, 193, 104);
}
.ais-RatingMenu-item--disabled .ais-RatingMenu-starIcon {
  fill: rgb(196, 200, 216);
}

.ais-HierarchicalMenu-searchBox > *,
.ais-Menu-searchBox > *,
.ais-RefinementList-searchBox > * {
  margin-bottom: 0.5rem;
}

.ais-SearchBox-form {
  display: block;
  position: relative;
}

.ais-SearchBox-input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding: 0.3rem 1.7rem;
  width: 100%;
  position: relative;
  background-color: #fff;
  border: 1px solid rgb(196, 200, 216);
  border-radius: 5px;
}
.ais-SearchBox-input::-webkit-input-placeholder {
  color: #a5aed1;
}
.ais-SearchBox-input::-moz-placeholder {
  color: #a5aed1;
}
.ais-SearchBox-input:-ms-input-placeholder {
  color: #a5aed1;
}
.ais-SearchBox-input:-moz-placeholder {
  color: #a5aed1;
}

.ais-SearchBox-submit,
.ais-SearchBox-reset,
.ais-SearchBox-loadingIndicator {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  position: absolute;
  z-index: 1;
  width: 20px;
  height: 20px;
  top: 50%;
  right: 0.3rem;
  transform: translateY(-50%);
}

.ais-SearchBox-submit {
  left: 0.3rem;
}

.ais-SearchBox-reset {
  right: 0.3rem;
}

.ais-SearchBox-submitIcon,
.ais-SearchBox-resetIcon,
.ais-SearchBox-loadingIcon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}

.ais-SearchBox-submitIcon path,
.ais-SearchBox-resetIcon path {
  fill: rgb(73, 85, 136);
}

.ais-SearchBox-submitIcon {
  width: 14px;
  height: 14px;
}

.ais-SearchBox-resetIcon {
  width: 12px;
  height: 12px;
}

.ais-SearchBox-loadingIcon {
  width: 16px;
  height: 16px;
}

.ais-VoiceSearch-button {
  border: none;
  width: 24px;
  height: 24px;
  padding: 4px;
  border-radius: 50%;
  color: rgb(58, 69, 112);
  background-color: transparent;
}

.ais-VoiceSearch-button svg {
  color: currentColor;
}

.ais-VoiceSearch-button:hover {
  cursor: pointer;
  background-color: #a5aed1;
  color: #ffffff;
}

.ais-VoiceSearch-button:disabled {
  color: #a5aed1;
}

.ais-VoiceSearch-button:disabled:hover {
  color: #a5aed1;
  cursor: not-allowed;
  background: inherit;
}
