/* static/css/product-cards.css — Flat gallery product cards, no borders/shadows/radius */

.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}

.product-card {
  position: relative;
}

.product-card-link {
  display: block;
}

/* Image — 1:1, no border-radius, no shadow */
.product-card-image-wrap {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--color-surface);
  margin-bottom: 12px;
}

.product-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 220ms ease;
}

.product-card-link:hover .product-card-image {
  transform: scale(1.03);
}

.product-card-placeholder {
  width: 100%;
  height: 100%;
  background: var(--color-surface);
}

/* Quick view overlay */
.product-card-quick-view {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 12px;
  background: rgba(26,25,23,0.75);
  color: #fff;
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  opacity: 0;
  transform: translateY(100%);
  transition: all var(--duration-base) var(--ease-standard);
  border: none;
  cursor: pointer;
}

.product-card-link:hover .product-card-quick-view,
.product-card-link:focus-visible .product-card-quick-view {
  opacity: 1;
  transform: translateY(0);
}

/* Card info */
.product-card-info {
  padding: 0;
}

.product-card-category {
  display: block;
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-text-secondary);
  margin-bottom: 4px;
}

.product-card-title {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-primary);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-top: 0;
  margin-bottom: 4px;
}

.product-card-price {
  font-size: 13px;
  color: var(--color-text-secondary);
}

@media (max-width: 1024px) {
  .product-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .product-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}
