.price-compare {
    color: var(--border-secondary);
    padding: 0 .25rem
}

.product-thumb-slider {
    position: relative
}

.product-thumb-slider img {
    border-radius: var(--radius-secondary, .125rem)
}

.js-prod-thumb-slides:not(.fm-slider__slides) {
    display: flex
}

.product-thumb-slider__btn {
    align-items: center;
    background-color: #fff0;
    color: var(--surface-primary);
    display: flex;
    flex-direction: row;
    height: 2.77113rem;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    transition: all .25s ease-in-out;
    width: 2.77113rem;
    z-index: 3
}

.product-thumb-slider__btn.prev {
    left: 0
}

.product-thumb-slider__btn.next {
    right: 0
}

.product-thumb-slider__btn .icon {
    --icon-size: 1.39581rem
}

.product-thumb-swatches {
    align-items: center;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--spacing-small-300, .5rem);
    justify-content: flex-start
}

.product-thumb-swatch {
    border: 1px solid var(--border-swatch);
    border-radius: 50%;
    cursor: pointer;
    height: 1.25rem;
    position: relative;
    width: 1.25rem
}

.product-thumb-swatch:before {
    background-color: var(--swatch-background);
    background-position: 50%;
    background-size: cover;
    border-radius: 50%;
    content: "";
    display: block;
    height: 1rem;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 1rem
}

.product-thumb-swatch.active {
    border: 1px solid #000
}

.ptsm__wrapper {
    align-items: center;
    display: flex;
    flex-direction: row;
    gap: var(--spacing-small-300, .5rem);
    justify-content: flex-start
}

.ptsm__wrapper .ptsm__link {
    display: flex
}

.ptsm__link--text {
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5
}

product-swatches.ptsm__wrapper {
    display: grid;
    flex: 1 0 auto;
    gap: 0;
    grid-template-columns: 1fr
}

product-swatches.ptsm__wrapper .swiper {
    height: 100%;
    width: 100%
}

product-swatches.ptsm__wrapper .swiper-container {
    display: grid;
    gap: .5rem;
    grid-template-columns: -webkit-max-content minmax(0, 1fr) -webkit-max-content;
    grid-template-columns: max-content minmax(0, 1fr) max-content
}

product-swatches.ptsm__wrapper .product-thumb-swatch.unavailable {
    opacity: .5;
    pointer-events: none
}

product-swatches.ptsm__wrapper .product-thumb-swatch.swiper-slide {
    height: 2rem;
    width: 2rem
}

product-swatches.ptsm__wrapper .product-thumb-swatch.swiper-slide:before {
    height: 1.6rem;
    width: 1.6rem
}

product-swatches.ptsm__wrapper .quick-add-to-cart {
    align-self: end;
    margin-top: .5rem;
    opacity: 1;
    transition: opacity .3s ease
}

product-swatches.ptsm__wrapper .quick-add-to-cart.is-loading {
    cursor: not-allowed;
    opacity: .5;
    pointer-events: none;
    transition: opacity .3s ease
}

product-swatches.ptsm__wrapper .quick-add-to-cart .quick-add-to-cart__text {
    display: block
}

product-swatches.ptsm__wrapper .quick-add-to-cart.is-loading .quick-add-to-cart__text,
product-swatches.ptsm__wrapper .quick-add-to-cart .quick-add-to-cart__loading {
    display: none
}

product-swatches.ptsm__wrapper .quick-add-to-cart.is-loading .quick-add-to-cart__loading {
    display: block
}

product-swatches.ptsm__wrapper button.quick-add-to-cart:before {
    content: none
}

product-swatches.ptsm__wrapper .swiper-pagination {
    margin-top: .5rem;
    position: static
}

product-swatches.ptsm__wrapper .swiper-pagination .swiper-pagination-progressbar-fill {
    background-color: #fdeb98
}

