/* ==========================================================================
   CASA ROVESTO — Store
   Handle: cr-store. Product grid + single product + collection layouts.
   Mobile-first (base = phone, min-width breakpoints up). Editorial, lots of
   whitespace, image-forward, 44px touch targets. Consumes cr-tokens.
   Plays nicely with woo-variation-swatches (swatch containers below).
   ========================================================================== */

/* ── Shared shell ── */
.cr-store {
  color: var(--cr-color-ink);
  font-family: var(--cr-font-text);
  font-size: var(--cr-text-base);
  line-height: var(--cr-leading-body);
  -webkit-font-smoothing: antialiased;
}
.cr-store *,
.cr-store *::before,
.cr-store *::after { box-sizing: border-box; }

.cr-wrap {
  width: 100%;
  max-width: var(--cr-container);
  margin-inline: auto;
  padding-inline: var(--cr-gutter);
}

.cr-eyebrow {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-weight-medium);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin: 0 0 var(--cr-space-2);
}

.cr-heading {
  font-family: var(--cr-font-display);
  font-weight: var(--cr-weight-regular);
  letter-spacing: var(--cr-tracking-tight);
  line-height: var(--cr-leading-tight);
  color: var(--cr-color-ink);
  margin: 0;
}

/* ── Section header (used by shop + collection) ── */
.cr-section-head {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-2);
  padding-block: var(--cr-space-6) var(--cr-space-5);
}
.cr-section-head__title { font-size: var(--cr-text-2xl); }
.cr-section-head__meta {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}

/* ── Filter / sort bar ── */
.cr-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cr-space-2);
  padding-block: var(--cr-space-3);
  border-block: 1px solid var(--cr-line);
  margin-bottom: var(--cr-space-5);
}
.cr-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-4);
  border: 1px solid var(--cr-line-strong);
  background: transparent;
  border-radius: var(--cr-radius-pill);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-ink);
  cursor: pointer;
  text-decoration: none;
  transition: border-color var(--cr-dur-fast) var(--cr-ease),
              background var(--cr-dur-fast) var(--cr-ease),
              color var(--cr-dur-fast) var(--cr-ease);
}
.cr-chip:hover { border-color: var(--cr-color-ink); }
.cr-chip[aria-pressed="true"],
.cr-chip.is-active {
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border-color: var(--cr-color-ink);
}

/* ==========================================================================
   PRODUCT GRID  ([cr_product_grid] / shop / wishlist)
   ========================================================================== */

/* ── Grid hero header (optional eyebrow + title above the product grid) ── */
.cr-grid__hero {
  padding-block: var(--cr-space-7) var(--cr-space-5);
  border-bottom: 1px solid var(--cr-line);
  margin-bottom: var(--cr-space-5);
}
.cr-grid__hero-eyebrow {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin: 0 0 var(--cr-space-3);
}
.cr-grid__hero-title {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-2xl);
  font-weight: 300;
  line-height: var(--cr-leading-snug);
  letter-spacing: var(--cr-tracking-tight);
  margin: 0;
}

.cr-product-grid,
.cr-grid__items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cr-space-4) var(--cr-space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ── Card ── */
.cr-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: transparent;
}
.cr-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
}

/* Image-forward cover */
.cr-card__media {
  position: relative;
  display: block;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--cr-paper-3);
  border-radius: var(--cr-radius-xs);
}
.cr-card__media img,
.cr-card__media .cr-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--cr-dur-slow) var(--cr-ease);
  will-change: transform;
}
.cr-card__media--alt {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity var(--cr-dur-base) var(--cr-ease);
}
@media (hover: hover) {
  .cr-card:hover .cr-card__img { transform: scale(1.04); }
  .cr-card:hover .cr-card__media--alt { opacity: 1; }
}

/* Badges (sold out / new / sale / made-to-order) */
.cr-badge {
  position: absolute;
  top: var(--cr-space-2);
  left: var(--cr-space-2);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  font-family: var(--cr-font-mono);
  font-size: 10px;
  font-weight: var(--cr-weight-medium);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  line-height: 1;
  color: var(--cr-color-paper);
  background: var(--cr-color-ink);
  border-radius: var(--cr-radius-xs);
}
.cr-badge--sale  { background: var(--cr-color-sale); }
.cr-badge--new   { background: var(--cr-accent-ink); }
.cr-badge--soldout {
  background: transparent;
  color: var(--cr-color-secondary);
  border: 1px solid var(--cr-line-strong);
}
.cr-card.is-soldout .cr-card__img { opacity: 0.55; }

