/* ==========================================================================
   WooPlainly – WooCommerce – Product Card
   ========================================================================= */

/* ---------------------------------------------------------
   BLOK 1 — System zmiennych + baza karty
   --------------------------------------------------------- */

.products .wooplainly-card {
  /* Paleta jak w pozostałych plikach */
  --bg: var(--wooplainly-color-surface) !important;
  --surface: var(--wooplainly-color-surface-alt) !important;
  --surface-2: color-mix(
    in srgb,
    var(--wooplainly-color-surface) 75%,
    var(--wooplainly-color-surface-contrast) 25%
  ) !important;
  --stroke: var(--wooplainly-color-surface-contrast) !important;

  --text: var(--wooplainly-color-text) !important;
  --muted: var(--wooplainly-color-text-muted) !important;
  --muted-2: var(--wooplainly-color-text-muted-strong) !important;

  --primary: var(--wooplainly-color-primary) !important;
  --primary-600: var(--wooplainly-color-primary-alt) !important;
  --primary-700: var(--wooplainly-color-primary-strong) !important;
  --on-primary: var(--wooplainly-color-on-primary) !important;

  --radius-lg: var(--wooplainly-radius-lg) !important;
  --radius-md: var(--wooplainly-radius-md) !important;
  --radius-sm: var(--wooplainly-radius-sm) !important;

  --shadow: var(--wooplainly-shadow-lg) !important;

  /* Spacje */
  --gap-lg: 1.5rem !important; /* 24px */
  --gap-md: 1rem !important; /* 16px */
  --gap-sm: 0.625rem !important; /* 10px */

  color: var(--text) !important;
  list-style: none !important;
  background: var(--bg) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: 0 0.125rem 0.5rem rgba(0, 0, 0, 0.08) !important; /* 0 2px 8px */
  overflow: hidden !important;
  transition:
    transform 0.2s ease,
    box-shadow 0.3s ease,
    background 0.3s ease !important;
}

.products .wooplainly-card:is(:hover, :focus-visible, :active) {
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.18) !important; /* 0 8px 24px */
}

/* Wnętrze karty */
.wooplainly-card__inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

/* ---------------------------------------------------------
   BLOK 2 — Obrazek / media
   --------------------------------------------------------- */

.wooplainly-card__media {
  position: relative !important;
  overflow: hidden !important;
  border-radius: var(--radius-md) var(--radius-md) 0 0 !important;
}

.wooplainly-card__image,
.wooplainly-card__image-link,
.wooplainly-card__image-media {
  display: block !important;
  position: relative !important;
  aspect-ratio: 1 / 1 !important;
}

.wooplainly-card__image-tag {
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.4s ease !important;
}
@media (min-width: 62rem) {
  /* 992px */
  .wooplainly-card:is(:hover, :focus-visible, :active)
    .wooplainly-card__image-tag {
    transform: scale(1.06) !important;
  }
}

/* Warstwy narzędziowe */
.wooplainly-card__layer {
  pointer-events: none !important;
}

/* ---------------------------------------------------------
   BLOK 3 — Badges (NOWOŚĆ / itp.)
   --------------------------------------------------------- */

.wooplainly-card__layer--badge {
  pointer-events: none !important;
}

.wooplainly-card__badge .new-badge,
.wooplainly-card__badge .bestseller-badge {
  position: absolute !important;
  inset: 0 auto auto 0 !important;
  transform: translate(0.75rem, 0.75rem) !important; /* 12px */
  font-size: 0.75rem !important; /* 12px */
  font-weight: 700 !important;
  padding: 0.375rem 0.75rem !important; /* 6px 12px */
  border-radius: 999rem !important;
  text-transform: uppercase !important;
  z-index: 7 !important;
  color: var(--on-primary) !important;
}

.wooplainly-card__badge .new-badge {
  background: var(--primary) !important;
}
.wooplainly-card__badge .bestseller-badge {
  background: var(--primary-600) !important;
}

/* ---------------------------------------------------------
   BLOK 4 — Wishlist (serduszko)
   --------------------------------------------------------- */

