.card {
  background-color: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--card-radius);
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  position: relative;
}

.card:hover {
  box-shadow: var(--shadow-md);
}

.card__media {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-color: var(--color-bg);
  overflow: hidden;
}

.card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.card:hover .card__media img {
  transform: scale(1.04);
}

.card__body {
  padding: var(--card-padding);
}

.card__title {
  font-size: var(--fs-lg);
  font-weight: var(--fw-heading);
  margin-bottom: var(--space-xs);
  color: var(--color-text);
}

.card__description {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-sm);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card__meta {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-xs);
}

.card__actions {
  margin-top: var(--space-md);
  display: flex;
  gap: var(--space-sm);
}

.card__ribbon {
  position: absolute;
  top: var(--space-sm);
  right: var(--space-sm);
  z-index: 2;
}

.card--featured {
  border-color: var(--color-status-featured);
  box-shadow: 0 0 0 2px var(--color-status-featured);
}

.product-card {
  display: flex;
  flex-direction: column;
  background-color: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--card-radius);
  overflow: hidden;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  position: relative;
  height: 100%;
}

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

.product-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.product-card__link:hover {
  text-decoration: none;
  color: inherit;
}

.product-card__media {
  width: 100%;
  aspect-ratio: 4 / 3;
  background-color: var(--color-bg);
  overflow: hidden;
}

.product-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

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

.product-card__body {
  padding: var(--card-padding);
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  gap: var(--space-xs);
}

.product-card__title {
  font-size: var(--fs-md);
  font-weight: var(--fw-heading);
  color: var(--color-text);
  margin-bottom: var(--space-xs);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-card__description {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-card__price {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--color-price);
  margin-top: auto;
}

.product-card__meta {
  font-size: var(--fs-xs);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.product-detail {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-2xl);
  padding-top: var(--space-xl);
}

.product-detail__header {
  grid-column: 1 / -1;
  margin-bottom: var(--space-lg);
}

.product-detail__title {
  font-size: var(--fs-3xl);
  margin-bottom: var(--space-sm);
}

.product-detail__meta {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.product-detail__media {
  background-color: var(--color-bg);
  border-radius: var(--card-radius);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.product-detail__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.product-detail__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  padding: var(--space-lg);
  background-color: var(--color-surface);
  border: var(--border-width) solid var(--color-border);
  border-radius: var(--card-radius);
  height: fit-content;
}

.product-detail__price {
  font-size: var(--fs-2xl);
  font-weight: 700;
  color: var(--color-price);
  margin: 0;
}

.product-detail__condition {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
}

.product-detail__short-description {
  font-size: var(--fs-md);
  color: var(--color-text);
  line-height: var(--lh-body);
}

.product-detail__content {
  grid-column: 1 / -1;
  margin-top: var(--space-2xl);
  font-size: var(--fs-md);
  line-height: var(--lh-body);
}

@media (max-width: 768px) {
  .product-detail {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
}