/* Quick wishlist toggle (top-right, 44px target) */
.cr-card__fav {
  position: absolute;
  top: var(--cr-space-1);
  right: var(--cr-space-1);
  z-index: 3;
  width: var(--cr-touch);
  height: var(--cr-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: var(--cr-color-ink);
  cursor: pointer;
  border-radius: var(--cr-radius-pill);
}
.cr-card__fav svg { width: 20px; height: 20px; }
.cr-card__fav.is-fav { color: var(--cr-color-accent); }

/* Card body */
.cr-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-1);
  padding-top: var(--cr-space-3);
}
.cr-card__title {
  font-family: var(--cr-font-text);
  font-size: var(--cr-text-sm);
  font-weight: var(--cr-weight-medium);
  letter-spacing: 0.01em;
  color: var(--cr-color-ink);
  margin: 0;
}
.cr-card__meta {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}
.cr-card__price {
  font-size: var(--cr-text-sm);
  color: var(--cr-color-ink);
}
.cr-card__price del {
  color: var(--cr-color-muted);
  margin-right: var(--cr-space-2);
}
.cr-card__price ins {
  text-decoration: none;
  color: var(--cr-color-sale);
}

/* Color dots on the card (micro swatches) */
.cr-card__swatches {
  display: flex;
  gap: 4px;
  padding-top: 2px;
}
.cr-card__swatch {
  width: 12px;
  height: 12px;
  border-radius: var(--cr-radius-pill);
  border: 1px solid var(--cr-line-strong);
  background: var(--cr-paper-3);
}

/* ── Empty state ── */
.cr-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--cr-space-9) var(--cr-space-4);
  color: var(--cr-color-secondary);
}
.cr-empty__title {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-lg);
  color: var(--cr-color-ink);
  margin: 0 0 var(--cr-space-2);
}

/* ==========================================================================
   SINGLE PRODUCT  ([cr_single_product] / product)
   ========================================================================== */

.cr-product {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cr-space-5);
  padding-block: var(--cr-space-5) var(--cr-space-8);
}

/* Gallery */
.cr-product__gallery {
  display: grid;
  gap: var(--cr-space-2);
}
.cr-product__hero {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--cr-paper-3);
  border-radius: var(--cr-radius-xs);
}
.cr-product__hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cr-product__thumbs {
  display: flex;
  gap: var(--cr-space-2);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.cr-product__thumbs::-webkit-scrollbar { display: none; }
.cr-product__thumb {
  flex: 0 0 64px;
  width: 64px;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: var(--cr-radius-xs);
  background: var(--cr-paper-3);
  cursor: pointer;
  padding: 0;
}
.cr-product__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cr-product__thumb.is-active { border-color: var(--cr-color-ink); }

/* Info column */
.cr-product__info {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-4);
}
.cr-product__title {
  font-family: var(--cr-font-display);
  font-weight: var(--cr-weight-regular);
  font-size: var(--cr-text-xl);
  line-height: var(--cr-leading-snug);
  letter-spacing: var(--cr-tracking-tight);
  margin: 0;
}
.cr-product__price {
  font-size: var(--cr-text-lg);
  color: var(--cr-color-ink);
}
.cr-product__price del { color: var(--cr-color-muted); margin-right: var(--cr-space-2); }
.cr-product__price ins { text-decoration: none; color: var(--cr-color-sale); }

.cr-product__desc {
  max-width: var(--cr-container-text);
  color: var(--cr-ink-soft);
}
.cr-product__desc p { margin: 0 0 var(--cr-space-3); }

/* Meta list (fabric, made in, care) — editorial dl */
.cr-product__meta {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: var(--cr-space-2) var(--cr-space-4);
  margin: 0;
  padding-top: var(--cr-space-3);
  border-top: 1px solid var(--cr-line);
  font-size: var(--cr-text-sm);
}
.cr-product__meta dt {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}
.cr-product__meta dd { margin: 0; color: var(--cr-color-ink); }