.wooplainly-card__layer--wishlist {
  position: absolute !important;
  top: 0.75rem !important;
  right: 0.75rem !important;
  pointer-events: auto !important;
  opacity: 0 !important;
  transform: translateY(-0.625rem) !important; /* 10px */
  transition:
    opacity 0.25s ease,
    transform 0.25s ease !important;
  z-index: 10 !important;
}

.wooplainly-card:is(:hover, :focus-visible, :active)
  .wooplainly-card__layer--wishlist,
.wooplainly-card .wooplainly-card__layer--wishlist:focus-within {
  opacity: 1 !important;
  transform: translateY(0) !important;
}

.wooplainly-card__wishlist .wooplainly-wishlist-button-block {
  pointer-events: auto !important;
}

.wooplainly-card__wishlist .wooplainly-wishlist-button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  inline-size: 2.25rem !important; /* 36px */
  block-size: 2.25rem !important;
  border-radius: 999rem !important;
  background: var(--bg);
  color: var(--text);
  box-shadow: 0 0.125rem 0.625rem rgba(0, 0, 0, 0.15) !important; /* 0 2px 10px */
  transition:
    background 0.2s ease,
    color 0.2s ease !important;
  padding: 0 !important;
}

.wooplainly-card__wishlist .wooplainly-wishlist-button svg {
  inline-size: 1.125rem !important; /* 18px */
  block-size: 1.125rem !important;
  stroke: currentColor;
}

.wooplainly-card__wishlist .wooplainly-wishlist-button__text {
  display: none !important;
}

.wooplainly-card__wishlist
  .wooplainly-wishlist-button:is(:hover, :focus-visible, :active) {
  color: var(--primary);
  background: var(--bg) !important;
}

.wooplainly-card__wishlist .wooplainly-wishlist-button.is-active {
  color: var(--primary);
}
.wooplainly-card__wishlist .wooplainly-wishlist-button.is-active svg {
  fill: currentColor;
}

.wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:is(:hover, :focus-visible, :active) {
  color: var(--text);
}

.wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:is(:hover, :focus-visible, :active)
  svg,
.wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:focus-visible
  svg {
  fill: currentcolor;
}

/* ---------------------------------------------------------
   BLOK 5 — CTA „Dodaj do koszyka”
   (Grid: na hover; Lista/Mobile: zawsze widoczny, w normalnym flow)
   --------------------------------------------------------- */

.wooplainly-card__layer--add_to_cart {
  position: absolute !important;
  inset: auto 0.75rem 0.75rem !important; /* 12px marginesy */
  pointer-events: none !important;
  display: flex !important;
  justify-content: center !important;
  z-index: 8 !important;
}

.wooplainly-card__add-to-cart-wrap {
  inline-size: 100% !important;
  pointer-events: auto !important;
  transform: scale(0.94) !important;
  opacity: 0 !important;
  transition:
    opacity 0.25s ease,
    transform 0.25s ease,
    box-shadow 0.3s ease,
    background 0.3s ease,
    color 0.3s ease !important;
}

.wooplainly-card:is(:hover, :focus-visible, :active)
  .wooplainly-card__add-to-cart-wrap {
  opacity: 1 !important;
  transform: scale(1) !important;
}

.wooplainly-card__add-to-cart {
  display: inline-flex !important;
  position: relative !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1rem !important; /* 16px */
  inline-size: 100% !important;
  block-size: 3rem !important; /* 48px */
  border-radius: var(--radius-sm) !important;
  background: var(--bg) !important;
  color: var(--text) !important;
  font-weight: 700 !important;
  font-size: 0.875rem !important; /* 14px */
  border: 0 !important;
  text-decoration: none !important;
  overflow: hidden;
  transition:
    background 0.3s ease,
    color 0.3s ease !important;
}

.wooplainly-card__add-to-cart:is(:hover, :focus-visible, :active) {
  color: var(--primary-600) !important;
}

.wooplainly-card__add-to-cart-icon {
  line-height: 1 !important;
}
.wooplainly-card__add-to-cart-icon svg {
  inline-size: 1.125rem !important; /* 18px */
  block-size: 1.125rem !important;
  stroke: currentColor !important;
  fill: none !important;
}

