/* Breathing room when gallery follows post body (e.g. auto-appended on locations) */
.entry-content > .bhi-media-gallery {
	margin-top: 2rem;
}

/* Block empty state: visible box so users see the block and know what to do */
.bhi-media-gallery-block--empty {
	border: 2px dashed #8c8f94;
	background: #f0f0f1;
	padding: 1.5rem 2rem;
	text-align: center;
	color: #1d2327;
	font-size: 1rem;
	line-height: 1.5;
}
.bhi-media-gallery-block--empty .bhi-media-gallery-block__empty-msg {
	margin: 0;
}

/* Grid: uniform rows */
.bhi-media-gallery:not(.is-layout-masonry) {
	display: grid;
	gap: var(--bhi-mm-gap, 1rem);
	grid-template-columns: repeat(var(--bhi-mm-columns, 3), minmax(0, 1fr));
}

@media (max-width: 782px) {
	.bhi-media-gallery:not(.is-layout-masonry) {
		grid-template-columns: repeat(var(--bhi-mm-columns-mobile, 2), minmax(0, 1fr));
	}
}

/*
 * Legacy fallback only: fake "masonry" via CSS grid (when core render_block fails).
 * Primary "masonry" layout uses WordPress core/gallery (.bhi-media-gallery--core).
 */
.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) {
	display: grid !important;
	grid-template-columns: repeat(var(--bhi-mm-columns, 4), 1fr);
	grid-auto-rows: 140px;
	grid-auto-flow: dense;
	gap: var(--bhi-mm-gap, 0.5rem);
}

@media (max-width: 782px) {
	.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) {
		grid-template-columns: repeat(var(--bhi-mm-columns-mobile, 2), 1fr);
		grid-auto-rows: 120px;
	}
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item {
	min-height: 0;
	display: flex;
	flex-direction: column;
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item--portrait {
	grid-row: span 2;
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item--landscape {
	grid-column: span 2;
}

@media (max-width: 782px) {
	.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item--landscape {
		grid-column: span 2;
	}
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__link {
	flex: 1;
	min-height: 0;
	display: block;
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__link .bhi-media-gallery__image,
.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item .bhi-media-gallery__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* WordPress core/gallery (legacy cached HTML only) */
.bhi-media-gallery--core .wp-block-gallery {
	margin-left: auto;
	margin-right: auto;
}

/*
 * Packed layout: custom .bhi-mm-masonry-root + Masonry.js (no wp-block-gallery CSS fights).
 */
.bhi-media-gallery--packed .bhi-mm-masonry-root {
	position: relative;
	width: 100%;
}

.bhi-media-gallery--packed .bhi-mm-masonry-item {
	box-sizing: border-box;
	margin: 0;
}

.bhi-media-gallery--packed .bhi-mm-masonry-item img {
	display: block;
	max-width: 100%;
	height: auto;
}

@media (min-width: 783px) {
	.bhi-media-gallery--packed .bhi-mm-masonry-item {
		width: calc(
			(100% - (var(--bhi-mm-columns, 4) - 1) * var(--bhi-mm-gap, 12px)) / var(--bhi-mm-columns, 4)
		);
	}
}

@media (max-width: 782px) {
	.bhi-media-gallery--packed .bhi-mm-masonry-item {
		width: calc(
			(100% - (var(--bhi-mm-columns-mobile, 2) - 1) * var(--bhi-mm-gap, 12px)) /
				var(--bhi-mm-columns-mobile, 2)
		);
	}
}

.bhi-media-gallery--packed.bhi-media-gallery--hide-captions .bhi-mm-masonry-item figcaption {
	display: none !important;
}

.bhi-media-gallery--packed .bhi-media-gallery__item--more {
	display: none !important;
}

.bhi-media-gallery--packed .bhi-media-gallery__item--more.is-visible {
	display: block !important;
}

.bhi-media-gallery--core.bhi-media-gallery--hide-captions .wp-block-gallery figcaption,
.bhi-media-gallery--core.bhi-media-gallery--hide-captions .wp-block-image figcaption {
	display: none !important;
}

.bhi-media-gallery--core .bhi-media-gallery__item--more {
	display: none !important;
}

.bhi-media-gallery--core .bhi-media-gallery__item--more.is-visible {
	display: block !important;
}

.bhi-media-gallery__item {
	position: relative;
}

.bhi-media-gallery__link,
.bhi-media-gallery__link:focus {
	display: block;
	text-decoration: none;
	outline: none;
}

.bhi-media-gallery__image {
	display: block;
	width: 100%;
	height: auto;
}

.bhi-media-gallery__caption {
	margin-top: 0.5rem;
	font-size: 0.875rem;
	line-height: 1.4;
	color: #43454b;
}

.bhi-media-gallery__item:hover .bhi-media-gallery__image,
.bhi-media-gallery__item:focus-within .bhi-media-gallery__image {
	opacity: 0.92;
}

.bhi-media-gallery-section {
	margin-bottom: 2rem;
}
.bhi-media-gallery-section:last-child {
	margin-bottom: 0;
}
.bhi-media-gallery__heading {
	margin: 0 0 1rem;
	font-size: 1.25rem;
	font-weight: 600;
}

.bhi-media-gallery__item--more {
	display: none !important;
}

.bhi-media-gallery__item--more.is-visible {
	display: inline-block !important;
}

.bhi-media-gallery.is-layout-masonry:not(.bhi-media-gallery--core) .bhi-media-gallery__item--more.is-visible {
	display: inline-block !important;
}

.bhi-media-gallery__load-more-wrap {
	margin: 1.5rem 0 0;
	text-align: center;
}

.bhi-media-gallery__load-more {
	display: inline-block;
	padding: 0.6rem 1.5rem;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.4;
	color: #fff;
	background: #1d2327;
	border: none;
	border-radius: 4px;
	cursor: pointer;
	text-decoration: none;
	transition: background 0.15s ease, opacity 0.15s ease;
}

.bhi-media-gallery__load-more:hover {
	background: #2c3338;
}

.bhi-media-gallery__load-more:focus {
	outline: 2px solid #1d2327;
	outline-offset: 2px;
}

.bhi-media-gallery__load-more-wrap.is-empty {
	display: none;
}
