.header__submenu {
    border-radius: var(--buttons-border-radius);
    text-transform: none;
    font-weight: var(--font-body-weight);
    transition: opacity var(--duration-default) ease, transform var(--duration-default) ease;
}

.header__submenu::before {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    border-radius: var(--buttons-border-radius);
    background-color: rgba(var(--substrate-color), var(--substrate-transparency));
}

.header__submenu .header__submenu::before {
    background-color: rgba(var(--substrate-color), calc(var(--substrate-transparency) / 3 * 4));
}

.header__submenu .header__submenu .header__submenu::before {
    background-color: rgba(var(--substrate-color), calc(var(--substrate-transparency) / 3 * 5));
}

.header__submenu.list-menu>*:first-child {
    padding-top: 1.6rem;
}

.header__submenu.list-menu>*:last-child {
    padding-bottom: 1.6rem;
}

.header__submenu li:hover {
    color: rgb(var(--clr-icon));
}

.header__submenu li {
    position: relative;
}

.header__submenu .header__submenu {
    display: none;
    position: absolute;
    top: 0;
    left: calc(100% - 1.3rem);
    min-width: 100%;
    width: 21rem;
    box-shadow: 0 var(--shadow-offset-y) 1rem rgba(var(--shadow-color), var(--shadow-transparency));
    background-color: rgb(var(--clr-theme-background));
}

.header__submenu .header__submenu > * {
    opacity: 0;
}

.header__submenu .header__submenu.header__submenu--right {
    left: auto;
    right: calc(100% - 1.3rem);
}

dropdown-menu details-disclosure details > .header__submenu--right {
    right: 0;
}

.header__submenu--visible {
    display: block !important;
}

.header__submenu--active > * {
    opacity: 1 !important;
}

.header__submenu .header__menu-item:after {
    right: 2rem;
}

.header__submenu .header__menu-item {
    --link-color: var(--color-foreground);
    padding: 0.4rem 3.5rem 0.4rem 2rem;
    color: rgb(var(--link-color));
}

.header__submenu .header__menu-item:hover {
    --link-color: var(--clr-theme-accent);
}

.header__menu-item .icon-caret {
    right: 1rem;
}

.header__submenu .icon-caret {
    right: 2rem;
    transform: rotate(-90deg);
}

.header__text-menu-item + .header__submenu {
    left: 1rem;
    top: calc(100% - 0.55rem + var(--submenu-top-offset, 0rem));
}

.header-section--transparent dropdown-menu details-disclosure details > .header__submenu::after {
    content: '';
    display: block;
    height: var(--submenu-top-offset, 0rem);
    position: absolute;
    left: 0;
    right: 0;
    top: calc(var(--submenu-top-offset, 0rem) * -1);
}

.sticky-header__spacer {
    display: none;
}

.sticky-header-fixed .sticky-header__spacer {
    height: var(--sticky-header-spacing);
}

.sticky-header__spacer--visible:empty {
    display: block;
}

.sticky-header__spacer--visible {
    position: relative;
    width: 100%;
}

.sticky-header__content--sticky {
    position: fixed !important;
    width: 100% !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 3;
    will-change: opacity;
    transition-property: opacity;
    &: hover{
    opacity:1 !important;
}
}

@media screen and (min-width: 1025px) {
    body.layout-boxed .sticky-header__content--sticky {
        left: 50% !important;
        transform: translateX(-50%) !important;
    }
}

.sticky-header__content--sticky .sticky-header__logo--sticky-hidden {
    display: none !important;
}

.sticky-header__content--sticky .sticky-header__logo--sticky-hidden + .sticky-header__sticky-logo-replace {
    display: flex !important;
}

.sticky-header__content--sticky .sticky-header__sticky-logo--containerized {
    display: flex !important;
}

.icon-loading-spinner {
    --icons-size: 1.8rem;
}

@media (hover: hover) and (pointer: fine) {
    .icon-close,
  .icon-close-2 {
        transition: transform var(--icon-close-rotation-duration) var(--icon-close-rotation-timing);
    }

    *:hover > :is(.icon-close, .icon-close-2) {
        transform: rotate(90deg);
    }
}

