/* ============================================
   VITTORIA LANDER — PRODUCTOS PAGE
   ============================================ */


/* page-hero reutiliza servicios.css */
@import 'servicios.css';


/* ─────────────────────────────────────────────
   INTRO TIENDA
───────────────────────────────────────────── */

.products-intro {
  padding-block: var(--space-2xl);
  background: var(--bg-surface);
  border-bottom: var(--border-gold-subtle);
}

.products-intro__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-xl);
}

.products-intro__text {
  max-width: 520px;
}

.products-intro__text p:not(.eyebrow) {
  font-size: var(--text-md);
  color: var(--gray-mid);
  line-height: 1.7;
}

.products-intro__badges {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-sm);
  flex-shrink: 0;
}

.products-badge {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--gray-light);
  white-space: nowrap;
}

.products-badge__icon {
  color: var(--gold-primary);
  font-size: 10px;
}


/* ─────────────────────────────────────────────
   BARRA DE FILTROS
───────────────────────────────────────────── */

.products-filters-bar {
  background: rgba(15, 12, 14, 0.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  position: sticky;
  top: 80px;
  z-index: calc(var(--z-nav) - 10);
  border-bottom: var(--border-gold-subtle);
}

/* Fila 1: marcas como tabs */
.filters-row {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}

.filters-row--brand {
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  padding-inline: 0;
}

/* Fila 2: necesidades + contador */
.filters-row--needs {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
  padding-block: 0.75rem;
}

.filters-needs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* Botones de marca — tab style */
.filter-marca {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gray-dark);
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  padding: 1rem 1.25rem;
  cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
  white-space: nowrap;
}

.filter-marca:hover {
  color: var(--gray-light);
}

.filter-marca.is-active {
  color: var(--gold-light);
  border-bottom-color: var(--gold-primary);
}

/* Pills de necesidad */
.filter-need {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gray-mid);
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: var(--radius-pill);
  padding: 0.35rem 0.875rem;
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.filter-need:hover {
  border-color: rgba(175, 121, 18, 0.4);
  color: var(--white);
}

.filter-need.is-active {
  background: rgba(175, 121, 18, 0.12);
  border-color: var(--gold-primary);
  color: var(--gold-light);
}

.products-filters__count {
  font-size: var(--text-xs);
  color: var(--gray-dark);
  letter-spacing: 0.08em;
  white-space: nowrap;
  flex-shrink: 0;
}


/* ─────────────────────────────────────────────
   CATÁLOGO
───────────────────────────────────────────── */

.products-catalog {
  padding-block: var(--space-2xl) var(--space-3xl);
  background: var(--bg-base);
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
  align-items: stretch;
}

.products-grid .product-card {
  height: 100%;
}

/* Estado vacío */
.products-empty {
  grid-column: 1 / -1;
  padding: var(--space-3xl);
  text-align: center;
}

.products-empty__text {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-style: italic;
  color: var(--gray-dark);
  line-height: 1.7;
}

.products-empty__text a {
  color: var(--gold-primary);
  transition: color var(--transition-fast);
}

.products-empty__text a:hover {
  color: var(--gold-light);
}


/* ─────────────────────────────────────────────
   PAGINACIÓN
───────────────────────────────────────────── */

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  padding-block: var(--space-xl) var(--space-2xl);
  min-height: 2rem;
}

.pagination:empty {
  padding: 0;
}

.pagination__prev,
.pagination__next {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: transparent;
  border: 1px solid rgba(175, 121, 18, 0.25);
  color: var(--gray-mid);
  cursor: pointer;
  transition: border-color var(--transition-fast), color var(--transition-fast);
  flex-shrink: 0;
}

.pagination__prev:hover:not(:disabled),
.pagination__next:hover:not(:disabled) {
  border-color: var(--gold-primary);
  color: var(--gold-light);
}

.pagination__prev:disabled,
.pagination__next:disabled {
  opacity: 0.25;
  cursor: default;
}

.pagination__pages {
  display: flex;
  gap: 4px;
}

.pagination__num {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.05em;
  background: transparent;
  border: 1px solid transparent;
  color: var(--gray-mid);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.pagination__num:hover {
  color: var(--white);
  border-color: rgba(255, 255, 255, 0.1);
}

.pagination__num.is-active {
  background: rgba(175, 121, 18, 0.12);
  border-color: var(--gold-primary);
  color: var(--gold-light);
}


/* ─────────────────────────────────────────────
   RESPONSIVE PRODUCTOS
───────────────────────────────────────────── */

@media (max-width: 1200px) {
  .products-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 1024px) {
  .products-intro__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .products-intro__badges {
    width: 100%;
  }
}

@media (max-width: 768px) {
  .products-grid {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .filters-row--brand {
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
  }

  .filters-row--brand::-webkit-scrollbar { display: none; }

  .filters-row--needs {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.625rem;
  }

  .filters-needs {
    gap: 5px;
  }

  .filter-marca {
    padding: 0.875rem 1rem;
    font-size: 10px;
  }
}

@media (max-width: 480px) {
  .products-grid {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }

  .products-intro__badges {
    grid-template-columns: 1fr;
  }

  .pagination__num {
    width: 32px;
    height: 32px;
  }

  .pagination__prev,
  .pagination__next {
    width: 36px;
    height: 36px;
  }
}

@media (max-width: 380px) {
  .products-grid {
    grid-template-columns: 1fr;
  }
}


/* ─────────────────────────────────────────────
   FICHA DE PRODUCTO (single-producto.php)
───────────────────────────────────────────── */

.product-single-wrap {
  padding-block: var(--space-xl);
}

.product-single {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-xl);
  align-items: start;
  margin-top: var(--space-lg);
}

/* La imagen de card (260px, pensada para el grid) se agranda a un
   cuadrado que escala con el ancho de la columna en la ficha individual. */
.product-single .product-card__img-wrap {
  height: auto;
  aspect-ratio: 1 / 1;
}

.product-single .product-card__name {
  font-size: var(--text-2xl);
}

.product-single .eyebrow {
  margin-block: var(--space-sm);
}

.product-single .product-card__desc {
  margin-block: var(--space-md);
}

.product-single .product-card__footer {
  margin-top: var(--space-lg);
}

.product-single__technical {
  margin-top: var(--space-md);
}

.product-single__back {
  margin-top: var(--space-lg);
}

@media (max-width: 768px) {
  .product-single {
    grid-template-columns: 1fr;
  }

  .product-single .product-card__img-wrap {
    aspect-ratio: 4 / 3;
  }
}
