/* ============================================================
   collections-grid.css
   Styles specific to the collections grid section and its cards.
   Depends on: layout.css (.grid, .grid--4-col), components.css (.badge)
   ============================================================ */

/* ============================================================
   Section wrapper
   ============================================================ */
.collections-grid-section {
  padding-top: 3rem;
  padding-bottom: 8rem;
}

@media screen and (min-width: 768px) {
  .collections-grid-section {
    padding-top: 4rem;
    padding-bottom: 9rem;
  }
}

/* Optional section heading (e.g. "EXPLORE OUR COLLECTIONS") */
.collections-grid-section__heading {
  font-family: var(--font-heading-family);
  font-weight: var(--font-heading-weight);
  font-size: var(--heading-h2-size);
  line-height: var(--heading-line-height);
  text-transform: uppercase;
  color: var(--color-text-title);
  margin: 0 0 4rem;
}

@media screen and (max-width: 749px) {
  .collections-grid-section__heading {
    font-size: 2.8rem;
    margin-bottom: 2.4rem;
  }
}


/* ============================================================
   Collection card
   ============================================================ */

/**
 * .collection-card          — outer anchor element (full card is clickable)
 * .collection-card__image   — aspect-ratio image container
 * .collection-card__info    — text area below the image
 * .collection-card__count   — product count badge, overlaid top-left of image
 * .collection-card__title   — uppercase collection name
 * .collection-card__desc    — short description text
 */

.collection-card {
  display: block;
  text-decoration: none;
  color: var(--color-text);
  position: relative;
}

/* ---- Image container — portrait ratio 4:5 ---- */
.collection-card__image {
  position: relative;
  width: 100%;
  overflow: hidden;
  background-color: var(--color-background-2);
}

.collection-card__image::before {
  content: "";
  display: block;
  padding-bottom: 125%; /* 4:5 portrait ratio */
}

.collection-card__image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-long, 0.5s) ease;
}

@media screen and (min-width: 990px) {
  .collection-card:hover .collection-card__image img {
    transform: scale(1.05);
  }
}

/* ---- Product count badge — absolute top-left of image ---- */
.collection-card__count {
  position: absolute;
  top: 1.3rem;
  left: 1.3rem;
  z-index: 2;
  padding: 0.35rem 1rem;
  font-family: var(--font-body-family);
  font-weight: 600;
  font-size: 0.75rem;
  line-height: 1.5;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text);
  background-color: var(--color-background-1);
  white-space: nowrap;
}

/* ---- Text area below image ---- */
.collection-card__info {
  padding-top: 1.6rem;
}

.collection-card__title {
  display: block;
  margin: 0 0 0.6rem;
  font-family: var(--font-heading-family);
  font-weight: var(--font-heading-weight);
  font-size: 1.5rem;
  line-height: 1.3;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--color-text-title);
  transition: color var(--duration-default, 0.2s);
}

@media screen and (min-width: 1024px) {
  .collection-card__title {
    font-size: 1.5rem;
    line-height: 2rem;
  }
}

.collection-card:hover .collection-card__title {
  color: var(--color-accent);
}

.collection-card__desc {
  margin: 0;
  font-family: var(--font-body-family);
  font-size: 0.9375rem;
  line-height: var(--font-body-line-height, 1.6);
  color: var(--color-text);
  opacity: 0.7;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
