/* Shop page specific styles (lean, leveraging base.css) */

.shop-hero { padding-block: var(--space-12); }
.shop-hero__inner { display: grid; gap: var(--space-8); }
.shop-hero__media img { width: 100%; height: auto; object-fit: cover; border-radius: var(--radius-lg); }
.shop-hero__content { max-width: 70ch; }
.shop-hero__cta { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-4); }

.category-highlights { padding-block: var(--space-10); }
.category-highlights__grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-8); }
.category-card p { margin-bottom: var(--space-4); }
.category-card .category-card__actions { display: flex; gap: var(--space-3); }

.shop-toolbar { position: sticky; top: 0; background: var(--color-bg); padding-block: var(--space-4); border-top: 1px solid var(--gray-200); border-bottom: 1px solid var(--gray-200); z-index: 10; }
.shop-toolbar__inner { display: flex; gap: var(--space-6); align-items: center; justify-content: space-between; }
.shop-toolbar__left { flex: 1; }
.shop-toolbar input[type="search"] { width: 100%; }
.shop-toolbar__right { display: flex; align-items: center; gap: var(--space-3); }

.shop-layout { padding-block: var(--space-10); }
.shop-layout__inner { display: grid; grid-template-columns: 100% 1fr; gap: var(--space-8); }

/* Filters */
.filters { background: var(--color-surface); border: 1px solid var(--gray-200); border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-sm); height: max-content; position: sticky; top: calc(56px + var(--space-4)); }
.filters__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.filters__form fieldset { border: 0; padding: 0; margin-bottom: var(--space-6); }
.filters__form legend { font-weight: 700; margin-bottom: var(--space-3); }
.filters__row { display: grid; gap: var(--space-2); margin-bottom: var(--space-3); }
.filters__checkboxes { display: grid; gap: var(--space-2); grid-template-columns: 1fr; }
.filters__actions { display: flex; gap: var(--space-3); }
.filters__hint { color: var(--gray-700); margin-bottom: var(--space-4); font-size: var(--fs-sm); }
.grid-auto-fit-min-250 {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 3fr));
  gap: var(--space-8);
}

/* Products */
.products__header { display: flex; align-items: end; justify-content: space-between; margin-bottom: var(--space-6); }
.product-card { display: grid; gap: var(--space-4); }
.product-card__media img { aspect-ratio: 3/2; object-fit: cover; width: 100%; }
.product-card__meta { color: var(--gray-700); font-size: var(--fs-sm); }
.product-card__rating { color: var(--color-warning); display: inline-flex; gap: 2px; }
.product-card__price { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-2); }
.product-card__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-4); }

/* Quick View Modal */
.quick-view[hidden] { display: none; }
.quick-view { position: fixed; inset: 0; z-index: 50; }
.quick-view__overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.35); backdrop-filter: blur(2px); }
.quick-view__dialog { position: relative; max-width: 980px; margin: 6vh auto; padding: var(--space-6); }
.quick-view__close { position: absolute; top: var(--space-4); right: var(--space-4); }
.quick-view__content { display: grid; gap: var(--space-6); grid-template-columns: 1fr 1fr; }
.quick-view__text .qv-price { font-weight: 700; font-size: 1.25rem; margin: var(--space-3) 0; }
.qv-actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.qv-meta { color: var(--gray-700); }

/* Wishlist */
.wishlist-section { padding-block: var(--space-10); }
.wishlist-list { display: grid; gap: var(--space-3); grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.wishlist-item { display: flex; align-items: center; justify-content: space-between; background: var(--color-surface); border: 1px solid var(--gray-200); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); box-shadow: var(--shadow-sm); }

/* Recommended */
.recommended { padding-block: var(--space-10); }
.recommended__list { display: grid; gap: var(--space-4); grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.recommended-card { background: var(--color-surface); border: 1px solid var(--gray-200); border-radius: var(--radius-md); padding: var(--space-4); box-shadow: var(--shadow-sm); display: grid; gap: var(--space-2); }

/* Trust */
.trust { padding-block: var(--space-10); }
.trust__grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--space-8); }
.trust__icon { font-size: 1.5rem; color: var(--color-primary-600); margin-bottom: var(--space-3); }

/* Responsive */
@media (max-width: 1023px) {
  .shop-layout__inner { grid-template-columns: 1fr; }
  .filters { position: fixed; inset: 0 0 auto 0; top: 0; max-height: 100vh; overflow: auto; border-radius: 0; z-index: 40; display: block; }
  .filters[hidden] { display: none; }
}

@media (max-width: 640px) {
  .quick-view__content { grid-template-columns: 1fr; }
}