@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
    .link:hover {
        text-decoration-color: rgba(var(--color-link), 1);
    }

    .link-button::after,
  .link-underlined::after {
        transition: width .4s cubic-bezier(.215, .61, .355, 1);
    }

    .link-button:not([aria-disabled='true']):hover::after,
  .link-button-trigger:hover .link-button:not([aria-disabled='true'])::after,
  .link-underlined:hover::after,
  .link-underlined-trigger:hover .link-underlined::after {
        width: 100%;
    }

    .underlined-link {
        transition: text-decoration-thickness ease 100ms;
    }

    .underlined-link:hover {
        color: rgb(var(--color-link));
        text-decoration-thickness: 0.2rem;
    }

    :is(
    .header__icon,
    .list-social__link
  ) .icon {
        transition: transform var(--icons-transition-duration) var(--icons-transition-timing);
    }

    :is(
    .header__icon,
    .list-social__link
  ):hover .icon {
        transform: translateY(calc(var(--icons-hover-distance) * -1));
    }

    .cart-count-bubble {
        transition: var(--icons-transition-duration) var(--icons-transition-timing);
        transition-property: width, height, bottom, left;
    }

    .header__icon:hover .cart-count-bubble {
        --hover-scale: var(--cart-count-bubble-hover-scale);
        --hover-bottom-distance: var(--icons-hover-distance) - calc(var(--hover-scale) / 2);
    }
}

.header__icon--cart.loading {
    animation: animateCartButtonLoading 1s ease-in-out forwards;
}

@media (hover: none) and (pointer: coarse) {
}

.animate-arrow .icon-arrow path {
    transition: transform var(--duration-short) ease;
}

.animate-arrow:hover .icon-arrow path {
    transform: translateX(-0.05rem);
}

.button {
    transition: opacity var(--buttons-transition-duration) var(--buttons-transition-timing);
}

.button-bare,
.button-bare__icon {
    transition: color var(--buttons-transition-duration) var(--buttons-transition-timing);
}

@media screen and (min-width: 1025px) {
    .shopify-payment-button__button:hover,
  .shopify-challenge__button:hover,
  .button:not(.button--static):hover {
        --alpha-button-border: 0;
    }

    .button:not(.button--static):hover::before,
  .shopify-payment-button__button:hover::before,
  .shopify-challenge__button:hover::before {
        border: var(--buttons-border-width) solid rgb(var(--color-button-border));
    }

    .button:not(.button--static)::before,
  .shopify-payment-button__button--unbranded::before,
  .shopify-challenge__button::before,
  .button--animation-light .button__light {
        transition: var(--buttons-transition-duration) var(--buttons-transition-timing);
        transition-property: top, bottom, left, right, border-radius;
        will-change: top, bottom, left, right, border-radius;
    }

    :is(.button--product-cart, .button--product-cart-below, .button--quick-view, .button--product-lists):not(.button--static)::before {
        transition-property: all;
    }

    .button--product-cart,
  .button--product-cart-below,
  .button--quick-view,
  .button--product-lists {
        transition: color var(--buttons-transition-duration) var(--buttons-transition-timing);
    }

    .button:not(.button--static):hover::before,
  .shopify-payment-button__button:hover::before,
  .shopify-challenge__button:hover::before,
  .button--animation-light:hover .button__light {
        top: calc(var(--buttons-scale) * -1);
        bottom: calc(var(--buttons-scale) * -1);
        left: calc(var(--buttons-scale) * -1);
        right: calc(var(--buttons-scale) * -1);
    }

    .button:is([disabled], [aria-disabled="true"]):not(.loading):not(.active):hover::before {
        top: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        --alpha-button-border: 0;
    }
}

.announcement-bar__link :is(.announcement-bar__content, .announcement-bar__icon),
.button__text,
.button__icon {
    transition: var(--buttons-transition-duration) var(--buttons-transition-timing);
}

.announcement-bar__link .announcement-bar__content,
.button__text {
    transition-property: transform;
    will-change: transform;
}

.announcement-bar__link .announcement-bar__icon,
.button__icon {
    transition-property: transform, opacity;
    will-change: transform, opacity;
}

:is(.button--product-cart, .button--product-cart-below, .button--quick-view, .button--product-lists) .button__icon .icon {
    transition: color var(--buttons-transition-duration) var(--buttons-transition-timing);
}

