@import url('../tokens.css');

:is(
  .cat-card__hover-board,
  .cat-card__hover-save,
  .personalized-card__hover-board,
  .personalized-card__hover-save,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag,
  .listing-side-card__save
) {
  --product-action-unit-x: 1px;
  --product-action-unit-y: 1px;
  --product-action-hover-scale: 1.035;
  --product-action-ink-wash: color-mix(in srgb, var(--color-ink) 46%, transparent);
  --product-action-ink-wash-strong: color-mix(in srgb, var(--color-ink) 56%, transparent);
}

@media (hover: hover) and (pointer: fine) {
  :is(
    .cat-card__media,
    .personalized-card__media,
    .christmas-special-product-card__media
  ) {
    isolation: isolate;
  }

  :is(
    .cat-card__media,
    .personalized-card__media,
    .christmas-special-product-card__media
  )::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    border-radius: inherit;
    pointer-events: none;
    opacity: 0;
    background:
      linear-gradient(
        180deg,
        color-mix(in srgb, var(--color-ink) 44%, transparent) 0%,
        color-mix(in srgb, var(--color-ink) 24%, transparent) 32%,
        transparent 68%
      );
    transition: opacity 0.22s ease;
  }

  :is(
    .cat-card:hover .cat-card__media,
    .cat-card:has(:focus-visible) .cat-card__media,
    .cat-card.is-actions-open .cat-card__media,
    .personalized-card:hover .personalized-card__media,
    .personalized-card:has(:focus-visible) .personalized-card__media,
    .personalized-card.is-actions-open .personalized-card__media,
    .christmas-special-product-card:hover .christmas-special-product-card__media,
    .christmas-special-product-card:has(:focus-visible) .christmas-special-product-card__media,
    .christmas-special-product-card.is-actions-open .christmas-special-product-card__media
  )::after {
    opacity: 1;
  }
}

.cat-card__hover-board,
.cat-card__hover-save {
  --product-action-unit-x: var(--cat-card-unit-x, 1px);
  --product-action-unit-y: var(--cat-card-unit-y, 1px);
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
) {
  --product-action-board-height: 38;
  --product-action-board-min-width: 124;
  --product-action-board-max-width: 150;
  --product-action-board-pad-y: 6;
  --product-action-board-pad-x: 15;
  --product-action-board-gap: 10;
  --product-action-board-label-size: 11;
  --product-action-board-label-weight: 650;
  --product-action-board-icon-width: 12;
  --product-action-board-icon-height: 12;
  --product-action-board-bg: var(--intent-surface-sunken);
  --product-action-board-active-bg: transparent;
  --product-action-board-active-bg-strong: var(--product-action-ink-wash-strong);
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board
) {
  --product-action-board-bg: transparent;
  --product-action-board-label-size: 13;
  --product-action-board-label-weight: 700;
}

.listing-side-card__tag {
  --product-action-board-height: 35;
  --product-action-board-min-width: 104;
  --product-action-board-max-width: 104;
  --product-action-board-pad-x: 10;
  --product-action-board-gap: 7;
  --product-action-board-label-size: 10.5;
  --product-action-board-icon-width: 11;
  --product-action-board-icon-height: 11;
}

.personalized-card__hover-board {
  --product-action-board-min-width: 102;
  --product-action-board-max-width: 132;
  --product-action-board-pad-x: 12;
  --product-action-board-gap: 7;
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
) {
  --product-action-save-height: 38;
  --product-action-save-min-width: 84;
  --product-action-save-pad-y: 6;
  --product-action-save-pad-x: 15;
  --product-action-save-gap: 10;
  --product-action-save-label-size: 13;
  --product-action-save-label-weight: 600;
  --product-action-save-icon-width: 17;
  --product-action-save-icon-height: 18;
  --product-action-save-bg: var(--color-forest);
}

.listing-side-card__save {
  --product-action-save-height: 35;
  --product-action-save-min-width: 78;
  --product-action-save-pad-x: 13;
  --product-action-save-gap: 8;
  --product-action-save-label-size: 12;
  --product-action-save-icon-width: 15;
  --product-action-save-icon-height: 16;
}

