.css-hover {
  position: relative;
  overflow: hidden;
  width: 100%;
  display: block;
  line-height: 0;
}

.css-hover__primary,
.css-hover__secondary {
  display: block;
  transition-property: opacity, transform, filter, clip-path, mask-size, border-radius;
  transition-duration: var(--css-hover-duration, 0.5s);
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.css-hover__fx {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 3;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--css-hover-duration, 0.5s) ease;
}

.css-hover__primary {
  z-index: 1;
}

.css-hover__secondary {
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}

/* Global product cards — overlay on Dawn media (Dawn images stay underneath) */
.media.css-hover-host {
  overflow: hidden;
}

.media.css-hover-host .css-hover-overlay {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  pointer-events: none;
  background: transparent;
  overflow: hidden;
}

.media.css-hover-host .css-hover-overlay .css-hover__primary,
.media.css-hover-host .css-hover-overlay .css-hover__secondary {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.media.css-hover-host .css-hover-overlay .css-hover__fx {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Suppress Dawn native hover until app overlay is ready */
.media.media--hover-effect:not(.css-hover-host) > img + img {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.card-wrapper:hover .media.media--hover-effect:not(.css-hover-host) > img:first-child:not(:only-child),
.product-card-wrapper:hover .media.media--hover-effect:not(.css-hover-host) > img:first-child:not(:only-child),
.product-card:hover .media.media--hover-effect:not(.css-hover-host) > img:first-child:not(:only-child),
.collection-card-wrapper:hover .media.media--hover-effect:not(.css-hover-host) > img:first-child:not(:only-child) {
  opacity: 1 !important;
  transform: none !important;
}

/* Disable Dawn native second-image swap once overlay is active */
.media.css-hover-host.media--hover-effect > img + img {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.card-wrapper:hover .media.css-hover-host.media--hover-effect > img:first-child:not(:only-child),
.product-card-wrapper:hover .media.css-hover-host.media--hover-effect > img:first-child:not(:only-child) {
  opacity: 1 !important;
  transform: none !important;
}

/* Free effects */
.css-hover--fade .css-hover__secondary {
  opacity: 0;
}
.css-hover--fade:hover .css-hover__secondary,
.css-hover--fade.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}

.css-hover--slide-up .css-hover__secondary {
  opacity: 1 !important;
  transform: translateY(100%) !important;
}
.css-hover--slide-up:hover .css-hover__secondary,
.css-hover--slide-up.is-hovered .css-hover__secondary {
  transform: translateY(0) !important;
}

.css-hover--slide-left .css-hover__secondary {
  opacity: 1 !important;
  transform: translateX(100%) !important;
}
.css-hover--slide-left:hover .css-hover__secondary,
.css-hover--slide-left.is-hovered .css-hover__secondary {
  transform: translateX(0) !important;
}

.css-hover--zoom-in .css-hover__secondary {
  opacity: 0;
  transform: scale(1.12);
}
.css-hover--zoom-in:hover .css-hover__secondary,
.css-hover--zoom-in.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.css-hover--circle-reveal .css-hover__secondary {
  opacity: 1;
  clip-path: circle(0% at 50% 50%);
}
.css-hover--circle-reveal .css-hover__secondary {
  opacity: 1 !important;
}
.css-hover--circle-reveal:hover .css-hover__secondary,
.css-hover--circle-reveal.is-hovered .css-hover__secondary {
  clip-path: circle(72% at 50% 50%);
}

.css-hover--bounce-in .css-hover__secondary {
  opacity: 0;
  transform: scale(0.82);
  transition-timing-function: cubic-bezier(0.34, 1.45, 0.64, 1);
}
.css-hover--bounce-in:hover .css-hover__secondary,
.css-hover--bounce-in.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.css-hover--slide-down .css-hover__secondary {
  opacity: 1 !important;
  transform: translateY(-100%) !important;
}
.css-hover--slide-down:hover .css-hover__secondary,
.css-hover--slide-down.is-hovered .css-hover__secondary {
  transform: translateY(0) !important;
}

.css-hover--slide-right .css-hover__secondary {
  opacity: 1 !important;
  transform: translateX(-100%) !important;
}
.css-hover--slide-right:hover .css-hover__secondary,
.css-hover--slide-right.is-hovered .css-hover__secondary {
  transform: translateX(0) !important;
}

.css-hover--zoom-out .css-hover__secondary {
  opacity: 0;
  transform: scale(0.88);
}
.css-hover--zoom-out:hover .css-hover__secondary,
.css-hover--zoom-out.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.css-hover--blur-reveal .css-hover__secondary {
  opacity: 0;
  filter: blur(14px);
}
.css-hover--blur-reveal:hover .css-hover__secondary,
.css-hover--blur-reveal.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  filter: blur(0);
}

/* Pro effects */
.css-hover--ken-burns .css-hover__secondary {
  opacity: 0;
  transform: scale(1.08) translate(-2%, -2%);
}
.css-hover--ken-burns:hover .css-hover__secondary,
.css-hover--ken-burns.is-hovered .css-hover__secondary {
  opacity: 1;
  transform: scale(1) translate(0, 0);
}

.css-hover--curtain-wipe .css-hover__secondary {
  opacity: 1;
  clip-path: inset(0 100% 0 0);
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}
.css-hover--curtain-wipe:hover .css-hover__secondary,
.css-hover--curtain-wipe.is-hovered .css-hover__secondary {
  clip-path: inset(0 0 0 0);
}

.css-hover--split-reveal .css-hover__secondary {
  opacity: 1;
  clip-path: polygon(50% 0, 50% 0, 50% 100%, 50% 100%);
}
.css-hover--split-reveal:hover .css-hover__secondary,
.css-hover--split-reveal.is-hovered .css-hover__secondary {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.css-hover--rotate-fade .css-hover__secondary {
  opacity: 0;
  transform: rotate(-6deg) scale(1.05);
}
.css-hover--rotate-fade:hover .css-hover__secondary,
.css-hover--rotate-fade.is-hovered .css-hover__secondary {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

.css-hover--flip-x .css-hover__secondary {
  opacity: 0;
  transform: rotateY(90deg);
  transform-origin: center;
  backface-visibility: hidden;
}
.css-hover--flip-x:hover .css-hover__secondary,
.css-hover--flip-x.is-hovered .css-hover__secondary {
  opacity: 1;
  transform: rotateY(0deg);
}
.css-hover--flip-x {
  perspective: 800px;
}

.css-hover--glow-pulse .css-hover__secondary {
  opacity: 0;
  filter: drop-shadow(0 0 0 transparent);
}
.css-hover--glow-pulse:hover .css-hover__secondary,
.css-hover--glow-pulse.is-hovered .css-hover__secondary {
  opacity: 1;
  filter: drop-shadow(0 0 18px rgba(255, 255, 255, 0.65));
  animation: css-hover-glow-pulse calc(var(--css-hover-duration, 0.5s) * 3) ease-in-out infinite alternate;
}

@keyframes css-hover-glow-pulse {
  from {
    filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.35));
  }
  to {
    filter: drop-shadow(0 0 22px rgba(255, 255, 255, 0.85));
  }
}

.css-hover--flip-y .css-hover__secondary {
  opacity: 0;
  transform: rotateX(90deg);
  transform-origin: center;
  backface-visibility: hidden;
}
.css-hover--flip-y:hover .css-hover__secondary,
.css-hover--flip-y.is-hovered .css-hover__secondary {
  opacity: 1;
  transform: rotateX(0deg);
}
.css-hover--flip-y {
  perspective: 800px;
}

.css-hover--diagonal-wipe .css-hover__secondary {
  opacity: 1;
  clip-path: polygon(0 0, 0 0, 0 100%);
}
.css-hover--diagonal-wipe:hover .css-hover__secondary,
.css-hover--diagonal-wipe.is-hovered .css-hover__secondary {
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.css-hover--diamond-reveal .css-hover__secondary {
  opacity: 1;
  clip-path: polygon(50% 50%, 50% 50%, 50% 50%, 50% 50%);
}
.css-hover--diamond-reveal:hover .css-hover__secondary,
.css-hover--diamond-reveal.is-hovered .css-hover__secondary {
  clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

/* Premium Pro effects */
.css-hover--parallax-shift .css-hover__primary {
  transition: transform var(--css-hover-duration, 0.5s) ease;
}
.css-hover--parallax-shift:hover .css-hover__primary,
.css-hover--parallax-shift.is-hovered .css-hover__primary {
  transform: scale(1.06);
}
.css-hover--parallax-shift .css-hover__secondary {
  opacity: 1 !important;
  transform: translateY(18%) scale(1.04);
}
.css-hover--parallax-shift:hover .css-hover__secondary,
.css-hover--parallax-shift.is-hovered .css-hover__secondary {
  transform: translateY(0) scale(1);
}

.css-hover--cross-zoom .css-hover__primary {
  transition: transform var(--css-hover-duration, 0.5s) ease, opacity var(--css-hover-duration, 0.5s) ease;
}
.css-hover--cross-zoom:hover .css-hover__primary,
.css-hover--cross-zoom.is-hovered .css-hover__primary {
  transform: scale(0.9);
  opacity: 0.35;
}
.css-hover--cross-zoom .css-hover__secondary {
  opacity: 0;
  transform: scale(1.18);
}
.css-hover--cross-zoom:hover .css-hover__secondary,
.css-hover--cross-zoom.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: scale(1);
}

.css-hover--glitch-slice .css-hover__secondary {
  opacity: 1 !important;
  clip-path: inset(0 0 100% 0);
  transform: translateX(0);
}
.css-hover--glitch-slice:hover .css-hover__secondary,
.css-hover--glitch-slice.is-hovered .css-hover__secondary {
  animation: css-hover-glitch-slice var(--css-hover-duration, 0.5s) steps(6, end) forwards;
}
@keyframes css-hover-glitch-slice {
  0% { clip-path: inset(0 0 100% 0); transform: translateX(0); }
  20% { clip-path: inset(10% 0 60% 0); transform: translateX(-4px); }
  40% { clip-path: inset(35% 0 35% 0); transform: translateX(5px); }
  60% { clip-path: inset(55% 0 15% 0); transform: translateX(-3px); }
  80% { clip-path: inset(80% 0 0 0); transform: translateX(2px); }
  100% { clip-path: inset(0 0 0 0); transform: translateX(0); }
}

.css-hover--duotone-fade .css-hover__secondary {
  opacity: 0;
  filter: sepia(0.85) hue-rotate(165deg) saturate(2.2);
  mix-blend-mode: multiply;
}
.css-hover--duotone-fade:hover .css-hover__secondary,
.css-hover--duotone-fade.is-hovered .css-hover__secondary {
  opacity: 0.92 !important;
  filter: sepia(0) hue-rotate(0deg) saturate(1);
}

.css-hover--vignette-reveal .css-hover__secondary {
  opacity: 0;
  -webkit-mask-image: radial-gradient(circle at center, #000 0%, transparent 72%);
  mask-image: radial-gradient(circle at center, #000 0%, transparent 72%);
  -webkit-mask-size: 0% 0%;
  mask-size: 0% 0%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
}
.css-hover--vignette-reveal:hover .css-hover__secondary,
.css-hover--vignette-reveal.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  -webkit-mask-size: 250% 250%;
  mask-size: 250% 250%;
}

.css-hover--liquid-wipe .css-hover__secondary {
  opacity: 1 !important;
  clip-path: ellipse(0% 0% at 50% 50%);
  border-radius: 60% 40% 55% 45% / 48% 52% 48% 52%;
}
.css-hover--liquid-wipe:hover .css-hover__secondary,
.css-hover--liquid-wipe.is-hovered .css-hover__secondary {
  clip-path: ellipse(120% 120% at 50% 50%);
  border-radius: 42% 58% 52% 48% / 55% 45% 55% 45%;
}

.css-hover--film-grain .css-hover__secondary {
  opacity: 0;
}
.css-hover--film-grain:hover .css-hover__secondary,
.css-hover--film-grain.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}
.css-hover--film-grain .css-hover__fx {
  opacity: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  mix-blend-mode: overlay;
}
.css-hover--film-grain:hover .css-hover__fx,
.css-hover--film-grain.is-hovered .css-hover__fx {
  opacity: 0.45;
}

.css-hover--light-leak .css-hover__secondary {
  opacity: 0;
}
.css-hover--light-leak:hover .css-hover__secondary,
.css-hover--light-leak.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}
.css-hover--light-leak .css-hover__fx {
  opacity: 0;
  background: linear-gradient(115deg, transparent 20%, rgba(255, 210, 120, 0.75) 48%, rgba(255, 120, 80, 0.55) 62%, transparent 78%);
  mix-blend-mode: screen;
  transform: translateX(-30%);
  transition: opacity var(--css-hover-duration, 0.5s) ease, transform calc(var(--css-hover-duration, 0.5s) * 1.4) ease;
}
.css-hover--light-leak:hover .css-hover__fx,
.css-hover--light-leak.is-hovered .css-hover__fx {
  opacity: 1;
  transform: translateX(8%);
}

.css-hover--stack-flip {
  perspective: 900px;
  transform-style: preserve-3d;
}
.css-hover--stack-flip .css-hover__primary,
.css-hover--stack-flip .css-hover__secondary {
  backface-visibility: hidden;
  transform-style: preserve-3d;
}
.css-hover--stack-flip .css-hover__primary {
  transition: transform var(--css-hover-duration, 0.5s) ease;
}
.css-hover--stack-flip:hover .css-hover__primary,
.css-hover--stack-flip.is-hovered .css-hover__primary {
  transform: rotateY(-90deg);
}
.css-hover--stack-flip .css-hover__secondary {
  opacity: 1 !important;
  transform: rotateY(90deg);
}
.css-hover--stack-flip:hover .css-hover__secondary,
.css-hover--stack-flip.is-hovered .css-hover__secondary {
  transform: rotateY(0deg);
}

.css-hover--zoom-blur .css-hover__secondary {
  opacity: 0;
  transform: scale(1.22);
  filter: blur(22px);
}
.css-hover--zoom-blur:hover .css-hover__secondary,
.css-hover--zoom-blur.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: scale(1);
  filter: blur(0);
}

.css-hover--chromatic-shift .css-hover__secondary {
  opacity: 0;
  transform: translateX(6px);
  filter: hue-rotate(40deg) saturate(1.4);
}
.css-hover--chromatic-shift:hover .css-hover__secondary,
.css-hover--chromatic-shift.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: translateX(0);
  filter: none;
}

