.shop-hero {
  padding-top: var(--space-12);
  padding-bottom: var(--space-12);
}

.shop-hero-grid {
  align-items: center;
  gap: var(--space-8);
}

.shop-hero-copy .section-label {
  margin-bottom: var(--space-2);
}

.shop-hero-copy .lead {
  margin-top: var(--space-2);
  max-width: 38rem;
}

.shop-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.shop-hero-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-6);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.shop-hero-meta dt {
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.shop-hero-figure {
  max-width: 480px;
  margin-left: auto;
}

.shop-layout-grid {
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: var(--space-6);
}

.shop-card + .shop-card {
  margin-top: var(--space-6);
}

.shop-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.shop-nav-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.shop-nav-list h3 {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-1);
}

.shop-nav-list p {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.shop-inline-cta {
  margin-top: var(--space-2);
}

.shop-filters-card {
  position: sticky;
  top: 6rem;
}

.shop-filters {
  display: grid;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.shop-filter-group label {
  display: block;
  font-size: var(--font-size-sm);
  font-weight: 500;
  margin-bottom: var(--space-1);
}

.shop-filters-note {
  margin-top: var(--space-3);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

.shop-collections-grid {
  margin-top: var(--space-4);
}

.shop-collection-item h3 {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-2);
}

.shop-collection-points {
  list-style: disc;
  padding-left: var(--space-5);
  margin-bottom: var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

.shop-quick-view-grid {
  display: grid;
  grid-template-columns: minmax(0, 340px) minmax(0, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-4);
  align-items: center;
}

.shop-quick-view-header-row {
  display: flex;
  justify-content: space-between;
  gap: var(--space-4);
  align-items: flex-start;
}

.shop-quick-view-specs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.shop-quick-view-specs dt {
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}

.shop-quick-view-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.shop-checkout-grid,
.shop-pricing-grid,
.shop-b2b-grid,
.shop-personalisation-grid {
  gap: var(--space-6);
}

.shop-list {
  list-style: disc;
  padding-left: var(--space-5);
  margin-top: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.shop-reviews-grid,
.shop-mobile-grid {
  display: grid;
  grid-template-columns: minmax(0, 320px) minmax(0, 1fr);
  gap: var(--space-6);
  align-items: center;
}

.shop-support-cta {
  margin-top: var(--space-8);
}

.shop-support-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  align-items: center;
  justify-content: space-between;
}

.shop-support-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
}

@media (max-width: 1024px) {
  .shop-layout-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .shop-filters-card {
    position: static;
  }

  .shop-hero-meta {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 768px) {
  .shop-hero {
    padding-top: var(--space-10);
    padding-bottom: var(--space-10);
  }

  .shop-hero-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .shop-hero-figure {
    max-width: 100%;
    margin: 0 auto;
  }

  .shop-quick-view-grid,
  .shop-reviews-grid,
  .shop-mobile-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .shop-quick-view-specs {
    grid-template-columns: minmax(0, 1fr);
  }

  .shop-support-grid {
    flex-direction: column;
    align-items: flex-start;
  }

  .mt-4.flex.gap-sm,
  .mt-4.flex.gap-md {
    flex-direction: column;
    align-items: stretch;
  }

  .mt-4.flex.gap-sm .button,
  .mt-4.flex.gap-md .button {
    width: 100%;
  }
}
