/* Product Categories Page Styles for PapeleriaBella */

.page-title {
  margin-bottom: var(--space-2);
  color: var(--color-primary);
}
.lead {
  color: var(--color-neutral-700);
  margin-bottom: var(--space-8);
  font-size: var(--font-size-lg);
}
.category-section {
  margin-bottom: var(--space-12);
}
.categories-grid {
  margin-top: var(--space-5);
}
.category-card {
  text-align: center;
  padding: var(--space-6) var(--space-3);
  transition: box-shadow .2s;
}
.category-card img {
  margin-left: auto;
  margin-right: auto;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  height: 90px;
  object-fit: contain;
  box-shadow: var(--shadow-xs);
}
.category-card h3 {
  font-size: var(--font-size-lg);
  color: var(--color-primary-accent);
  line-height: var(--line-height-normal);
  margin-bottom: var(--space-1);
}
.category-card span {
  display: block;
  color: var(--color-neutral-700);
  font-size: var(--font-size-sm);
}

/* Carousel Styles*/
.categories-carousel {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  margin-top: var(--space-2);
}
.product-carousel {
  flex: 1 1 300px;
  min-width: 270px;
  background: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  padding: var(--space-5) var(--space-3);
}
.carousel-category {
  text-align: left;
  margin-bottom: var(--space-3);
  color: var(--color-primary);
}
.carousel-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.carousel-list li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-neutral-200);
}
.carousel-list li:last-child {
  margin-bottom: 0;
  border-bottom: none;
}
.carousel-list img {
  width: 58px;
  height: 58px;
  border-radius: var(--radius-sm);
  object-fit: cover;
}
.arrival-badge {
  color: var(--color-success);
  background: var(--color-neutral-200);
  font-size: var(--font-size-xs);
  margin-left: var(--space-2);
  padding: 2px 8px;
  border-radius: var(--radius-xs);
  display: inline-block;
}
.rating {
  color: var(--color-warning);
  font-size: var(--font-size-sm);
}

.offer-card img { margin-bottom: var(--space-2); }
.offer-info { font-size: var(--font-size-xs); color: var(--color-neutral-500); margin-top: var(--space-2); text-align: right; }

.reviews-list blockquote { font-style: italic; margin: 0 0 var(--space-3) 0; font-size: var(--font-size-sm); }
.reviews-list cite { color: var(--color-primary-accent); font-size: var(--font-size-xs); }
.all-reviews { margin-top: var(--space-2); text-align: right; }

.comparisons-table-wrapper { overflow-x: auto; margin-top: var(--space-3); }
.comparisons-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-alt);
  font-size: var(--font-size-sm);
  min-width: 630px;
}
.comparisons-table th,
.comparisons-table td {
  border: 1px solid var(--color-neutral-300);
  padding: var(--space-2) var(--space-3);
  text-align: left;
}
.comparisons-table th {
  background: var(--color-neutral-200);
  color: var(--color-text);
  font-weight: 700;
}
.comparisons-table td a {
  font-size: var(--font-size-xs);
}

.accessories-list {
  margin-top: var(--space-2);
  list-style: none;
}
.accessory-card img {
  margin-bottom: var(--space-2);
  border-radius: var(--radius-md);
  height: 56px;
  width: 100%;
  object-fit: contain;
  background: var(--color-neutral-200);
}
.accessory-card strong {
  color: var(--color-primary);
}

td .button,
.accessory-card .button,
.carousel-list .button {
  margin-top: var(--space-1);
}

td .button,
.button-sm {
  padding: 3px 12px;
  font-size: var(--font-size-sm);
}

div.guides-list {
  margin-top: var(--space-3);
}
.guide-card p {
  margin-top: 0;
  margin-bottom: var(--space-3);
}

@media (max-width: 1000px) {
  .grid-cols-4 { grid-template-columns: repeat(2, 1fr); }
  .grid-cols-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .categories-grid, .offers-list, .reviews-list, .accessories-list, .guides-list {
    grid-template-columns: 1fr !important;
  }
  .categories-carousel {
    flex-direction: column;
    gap: var(--space-4);
  }
  .comparisons-table { font-size: var(--font-size-xs); }
}
@media (max-width: 410px) {
  .card { padding: var(--space-3) !important; }
  .offer-card img, .category-card img, .accessory-card img { height: 48px !important; }
}