@media screen and (min-width: 1025px) {
    .announcement-bar__link .announcement-bar__message:hover .announcement-bar__content,
  .button--dynamic:not([disabled]):hover .button__text,
  .button--icon-static:not([disabled]) .button__text {
        transform: translateX(calc((var(--buttons-text-hover-distance) + var(--buttons-scale)) * var(--button-icon-position-factor)));
    }

    .button--dynamic:is([disabled], [aria-disabled="true"]):not(.loading):not(.active):hover .button__text {
        transform: none;
    }
}

.button--dynamic:not([disabled]):is(.loading, .active) .button__text {
    transform: translateX(calc((100% + var(--buttons-paddings-x)) * var(--button-icon-position-factor)));
}

@media screen and (min-width: 1025px) {
    .announcement-bar__link .announcement-bar__message:hover .announcement-bar__icon,
  .button--dynamic:not(.button--icon-only):not([disabled]):not(.loading):not(.active):hover .button__icon,
  .button--icon-static:not([disabled]):not(.loading):not(.active) .button__icon {
        transform: translateX(calc((var(--buttons-paddings-x) + var(--buttons-scale) - var(--icons-size) - var(--buttons-text-hover-distance)) * var(--button-icon-position-factor)));
        opacity: 1;
    }

    .button--dynamic:not(.button--icon-only):is([disabled], [aria-disabled="true"]):not(.loading):not(.active):hover .button__icon,
  .button--dynamic:not([disabled]):is(.loading, .active) .button__icon {
        opacity: 0;
    }

    .button--dynamic:not(.button--icon-only):is([disabled], [aria-disabled="true"]):not(.loading):not(.active):hover .button__icon,
  .button--dynamic:not(.button--icon-only):not([disabled]):is(.loading, .active) .button__icon {
        transform: translateX(calc(var(--buttons-paddings-x) * -1 * var(--button-icon-position-factor)));
    }

    .button--dynamic:not(.button--icon-only):is([disabled], [aria-disabled="true"]):not(.loading):not(.active):hover .button__icon,
  .button--dynamic.button--icon-only:not([disabled]):is(.loading, .active) .button__icon {
        transform: translateY(calc(var(--buttons-paddings-y) + var(--buttons-scale) + var(--icons-size)));
    }
}

.button-bare:not([disabled]):is(.loading, .active) .button-bare__icon-default {
    transform: translateY(var(--icons-size));
}

@media screen and (max-width: 1024px) {
    .button--dynamic:not([disabled]):is(.loading, .active) .button__icon {
        transform: translateX(calc((var(--icons-size) + var(--buttons-paddings-x)) * -1 * var(--button-icon-position-factor)));
        opacity: 0;
    }
}

.button__loading, .button__active,
.button-bare__icon-loading, .button-bare__icon-active {
    transition: var(--buttons-transition-duration) var(--buttons-transition-timing);
    transition-property: top;
}

.button-bare__icon-default {
    transition: var(--buttons-transition-duration) var(--buttons-transition-timing);
    transition-property: transform;
}

.button__active,
.button.active:not(.removing) .button__loading,
.button-bare__icon-loading,
.button-bare.loading .button-bare__icon-active {
    visibility: hidden;
}

.button.active:not(.removing) .button__active,
.button-bare.loading .button-bare__icon-loading {
    visibility: visible;
}

.button--dynamic:not([disabled]).loading .button__loading,
.button--dynamic:not([disabled]).active:not(.removing) .button__active,
.button-bare:not([disabled]).loading .button-bare__icon-loading, 
.button-bare:not([disabled]).active .button-bare__icon-active {
    will-change: top;
    top: var(--icons-center);
}

.button.loading,
.button-bare.loading {
    cursor: default;
}

@media screen and (forced-colors: active) {
    .button:is(.loading, .active) {
        color: rgb(var(--color-foreground));
    }
}

.button__spinner {
    display: none;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: var(--icons-size);
    height: var(--icons-size);
}

.button__spinner .icon-loading-spinner {
    color: rgb(var(--color-button-text));
}

.button--loading {
    color: transparent !important;
}

.button--loading .button__spinner {
    display: block;
}

.button--active-filter {
    --color-button: var(--clr-line);
    --color-button-text: var(--clr-theme-base);
    --color-button-background: var(--clr-theme-background);
    --color-button-border: var(--color-button);
    --alpha-button-background: 0;
    --alpha-button-border: var(--clr-line-alpha);
    --alpha-button-icon: 0.3;
    padding-left: 2rem;
    padding-right: 2rem;
    text-transform: initial;
    font-family: var(--font-body-family);
    font-weight: 300;
}