.css-hover--ripple-reveal .css-hover__secondary {
  opacity: 1 !important;
  clip-path: circle(0% at 50% 50%);
  transform: scale(1.05);
}
.css-hover--ripple-reveal:hover .css-hover__secondary,
.css-hover--ripple-reveal.is-hovered .css-hover__secondary {
  clip-path: circle(75% at 50% 50%);
  transform: scale(1);
}

.css-hover--holographic-sheen .css-hover__secondary {
  opacity: 0;
}
.css-hover--holographic-sheen:hover .css-hover__secondary,
.css-hover--holographic-sheen.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}
.css-hover--holographic-sheen .css-hover__fx {
  opacity: 0;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255, 255, 255, 0.5) 35%,
    rgba(180, 120, 255, 0.4) 55%,
    transparent 80%
  );
  mix-blend-mode: overlay;
  transform: translateX(-40%);
  transition: opacity var(--css-hover-duration, 0.5s) ease,
    transform calc(var(--css-hover-duration, 0.5s) * 1.3) ease;
}
.css-hover--holographic-sheen:hover .css-hover__fx,
.css-hover--holographic-sheen.is-hovered .css-hover__fx {
  opacity: 1;
  transform: translateX(40%);
}

.css-hover--ink-bleed .css-hover__secondary {
  opacity: 1 !important;
  clip-path: inset(100% 0 0 0);
  filter: blur(18px);
}
.css-hover--ink-bleed:hover .css-hover__secondary,
.css-hover--ink-bleed.is-hovered .css-hover__secondary {
  clip-path: inset(0 0 0 0);
  filter: blur(0);
}

