/* ============================================
   CATÁLOGO DE PRODUCTOS – ESTILOS AISLADOS
   ============================================ */
.page-catalogo {
  font-family: "Poppins", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: #333;
}

/* ===== Layout general ===== */
.page-catalogo .infoproducto {
  background: #f9f9f9;
  padding: 40px 0;
}
.page-catalogo .container { max-width: 1320px; }
.page-catalogo .text-center { text-align: center; }

/* ===== Grid de productos (responsive) ===== */
.page-catalogo .catalogo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
@media (min-width: 576px) { .page-catalogo .catalogo-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .page-catalogo .catalogo-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1200px) { .page-catalogo .catalogo-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1400px) { .page-catalogo .catalogo-grid { grid-template-columns: repeat(4, 1fr); } }

/* ===== Card de producto ===== */
.page-catalogo .product-card {
  background: #fff;
  border-radius: 14px;
  border: 1px solid #eee;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  transition: transform .18s ease, box-shadow .18s ease;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: fadeIn .4s ease;
}
.page-catalogo .product-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
}

/* ===== Imagen principal ===== */
.page-catalogo .product-media {
  position: relative;
  width: 100%;
  padding-top: 100%;
  background: #fafafa;
}
@media (max-width: 420px) {
  .page-catalogo .product-media { padding-top: 120%; }
}
.page-catalogo .product-media img {
  position: absolute;
  inset: 0;
  margin: auto;
  max-width: 92%;
  max-height: 92%;
  object-fit: contain;
  border-radius: 10px;
}

/* ===== Cuerpo y botones ===== */
.page-catalogo .product-body {
  padding: 14px 14px 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.page-catalogo .product-title {
  font-size: clamp(1rem, 1.2vw + .6rem, 1.15rem);
  font-weight: 600;
  line-height: 1.3;
  min-height: 2.6em;
}
.page-catalogo .product-actions {
  display: grid;
  gap: 8px;
}
.page-catalogo .product-actions .btn {
  width: 100%;
  border-radius: 10px;
}

/* ===== Thumbnails ===== */
.page-catalogo .thumb-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  padding: 0 14px 14px;
}
.page-catalogo .thumb-grid img {
  width: 100%;
  height: 64px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid #eee;
}

/* ===== Botones scoped ===== */
.page-catalogo .btn-success { background-color: #3fb57e; border: none; }
.page-catalogo .btn-danger  { background-color: #dc3545; border: none; }
.page-catalogo .btn-primary { background-color: #007bff; border: none; }
.page-catalogo .btn-info    { background-color: #17a2b8; border: none; }
.page-catalogo .btn:hover   { opacity: .9; transition: opacity .2s ease; }

/* ===== Modal de producto (info) ===== */
.page-catalogo .modal-product .modal-header {
  border: 0;
  padding: 16px 20px 0;
}
.page-catalogo .modal-product .modal-title {
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
  margin: 0 auto 10px;
}
.page-catalogo .modal-product .hero {
  display: flex;
  justify-content: center;
  padding: 8px 16px 0;
}
.page-catalogo .modal-product .hero img {
  max-width: 720px;
  width: 100%;
  border-radius: 12px;
  object-fit: contain;
}
.page-catalogo .modal-product .section {
  padding: 10px 20px;
}
.page-catalogo .modal-product .section + .section { padding-top: 0; }
.page-catalogo .modal-product .label-muted {
  color: #6c757d;
  font-size: .85rem;
  margin-bottom: 6px;
}
.page-catalogo .modal-product .gallery {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width:768px){
  .page-catalogo .modal-product .gallery { grid-template-columns: repeat(4, 1fr); }
}
.page-catalogo .modal-product .gallery img {
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid #eee;
}

/* ===== Modal de galería (carrusel ampliable) ===== */
/* MODAL GALERÍA – compatible BS3/BS4/BS5 */

.page-catalogo #modalGaleria .modal-dialog {
  width: 100%;
  max-width: 96vw;
  margin: 0 auto;
  height: 100vh;
}
@supports (height: 100dvh) {
  .page-catalogo #modalGaleria .modal-dialog { height: 100dvh; }
}
.page-catalogo #modalGaleria .modal-content {
  background: #0b0b0be6;
  border: 0;
  border-radius: 10px;
  overflow: hidden;
  height: 100%;
}
.page-catalogo #modalGaleria .modal-header,
.page-catalogo #modalGaleria .modal-footer {
  border: 0;
  color: #fff;
}
.page-catalogo #modalGaleria .close {
  color: #fff;
  opacity: 1;
  font-size: 32px;
  line-height: 1;
}
.page-catalogo #modalGaleria .modal-body {
  padding: 8px;
  height: calc(100vh - 100px);
}
@supports (height: 100dvh) {
  .page-catalogo #modalGaleria .modal-body { height: calc(100dvh - 100px); }
}
.page-catalogo #modalGaleria .carousel,
.page-catalogo #modalGaleria .carousel-inner {
  width: 100%;
  height: 100%;
}

/* ✅ Aquí soportamos ambas clases: .carousel-item (BS4/5) y .item (BS3) */
.page-catalogo #modalGaleria .carousel-item,
.page-catalogo #modalGaleria .item {
  text-align: center;
  height: 100%;
}

/* wrapper para centrar verticalmente la imagen en cualquier versión */
.page-catalogo #modalGaleria .slide-center {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

/* Imagen ajustada sin recortes */
.page-catalogo #modalGaleria .carousel-item img,
.page-catalogo #modalGaleria .item img {
  max-width: min(96vw, 1600px);
  max-height: calc(100vh - 140px);
  object-fit: contain;
  margin: 0 auto;
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,.35);
}
@supports (height: 100dvh) {
  .page-catalogo #modalGaleria .carousel-item img,
  .page-catalogo #modalGaleria .item img {
    max-height: calc(100dvh - 140px);
  }
}

/* Indicadores/controles */
.page-catalogo #modalGaleria .carousel-indicators { bottom: 10px; }
.page-catalogo #modalGaleria .carousel-indicators li { background: #ffffff66; }
.page-catalogo #modalGaleria .carousel-indicators .active { background: #fff; }
.page-catalogo #modalGaleria .carousel-control-prev-icon,
.page-catalogo #modalGaleria .carousel-control-next-icon {
  filter: invert(1) contrast(2);
}