.personalized-card__hover-save {
  --product-action-save-pad-x: 12;
  --product-action-save-gap: 8;
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
) {
  min-width: calc(var(--product-action-board-min-width) * var(--product-action-unit-x));
  width: auto;
  max-width: calc(var(--product-action-board-max-width) * var(--product-action-unit-x));
  height: calc(var(--product-action-board-height) * var(--product-action-unit-y));
  padding: calc(var(--product-action-board-pad-y) * var(--product-action-unit-y))
    calc(var(--product-action-board-pad-x) * var(--product-action-unit-x));
  border: 0;
  border-radius: 999px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--product-action-board-gap) * var(--product-action-unit-x));
  overflow: visible;
  cursor: pointer;
  font-family: var(--font-heading);
  font-weight: var(--product-action-board-label-weight);
  line-height: 1;
  white-space: nowrap;
  background: transparent;
  color: var(--color-ink);
  isolation: isolate;
  flex: 1 1 auto;
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board
) {
  color: var(--color-cream);
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
) {
  min-width: calc(var(--product-action-save-min-width) * var(--product-action-unit-x));
  width: auto;
  height: calc(var(--product-action-save-height) * var(--product-action-unit-y));
  padding: calc(var(--product-action-save-pad-y) * var(--product-action-unit-y))
    calc(var(--product-action-save-pad-x) * var(--product-action-unit-x));
  border: 0;
  border-radius: 999px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: calc(var(--product-action-save-gap) * var(--product-action-unit-x));
  overflow: visible;
  cursor: pointer;
  font-family: var(--font-heading);
  line-height: 1;
  white-space: nowrap;
  background: transparent;
  color: var(--color-cream);
  isolation: isolate;
  flex: 0 0 auto;
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
)::before,
:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: inherit;
  pointer-events: none;
  transform: scale(1);
  transform-origin: center;
  transition: transform 0.18s ease;
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
)::before {
  background: var(--product-action-board-bg);
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
)::before {
  background: var(--product-action-save-bg);
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
):hover::before,
:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
):focus-visible::before,
:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
):hover::before,
:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
):focus-visible::before {
  transform: scale(var(--product-action-hover-scale));
}

:is(
  .cat-card__hover-board,
  .personalized-card__hover-board,
  .christmas-special-product-card__hover-board,
  .listing-side-card__tag
):focus-visible,
:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .listing-side-card__save
):focus-visible {
  outline: 1px solid color-mix(in srgb, var(--color-ink) 70%, transparent);
  outline-offset: 0;
}

:is(
  .cat-card:hover .cat-card__hover-board,
  .cat-card:has(:focus-visible) .cat-card__hover-board,
  .cat-card.is-actions-open .cat-card__hover-board,
  .personalized-card:hover .personalized-card__hover-board,
  .personalized-card:has(:focus-visible) .personalized-card__hover-board,
  .personalized-card.is-actions-open .personalized-card__hover-board,
  .christmas-special-product-card:hover .christmas-special-product-card__hover-board,
  .christmas-special-product-card:has(:focus-visible) .christmas-special-product-card__hover-board,
  .christmas-special-product-card.is-actions-open .christmas-special-product-card__hover-board
) {
  color: var(--intent-text-on-brand);
}

:is(
  .cat-card:hover .cat-card__hover-board,
  .cat-card:has(:focus-visible) .cat-card__hover-board,
  .cat-card.is-actions-open .cat-card__hover-board,
  .personalized-card:hover .personalized-card__hover-board,
  .personalized-card:has(:focus-visible) .personalized-card__hover-board,
  .personalized-card.is-actions-open .personalized-card__hover-board,
  .christmas-special-product-card:hover .christmas-special-product-card__hover-board,
  .christmas-special-product-card:has(:focus-visible) .christmas-special-product-card__hover-board,
  .christmas-special-product-card.is-actions-open .christmas-special-product-card__hover-board
)::before {
  background: var(--product-action-board-active-bg);
}