.css-hover--spotlight-sweep .css-hover__secondary {
  opacity: 1 !important;
  -webkit-mask-image: radial-gradient(circle, #000 0%, #000 42%, transparent 68%);
  mask-image: radial-gradient(circle, #000 0%, #000 42%, transparent 68%);
  -webkit-mask-size: 20% 20%;
  mask-size: 20% 20%;
  -webkit-mask-position: 30% 40%;
  mask-position: 30% 40%;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  transition-property: opacity, transform, filter, clip-path, mask-size, border-radius,
    -webkit-mask-size, mask-size, -webkit-mask-position, mask-position;
}
.css-hover--spotlight-sweep:hover .css-hover__secondary,
.css-hover--spotlight-sweep.is-hovered .css-hover__secondary {
  -webkit-mask-size: 120% 120%;
  mask-size: 120% 120%;
  -webkit-mask-position: 70% 60%;
  mask-position: 70% 60%;
}

.css-hover--prism-tilt .css-hover__secondary {
  opacity: 0;
  transform: skewY(8deg) rotate(2deg);
  filter: hue-rotate(90deg);
}
.css-hover--prism-tilt:hover .css-hover__secondary,
.css-hover--prism-tilt.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: none;
  filter: none;
}

.css-hover--shutter-blinds .css-hover__secondary {
  opacity: 1 !important;
  clip-path: inset(0 0 100% 0);
}
.css-hover--shutter-blinds:hover .css-hover__secondary,
.css-hover--shutter-blinds.is-hovered .css-hover__secondary {
  animation: css-hover-shutter var(--css-hover-duration, 0.5s) steps(8, end) forwards;
}
@keyframes css-hover-shutter {
  0% { clip-path: inset(0 0 100% 0); }
  12.5% { clip-path: inset(0 0 87.5% 0); }
  25% { clip-path: inset(0 0 75% 0); }
  37.5% { clip-path: inset(0 0 62.5% 0); }
  50% { clip-path: inset(0 0 50% 0); }
  62.5% { clip-path: inset(0 0 37.5% 0); }
  75% { clip-path: inset(0 0 25% 0); }
  87.5% { clip-path: inset(0 0 12.5% 0); }
  100% { clip-path: inset(0 0 0 0); }
}

.css-hover--flash-bloom .css-hover__secondary {
  opacity: 0;
}
.css-hover--flash-bloom:hover .css-hover__secondary,
.css-hover--flash-bloom.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}
.css-hover--flash-bloom .css-hover__fx {
  opacity: 0;
  background: #fff;
  mix-blend-mode: screen;
  transition: opacity calc(var(--css-hover-duration, 0.5s) * 0.6) ease-out;
}
.css-hover--flash-bloom:hover .css-hover__fx,
.css-hover--flash-bloom.is-hovered .css-hover__fx {
  opacity: 0.9;
  animation: css-hover-flash-bloom var(--css-hover-duration, 0.5s) ease-out forwards;
}
@keyframes css-hover-flash-bloom {
  0% { opacity: 0.9; }
  35% { opacity: 0.9; }
  100% { opacity: 0; }
}

