.publicacion-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.8rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}

.titulo-publicacion {
  font-size: 1.4rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0;
}

.tabs-multimedia {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.tabs-multimedia .btn-d{
  padding: 10px;
}


/* Contenedor general de la sección galería */
.galeria {
  margin-top: 1.5rem;
  width: 100%;
  max-width: 100%;
  min-width: 0;
}

/* Cada panel (fotos, video, 360, tour) */
.galeria-panel {
  display: none;             /* por defecto oculto, lo muestra el JS */
}

/* Solo el panel activo se muestra y toma el layout de galería */
.galeria-panel.active {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;               /* separación entre foto grande y thumbs */
}

/* Columna izquierda: imagen principal */
.galeria-panel .galeria-principal {
  flex: 1;                   /* ocupa todo el ancho disponible */
  position: relative;        /* para posicionar las flechas dentro */
  aspect-ratio: 16 / 9;      
  max-height: 520px;
}

/* La imagen principal ocupa todo el ancho del contenedor */
.galeria-panel .galeria-principal img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 8px;
  background: #e2e1e1;
  cursor: zoom-in;
}

/* Flechas centradas verticalmente */
.galeria-panel .galeria-principal .ctrl {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  padding: 0.4rem 0.6rem;
  border-radius: 999px;
  border: none;
  cursor: pointer;
}

/* Flecha izquierda */
.galeria-panel .galeria-principal .ctrl.prev {
  left: 10px;
}

/* Flecha derecha */
.galeria-panel .galeria-principal .ctrl.next {
  right: 10px;
}

/* Columna derecha: lista vertical de miniaturas */
.galeria-panel .galeria-thumbs {
  width: 220px;              /* ancho fijo de la columna de thumbs */
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-height: 520px;         /* misma altura que la principal */
  overflow-y: auto;          /* scroll vertical si hay muchas */
}

/* Cada miniatura ocupa todo el ancho de su columna */
.galeria-panel .galeria-thumbs .thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: contain;
  background: #e2e1e1;
  display: block;
  border-radius: 6px;
  cursor: pointer;
  opacity: 0.8;
  transition: opacity 0.15s ease, transform 0.15s ease;
}


.galeria-panel .galeria-thumbs .thumb.active {
  opacity: 1;
  outline: 2px solid rgba(0,0,0,0.25);
}

/* Paneles que no son de fotos pueden tener su propio estilo interno */
.galeria-video iframe,
.galeria-tour iframe {
  border-radius: 8px;
}

/* Simple grid para fotos 360 */
.galeria-360-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 0.75rem;
}

.galeria-360-grid .thumb-360 {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-radius: 8px;
}

/* Mensaje de sin contenido */
.sin-contenido {
  font-size: 0.95rem;
  color: #777;
}

/* 🌐 Responsive: en mobile la galería se apila */
@media (max-width: 768px) {
  .galeria {
    overflow-x: hidden;
    width: 100vw;

  }

  .galeria-panel.active {
    flex-direction: column;
  }

  .galeria-panel .galeria-thumbs {
    width: 100%;
    max-height: 120px;
    flex-direction: row;
    overflow-y: hidden;
    overflow-x: auto;
  }

  .galeria-panel .galeria-thumbs .thumb {
    height: 100px;
    width: 140px;
    flex: 0 0 140px;
  }
}


.detalle-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
  gap: 1.5rem;
  align-items: flex-start;
  margin-top: 2rem;
}

/* Columna izquierda */
.detalle-main {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* Columna derecha */
.detalle-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.resumen-grid {
  display: grid;                                /* <- NUEVO */
  grid-template-columns: repeat(2, 1fr);        /* <- NUEVO */
  column-gap: 2rem;                             /* <- NUEVO */
  row-gap: 0.5rem;                              /* <- NUEVO */
  margin-top: 1rem;                             /* <- opcional, separa del header */
}

/* cada fila: icono + texto (si no lo tenés ya) */
.resumen-item {
  display: flex;                                /* <- NUEVO (si no estaba) */
  align-items: flex-start;                      /* <- NUEVO */
  gap: 0.5rem;                                  /* <- NUEVO */
}
.resumen-estado, .resumen-caracteristicas{
  margin-top: 15px;
}

.btn-contactar{
  padding: 10px;
}



.descripcion-body.is-open {
  max-height: none;       /* muestra todo al abrir */
}

.descripcion-body p {
  word-wrap: break-word;
}

.descripcion-button{
  display: flex;
  justify-content: center;
}



.financiacion-card p{
  text-align: center;
}



.ubicacion-card iframe {
  width: 100%;
  height: 320px;
  border: 0;
  border-radius: 8px;
}

.ubicacion-text{
  margin: 15px 0;
}

/* Responsive mobile/tablet (sin tocar desktop) */
@media (max-width: 1024px) {
  .detalle-layout {
    grid-template-columns: 1fr;
    gap: 1rem;
    margin-top: 1.2rem;
  }
}

@media (max-width: 768px) {
  main.container {
    margin-left: 10px;
    margin-right: 10px;
  }

  .publicacion-header {
    align-items: stretch;
    gap: 0.6rem;
    padding: 0.8rem 0;
    min-width: 0;
  }

  .publicacion-header .titulo {
    width: 100%;
    min-width: 0;
  }

  .publicacion-header .titulo h1 {
    font-size: clamp(1.2rem, 5vw, 1.5rem);
    line-height: 1.25;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .tabs-multimedia {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.45rem;
  }

  .tabs-multimedia .btn-d,
  .tabs-multimedia .tab-tour {
    width: 100%;
    min-height: 40px;
    padding: 8px 4px;
    font-size: 0.78rem;
    line-height: 1.1;
    justify-content: center;
    text-align: center;
  }

  .galeria {
    margin-top: 1rem;
  }

  .galeria-panel.active {
    flex-direction: column;
    gap: 0.75rem;
    min-width: 0;
  }

  .galeria-panel .galeria-principal {
    width: 100%;
    max-width: 100%;
    max-height: none;
    min-width: 0;
    overflow: hidden;
  }

  .galeria-panel .galeria-principal img {
    width: 100%;
    max-width: 100%;
    display: block;
  }

  .galeria-panel .galeria-thumbs {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    max-height: none;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(110px, 34vw);
    gap: 0.5rem;
    overflow-x: auto;
    overflow-y: hidden;
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
  }

  .galeria-panel .galeria-thumbs .thumb {
    width: 100%;
    min-width: 0;
    height: auto;
    aspect-ratio: 16 / 9;
    flex: none;
  }

  .detalle-main,
  .detalle-sidebar {
    gap: 0.85rem;
  }

  .resumen-grid {
    grid-template-columns: 1fr;
    column-gap: 0;
    row-gap: 0.6rem;
  }

  .resumen-item {
    gap: 0.4rem;
  }

  .btn-contactar {
    width: 100%;
  }

  .ubicacion-card iframe {
    height: 240px;
  }
}

@media (max-width: 520px) {
  .tabs-multimedia {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.4rem;
  }

  .galeria-panel .galeria-thumbs {
    grid-auto-columns: minmax(100px, 42vw);
  }

  .ubicacion-card iframe {
    height: 220px;
  }
}

.detalle-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.9);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 0.5rem;
  z-index: 9999;
}

.detalle-lightbox.is-open {
  display: flex;
}

.detalle-lightbox-img {
  max-width: 98vw;
  max-height: 96vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 4px;
}

.detalle-lightbox-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 42px;
  height: 42px;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
}