:is(
  .cat-card:hover .cat-card__hover-board:hover,
  .cat-card:has(:focus-visible) .cat-card__hover-board:focus-visible,
  .personalized-card:hover .personalized-card__hover-board:hover,
  .personalized-card:has(:focus-visible) .personalized-card__hover-board:focus-visible,
  .christmas-special-product-card:hover .christmas-special-product-card__hover-board:hover,
  .christmas-special-product-card:has(:focus-visible) .christmas-special-product-card__hover-board:focus-visible
)::before {
  background: var(--product-action-board-active-bg-strong);
}

:is(
  .cat-card:hover .cat-card__hover-board img,
  .cat-card:has(:focus-visible) .cat-card__hover-board img,
  .cat-card.is-actions-open .cat-card__hover-board img,
  .personalized-card:hover .personalized-card__hover-board img,
  .personalized-card:has(:focus-visible) .personalized-card__hover-board img,
  .personalized-card.is-actions-open .personalized-card__hover-board img,
  .christmas-special-product-card:hover .christmas-special-product-card__hover-board img,
  .christmas-special-product-card:has(:focus-visible) .christmas-special-product-card__hover-board img,
  .christmas-special-product-card.is-actions-open .christmas-special-product-card__hover-board img
) {
  filter: brightness(0) invert(1);
}

:is(
  .cat-card.is-product-saved .cat-card__hover-actions,
  .cat-card.is-in-collection .cat-card__hover-actions,
  .personalized-card.is-product-saved .personalized-card__hover-actions,
  .personalized-card.is-in-collection .personalized-card__hover-actions,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-actions,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-actions
) {
  right: calc(18 * var(--cat-card-unit-x, 1px));
  left: auto;
  width: auto;
  max-width: calc(100% - calc(36 * var(--cat-card-unit-x, 1px)));
  height: auto;
  align-items: flex-start;
  justify-content: flex-end;
  gap: calc(10 * var(--cat-card-unit-x, 1px));
}

:is(
  .cat-card.is-product-saved .cat-card__hover-board,
  .cat-card.is-in-collection .cat-card__hover-board,
  .personalized-card.is-product-saved .personalized-card__hover-board,
  .personalized-card.is-in-collection .personalized-card__hover-board,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-board,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-board
) {
  flex: 0 1 auto;
  width: max-content;
  min-width: calc(76 * var(--product-action-unit-x));
  max-width: min(
    calc(156 * var(--product-action-unit-x)),
    calc(100% - calc(96 * var(--product-action-unit-x)))
  );
  height: auto;
  min-height: calc(38 * var(--product-action-unit-y));
  padding: 0;
  border-radius: 0;
  justify-content: flex-start;
  gap: 0;
  color: var(--color-cream);
  cursor: default;
  pointer-events: none;
  text-align: right;
  text-shadow: none;
}

.cat-card.cat-card--ad:is(.is-product-saved, .is-in-collection) .cat-card__hover-board {
  max-width: min(
    calc(132 * var(--product-action-unit-x)),
    calc(100% - calc(100 * var(--product-action-unit-x)))
  );
}

:is(
  .cat-card.is-product-saved .cat-card__hover-board::before,
  .cat-card.is-in-collection .cat-card__hover-board::before,
  .cat-card.is-product-saved:hover .cat-card__hover-board:hover::before,
  .cat-card.is-in-collection:hover .cat-card__hover-board:hover::before,
  .cat-card.is-product-saved:has(:focus-visible) .cat-card__hover-board:focus-visible::before,
  .cat-card.is-in-collection:has(:focus-visible) .cat-card__hover-board:focus-visible::before,
  .personalized-card.is-product-saved .personalized-card__hover-board::before,
  .personalized-card.is-in-collection .personalized-card__hover-board::before,
  .personalized-card.is-product-saved:hover .personalized-card__hover-board:hover::before,
  .personalized-card.is-in-collection:hover .personalized-card__hover-board:hover::before,
  .personalized-card.is-product-saved:has(:focus-visible) .personalized-card__hover-board:focus-visible::before,
  .personalized-card.is-in-collection:has(:focus-visible) .personalized-card__hover-board:focus-visible::before,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-board::before,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-board::before,
  .christmas-special-product-card.is-product-saved:hover .christmas-special-product-card__hover-board:hover::before,
  .christmas-special-product-card.is-in-collection:hover .christmas-special-product-card__hover-board:hover::before,
  .christmas-special-product-card.is-product-saved:has(:focus-visible) .christmas-special-product-card__hover-board:focus-visible::before,
  .christmas-special-product-card.is-in-collection:has(:focus-visible) .christmas-special-product-card__hover-board:focus-visible::before
) {
  background: transparent;
  transform: none;
}