/* ── Variation / swatch container (woo-variation-swatches friendly) ── */
.cr-options { display: flex; flex-direction: column; gap: var(--cr-space-4); }
.cr-option__label {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--cr-space-3);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin-bottom: var(--cr-space-2);
}
.cr-option__label a {
  color: var(--cr-color-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Swatch row — works whether woo-variation-swatches renders ULs or our own */
.cr-swatches,
.cr-options .woo-variation-swatches .variable-items-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cr-space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

/* Size swatch (button look) */
.cr-swatch--size,
.cr-options .variable-item.button-variable-item {
  min-width: var(--cr-touch);
  min-height: var(--cr-touch);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--cr-space-3);
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  background: var(--cr-color-paper);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--cr-color-ink);
  cursor: pointer;
  transition: border-color var(--cr-dur-fast) var(--cr-ease),
              background var(--cr-dur-fast) var(--cr-ease);
}
.cr-swatch--size:hover,
.cr-options .variable-item.button-variable-item:hover { border-color: var(--cr-color-ink); }
.cr-swatch--size[aria-pressed="true"],
.cr-options .variable-item.button-variable-item.selected {
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border-color: var(--cr-color-ink);
}

/* Color swatch (round chip) */
.cr-swatch--color,
.cr-options .variable-item.color-variable-item {
  width: var(--cr-touch);
  height: var(--cr-touch);
  border-radius: var(--cr-radius-pill);
  border: 1px solid var(--cr-line-strong);
  cursor: pointer;
  padding: 3px;
  background-clip: content-box;
  box-shadow: inset 0 0 0 2px var(--cr-color-paper);
  transition: box-shadow var(--cr-dur-fast) var(--cr-ease),
              border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-swatch--color[aria-pressed="true"],
.cr-options .variable-item.color-variable-item.selected {
  border-color: var(--cr-color-ink);
  box-shadow: inset 0 0 0 2px var(--cr-color-paper),
              0 0 0 1px var(--cr-color-ink);
}

/* Disabled / unavailable swatch */
.cr-swatch[disabled],
.cr-swatch.is-disabled,
.cr-options .variable-item.disabled {
  opacity: 0.4;
  cursor: not-allowed;
  position: relative;
}
.cr-swatch.is-disabled::after,
.cr-options .variable-item.disabled::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top left,
    transparent calc(50% - 0.5px),
    var(--cr-color-secondary) calc(50% - 0.5px),
    var(--cr-color-secondary) calc(50% + 0.5px),
    transparent calc(50% + 0.5px));
}

/* ── Add to cart / actions ── */
.cr-product__actions {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-3);
  padding-top: var(--cr-space-2);
}
.cr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cr-space-2);
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-5);
  border: 1px solid var(--cr-color-ink);
  border-radius: var(--cr-radius-xs);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-weight-medium);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--cr-dur-fast) var(--cr-ease),
              color var(--cr-dur-fast) var(--cr-ease),
              transform var(--cr-dur-fast) var(--cr-ease),
              opacity var(--cr-dur-fast) var(--cr-ease);
}
.cr-btn:active { transform: scale(0.98); }
.cr-btn--primary {
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
}
.cr-btn--primary:hover { background: var(--cr-accent-ink); border-color: var(--cr-accent-ink); }
.cr-btn--ghost {
  background: transparent;
  color: var(--cr-color-ink);
}
.cr-btn--ghost:hover { background: var(--cr-color-ink); color: var(--cr-color-paper); }
.cr-btn--block { width: 100%; }
.cr-btn[disabled],
.cr-btn.is-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
}

/* Sold-out / notify-me line */
.cr-product__soldout {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-2);
  padding: var(--cr-space-4);
  border: 1px solid var(--cr-line);
  border-radius: var(--cr-radius-xs);
  background: var(--cr-paper-1);
}
.cr-product__soldout-label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}

/* ==========================================================================
   COLLECTION  ([cr_collection])
   Editorial hero + alternating image/text bands.
   ========================================================================== */