product-swatches.ptsm__wrapper .swiper-button-next,
product-swatches.ptsm__wrapper .swiper-button-prev {
    border-radius: 50%;
    height: 2rem;
    margin-top: 0;
    position: static;
    width: 2rem
}

product-swatches.ptsm__wrapper .swiper-button-next:after,
product-swatches.ptsm__wrapper .swiper-button-prev:after {
    content: none
}

.product-reviews {
    align-items: center;
    color: var(--text-secondary);
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: flex-start
}

.product-reviews .icon {
    --icon-size: 1.125rem
}

.product-reviews__stars {
    align-items: center;
    display: flex;
    flex-direction: row;
    gap: .125rem;
    justify-content: flex-start
}

.product-reviews__count {
    display: block;
    font-size: .688rem;
    font-size: .813rem;
    font-weight: 500;
    line-height: 1.25;
    line-height: 1;
    text-transform: capitalize
}

.product-badge {
    background-color: var(--surface-accent);
    color: var(--text-primary);
    font-size: .688rem;
    font-weight: 600;
    left: .5rem;
    letter-spacing: .06875rem;
    line-height: 1.4;
    padding: var(--spacing-small-300, .5rem);
    position: absolute;
    text-transform: uppercase;
    top: .5rem;
    z-index: 2
}

.product-badges {
    align-items: center;
    box-sizing: border-box;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: .5rem;
    justify-content: space-between;
    left: 0;
    padding: 0 .5rem;
    position: absolute;
    top: .5rem;
    width: 100%;
    z-index: 1
}

.product-badges__badge {
    background-color: var(--surface-accent);
    color: var(--text-primary);
    font-size: .688rem;
    font-weight: 600;
    letter-spacing: .06875rem;
    line-height: 1.4;
    padding: var(--spacing-small-300, .5rem);
    text-transform: uppercase;
    z-index: 2
}

.product-badges__badge.new-arrival-badge {
    background-color: var(--badge-new-arrival-color);
    color: var(--badge-new-arrival-text-color)
}

.product-badges__badge.discount-percentage-badge {
    background-color: var(--badge-discount-color);
    color: var(--badge-discount-text-color)
}

.product-badges__badge.metafield-badge {
    background-color: var(--badge-metafield-color);
    color: var(--badge-metafield-text-color)
}

.product-thumb {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-base, 1rem);
    height: 100%;
    position: relative
}

.product-thumb a:first-of-type:before,
.product-thumb button:first-of-type:before {
    bottom: 0;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 100%;
    z-index: 1
}

.product-thumb a:first-of-type.focus-visible,
.product-thumb button:first-of-type.focus-visible {
    box-shadow: none
}

.product-thumb a:first-of-type.focus-visible:before,
.product-thumb button:first-of-type.focus-visible:before {
    border-color: inherit;
    border-radius: var(--radius-secondary, .125rem);
    box-shadow: 0 0 0 .125rem var(--surface-primary), 0 0 0 .25rem var(--border-focus);
    outline: none
}

.product-thumb:hover .product-thumb-slider__btn {
    background-color: var(--surface-subtle);
    color: var(--icon-link-primary)
}

.product-thumb .product-reviews {
    padding: .25rem 0 0
}

.product-thumb .product-thumb__img .swiper-slide {
    width: 100% !important
}

.product-thumb .product-thumb__img .swiper-slide .image-container {
    position: relative;
    overflow: hidden
}

.product-thumb .image-container .hover-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 0.3s ease;
    z-index: 2
}

.product-thumb:hover .image-container .hover-image {
    opacity: 1
}

.product-thumb a:first-of-type:before {
    content: none
}

.product-thumb__img {
    position: relative
}

.product-thumb__content-wrapper {
    display: flex;
    flex: 1 0 auto;
    flex-direction: column;
    gap: var(--spacing-small-500, 1.25rem)
}

.product-thumb__content {
    display: grid;
    gap: .5rem
}

.product-thumb__content--header {
    display: grid;
    gap: var(--spacing-small-100, .125rem)
}