/* Modyfikatory układu — przycisk koszyka i wishlisty w treści */
.wooplainly-card--add-to-cart-detached .wooplainly-card__layer--add_to_cart,
.wooplainly-card--add-to-cart-inline .wooplainly-card__layer--add_to_cart,
.wooplainly-card--wishlist-expanded .wooplainly-card__layer--wishlist,
.wooplainly-card--wishlist-inline .wooplainly-card__layer--wishlist {
  position: static !important;
  inset: auto !important;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
}

.wooplainly-card--add-to-cart-detached .wooplainly-card__add-to-cart-wrap,
.wooplainly-card--add-to-cart-inline .wooplainly-card__add-to-cart-wrap {
  opacity: 1 !important;
  transform: none !important;
}

.wooplainly-card--wishlist-expanded .wooplainly-card__layer--wishlist {
  margin-inline-start: auto !important;
}

.wooplainly-card--wishlist-inline .wooplainly-card__layer--wishlist {
  margin: 0 !important;
}

.wooplainly-card--add-to-cart-inline .wooplainly-card__layer--add_to_cart,
.wooplainly-card--wishlist-inline .wooplainly-card__layer--wishlist {
  inline-size: 100% !important;
}

.wooplainly-card--add-to-cart-inline .wooplainly-card__add-to-cart {
  background: var(--primary) !important;
  color: var(--bg) !important;
}

.wooplainly-card--add-to-cart-inline
  .wooplainly-card__add-to-cart:is(:hover, :focus-visible, :active),
.wooplainly-card--add-to-cart-inline
  .wooplainly-card__add-to-cart:focus-visible {
  background: color-mix(in srgb, var(--primary) 12%, var(--bg) 88%) !important;
  color: var(--primary) !important;
}