.cr-collection__hero {
  position: relative;
  padding-block: var(--cr-space-6) var(--cr-space-5);
  margin-bottom: 0;
  border-radius: var(--cr-radius-xs);
  overflow: hidden;
}
.cr-collection__hero-media {
  aspect-ratio: 4 / 5;
  background: var(--cr-paper-3);
}
.cr-collection__hero-media img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.cr-collection__hero-caption {
  padding: var(--cr-space-5) 0 0;
}
.cr-collection__title {
  font-family: var(--cr-font-display);
  font-weight: var(--cr-weight-regular);
  font-size: var(--cr-text-2xl);
  line-height: var(--cr-leading-tight);
  letter-spacing: var(--cr-tracking-tight);
  margin: 0 0 var(--cr-space-3);
}
.cr-collection__intro {
  max-width: var(--cr-container-text);
  color: var(--cr-ink-soft);
  font-size: var(--cr-text-md);
}

/* Editorial band */
.cr-band {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cr-space-4);
  padding-block: var(--cr-space-6);
  border-top: 1px solid var(--cr-line);
}
.cr-band__media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--cr-paper-3);
  border-radius: var(--cr-radius-xs);
}
.cr-band__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cr-band__body { display: flex; flex-direction: column; gap: var(--cr-space-3); justify-content: center; }
.cr-band__title {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-lg);
  margin: 0;
}
.cr-band__text { color: var(--cr-ink-soft); max-width: var(--cr-container-text); }

/* ── Focus visibility (accessibility) ── */
.cr-store a:focus-visible,
.cr-store button:focus-visible,
.cr-store [tabindex]:focus-visible {
  outline: 2px solid var(--cr-color-accent);
  outline-offset: 2px;
  box-shadow: var(--cr-shadow-focus);
}

/* ==========================================================================
   CLASS MAP — PHP render → CSS
   product_grid.php emits these class names; styled here.
   ========================================================================== */

/* Grid section wrapper */
.cr-grid { color: var(--cr-color-ink); }

/* ── Toolbar ── */
.cr-grid__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cr-space-3);
  padding-block: var(--cr-space-4);
  border-block: 1px solid var(--cr-line);
  margin-bottom: var(--cr-space-5);
}

.cr-grid__search { flex: 1 1 180px; }
.cr-grid__search-input {
  width: 100%;
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-4);
  background: transparent;
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-pill);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  color: var(--cr-color-ink);
  outline: none;
  transition: border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-grid__search-input::placeholder { color: var(--cr-color-muted); }
.cr-grid__search-input:focus { border-color: var(--cr-color-ink); }

.cr-grid__filters { display: flex; flex-wrap: wrap; gap: var(--cr-space-2); }

.cr-grid__sort {
  display: flex;
  align-items: center;
  gap: var(--cr-space-2);
  margin-left: auto;
}
.cr-grid__sort-label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  white-space: nowrap;
}
.cr-grid__sort-select {
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-3);
  background: transparent;
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: 0.04em;
  color: var(--cr-color-ink);
  cursor: pointer;
}

/* ── Card badge alias ── */
.cr-card__badge {
  position: absolute;
  top: var(--cr-space-2);
  left: var(--cr-space-2);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  font-family: var(--cr-font-mono);
  font-size: 10px;
  font-weight: var(--cr-weight-medium);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  line-height: 1;
  color: var(--cr-color-paper);
  background: var(--cr-color-ink);
  border-radius: var(--cr-radius-xs);
}
.cr-card__badge--soldout {
  background: transparent;
  color: var(--cr-color-secondary);
  border: 1px solid var(--cr-line-strong);
}

/* ── Button alias: --solid maps to --primary ── */
.cr-btn--solid {
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
}
.cr-btn--solid:hover { background: var(--cr-accent-ink); border-color: var(--cr-accent-ink); }

/* ATC button feedback states (set by cr-product-grid.js) */
.cr-card__add.is-loading {
  opacity: 0.6;
  pointer-events: none;
  cursor: wait;
}
.cr-card__add.is-added {
  background: var(--cr-color-accent);
  border-color: var(--cr-color-accent);
  color: var(--cr-color-paper);
}

