.leg-gallery {
	--leg-gap: 16px;
	width: 100%;
}

.leg-gallery,
.leg-gallery * {
	box-sizing: border-box;
}

.leg-gallery__item {
	margin: 0;
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
}

.leg-gallery__link {
	display: block;
	text-decoration: none;
	outline: none;
}

.leg-gallery__image {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
	object-fit: cover;
	overflow: hidden;
	transition: transform .28s ease, filter .28s ease, box-shadow .28s ease;
	box-shadow: 0 8px 24px rgba(0, 0, 0, .08);
}

.leg-gallery__link:hover .leg-gallery__image,
.leg-gallery__item:hover .leg-gallery__image {
	transform: translateY(-2px) scale(1.015);
	box-shadow: 0 14px 34px rgba(0, 0, 0, .14);
}

/* Cuadrícula */
.leg-gallery--grid {
	display: grid;
	gap: var(--leg-gap);
}

.leg-gallery--grid.leg-gallery--cols-1 { grid-template-columns: repeat(1, minmax(0, 1fr)); }
.leg-gallery--grid.leg-gallery--cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.leg-gallery--grid.leg-gallery--cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.leg-gallery--grid.leg-gallery--cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.leg-gallery--grid .leg-gallery__image {
	height: 260px;
}

.leg-gallery--grid.leg-gallery--size-small .leg-gallery__image { height: 180px; }
.leg-gallery--grid.leg-gallery--size-medium .leg-gallery__image { height: 260px; }
.leg-gallery--grid.leg-gallery--size-large .leg-gallery__image { height: 360px; }

/* Masonry liviano con CSS columns */
.leg-gallery--masonry {
	column-gap: var(--leg-gap);
}

.leg-gallery--masonry.leg-gallery--cols-1 { column-count: 1; }
.leg-gallery--masonry.leg-gallery--cols-2 { column-count: 2; }
.leg-gallery--masonry.leg-gallery--cols-3 { column-count: 3; }
.leg-gallery--masonry.leg-gallery--cols-4 { column-count: 4; }

.leg-gallery--masonry .leg-gallery__item {
	display: inline-block;
	width: 100%;
	margin: 0 0 var(--leg-gap);
}

.leg-gallery--masonry .leg-gallery__image {
	height: auto;
}

.leg-gallery--masonry.leg-gallery--size-small .leg-gallery__image {
	max-height: 260px;
	object-fit: cover;
}

.leg-gallery--masonry.leg-gallery--size-medium .leg-gallery__image {
	max-height: 420px;
	object-fit: cover;
}

.leg-gallery--masonry.leg-gallery--size-large .leg-gallery__image {
	max-height: none;
}

.leg-gallery-empty {
	padding: 18px;
	border: 1px dashed #cbd5e1;
	border-radius: 12px;
	background: #f8fafc;
	color: #475569;
	font-size: 14px;
	text-align: center;
}

@media (max-width: 1024px) {
	.leg-gallery--grid.leg-gallery--cols-4 {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.leg-gallery--masonry.leg-gallery--cols-4 {
		column-count: 3;
	}
}

@media (max-width: 767px) {
	.leg-gallery--grid.leg-gallery--cols-2,
	.leg-gallery--grid.leg-gallery--cols-3,
	.leg-gallery--grid.leg-gallery--cols-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.leg-gallery--masonry.leg-gallery--cols-2,
	.leg-gallery--masonry.leg-gallery--cols-3,
	.leg-gallery--masonry.leg-gallery--cols-4 {
		column-count: 2;
	}

	.leg-gallery--grid.leg-gallery--size-small .leg-gallery__image { height: 140px; }
	.leg-gallery--grid.leg-gallery--size-medium .leg-gallery__image { height: 180px; }
	.leg-gallery--grid.leg-gallery--size-large .leg-gallery__image { height: 240px; }
}

@media (max-width: 480px) {
	.leg-gallery--grid,
	.leg-gallery--grid.leg-gallery--cols-1,
	.leg-gallery--grid.leg-gallery--cols-2,
	.leg-gallery--grid.leg-gallery--cols-3,
	.leg-gallery--grid.leg-gallery--cols-4 {
		grid-template-columns: 1fr;
	}

	.leg-gallery--masonry,
	.leg-gallery--masonry.leg-gallery--cols-1,
	.leg-gallery--masonry.leg-gallery--cols-2,
	.leg-gallery--masonry.leg-gallery--cols-3,
	.leg-gallery--masonry.leg-gallery--cols-4 {
		column-count: 1;
	}
}
