/* =========================================================
   BLOQUE GALERÍA AISLADO (prefijo galeria-)
   ========================================================= */

.galeria-wrap, .galeria-wrap * { box-sizing: border-box; }

.galeria-wrap {
	padding: 5% 0;
	background: #f9f9f9;
	--galeria-cols: 4;       /* columnas por defecto (escritorio) */
	--galeria-ratio: 4/3;    /* relación ancho/alto de cada imagen */
}

/* ===== Caja general ===== */
.galeria-caja {
	max-width: 1280px;
	margin: 0 auto;
	padding: 2rem;
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 0 20px rgba(0,0,0,.05);
}

/* ===== Título ===== */
.galeria-titulo {
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 2rem;
	color: #333;
}

/* ===== Grid ===== */
.galeria-grid {
	display: grid !important;
	grid-template-columns: repeat(var(--galeria-cols, 4), minmax(0, 1fr)) !important;
	gap: 1rem;
	align-items: stretch;
}

/* Control de columnas por clase */
.galeria-col-1 { --galeria-cols: 1; }
.galeria-col-2 { --galeria-cols: 2; }
.galeria-col-3 { --galeria-cols: 3; }
.galeria-col-4 { --galeria-cols: 4; }
.galeria-col-5 { --galeria-cols: 5; }
.galeria-col-6 { --galeria-cols: 6; }

/* ===== Tarjeta ===== */
.galeria-item {
	position: relative;
	overflow: hidden;
	border-radius: 12px;
}

/* ===== Imagen con ratio ===== */
.galeria-imgwrap {
	position: relative;
	width: 100%;
	aspect-ratio: var(--galeria-ratio, 4/3);
	min-height: 220px;
	overflow: hidden;
	border-radius: 12px;
}

.galeria-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform 0.5s ease;
}

/* ===== Overlay con lupa ===== */
.galeria-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.4);
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity .4s ease;
}

.galeria-icono {
	font-size: 2rem;
	color: #fff;
	transform: scale(.9);
	opacity: 0;
	transition: opacity .3s ease, transform .3s ease;
}

/* Hover: zoom + mostrar lupa */
.galeria-item:hover .galeria-img { transform: scale(1.1); }
.galeria-item:hover .galeria-overlay { opacity: 1; }
.galeria-item:hover .galeria-icono { opacity: 1; transform: scale(1.1); }

/* ===== Nombre fijo ===== */
.galeria-texto {
	position: absolute;
	bottom: 0; left: 0; width: 100%;
	margin: 0; padding: .6rem 1rem;
	background: rgba(0,0,0,.65);
	color: #fff; font-size: 1rem; font-weight: 500;
	text-align: center; z-index: 5;
}
.galeria-texto:empty { display: none; }

/* ===== Botón que envuelve la imagen ===== */
.galeria-open {
	display: block; width: 100%; height: 100%;
	padding: 0; margin: 0; border: 0; background: transparent;
	cursor: pointer; touch-action: manipulation;
}

/* =========================================================
   LIGHTBOX — SOLO FOTO PANTALLA COMPLETA REAL
   ========================================================= */
.galeria-lightbox {
	position: fixed;
	inset: 0;
	width: 100vw;

	/* Soporte completo de alturas (Android/iOS/desktop) */
	height: 100dvh;
	height: 100svh;
	height: 100lvh;
	min-height: -webkit-fill-available;

	display: none;
	align-items: center;
	justify-content: center;
	background: #000;
	z-index: 999999;
}
.galeria-lightbox.is-open { display: flex; }

.galeria-lightbox-backdrop {
	position: absolute;
	inset: 0;
	cursor: pointer;
}

/* Contenedor sin márgenes ni padding, ocupa todo */
.galeria-lightbox-dialog {
	position: relative;
	outline: none;
	padding: 0;
	margin: 0;
	width: 100vw;
	height: 100dvh;
	height: 100svh;
	height: 100lvh;
	min-height: -webkit-fill-available;
	display: grid;
	place-items: center;
}

/* Figura contenedora */
.galeria-lightbox-figure {
	margin: 0;
	width: 100vw;
	height: 100dvh;
	height: 100svh;
	height: 100lvh;
	min-height: -webkit-fill-available;
	display: grid;
	place-items: center;
}

/* Imagen única (ajustada o recortada según preferencia) */
.galeria-lightbox-img {
	max-width: 100vw;
	max-height: 100dvh;
	max-height: 100svh;
	max-height: 100lvh;
	max-height: -webkit-fill-available;
	width: auto;
	height: auto;
	object-fit: contain; /* cambia a cover si prefieres llenar recortando */
	background: #000;
	border-radius: 0;
	box-shadow: none;
}

/* Sin pie */
.galeria-lightbox-caption { display: none !important; }

/* ===== Botones flotantes ===== */
.galeria-lightbox-btn {
	position: absolute;
	background: rgba(0,0,0,.35);
	color: #fff;
	border: none;
	width: 48px; height: 48px; font-size: 1.8rem;
	border-radius: 999px;
	display: grid; place-items: center;
	cursor: pointer;
	user-select: none;
	z-index: 3;
	transition: background .3s ease;
}
.galeria-lightbox-btn:hover { background: rgba(0,0,0,.6); }

.galeria-lightbox-prev { left: 12px;  top: 50%; transform: translateY(-50%); }
.galeria-lightbox-next { right: 12px; top: 50%; transform: translateY(-50%); }
.galeria-lightbox-close{ right: 12px; top: 12px; width: 44px; height: 44px; font-size: 2rem; }

/* Descomenta si quieres ocultar todos los botones (solo foto)
.galeria-lightbox-btn { display: none !important; }
*/

/* =========================================================
   RESPONSIVE
   ========================================================= */

/* Tablet */
@media (max-width: 992px) {
	.galeria-wrap { --galeria-cols: 3 !important; }
}

/* Móvil */
@media (max-width: 768px) {
	.galeria-wrap { --galeria-cols: 2 !important; }
	.galeria-imgwrap { min-height: 170px; }
	.galeria-titulo { font-size: 1.6rem; margin-bottom: 1.2rem; }
	.galeria-lightbox-btn { width: 42px; height: 42px; font-size: 1.6rem; }
}

/* Móviles pequeños */
@media (max-width: 480px) {
	.galeria-wrap { --galeria-cols: 1 !important; }
	.galeria-imgwrap { min-height: 150px; }
	.galeria-lightbox-prev { left: .75rem; }
	.galeria-lightbox-next { right: .75rem; }
	.galeria-lightbox-close{ right: .75rem; top: .75rem; width: 42px; height: 42px; font-size: 1.6rem; }
}

/* Evita scroll del fondo con visor abierto */
html.galeria-lock, body.galeria-lock { overflow: hidden !important; }
