/* ==========================================================================
   Mirage Furniture — Finishes (#finishes)
   Showcases the brand-wide REHAU® weave colours as large, selectable swatches
   with the active colour's name shown prominently. Built from the catalogue's
   weaveColours by scripts/sections/finishes.js.
   ========================================================================== */

.finishes {
  position: relative;
  z-index: 1;                       /* scrolls over the pinned hero */
  width: 100%;
  background: var(--color-photo-bg);
  padding: clamp(4rem, 10vh, 7rem) var(--nav-pad-x);
}

.finishes__head {
  max-width: 52rem;
  margin: 0 auto;
  text-align: center;
}
.finishes__eyebrow {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-size: var(--text-sm);
  color: var(--color-text-body);
}
.finishes__title {
  margin-top: var(--space-2);
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(1.5rem, 2.6vw, 2.25rem);
  line-height: var(--leading-snug);
  color: var(--color-text-primary);
}
.finishes__lead {
  margin: var(--space-3) auto 0;
  max-width: 34rem;
  font-family: var(--font-body);
  font-size: clamp(1rem, 1.2vw, 1.1rem);
  color: var(--color-text-body);
}

/* --- Swatch grid ---------------------------------------------------------- */
.finishes__grid {
  max-width: 60rem;
  margin: clamp(2rem, 5vh, 3.5rem) auto 0;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(0.75rem, 2vw, 1.5rem);
}
.finishes__swatch {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.7rem;
  background: none;
  cursor: pointer;
}
.finishes__chip {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border: 1px solid var(--color-hairline);
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.3s ease, outline-color 0.2s ease;
  outline: 2px solid transparent;
  outline-offset: 3px;
}
.finishes__swatch:hover .finishes__chip {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.14);
}
.finishes__swatch.is-active .finishes__chip {
  outline-color: var(--color-text-primary);
}
.finishes__name {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
}

.finishes__active {
  margin-top: clamp(1.5rem, 4vh, 2.5rem);
  text-align: center;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-size: var(--text-sm);
  color: var(--color-text-body);
}
.finishes__active strong {
  color: var(--color-text-primary);
  font-weight: 400;
}

.finishes__foot {
  margin-top: var(--space-3);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-body);
}

@media (max-width: 640px) {
  .finishes__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-3);
  }
}

@media (prefers-reduced-motion: reduce) {
  .finishes__chip {
    transition: outline-color 0.2s ease;
  }
  .finishes__swatch:hover .finishes__chip {
    transform: none;
    box-shadow: none;
  }
}