/* ── Card category + price prefix ── */
.cr-card__cat {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin: 0;
}
.cr-card__from {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin-right: var(--cr-space-1);
}

/* ── Card actions ── */
.cr-card__actions { padding-top: var(--cr-space-2); }
.cr-card__actions .cr-btn { width: 100%; }

/* ── Sold-out BEM modifier (PHP renders .cr-card--soldout) ── */
.cr-card--soldout .cr-card__img { opacity: 0.55; }
.cr-card--soldout .cr-card__media { cursor: default; }

/* ── Price val wrapper (contains WC price_html) ── */
.cr-card__price-val { display: inline; }
.cr-card__price-val .woocommerce-Price-amount { font-size: inherit; }

/* ── Grid notice (WC unavailable fallback) ── */
.cr-grid--notice {
  padding: var(--cr-space-6) var(--cr-space-4);
  text-align: center;
  color: var(--cr-color-secondary);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-sm);
}

/* ── Empty state aliases ── */
.cr-grid__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--cr-space-9) var(--cr-space-4);
  color: var(--cr-color-secondary);
}
.cr-grid__empty[hidden] { display: none; }
.cr-grid__empty-title {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-lg);
  color: var(--cr-color-ink);
  margin: 0 0 var(--cr-space-2);
}
.cr-grid__empty-body { margin: 0; }

/* ==========================================================================
   CLASS MAP — cr_collection PHP render
   ========================================================================== */

/* Collection eyebrow / subtitle */
.cr-collection__eyebrow,
.cr-lookbook__eyebrow {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin: 0 0 var(--cr-space-2);
}
.cr-collection__subtitle,
.cr-lookbook__subtitle {
  max-width: var(--cr-container-text);
  color: var(--cr-ink-soft);
  font-size: var(--cr-text-md);
  margin: var(--cr-space-3) 0 0;
}

/* Category pill navigation (.cr-pill ≈ .cr-chip but with count badge) */
.cr-collection__pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cr-space-2);
  padding-block: var(--cr-space-3);
  border-block: 1px solid var(--cr-line);
  margin-bottom: var(--cr-space-5);
}
.cr-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-2);
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-4);
  border: 1px solid var(--cr-line-strong);
  background: transparent;
  border-radius: var(--cr-radius-pill);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-ink);
  cursor: pointer;
  text-decoration: none;
  transition: border-color var(--cr-dur-fast) var(--cr-ease),
              background var(--cr-dur-fast) var(--cr-ease),
              color var(--cr-dur-fast) var(--cr-ease);
}
.cr-pill:hover { border-color: var(--cr-color-ink); }
.cr-pill.is-active {
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border-color: var(--cr-color-ink);
}
.cr-pill__count {
  font-size: 10px;
  opacity: 0.6;
}

.cr-collection__grid { /* grid items container — inherits cr-store spacing */ }

/* ==========================================================================
   CLASS MAP — cr_lookbook PHP render
   ========================================================================== */

.cr-lookbook__hero {
  padding-block: var(--cr-space-6) var(--cr-space-5);
}
.cr-lookbook__title {
  font-family: var(--cr-font-display);
  font-weight: var(--cr-weight-regular);
  font-size: var(--cr-text-2xl);
  letter-spacing: var(--cr-tracking-tight);
  line-height: var(--cr-leading-tight);
  margin: 0;
}

/* Drop countdown banner */
.cr-lookbook__drop {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--cr-space-3);
  padding: var(--cr-space-6) var(--cr-space-4);
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border-radius: var(--cr-radius-xs);
  text-align: center;
  margin-bottom: var(--cr-space-6);
}
.cr-drop__label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  opacity: 0.7;
}
.cr-drop__timer {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
}
.cr-drop__unit { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.cr-drop__num {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-2xl);
  font-weight: var(--cr-weight-regular);
  font-style: normal;
  line-height: 1;
}
.cr-drop__tag {
  font-family: var(--cr-font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.6;
  font-style: normal;
}
.cr-drop__sep { font-family: var(--cr-font-display); font-size: var(--cr-text-lg); opacity: 0.3; }
.cr-drop__live[hidden] { display: none; }
.cr-drop__live {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-accent);
}