.button--active-filter:hover {
    --alpha-button-border: 1;
    --alpha-button-icon: 1;
}

.button--active-filter .icon {
    --icons-size: 1.2rem;
    color: rgba(var(--clr-icon), var(--alpha-button-icon));
}

@media screen and (max-width: 1024px) {
    facet-remove .button--active-filter {
        --alpha-button-border: 1;
        --alpha-button-icon: 1;
    }

    .button--active-filter:not([disabled]):not([aria-disabled="true"]):hover::before {
        border-radius: calc(var(--buttons-border-radius) + 0.2rem);
        top: -0.2rem;
        bottom: -0.2rem;
        left: -0.2rem;
        right: -0.2rem;
    }
}

.share-button__fallback button:hover {
    color: rgba(var(--color-foreground), 0.75);
}

.share-button__fallback button:hover svg {
    transform: scale(1.1);
}

.checkbox:hover span,
label:hover > .checkbox span,
.radio:hover span,
label:hover > .radio span {
    background-color: rgba(var(--color-foreground), 0);
    border: 0.1rem solid rgb(var(--color-foreground));
    transition: border-color var(--duration-short) ease, background-color var(--duration-short) ease;
}

.styled-checkbox__checkmark::before,
.styled-checkbox__checkmark::after {
    transition: transform var(--duration-short) ease;
}

.styled-checkbox__checkmark::before {
    transition-property: transform, border-color, background-color;
}

.styled-checkbox:hover input[type='checkbox']:not([disabled]) ~ .styled-checkbox__checkmark::before,
input[type='checkbox']:not([disabled]) + .styled-checkbox:hover .styled-checkbox__checkmark::before {
    background-color: rgba(var(--clr-input-hover-background), var(--clr-input-hover-background-alpha));
    border: 0.1rem solid rgb(var(--clr-input-hover-line));
}

.styled-checkbox__checkmark svg {
    transition: opacity var(--duration-short) ease, transform var(--duration-short) ease;
}

.field__input:hover,
.select__select:hover,
.theme-form input:not([type="submit"]):hover,
.localization-form__select:hover {
    background-color: rgba(var(--clr-input-hover-background), var(--clr-input-hover-background-alpha));
    border: 0.1rem solid rgb(var(--clr-input-hover-line));
    color: rgb(var(--clr-input-hover-text));
}

.field__input:hover~.field__label {
    color: rgb(var(--clr-input-hover-text));
}

.header__menu-item:hover {
    --link-color: var(--inline-menu-hover-color);
}

.select__select:is(:hover, :focus)~.field__label {
    color: rgb(var(--clr-input-hover-text));
}

.field__input:is(:hover, :focus)~.field__icon {
    color: rgb(var(--clr-input-hover-icon));
}

.quantity:hover .quantity__input,
.quantity__input:is(:hover, :focus) {
    color: rgb(var(--clr-input-hover-text));
    background-color: rgba(var(--clr-input-hover-background), var(--clr-input-hover-background-alpha));
    border: 0.1rem solid rgb(var(--clr-input-hover-line));
}

.quantity:hover .quantity__button,
.quantity__input:is(:hover, :focus) ~ .quantity__button,
.quantity__button:hover {
    color: rgb(var(--clr-input-hover-icon));
}

@media screen and (max-width: 1024px) {
  
    .search-inline {
        padding-bottom: 1rem;
    }
}

.search-inline__select .select__select:is(:hover, :focus) {
    position: relative;
    z-index: 1;
}

.search-inline__select .select__select:is(:hover, :focus) + svg {
    z-index: 1;
}

details>.header__submenu>*,
.header__submenu--visible {
    transition: opacity calc(var(--dropdown-menu-transition-duration) / 3) var(--dropdown-menu-transition-timing);
}

details[open]>.share-button__fallback {
    animation: animateMenuOpen var(--duration-default) ease;
}

.header__contact-popup {
    --content-height: 40rem;
    display: none;
    position: absolute;
    top: calc(var(--outer-offset) * -1);
    left: 0;
    right: 0;
    padding: var(--outer-offset);
    background-color: rgb(var(--clr-theme-background));
    border-radius: var(--images-border-radius);
    z-index: 113;
    overflow: hidden;
}