.css-hover--door-hinge {
  perspective: 900px;
  transform-style: preserve-3d;
}
.css-hover--door-hinge .css-hover__primary,
.css-hover--door-hinge .css-hover__secondary {
  backface-visibility: hidden;
  transform-style: preserve-3d;
}
.css-hover--door-hinge .css-hover__secondary {
  opacity: 0;
  transform: rotateY(-78deg);
  transform-origin: left center;
}
.css-hover--door-hinge:hover .css-hover__primary,
.css-hover--door-hinge.is-hovered .css-hover__primary {
  transform: rotateY(12deg) scale(0.96);
  opacity: 0.75;
}
.css-hover--door-hinge:hover .css-hover__secondary,
.css-hover--door-hinge.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: rotateY(0deg);
}

.css-hover--page-flip {
  perspective: 850px;
  transform-style: preserve-3d;
}
.css-hover--page-flip .css-hover__secondary {
  opacity: 0;
  transform: rotateX(88deg);
  transform-origin: bottom center;
  backface-visibility: hidden;
}
.css-hover--page-flip:hover .css-hover__secondary,
.css-hover--page-flip.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: rotateX(0deg);
}

.css-hover--card-lift {
  perspective: 1000px;
  transform-style: preserve-3d;
  transition: transform var(--css-hover-duration, 0.5s) ease,
    box-shadow var(--css-hover-duration, 0.5s) ease;
}
.css-hover--card-lift .css-hover__secondary {
  opacity: 0;
}
.css-hover--card-lift:hover,
.css-hover--card-lift.is-hovered {
  transform: rotateX(10deg) rotateY(-8deg) scale(1.03);
}
.css-hover--card-lift:hover .css-hover__secondary,
.css-hover--card-lift.is-hovered .css-hover__secondary {
  opacity: 1 !important;
}
.media.css-hover-host:has(.css-hover--card-lift.is-hovered) {
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.22);
}