/* Lookbook image grid — 2 cols mobile → masonry-like on wider screens */
.cr-lookbook__grid {
  columns: 2;
  column-gap: var(--cr-space-3);
  margin-bottom: var(--cr-space-7);
}
.cr-lookbook__item {
  display: block;
  break-inside: avoid;
  margin-bottom: var(--cr-space-3);
  border-radius: var(--cr-radius-xs);
  overflow: hidden;
}
.cr-lookbook__img {
  display: block;
  width: 100%;
  height: auto;
  transition: transform var(--cr-dur-slow) var(--cr-ease);
}
@media (hover: hover) {
  .cr-lookbook__item:hover .cr-lookbook__img { transform: scale(1.03); }
}
@media (min-width: 600px) {
  .cr-lookbook__grid { columns: 3; }
}
@media (min-width: 1024px) {
  .cr-lookbook__grid { columns: 4; }
}

/* Lookbook empty / coming-soon state */
.cr-lookbook__coming-soon {
  padding-block: var(--cr-space-9) var(--cr-space-7);
  text-align: center;
  border-block: 1px solid var(--cr-line);
  margin-bottom: var(--cr-space-6);
}
.cr-lookbook__coming-title {
  font-family: var(--cr-font-display);
  font-size: var(--cr-text-2xl);
  font-weight: var(--cr-weight-regular);
  letter-spacing: var(--cr-tracking-tight);
  color: var(--cr-color-ink);
  margin: 0 0 var(--cr-space-3);
}
.cr-lookbook__coming-sub {
  font-size: var(--cr-text-sm);
  color: var(--cr-color-secondary);
  max-width: 380px;
  margin: 0 auto;
  line-height: var(--cr-leading-body);
}

/* Notify-me form (drop capture) */
.cr-notify {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-3);
  max-width: 480px;
  margin: var(--cr-space-7) auto;
  text-align: center;
}
.cr-notify__label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}
.cr-notify__row { display: flex; gap: var(--cr-space-2); }
.cr-notify__input {
  flex: 1;
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-4);
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  background: transparent;
  font-size: var(--cr-text-sm);
  color: var(--cr-color-ink);
  outline: none;
  transition: border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-notify__input:focus { border-color: var(--cr-color-ink); }
.cr-notify__btn {
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-5);
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border: 1px solid var(--cr-color-ink);
  border-radius: var(--cr-radius-xs);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--cr-dur-fast) var(--cr-ease);
}
.cr-notify__btn:hover { background: var(--cr-accent-ink); border-color: var(--cr-accent-ink); }
.cr-notify__msg { font-size: var(--cr-text-sm); color: var(--cr-color-secondary); margin: 0; }
.cr-notify__msg[hidden] { display: none; }
.cr-notify__msg.is-ok    { color: var(--cr-color-success); }
.cr-notify__msg.is-error { color: var(--cr-color-error); }

/* ==========================================================================
   CLASS MAP — cr_single_product PHP render
   PHP emits .cr-single__* and .cr-gallery__*; no duplication of .cr-product__*.
   ========================================================================== */

.cr-single {
  color: var(--cr-color-ink);
  padding-block: var(--cr-space-5) var(--cr-space-8);
}
.cr-single__breadcrumb { margin-bottom: var(--cr-space-4); }
.cr-single__back {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  text-decoration: none;
  transition: color var(--cr-dur-fast) var(--cr-ease);
}
.cr-single__back:hover { color: var(--cr-color-ink); }
.cr-single__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--cr-space-5);
}