.header__contact:hover .header__contact-popup {
    display: block;
}

.header__contact-bg,
.search-inline__bg {
    width: 100vw;
    height: 100vh;
    position: fixed;
    opacity: 1;
    top: 0;
    bottom: 0;
    right: 0;
    left: calc(50% - 50vw);
    background-color: rgb(0, 0, 0, var(--substrate-transparency));
    animation: fadeIn .3s ease;
}

.header__contact-bg {
    pointer-events: none;
    z-index: 4;
}

.header__contact:hover .header__contact-bg,
predictive-search[open="true"] .search-inline__bg {
    display: block;
}

.modal-overlay::after {
    position: absolute;
    display: block;
    content: '';
    background-color: rgb(0, 0, 0, var(--substrate-transparency));
    top: 0;
    left: 0;
    right: 0;
    height: 100vh;
    opacity: 0;
    transition: opacity var(--popups-transition-duration) ease;
}

:is(.popup-section, .search-popup, details[open]) .modal-overlay {
    display: block;
    pointer-events: all;
}

details[open].menu-opening .modal-overlay::after {
    opacity: 1;
}

.layout-boxed details[open] .modal-overlay::after {
    width: 100vw;
    left: calc((100vw - 100%) / 2 * -1);
}

.popup-module {
    --z-index: 999;
    opacity: 0;
    z-index: -99;
    display: none;
    will-change: transform, opacity;
    contain: layout;
}

.popup-module--open,
.popup-module--visible {
    display: block;
    opacity: 1;
    z-index: var(--z-index);
}

.popup-module--preopen .modal-overlay::after {
    opacity: 0;
}

.popup-module--preopen:not(.popup-module--open) {
    display: block;
    visibility: hidden;
}

.popup-module--flex.popup-module--open,
.popup-module--flex.popup-module--visible {
    display: flex;
}

.popup-module--open {
    --animation-open-name: animatePopupModuleOpen;
    --animation-content-open-name: animatePopupModuleContentOpen;
    --animation-close-name: animatePopupModuleClose;
    --animation-content-close-name: animatePopupModuleContentClose;
    animation: var(--animation-open-name) var(--popups-transition-duration) ease;
}

.popup-module--open > *:not(.modal-overlay) {
    animation: var(--animation-content-open-name) var(--popups-transition-duration) ease;
}

.popup-module--open .modal-overlay::after {
    opacity: 1;
}

.popup-module--close {
    animation: var(--animation-close-name) var(--popups-transition-duration) ease forwards;
    pointer-events: none;
}

.popup-module--close > *:not(.modal-overlay) {
    animation: var(--animation-content-close-name) var(--popups-transition-duration) ease;
}

.popup-module--close .modal-overlay::after {
    opacity: 0;
}

@media screen and (min-width: 1025px) {
  
    .announcement-bar__border {
        animation: fadeIn 1s ease forwards;
    }

    .header__icons-menu-item,
  .header__icons-menu-item-icon svg,
  .header__icons-menu-item .badge,
  .header__icons-menu-item-text .icon {
        transition: var(--menu-hover-transition-duration) var(--menu-hover-transition-timing);
        transition-property: color, background-color;
        will-change: color, background-color;
    }

    .header__icons-menu-item.content-calculated :is(.header__icons-menu-item-icon, .header__icons-menu-item-text) {
        transition: transform var(--menu-hover-transition-duration) var(--menu-hover-transition-timing);
        will-change: transform;
    }

    .header__icons-menu-item.content-calculated .header__icons-menu-item-text .icon {
        transition: opacity var(--menu-hover-transition-duration) var(--menu-hover-transition-timing), background-color var(--menu-hover-transition-duration) var(--menu-hover-transition-timing), color var(--menu-hover-transition-duration) var(--menu-hover-transition-timing);
        will-change: color, background-color, opacity;
    }

    .header__icons-menu-item.content-calculated:is(:hover, .menu-button-active) .header__icons-menu-item-icon {
        transform: translateY(calc((var(--item-text-height) + var(--item-gap))));
    }

    .header__icons-menu-item.content-calculated:is(:hover, .menu-button-active) .header__icons-menu-item-text {
        transform: translateY(calc((var(--item-icon-height) + var(--item-gap)) * -1));
    }

    .header__icons-menu-item.content-calculated:is(:hover, .menu-button-active) .header__icons-menu-item-text .icon {
        opacity: 0;
    }
}