.product-thumb__title {
    font-size: 1.188rem;
    font-weight: 400;
    letter-spacing: -.01188rem;
    line-height: 1.2;
    z-index: 2
}

.product-thumb__price {
    align-items: center;
    display: flex;
    flex-direction: row;
    font-size: .813rem;
    font-weight: 400;
    gap: var(--spacing-small-200, .25rem);
    justify-content: flex-start;
    letter-spacing: -.00813rem;
    line-height: 150%;
    padding: 0;
    position: relative;
    z-index: 2
}

.product-thumb__price .price-on-sale {
    color: var(--theme-sale-price-colour)
}

.product-thumb__price .price-compare {
    color: inherit;
    font-size: .813rem;
    letter-spacing: -.00813rem;
    opacity: .6;
    padding: 0
}

.product-thumb__footer {
    display: grid;
    margin-top: auto;
    width: 100%
}

.loox-rating .loox-icon {
    color: var(--icon-secondary) !important;
    height: auto;
    width: .9375rem
}

.loox-rating-label {
    color: var(--text-secondary);
    font-size: .813rem;
    font-weight: 400;
    line-height: 1;
    margin-left: .25rem
}

.product-thumb-small {
    align-items: flex-start;
    display: flex;
    flex-direction: row;
    gap: var(--spacing-small-500, 1.25rem);
    justify-content: flex-start;
    position: relative
}

.product-thumb-small__image {
    flex-shrink: 0;
    height: 9rem;
    position: relative;
    width: 9rem
}

.product-thumb-small__image img {
    bottom: 0;
    left: 0;
    position: absolute;
    right: 0;
    top: 0
}

.product-thumb-small__content {
    display: grid;
    gap: 0
}

.product-thumb-small__title {
    font-size: 1.188rem;
    font-weight: 400;
    letter-spacing: -.01188rem;
    line-height: 1.2
}

.product-thumb-small__price {
    align-items: flex-start;
    display: flex;
    flex-direction: row;
    font-size: .813rem;
    font-weight: 400;
    gap: var(--spacing-small-300, .5rem);
    justify-content: flex-start;
    letter-spacing: -.00813rem;
    line-height: 1;
    padding: .75rem 0 .25rem
}

.product-thumb-small__price .price-compare {
    font-size: .813rem;
    padding: 0
}

.product-thumb-small__options {
    color: var(--text-secondary);
    font-size: .813rem;
    font-weight: 400;
    line-height: 1;
    padding: var(--spacing-small-200, .25rem) 0
}

.slider {
    overflow: hidden;
    position: relative;
    width: 100%
}

.slider__slide {
    padding: 0
}

.slider__controls {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin: 0;
    width: 100%
}

.slider__controls button {
    min-width: 3rem
}

.slider__dots .fm-slider__dot--standard~label:before {
    background-color: #fff0;
    border: .0625rem solid;
    height: .75rem;
    opacity: 1;
    width: .75rem
}

.slider__dots .fm-slider__dot--standard:checked~label:before {
    background-color: currentColor
}

.slider__dots .fm-slider__dot--thumb~label {
    background-position: 50%;
    background-size: cover;
    border: none;
    height: 54px;
    margin: 2px;
    width: 54px
}

.slider__dots .fm-slider__dot--thumb.current~label {
    box-shadow: inset 0 0 0 2px var(--border-primary)
}

.slider__btn {
    flex-shrink: 0
}

.slider__autoplay-btn {
    background-color: var(--surface-primary);
    border-radius: 50%;
    left: spacing(2);
    position: absolute;
    top: spacing(2);
    z-index: 2
}

.slider__autoplay-btn .play {
    display: none
}

.slider__autoplay-btn.paused .play {
    display: block
}

.slider__autoplay-btn.paused .pause {
    display: none
}

.featured-products {
    padding: var(--spacing-primary-vertical, 2rem) 0;
    overflow: hidden;
}