/* Gallery */
.cr-gallery { display: grid; gap: var(--cr-space-2); }
.cr-gallery__main {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background: var(--cr-paper-3);
  border-radius: var(--cr-radius-xs);
}
.cr-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.cr-gallery__main-img--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cr-color-muted);
}
.cr-gallery__thumbs {
  display: flex;
  gap: var(--cr-space-2);
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.cr-gallery__thumbs::-webkit-scrollbar { display: none; }
.cr-gallery__thumb {
  flex: 0 0 64px;
  width: 64px;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: var(--cr-radius-xs);
  background: var(--cr-paper-3);
  cursor: pointer;
  padding: 0;
  transition: border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cr-gallery__thumb.is-active { border-color: var(--cr-color-ink); }

/* Details column */
.cr-single__details {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-4);
}
.cr-single__title {
  font-family: var(--cr-font-display);
  font-weight: var(--cr-weight-regular);
  font-size: var(--cr-text-xl);
  line-height: var(--cr-leading-snug);
  letter-spacing: var(--cr-tracking-tight);
  margin: 0;
}
.cr-single__price {
  font-size: var(--cr-text-lg);
  color: var(--cr-color-ink);
}
.cr-single__price del { color: var(--cr-color-muted); margin-right: var(--cr-space-2); }
.cr-single__price ins { text-decoration: none; color: var(--cr-color-sale); }
.cr-single__short-desc {
  max-width: var(--cr-container-text);
  color: var(--cr-ink-soft);
  font-size: var(--cr-text-base);
}
.cr-single__short-desc p { margin: 0 0 var(--cr-space-3); }

/* WooCommerce native add-to-cart form inside our wrapper */
.cr-single__form.woocommerce .single_add_to_cart_button {
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-6);
  background: var(--cr-color-ink);
  color: var(--cr-color-paper);
  border: 1px solid var(--cr-color-ink);
  border-radius: var(--cr-radius-xs);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: background var(--cr-dur-fast) var(--cr-ease),
              border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-single__form.woocommerce .single_add_to_cart_button:hover {
  background: var(--cr-accent-ink);
  border-color: var(--cr-accent-ink);
}
.cr-single__form.woocommerce .single_add_to_cart_button[disabled],
.cr-single__form.woocommerce .single_add_to_cart_button.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.cr-single__form.woocommerce .quantity { display: flex; align-items: center; gap: var(--cr-space-2); }
.cr-single__form.woocommerce .qty {
  width: 64px;
  min-height: var(--cr-touch);
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  background: transparent;
  text-align: center;
  font-size: var(--cr-text-base);
  color: var(--cr-color-ink);
}

/* WooCommerce native variations table (fallback when woo-variation-swatches
   doesn't replace an attribute, or before swatches initialise). */
.cr-single__form.woocommerce table.variations {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--cr-space-4);
}
.cr-single__form.woocommerce table.variations th.label {
  width: auto;
  padding: 0 var(--cr-space-4) 0 0;
  vertical-align: middle;
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  white-space: nowrap;
}
.cr-single__form.woocommerce table.variations td.value {
  vertical-align: middle;
  padding: var(--cr-space-2) 0;
}
.cr-single__form.woocommerce table.variations select {
  min-height: var(--cr-touch);
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  background: transparent;
  color: var(--cr-color-ink);
  font-size: var(--cr-text-sm);
  padding: 0 var(--cr-space-3);
  cursor: pointer;
}
.cr-single__form.woocommerce .reset_variations {
  display: inline-block;
  margin-left: var(--cr-space-3);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  text-decoration: underline;
  text-underline-offset: 3px;
}
/* Variation price / availability update */
.cr-single__form.woocommerce .woocommerce-variation-price { margin-bottom: var(--cr-space-3); }
.cr-single__form.woocommerce .woocommerce-variation-availability { margin-bottom: var(--cr-space-3); }
/* Wrapper revealed by WC JS when a variation is selected */
.cr-single__form.woocommerce .single_variation_wrap { display: flex; flex-direction: column; gap: var(--cr-space-3); }
.cr-single__form.woocommerce .variations_button { display: flex; align-items: center; gap: var(--cr-space-3); flex-wrap: wrap; }

/* Aux + size guide */
.cr-single__aux {
  padding-top: var(--cr-space-3);
  border-top: 1px solid var(--cr-line);
}
.cr-single__size-guide {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-2);
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  text-decoration: none;
}
.cr-single__size-guide:hover { color: var(--cr-color-ink); }