:is(
  .cat-card.is-product-saved .cat-card__hover-board img,
  .cat-card.is-in-collection .cat-card__hover-board img,
  .cat-card.is-product-saved .cat-card__hover-board svg,
  .cat-card.is-in-collection .cat-card__hover-board svg,
  .personalized-card.is-product-saved .personalized-card__hover-board img,
  .personalized-card.is-in-collection .personalized-card__hover-board img,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-board img,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-board img
) {
  display: none;
}

:is(
  .cat-card.is-product-saved .cat-card__hover-board-label,
  .cat-card.is-in-collection .cat-card__hover-board-label,
  .personalized-card.is-product-saved .personalized-card__hover-board-label,
  .personalized-card.is-in-collection .personalized-card__hover-board-label,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-board-label,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-board-label
) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
  line-height: 1.28;
  font-size: calc(15 * var(--product-action-unit-x));
  font-weight: 760;
  max-width: 100%;
  padding-bottom: calc(1 * var(--product-action-unit-y));
}

:is(
  .cat-card.is-product-saved .cat-card__hover-board.is-board-label-long .cat-card__hover-board-label,
  .cat-card.is-in-collection .cat-card__hover-board.is-board-label-long .cat-card__hover-board-label,
  .personalized-card.is-product-saved .personalized-card__hover-board.is-board-label-long .personalized-card__hover-board-label,
  .personalized-card.is-in-collection .personalized-card__hover-board.is-board-label-long .personalized-card__hover-board-label,
  .christmas-special-product-card.is-product-saved .christmas-special-product-card__hover-board.is-board-label-long .christmas-special-product-card__hover-board-label,
  .christmas-special-product-card.is-in-collection .christmas-special-product-card__hover-board.is-board-label-long .christmas-special-product-card__hover-board-label
) {
  white-space: normal;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-height: 1.22;
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .christmas-special-product-card__hover-save,
  .listing-side-card__save,
  .search-curated-card__save
).is-liked {
  background: transparent;
  color: var(--color-cream);
  overflow: hidden;
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .christmas-special-product-card__hover-save,
  .listing-side-card__save,
  .search-curated-card__save
).is-liked::before {
  background: var(--color-ink);
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .christmas-special-product-card__hover-save,
  .listing-side-card__save,
  .search-curated-card__save
)::before {
  transition: transform 180ms ease;
}

:is(
  .cat-card__hover-save,
  .personalized-card__hover-save,
  .christmas-special-product-card__hover-save,
  .listing-side-card__save,
  .search-curated-card__save
).is-liked::after {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 0;
  border-radius: inherit;
  background: var(--color-ink);
  clip-path: circle(var(--product-action-ripple-radius, 150%) at var(--product-action-ripple-x, 50%) var(--product-action-ripple-y, 50%));
  pointer-events: none;
}

@media (prefers-reduced-motion: no-preference) {
  :is(
    .cat-card__hover-save,
    .personalized-card__hover-save,
    .christmas-special-product-card__hover-save,
    .listing-side-card__save,
    .search-curated-card__save
  ).is-liked {
    animation: product-action-saved-settle 300ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  }

  :is(
    .cat-card__hover-save,
    .personalized-card__hover-save,
    .christmas-special-product-card__hover-save,
    .listing-side-card__save,
    .search-curated-card__save
  ).is-liked::after {
    animation: product-action-saved-ripple 420ms cubic-bezier(0.0, 0.0, 0.2, 1) forwards;
  }

  .cat-card__hover-save.is-liked .cat-card__hover-save-label,
  .personalized-card__hover-save.is-liked .personalized-card__hover-save-label,
  .christmas-special-product-card__hover-save.is-liked .christmas-special-product-card__hover-save-label,
  .listing-side-card__save.is-liked .listing-side-card__save-label,
  .search-curated-card__save.is-liked .search-curated-card__save-label {
    animation: product-action-saved-label 240ms ease-out;
  }
}

