/* TAMSIC — product-card.css  (extracted from base.css; tokens defined in base.css) */
/* ---------- PRODUCT CARD (v2 style: with media subdivision) ---------- */
.product-card {
  position: relative;
  background: var(--charcoal);
  overflow: hidden;
  transition: all 0.4s var(--ease);
  height: 100%;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}
.product-card:hover {
  transform: translateY(-4px);
  border-color: var(--border-crimson);
  box-shadow:
    0 22px 60px rgba(0, 0, 0, 0.38),
    0 0 30px var(--crimson-glow);
}
.product-card-media {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--charcoal-light);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.product-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 0.8s var(--ease),
    filter 0.5s var(--ease);
  filter: grayscale(0.3) contrast(1.05);
  border-radius: inherit;
}
.product-card:hover .product-card-img {
  transform: scale(1.08);
  filter: grayscale(0) contrast(1);
}

.product-card-tag {
  position: absolute;
  top: var(--sm);
  left: var(--sm);
  background: var(--crimson);
  color: var(--bone);
  font-size: 10px;
  font-weight: 600;
  padding: 6px 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  z-index: 2;
  border-radius: var(--radius-pill);
}
.product-card-tag.tag-gold {
  background: var(--gold);
  color: var(--black);
}
.product-card-tag.tag-dark {
  background: var(--black);
  border: 1px solid var(--crimson);
  color: var(--crimson-text);
}

.product-card-actions {
  position: absolute;
  top: var(--sm);
  right: var(--sm);
  display: flex;
  flex-direction: column;
  gap: 8px;
  opacity: 0;
  transform: translateX(20px);
  transition: all 0.4s var(--ease);
  z-index: 2;
}
.product-card:hover .product-card-actions {
  opacity: 1;
  transform: translateX(0);
}
.product-card-actions button {
  width: 38px;
  height: 38px;
  background: rgba(5, 5, 5, 0.8);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(232, 230, 227, 0.1);
  color: var(--bone);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s var(--ease);
  border-radius: var(--radius-md);
}
.product-card-actions button:hover {
  background: var(--crimson);
  border-color: var(--crimson);
}

.product-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    transparent 50%,
    rgba(5, 5, 5, 0.95) 100%
  );
  opacity: 0;
  transition: opacity 0.4s var(--ease);
  /* display: flex; */
  align-items: flex-end;
  padding: var(--md);
  z-index: 1;
  top: 80%;
}
.product-card:hover .product-card-overlay {
  opacity: 1;
}
.quick-add {
  width: 100%;
  padding: 12px;
  background: var(--crimson);
  color: var(--bone);
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s var(--ease);
  transform: translateY(20px);
  opacity: 0;
  border-radius: var(--radius-md);
}
.product-card:hover .quick-add {
  transform: translateY(0);
  opacity: 1;
  transition-delay: 0.1s;
}
.quick-add:hover {
  background: var(--crimson-hover);
  color: var(--bone);
}

.product-card-body {
  padding: var(--md);
  border-top: 1px solid rgba(232, 230, 227, 0.05);
}
.product-card-category {
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--crimson-text);
  margin-bottom: 8px;
  display: block;
}
.product-card-title {
  font-size: 1rem;
  font-weight: 500;
  color: var(--bone);
  margin-bottom: 8px;
  letter-spacing: 0.02em;
}
.product-card-title a {
  color: inherit;
}
.product-card-title a:hover {
  color: var(--crimson-text);
}
.product-card-price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sm);
}
.price {
  font-size: 1.1rem;
  color: var(--bone);
  font-weight: 600;
}
.price-old {
  font-size: 0.9rem;
  color: var(--bone-dim);
  text-decoration: line-through;
}
.product-card-colors {
  display: flex;
  gap: 6px;
}
.color-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid rgba(232, 230, 227, 0.2);
}

.swatch-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.swatch {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(232, 230, 227, 0.2);
  cursor: pointer;
  position: relative;
  transition: all 0.3s var(--ease);
}
.swatch:hover,
.swatch.active {
  transform: scale(1.15);
  box-shadow: 0 0 0 2px var(--crimson);
}

.size-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
@media (max-width: 768px) {
  .quick-add {
    min-height: 40px;
    font-size: 11px;
  }
  .filter-pills,
  .size-list,
  .swatch-list {
    gap: 8px;
  }
}

@media (max-width: 480px) {
  .product-card-price {
    align-items: flex-start;
    gap: 8px;
  }
}

.wish-toggle,
.eye-btn {
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(0, 0, 0, 0.6);
  color: var(--bone-dim);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  backdrop-filter: blur(4px);
}
.wish-toggle:hover,
.eye-btn:hover {
  color: var(--crimson-text);
  background: rgba(0, 0, 0, 0.8);
}
@media (hover: none) {
  .product-card-overlay {
    opacity: 1;
  }
  .quick-add {
    transform: translateY(0);
    opacity: 1;
    transition-delay: 0s;
  }
  .product-card-actions {
    opacity: 1;
    transform: translateX(0);
  }
}

@media (max-width: 768px) {
  .product-card-body {
    padding: 14px 16px 16px;
  }
  .product-card-title {
    font-size: 0.9rem;
  }
  .product-card-price {
    font-size: 13px;
  }
}