/* Waitlist / sold-out block */
.cr-single__waitlist.is-hidden,
.cr-single__waitlist[hidden] { display: none; }
.cr-single__sold-out-label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
  margin: 0 0 var(--cr-space-2);
}
.cr-single__waitlist-sub { color: var(--cr-ink-soft); margin: 0 0 var(--cr-space-3); font-size: var(--cr-text-sm); }
.cr-waitlist-form { display: flex; flex-direction: column; gap: var(--cr-space-3); }
.cr-waitlist-form__label {
  font-family: var(--cr-font-mono);
  font-size: var(--cr-text-xs);
  letter-spacing: var(--cr-tracking-wide);
  text-transform: uppercase;
  color: var(--cr-color-secondary);
}
.cr-waitlist-form__row { display: flex; gap: var(--cr-space-2); flex-wrap: wrap; }
.cr-waitlist-form__input {
  flex: 1 1 180px;
  min-height: var(--cr-touch);
  padding: 0 var(--cr-space-4);
  border: 1px solid var(--cr-line-strong);
  border-radius: var(--cr-radius-xs);
  background: transparent;
  font-size: var(--cr-text-sm);
  color: var(--cr-color-ink);
  outline: none;
  transition: border-color var(--cr-dur-fast) var(--cr-ease);
}
.cr-waitlist-form__input:focus { border-color: var(--cr-color-ink); }
.cr-waitlist-form__msg { font-size: var(--cr-text-sm); color: var(--cr-color-secondary); margin: 0; }
.cr-waitlist-form__msg--ok  { color: var(--cr-color-success); }
.cr-waitlist-form__msg--err { color: var(--cr-color-error); }
.cr-waitlist-form__submit.is-busy { opacity: 0.6; pointer-events: none; cursor: wait; }
.cr-single__waitlist--done .cr-waitlist-form__row { opacity: 0.4; pointer-events: none; }

/* Empty state */
.cr-single-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--cr-space-9) var(--cr-space-4);
  gap: var(--cr-space-3);
}
.cr-single-empty__icon { color: var(--cr-color-muted); }
.cr-single-empty__title { font-family: var(--cr-font-display); font-size: var(--cr-text-lg); margin: 0; }
.cr-single-empty__body { color: var(--cr-ink-soft); margin: 0; }

/* ==========================================================================
   BREAKPOINTS (mobile-first, min-width up)
   ========================================================================== */

/* ≥ 600px — wider phones / small tablets */
@media (min-width: 600px) {
  .cr-product-grid,
  .cr-grid__items { gap: var(--cr-space-6) var(--cr-space-4); }
  .cr-band {
    grid-template-columns: 1fr 1fr;
    gap: var(--cr-space-6);
    align-items: center;
  }
  .cr-band--reverse .cr-band__media { order: 2; }
}

/* ≥ 768px — tablet */
@media (min-width: 768px) {
  .cr-product-grid,
  .cr-grid__items { grid-template-columns: repeat(3, 1fr); }
  .cr-product {
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 1fr);
    gap: var(--cr-space-7);
    align-items: start;
  }
  .cr-product__gallery { position: sticky; top: calc(var(--cr-header-h, 64px) + var(--cr-space-4, 1rem)); }
  .cr-product__info { padding-top: var(--cr-space-2); }
  .cr-product__title { font-size: var(--cr-text-2xl); }
  /* cr_single_product responsive */
  .cr-single__grid {
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, 1fr);
    gap: var(--cr-space-7);
    align-items: start;
  }
  .cr-single__gallery { position: sticky; top: calc(var(--cr-header-h, 60px) + var(--cr-space-4)); }
  .cr-single__title { font-size: var(--cr-text-2xl); }
  .cr-collection__hero {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: var(--cr-space-6);
    align-items: center;
  }
  .cr-collection__hero-caption { padding: 0; }
}

/* ≥ 1024px — desktop */
@media (min-width: 1024px) {
  .cr-product-grid,
  .cr-grid__items { grid-template-columns: repeat(4, 1fr); }
  .cr-section-head__title { font-size: var(--cr-text-3xl); }
}

/* Reduced motion: kill image zoom + transitions */
@media (prefers-reduced-motion: reduce) {
  .cr-store *,
  .cr-store *::before,
  .cr-store *::after {
    transition-duration: 0.001s !important;
    animation-duration: 0.001s !important;
  }
  .cr-card:hover .cr-card__img { transform: none; }
}