.css-hover--depth-push {
  perspective: 900px;
  transform-style: preserve-3d;
}
.css-hover--depth-push .css-hover__primary,
.css-hover--depth-push .css-hover__secondary {
  transform-style: preserve-3d;
  backface-visibility: hidden;
}
.css-hover--depth-push .css-hover__secondary {
  opacity: 0;
  transform: translateZ(45px) scale(1.06);
}
.css-hover--depth-push:hover .css-hover__primary,
.css-hover--depth-push.is-hovered .css-hover__primary {
  transform: translateZ(-55px) scale(0.9);
  opacity: 0.6;
}
.css-hover--depth-push:hover .css-hover__secondary,
.css-hover--depth-push.is-hovered .css-hover__secondary {
  opacity: 1 !important;
  transform: translateZ(0) scale(1);
}

.css-hover--slot-roll {
  perspective: 900px;
  transform-style: preserve-3d;
}
.css-hover--slot-roll .css-hover__secondary {
  opacity: 0;
  transform: rotateX(90deg);
  transform-origin: center center;
  backface-visibility: hidden;
}
.css-hover--slot-roll:hover .css-hover__secondary,
.css-hover--slot-roll.is-hovered .css-hover__secondary {
  animation: css-hover-slot-roll var(--css-hover-duration, 0.5s) steps(6, end) forwards;
}
@keyframes css-hover-slot-roll {
  0% { transform: rotateX(90deg); opacity: 0; }
  16.67% { transform: rotateX(72deg); opacity: 0.35; }
  33.33% { transform: rotateX(54deg); opacity: 0.55; }
  50% { transform: rotateX(36deg); opacity: 0.75; }
  66.67% { transform: rotateX(18deg); opacity: 0.9; }
  83.33% { transform: rotateX(6deg); opacity: 1; }
  100% { transform: rotateX(0deg); opacity: 1; }
}

