/* ===== lazy para un efecto de optimizacion ===== */
.lazy {
  opacity: 0;
  transition: opacity .4s ease;
  width: 100%;
  height: auto;
  display: block;
}

.loaded {
  opacity: 1;
}
/* =================================================== */
.galeria {
  max-width: 1200px;
  margin: 129px auto;
  padding: clamp(12px, 2.5vw, 28px); /* padding responsivo */
  box-sizing: border-box;
  font-family: "Open Sans", Arial, sans-serif;
}

/* Grid responsive: auto-fit + minmax hacen que las columnas cambien según ancho */
.galeria-grid {
  display: grid;
  gap: clamp(12px, 1.6vw, 20px);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

/* Tarjeta */
.galeria .item {
  background: #ffffff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  transition: transform .22s ease, box-shadow .22s ease;
  display: flex;
  flex-direction: column;
}

/* Soporte para imagen con proporción fija y escalable */
.card-media {
  width: 100%;
  aspect-ratio: 16 / 11;           /* mantiene relación similar a 1170x450 */
  background: #f4f4f4;
  display: block;
  position: relative;
  overflow: hidden;
}

/* Imagen: cover para pantallas grandes, center/contain en móvil se puede cambiar más abajo */
.card-media img {
  width: 100%;
  height: 100%;
  /*object-fit: cover;               /* rellena y recorta si hace falta */
  object-position: center;
  display: block;
  transition: transform .4s ease;
}

/* Cuerpo de la tarjeta */
.card-body {
  padding: clamp(10px, 1.8vw, 14px);
}
.card-title {
  margin: 0 0 6px;
  font-weight: 700;
  font-size: clamp(15px, 1.4vw, 18px);
  color: #222;
}
.card-sub {
  margin: 0;
  color: #666;
  font-size: clamp(13px, 1.05vw, 14px);
  line-height: 1.35;
}

/* Hover */
.galeria .item:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 36px rgba(0,0,0,.12);
}
.galeria .item:focus-within { outline: 2px solid rgba(0,174,239,.12); }

/* Ajustes por breakpoint: tablet */
@media (max-width: 992px) {
  .card-media { aspect-ratio: 16 / 9; }
}

/* Ajustes por breakpoint: móvil */
@media (max-width: 600px) {
  .galeria-grid { gap: 12px; }
  .card-media { aspect-ratio: 4 / 3; }     /* imagen más alta en móvil */
  .card-media img { object-fit: contain; } /* evita recortes fuertes en fotos verticales */
  .galeria .item { border-radius: 8px; }
  .card-body { padding: 10px; }
}