/*
 * components/product_card.css — картка товару в каталозі
 */

.product-card {
  display: flex;
  flex-direction: column;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: box-shadow var(--t-base), transform var(--t-base);
}

.product-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.product-card__image-wrap {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--c-bg-alt);
}

.product-card__picture {
  display: block;
  width: 100%;
  height: 100%;
}

.product-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow);
}

.product-card:hover .product-card__image {
  transform: scale(1.04);
}

.product-card__badges {
  position: absolute;
  top: var(--sp-2);
  left: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}

.product-card__body {
  padding: var(--sp-3);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.product-card__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  line-height: var(--lh-snug);
  color: var(--c-text);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.product-card__sizes {
  font-size: var(--fs-xs);
  color: var(--c-text-muted);
}

.product-card__price-row {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  margin-top: auto;
}

.product-card__price {
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--c-text);
}

.product-card__price-old {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  text-decoration: line-through;
}

.product-card__stock {
  font-size: var(--fs-xs);
  color: var(--c-success);
  font-weight: var(--fw-medium);
}

.product-card__btn {
  margin-top: var(--sp-2);
}

.product-card__no-image {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  background: linear-gradient(145deg, var(--c-bg-alt) 0%, var(--c-accent-bg) 100%);
}

.product-card__no-image-icon {
  font-size: 40px;
  opacity: 0.55;
}

@media (max-width: 639px) {
  .product-card__body {
    padding: var(--sp-2) var(--sp-3) var(--sp-3);
    gap: var(--sp-1);
  }

  .product-card__name {
    font-size: var(--fs-xs);
    min-height: 2.5em;
  }

  .product-card__price {
    font-size: var(--fs-md);
  }

  .product-card__btn {
    margin-top: var(--sp-1);
    padding-inline: var(--sp-3);
    font-size: var(--fs-sm);
    min-height: 40px;
  }

  .product-card__badges {
    top: var(--sp-1);
    left: var(--sp-1);
  }
}