.css-hover--pointer-tilt {
  --hover-tilt-x: 0deg;
  --hover-tilt-y: 0deg;
  perspective: 1000px;
  transform-style: preserve-3d;
  transition: transform 0.12s ease-out;
}
.css-hover--pointer-tilt .css-hover__secondary {
  opacity: 0;
}
.css-hover--pointer-tilt.is-hovered,
.css-hover--pointer-tilt:hover {
  transform: rotateX(var(--hover-tilt-y)) rotateY(var(--hover-tilt-x)) scale(1.02);
}
.css-hover--pointer-tilt.is-hovered .css-hover__secondary,
.css-hover--pointer-tilt:hover .css-hover__secondary {
  opacity: 1 !important;
}

.card-wrapper:hover .media.css-hover-host,
.product-card-wrapper:hover .media.css-hover-host,
.product-card:hover .media.css-hover-host,
.collection-card-wrapper:hover .media.css-hover-host {
  z-index: 1;
}

/*
 * Dawn stretches .card__heading a::after over the full card (invisible link).
 * On touch devices, disable until tap-reveal so first tap shows the effect.
 */
@media (hover: none) {
  .card-wrapper:has(.css-hover-host):not(.is-revealed) a.full-unstyled-link,
  .product-card-wrapper:has(.css-hover-host):not(.is-revealed) a.full-unstyled-link {
    pointer-events: none !important;
  }
}