.wooplainly-card--wishlist-inline .wooplainly-card__wishlist {
  display: flex !important;
  inline-size: 100% !important;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button-block {
  width: 100%;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button {
  inline-size: 100% !important;
  block-size: 3rem !important;
  border-radius: var(--radius-sm) !important;
  background: var(--bg);
  color: var(--text);
  font-weight: 700 !important;
  font-size: 0.875rem !important;
  gap: 0.75rem !important;
  box-shadow: 0 0.125rem 0.625rem rgba(0, 0, 0, 0.12) !important;
  padding-inline: 1.25rem !important;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button__text {
  display: inline !important;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button
  svg {
  inline-size: 1.125rem !important;
  block-size: 1.125rem !important;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button:is(:hover, :focus-visible, :active),
.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button:focus-visible {
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 12%, var(--bg) 88%) !important;
}

.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active {
  color: var(--primary);
}
.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:is(:hover, :focus-visible, :active),
.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:focus-visible {
  color: var(--text);
}
.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:is(:hover, :focus-visible, :active)
  svg,
.wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button.is-active:focus-visible
  svg {
  fill: currentcolor;
}

/* ---------------------------------------------------------
   BLOK 6 — Content: kategoria, tytuł, cena
   --------------------------------------------------------- */

.wooplainly-card__content {
  padding: 1rem 1.125rem 1.25rem !important; /* 16 18 20 */
  display: flex !important;
  flex-direction: column !important;
  gap: 0.625rem !important; /* 10px */
  flex: 1;
}

.wooplainly-card__element--price {
  margin-top: auto;
}

.wooplainly-card__category {
  font-size: 0.8125rem !important; /* 13px */
  font-weight: 500 !important;
  color: color-mix(in srgb, var(--muted) 77%, transparent) !important;
}

.wooplainly-card__title {
  color: var(--text) !important;
  text-decoration: none !important;
}

.wooplainly-card__title-text {
  font-size: 1rem !important; /* 16px */
  font-weight: 600 !important;
  margin: 0 !important;
  padding-bottom: 0 !important;
  color: inherit !important;
}

.wooplainly-card__price {
  font-size: 1.125rem !important; /* ~18px */
  font-weight: 700 !important;
  color: var(--muted) !important;
}

/* ---------------------------------------------------------
   BLOK 7 — Atrybuty / Swatches
   --------------------------------------------------------- */

.wooplainly-card__attributes {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important; /* 8px */
  flex-wrap: wrap !important;
}

.wooplainly-card__attributes-label {
  font-size: 0.8125rem !important; /* 13px */
  color: color-mix(in srgb, var(--muted) 77%, transparent) !important;
}

.wooplainly-card__swatches {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.375rem !important; /* 6px */
  max-inline-size: 100% !important;
}

.wooplainly-card__swatch {
  inline-size: 1.125rem !important; /* 18px */
  block-size: 1.125rem !important;
  border-radius: 999rem !important;
  border: 0.125rem solid var(--bg) !important; /* 2px */
  box-shadow: 0 0 0 0.0625rem rgba(0, 0, 0, 0.1) !important; /* 1px */
  background: var(--swatch-color, #ccc) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
}

/* ---------------------------------------------------------
   BLOK 8 — Ocena / gwiazdki
   --------------------------------------------------------- */

.wooplainly-card__rating {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
}
.wooplainly-card__stars {
  position: relative !important;
  inline-size: 5.3125rem !important;
  block-size: 0.875rem !important;
} /* 85x14px */

.wooplainly-card__stars-base,
.wooplainly-card__stars-fill {
  display: inline-flex !important;
  gap: 0.125rem !important; /* 2px */
  position: absolute !important;
  inset: 0 auto auto 0 !important;
}

.wooplainly-card__stars-fill {
  overflow: hidden !important;
  color: var(--primary-600) !important;
}
.wooplainly-card__stars-base {
  color: rgba(0, 0, 0, 0.12) !important;
}

.wooplainly-card__star svg {
  inline-size: 0.875rem !important; /* 14px */
  block-size: 0.875rem !important;
  display: block !important;
}
.wooplainly-card__stars-fill .wooplainly-card__star.is-filled svg {
  fill: #f4b63f !important;
}

.wooplainly-card__rating-count {
  font-size: 0.75rem !important;
  color: color-mix(in srgb, var(--muted) 70%, transparent) !important;
}

/* ---------------------------------------------------------
   BLOK 9 — Widok LIST (desktop)
   – CTA + Wishlist w normalnym przepływie, bez hovera
   --------------------------------------------------------- */

body.wooplainly-view-list ul.products {
  display: flex !important;
  flex-direction: column !important;
  gap: 1.5rem !important; /* 24px */
}

body.wooplainly-view-list ul.products li.product {
  inline-size: 100% !important;
  margin: 0 !important;
}

body.wooplainly-view-list .wooplainly-card__inner {
  flex-direction: row !important;
  align-items: stretch !important;
}

body.wooplainly-view-list .wooplainly-card__media {
  inline-size: min(12.5rem, 40%) !important; /* 200px lub 40% */
  border-radius: var(--radius-md) !important;
  flex-shrink: 0 !important;
}

/* CTA i Wishlist – w normalnym flow */
body.wooplainly-view-list .wooplainly-card__layer--add_to_cart,
body.wooplainly-view-list .wooplainly-card__layer--wishlist {
  position: static !important;
  inset: auto !important;
  opacity: 1 !important;
  transform: none !important;
  pointer-events: auto !important;
}

body.wooplainly-view-list .wooplainly-card__add-to-cart-wrap {
  opacity: 1 !important;
  transform: none !important;
}

/* Ustawienie „pasków akcji” pod obrazkiem w kolumnie media */
body.wooplainly-view-list .wooplainly-card__media {
  display: flex !important;
  gap: 0.75rem !important;
}

body.wooplainly-view-list .wooplainly-card__layer--wishlist {
  margin-inline-start: auto !important;
}

body.wooplainly-view-list .wooplainly-card__content {
  padding: 1.5rem !important; /* 24px */
  gap: 0.875rem !important; /* 14px */
  justify-content: center !important;
  flex: 1 1 auto !important;
}

body.wooplainly-view-list .wooplainly-card__title-text {
  font-size: 1.25rem !important;
} /* 20px */
body.wooplainly-view-list .wooplainly-card__category,
body.wooplainly-view-list .wooplainly-card__rating-count {
  font-size: 0.9375rem !important;
} /* 15px */

body.wooplainly-view-list .wooplainly-card__element--wishlist{
  position: absolute;
  right: 2rem;
  top: 2rem;
}
body.wooplainly-view-list .wooplainly-card__element--wishlist .wooplainly-wishlist-button__text{
	display: none !important;
}

body.wooplainly-view-list .wooplainly-card__element--add_to_cart{
  position: absolute;
  right: 2rem;
  bottom: 2rem;
}
body.wooplainly-view-list .wooplainly-card__element--add_to_cart .wooplainly-card__add-to-cart{
  padding-inline: 1.25rem !important;
}
body.wooplainly-view-list .wooplainly-card__element--add_to_cart .wooplainly-card__add-to-cart-label{
	display: none !important;
}

body.wooplainly-view-list .wooplainly-card__price {
    font-size: 1.25rem !important;
}

/* ---------------------------------------------------------
   BLOK 10 — Responsywność (992px / 576px)
   --------------------------------------------------------- */

@media (max-width: 62rem) {
  /* 992px */
  .wooplainly-card__title-text {
    font-size: 1rem !important;
  }
  body.wooplainly-view-list .wooplainly-card__inner {
    flex-direction: column !important;
  }
  body.wooplainly-view-list .wooplainly-card__media {
    inline-size: 100% !important;
  }
  body.wooplainly-view-list .wooplainly-card__content {
    padding: 1.25rem !important;
  }
}

/* Mobile — CTA & Wishlist zawsze widoczne (także w grid) */
@media (max-width: 36rem) {
  /* 576px */
  .wooplainly-card__layer--add_to_cart,
  .wooplainly-card__layer--wishlist {
    position: static !important;
    inset: auto !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
  }

  .wooplainly-card__add-to-cart-wrap {
    opacity: 1 !important;
    transform: none !important;
  }

  /* Uporządkowanie kolejności: media, actions, content */
  .wooplainly-card__media {
    display: flex !important;
    flex-direction: column !important;
  }

  .wooplainly-card__layer--wishlist {
    margin-inline-start: auto !important;
  }

  /* Swatche — poziomy scroll, żadnych rozwinięć */
  .wooplainly-card__swatches {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding-block-end: 0.125rem !important;
  }
}

/* ---------------------------------------------------------
   BLOK 11 — Dark mode
   --------------------------------------------------------- */

[data-theme="dark"] .product .wooplainly-card {
  background: var(--surface-2) !important;
  border-color: color-mix(in srgb, var(--stroke) 45%, transparent) !important;
}

[data-theme="dark"]
  .wooplainly-card--add-to-cart-inline
  .wooplainly-card__add-to-cart {
  color: var(--text) !important;
}
[data-theme="dark"]
  .wooplainly-card--add-to-cart-inline
  .wooplainly-card__add-to-cart:is(:hover, :focus-visible, :active),
[data-theme="dark"]
  .wooplainly-card--add-to-cart-inline
  .wooplainly-card__add-to-cart:focus-visible {
  color: var(--primary) !important;
}
[data-theme="dark"]
  .wooplainly-card--wishlist-inline
  .wooplainly-card__wishlist
  .wooplainly-wishlist-button {
  background: color-mix(in srgb, var(--surface) 85%, transparent) !important;
}

[data-theme="dark"] .wooplainly-card__category,
[data-theme="dark"] .wooplainly-card__attributes-label,
[data-theme="dark"] .wooplainly-card__rating-count {
  color: color-mix(in srgb, var(--muted) 70%, transparent) !important;
}

[data-theme="dark"] .wooplainly-card__swatch {
  border-color: var(--text) !important;
}

[data-theme="dark"] .wooplainly-card__stars-base {
  color: rgba(255, 255, 255, 0.2) !important;
}

/* ---------------------------------------------------------
   BLOK 12 — Focus / dostępność
   --------------------------------------------------------- */

.wooplainly-card a:focus-visible,
.wooplainly-card button:focus-visible {
  outline: 0.1875rem solid color-mix(in srgb, var(--primary) 35%, transparent) !important; /* 3px */
  outline-offset: 0.125rem !important; /* 2px */
  border-radius: 0.5rem !important; /* 8px */
}