.modal__close-button {
    border-radius: 50%;
}

@media screen and (max-width: 1024px) {
    .modal__close-button:focus-visible,
  .modal__close-button:focus {
        outline: none;
    }
}

.modal__close-button {
    --button-size: 5rem;
    --button-offset: 2rem;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    padding: 0rem;
    height: var(--button-size);
    width: var(--button-size);
    background-color: transparent;
}

.modal__close-button--offset {
    position: absolute;
    top: calc(var(--button-offset) - (var(--button-size) - var(--icons-size)) / 2);
    right: calc(var(--button-offset) - (var(--button-size) - var(--icons-size)) / 2);
}

@media screen and (min-width: 577px) {
    .modal__close-button--offset {
        --button-offset: 3rem;
    }
}

.modal__close-button .icon {
    color: rgb(var(--clr-icon));
}

.popup-modal {
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    overflow-y: auto;
    overflow-x: hidden;
    width: 100%;
    height: calc(var(--window-height, 100vh) - var(--preview-bar-iframe-height));
    z-index: 101;
    box-sizing: border-box;
    margin: 0 auto;
    background-color: rgb(0, 0, 0, 0);
    transition: background-color var(--popups-transition-duration) ease, visibility var(--popups-transition-duration) ease;
}

.popup-modal.ready {
    display: block;
}

.popup-modal[open] {
    background-color: rgb(0, 0, 0, var(--substrate-transparency));
    visibility: visible;
}

.popup-modal__content {
    position: absolute;
    width: var(--mobile-drawer-width);
    max-width: 100%;
    left: initial;
    right: 0;
    background-color: rgb(var(--color-background));
    overflow: auto;
    height: 100%;
    transform: translate(100%);
    transition: transform var(--popups-transition-duration) ease;
    will-change: transform;
}

.popup-modal--left .popup-modal__content {
    left: 0;
    right: initial;
    transform: translate(-100%);
}

.popup-modal__content-inner {
    overflow: auto;
    height: 100%;
    background-color: rgba(var(--substrate-color), var(--substrate-transparency));
}

.popup-modal[open] .popup-modal__content {
    transform: translate(0);
}

@media screen and (min-width: 577px) {
    .popup-modal__content {
        width: 50%;
        min-width: var(--mobile-drawer-width);
    }
}

@media screen and (min-width: 1025px) {
    .popup-modal__content {
        width: 60rem;
        min-width: 60rem;
        max-width: 100%;
    }
}

.popup-modal__content img {
    max-width: 100%;
}

@media screen and (max-width: 576px) {
    .popup-modal__content table {
        display: block;
        max-width: fit-content;
        overflow-x: auto;
        white-space: nowrap;
        margin: 0;
    }
}

.popup-modal__content-header {
    position: relative;
    padding: 2rem 2rem 4rem;
}

@media screen and (min-width: 577px) {
    .popup-modal__content-header {
        padding: 3rem 3rem 4rem;
    }
}

@media screen and (min-width: 1025px) {
    .popup-modal__content-header {
        padding: 4rem 4rem 3.5rem;
    }
}

.popup-modal__content-header .title {
    margin: 0;
}

.popup-modal__content-info {
    padding: 0 2rem 2rem;
}

@media screen and (min-width: 577px) {
    .popup-modal__content-info {
        padding: 0 3rem 3rem;
    }
}

@media screen and (min-width: 1025px) {
    .popup-modal__content-info {
        padding: 0 4rem 4rem;
    }
}

.popup-modal__content-info > *:first-child {
    margin-top: 0;
}

@media screen and (max-width: 576px) {
    .popup-modal__content-info > * {
        max-height: 100%;
    }
}

.popup-modal__content-info table {
    height: auto !important;
}

.media-modal {
    cursor: zoom-out;
}

.media-modal .deferred-media {
    cursor: initial;
}

:is(cart-remove-button, cart-quantity-input) {
    transition: opacity 1s;
}

:is(cart-remove-button, cart-quantity-input).loading {
    opacity: 0.5;
}

:is(cart-remove-button, cart-quantity-input).loading * {
    cursor: default;
}