@keyframes product-action-saved-settle {
  0%   { transform: scale(1); }
  28%  { transform: scale(0.92); }
  100% { transform: scale(1); }
}

@keyframes product-action-saved-ripple {
  0%   { clip-path: circle(0% at var(--product-action-ripple-x, 50%) var(--product-action-ripple-y, 50%)); }
  100% { clip-path: circle(var(--product-action-ripple-radius, 150%) at var(--product-action-ripple-x, 50%) var(--product-action-ripple-y, 50%)); }
}

@keyframes product-action-saved-label {
  0%   { opacity: 0; transform: translateY(3px); }
  100% { opacity: 1; transform: translateY(0); }
}

:is(
  .cat-card__hover-board-label,
  .personalized-card__hover-board-label,
  .listing-side-card__tag-label
) {
  display: block;
  min-width: 0;
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: calc(var(--product-action-board-label-size) * var(--product-action-unit-x));
  font-weight: var(--product-action-board-label-weight);
  line-height: 1.24;
  letter-spacing: 0;
  padding-bottom: calc(1 * var(--product-action-unit-y));
}

:is(
  .cat-card__hover-save-label,
  .personalized-card__hover-save-label,
  .christmas-special-product-card__hover-save-label,
  .listing-side-card__save-label,
  .search-curated-card__save-label
) {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-heading);
  font-size: calc(var(--product-action-save-label-size) * var(--product-action-unit-x));
  font-weight: var(--product-action-save-label-weight);
  line-height: 1;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
}

:is(
  .cat-card__hover-board svg,
  .cat-card__hover-board img,
  .personalized-card__hover-board img,
  .christmas-special-product-card__hover-board img,
  .listing-side-card__tag-icon
) {
  width: calc(var(--product-action-board-icon-width) * var(--product-action-unit-x));
  height: calc(var(--product-action-board-icon-height) * var(--product-action-unit-y));
  flex: 0 0 calc(var(--product-action-board-icon-width) * var(--product-action-unit-x));
  display: block;
  object-fit: contain;
}

:is(
  .cat-card__hover-board img,
  .personalized-card__hover-board img,
  .christmas-special-product-card__hover-board img
) {
  filter: brightness(0) invert(1);
}

:is(
  .cat-card__hover-save svg,
  .cat-card__hover-save img,
  .personalized-card__hover-save img,
  .listing-side-card__save-icon
) {
  width: calc(var(--product-action-save-icon-width) * var(--product-action-unit-x));
  height: calc(var(--product-action-save-icon-height) * var(--product-action-unit-y));
  flex: 0 0 calc(var(--product-action-save-icon-width) * var(--product-action-unit-x));
  display: block;
  object-fit: contain;
  filter: none;
}

@media (max-width: 1199px) {
  .personalized-card__hover-board {
    --product-action-board-min-width: 38;
    --product-action-board-max-width: 38;
    --product-action-board-pad-y: 0;
    --product-action-board-pad-x: 0;
    --product-action-board-gap: 0;
    width: 38px;
    flex: 0 0 38px;
    justify-content: center;
  }

  .personalized-card__hover-save {
    --product-action-save-min-width: 84;
    --product-action-save-pad-y: 6;
    --product-action-save-pad-x: 15;
    --product-action-save-gap: 0;
    width: auto;
    flex: 0 0 auto;
  }

  .personalized-card__hover-board-label {
    display: none;
  }

  .personalized-card__hover-save-label {
    display: block;
  }
}

@media (hover: none), (pointer: coarse) {
  :is(
    .cat-card__hover-actions,
    .personalized-card__hover-actions,
    .christmas-special-product-card__hover-actions
  ) {
    display: none !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: none !important;
  }
}

/* Shared ad marker: category/search/favorites cards all render this class. */
.cat-card__ad-mark {
  width: var(--cat-card-corner-badge-size, 38px);
  height: var(--cat-card-corner-badge-size, 38px);
  left: var(--cat-card-corner-badge-left, 8px);
  top: var(--cat-card-corner-badge-top, 8px);
  box-shadow: none;
  opacity: 0.7;
  font-size: var(--cat-card-corner-badge-ad-font-size, 15px);
  font-weight: 800;
}