.featured-products__header {
    display: grid;
    gap: var(--spacing-small-200, .25rem);
    padding-bottom: var(--spacing-primary-vertical);
    text-align: left
}

.featured-products__header--title {
    font-family: argent-cf, serif;
    font-size: 2.062rem;
    font-weight: 100;
    line-height: 1.2
}

.featured-products__header--desc {
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.5
}

.featured-products__content.fm-slider--active {
    margin-left: -.5rem;
    margin-right: -1.25rem;
    width: calc(100% + 1.75rem)
}

.featured-products__content.fm-slider--active .product-thumb {
    padding: 0 var(--spacing-small-300, .5rem)
}

.featured-products__content .featured-products__controls {
    padding: var(--spacing-primary-vertical, 2rem) var(--spacing-small-500, 1.25rem) 0 var(--spacing-small-300, .5rem)
}

@media only screen and (hover:hover) {
    .product-thumb__title:hover {
        text-decoration: underline
    }
}

@media only screen and (min-width:48em) {

    .product-thumb-small__title,
    .product-thumb__title {
        font-size: 1.438rem
    }

    div.featured-products__slides>.swiper-wrapper {
        display: grid;
        gap: var(--spacing-large-200, 2rem);
        grid-template-columns: repeat(1, minmax(0, 1fr))
    }
}

@media only screen and (min-width:64em) {
    .product-thumb-slider__btn {
        height: 3.375rem;
        width: 3.375rem
    }

    .product-thumb__content {
        gap: .75rem
    }

    .product-thumb__price,
    .product-thumb__price .price-compare {
        font-size: 1rem;
        letter-spacing: 0
    }

    .slider__dots .fm-slider__dot--thumb~label {
        height: 100px;
        width: 100px
    }

    .featured-products__header {
        text-align: center
    }

    .featured-products__header--title {
        font-size: 3rem;
        line-height: 1
    }

    .featured-products__header--desc {
        font-size: 1.188rem
    }

    div.featured-products__slides>.swiper-wrapper {
        gap: var(--spacing-large-300, 2.5rem);
        grid-template-columns: repeat(3, minmax(0, 1fr))
    }
}

@media only screen and (min-width:80em) {
    div.featured-products__slides>.swiper-wrapper {
        gap: var(--spacing-large-500, 3.75rem)
    }
}

@media screen and (min-width:993px) {
    feature-products-slider>.swiper>.swiper-wrapper>.swiper-slide {
        flex-basis: auto !important;
        width: auto !important
    }

    feature-products-slider .slider__controls {
        display: none
    }
}

@media screen and (max-width:992px) {
    feature-products-slider>.swiper:not(.swiper-initialized)>.swiper-wrapper {
        display: flex;
        flex: 1 0 auto;
        flex-direction: row;
        gap: .625rem
    }

    feature-products-slider .swiper .swiper-wrapper {
        display: flex
    }

    feature-products-slider div.swiper-pagination-bullets.swiper-pagination-horizontal {
        width: auto
    }

    feature-products-slider div.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet {
        background-color: #fff0;
        border: .0625rem solid;
        height: .75rem;
        opacity: 1;
        width: .75rem
    }

    feature-products-slider div.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet-active {
        background-color: currentColor
    }

    feature-products-slider .slider__controls {
        display: flex
    }

    .product-thumb .image-container .hover-image {
        display: none
    }
}

@media only screen and (max-width:calc(64em - 1px)) {
    .featured-products__content .fm-slider__slide {
        max-height: 1042px
    }
}

@media only screen and (max-width:calc(48em - 1px)) {
    div.featured-products__slides>.swiper-wrapper.no-slider {
        display: grid;
        gap: var(--spacing-large-200, 2rem)
    }

    .featured-products__content .fm-slider__slide {
        max-height: 782px
    }
}

@media only screen and (max-width:calc(30em - 1px)) {
    .featured-products__content .fm-slider__slide {
        max-height: 524px
    }
}