.pulse-animation::before {
    --pulse-start: 0.5;
    --pulse-end: 1.5;
    content: '';
    display: block;
    border-radius: 50%;
    width: var(--pulse-size);
    height: var(--pulse-size);
    background-color: rgb(var(--clr-theme-background));
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    animation: pulsate 1.25s linear infinite;
}

@media (hover: hover) and (pointer: fine) {
    .tooltip-wrapper {
        display: block;
        position: relative;
    }

    .tooltip {
        --tooltip-background: var(--color-foreground);
        --tooltip-foreground: var(--color-background);
        --offset: 0rem;
        position: absolute;
        max-width: initial !important;
        left: 50%;
        padding: 0.3rem 0.8rem;
        display: flex !important;
        align-items: center;
        justify-content: center;
        font-size: calc(1.2rem * var(--font-body-scale));
        line-height: calc(1 + 0.3 / max(1, var(--font-body-scale)));
        text-align: center;
        border-radius: var(--tooltip-border-radius);
        background-color: rgb(var(--tooltip-background));
        color: rgb(var(--tooltip-foreground));
        white-space: nowrap;
        transform: translateX(-50%);
        opacity: 0;
        z-index: 1;
        pointer-events: none;
        transition: opacity var(--duration-short) ease;
    }

    .tooltip--top {
        bottom: calc(100% + 1.1rem + var(--offset));
    }

    .tooltip--bottom {
        top: calc(100% + 1.1rem + var(--offset));
    }

    *:hover > .tooltip,
  .tooltip-wrapper:hover .tooltip {
        opacity: 1;
    }

    .tooltip::before {
        content: '';
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
    }

    .tooltip--top::before {
        top: 100%;
        border-top: 6px solid rgb(var(--tooltip-background));
    }

    .tooltip--bottom::before {
        bottom: 100%;
        border-bottom: 6px solid rgb(var(--tooltip-background));
    }
}

@media screen and (max-width: 1024px) {
    .is-ios.is-touch .ios-urlbar-offset::after {
        content: '';
        display: block;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        height: 10rem;
        background-color: rgb(var(--clr-theme-background));
    }

    .is-ios.is-touch .ios-urlbar-offset:not([class*="--visible"]) {
        visibility: hidden;
    }
}

.icon-loading-spinner {
    stroke: currentColor;
    color: rgb(var(--color-foreground));
}

.loading .icon-loading-spinner {
    animation: rotator 1.4s linear infinite;
}

.icon-loading-spinner .path {
    stroke-dasharray: 280;
    stroke-dashoffset: 0;
    transform-origin: center;
    stroke: currentColor;
}

.loading .icon-loading-spinner .path {
    animation: dash 1.4s ease-in-out infinite;
}

@media screen and (forced-colors: active) {
    .icon-loading-spinner .path {
        stroke: UnicornText;
    }
}

@keyframes rotator {
    0% {
        transform: rotate(0deg);
    }

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

@keyframes dash {
    0% {
        stroke-dashoffset: 280;
    }

    50% {
        stroke-dashoffset: 75;
        transform: rotate(135deg);
    }

    100% {
        stroke-dashoffset: 280;
        transform: rotate(450deg);
    }
}

@keyframes pulsate {
    0% {
        transform: translate(-50%, -50%) scale(var(--pulse-start));
        opacity: 1;
    }

    45% {
        transform: translate(-50%, -50%) scale(calc((var(--pulse-end) + var(--pulse-start)) / 2));
    }

    100% {
        transform: translate(-50%, -50%) scale(var(--pulse-end));
        opacity: 0;
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    100% {
        opacity: 1
    }
}

@keyframes animateMenuOpen {
    0%,
  10% {
        opacity: 0;
        transform: translateY(-1.5rem);
    }

    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes animatePopupModuleOpen {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes animatePopupModuleContentOpen {
    0% {
        transform: translateY(1.5rem);
    }

    100% {
        transform: translateY(0);
    }
}

@keyframes animatePopupModuleClose {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

@keyframes animatePopupModuleContentClose {
    0% {
        transform: translateY(0);
    }

    100% {
        transform: translateY(1.5rem);
    }
}

@keyframes animateCartButtonLoading {
    0%,
  100% {
        transform: translateY(0rem);
    }

    50% {
        transform: translateY(calc(var(--icons-hover-distance) * -1));
    }
}