/* =========================
   SHOP PAGE STYLES
   ========================= */
.shop-hero {
  margin-top: var(--space-12);
  margin-bottom: var(--space-12);
  text-align: center;
}
.shop-hero h1 {
  color: var(--color-primary);
}
.hero-desc {
  font-size: var(--font-size-lg);
  color: var(--color-gray-600);
  margin-bottom: var(--space-8);
  font-weight: 500;
}
.shop-search-form {
  display: flex;
  max-width: 420px;
  margin: 0 auto;
  gap: var(--space-3);
}
.shop-search-form input[type="search"] {
  flex: 1;
  min-width: 0;
}
.shop-featured, 
.shop-deals, 
.shop-categories, 
.shop-top-sellers {
  margin-bottom: var(--space-16);
}
.product-list {
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-6);
}
.product-card figure {
  margin-bottom: var(--space-4);
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.product-card img {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}
.product-card figcaption {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--color-primary);
  color: #fff;
  font-size: var(--font-size-xs);
  font-weight: bold;
  padding: 2px 10px;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  letter-spacing: 0.2px;
}
.product-title {
  margin-bottom: var(--space-2);
  font-size: var(--font-size-lg);
}
.product-desc {
  margin-bottom: var(--space-2);
  color: var(--color-gray-500);
  font-size: var(--font-size-sm);
}
.product-meta {
  font-size: var(--font-size-base);
  margin-bottom: var(--space-4);
}
.product-price s {
  color: var(--color-gray-400);
  font-size: var(--font-size-sm);
  margin-right: 4px;
}
.product-rating {
  color: var(--color-warning);
  font-size: var(--font-size-base);
  font-weight: bold;
}

.deals-list {
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.deal-card {
  background: var(--color-primary);
  color: #fff;
  text-align: center;
}
.deal-card h3 {
  color: #fff;
  margin-bottom: var(--space-3);
}
.deal-card .button {
  background: #fff;
  color: var(--color-primary);
  box-shadow: var(--shadow-sm);
  margin-top: var(--space-3);
}
.deal-card .button:hover,
.deal-card .button:focus-visible {
  background: var(--color-success);
  color: #fff;
}

.categories-nav {
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-6);
}
.category-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-2);
  text-align: center;
  text-decoration: none;
  background: var(--color-surface);
  transition: box-shadow var(--transition-med), background var(--transition-fast), transform var(--transition-fast);
}
.category-link img {
  width: 74px;
  height: 74px;
  object-fit: cover;
  border-radius: var(--radius-full);
  margin-bottom: var(--space-2);
  box-shadow: var(--shadow-sm);
}
.category-link span {
  font-size: var(--font-size-base);
  color: var(--color-text);
  font-weight: 600;
}
.category-link:hover, .category-link:focus-visible {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px) scale(1.03);
  background: var(--color-gray-100);
}

.shop-reviews-tips {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  margin-bottom: var(--space-16);
}
.block {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  height: 100%;
}
.reviews-list,
.tips-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.reviews-list blockquote {
  font-size: var(--font-size-base);
  color: var(--color-gray-600);
  border-left: 4px solid var(--color-primary);
  padding-left: var(--space-3);
  margin-bottom: var(--space-1);
}
.reviews-list footer {
  font-size: var(--font-size-sm);
  color: var(--color-primary);
  margin-top: var(--space-1);
}
.tips-list li {
  font-size: var(--font-size-base);
}
.tips-list strong {
  color: var(--color-primary);
}

.shop-contact-shipping {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  margin-bottom: var(--space-16);
}
.contact-list,
.shipping-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.contact-list a:where(:not(.button)) {
  color: var(--color-primary);
  text-decoration: underline;
}

@media (max-width: 1100px) {
  .product-list,
  .categories-nav {
    grid-template-columns: repeat(2, 1fr);
  }
  .deals-list {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 900px) {
  .product-list {
    grid-template-columns: 1fr 1fr;
  }
  .categories-nav {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .shop-reviews-tips,
  .shop-contact-shipping {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 700px) {
  .container {
    padding-inline: var(--space-1);
  }
  .shop-hero {
    margin-top: var(--space-8);
    margin-bottom: var(--space-8);
  }
  .product-list,
  .categories-nav {
    grid-template-columns: 1fr;
  }
}
