/**
 * Inversaweb Galleries — front (linked + main). Grid / slider layouts, GLightbox.
 */

.iw-galleries-stack {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
	margin: 0;
	padding: 0;
}

.iw-gal {
	position: relative;
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
	box-shadow: none;
}

/* Title: paragraph, bold, slightly larger than description */
.iw-gal__title {
	margin: 0 0 0.5rem;
	padding: 0;
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.35;
	color: inherit;
	border: none;
	background: transparent;
}

.iw-gal__desc {
	margin: 0 0 1rem;
	padding: 0;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: inherit;
	opacity: 0.9;
}

.iw-gal__grid {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	border: 0;
	list-style: none;
}

.iw-gal--layout-grid .iw-gal__grid {
	grid-template-columns: repeat(var(--iw-gal-cols-mobile, 2), minmax(0, 1fr));
}

@media (min-width: 640px) {
	.iw-gal--layout-grid .iw-gal__grid {
		grid-template-columns: repeat(var(--iw-gal-cols-tablet, 3), minmax(0, 1fr));
	}
}

@media (min-width: 1024px) {
	.iw-gal--layout-grid .iw-gal__grid {
		grid-template-columns: repeat(var(--iw-gal-cols-desktop, 4), minmax(0, 1fr));
	}
}

.iw-gal__grid::before,
.iw-gal__grid::after {
	display: none;
	content: none;
}

.iw-gal__cell {
	margin: 0;
	padding: 0;
	list-style: none;
	min-width: 0;
}

.iw-gal__cell::marker {
	content: none;
}

/* Full-gallery lightbox sources when the grid is paginated (not for display). */
.iw-gal__lightbox-chain {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.iw-gal__lb-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

.iw-gal__link {
	display: block;
	text-decoration: none;
	border: none;
	outline: none;
	transition: opacity 0.2s ease, transform 0.2s ease;
}

.iw-gal__link:hover,
.iw-gal__link:focus-visible {
	opacity: 0.92;
}

.iw-gal__link:focus-visible .iw-gal__link-inner {
	box-shadow: 0 0 0 2px currentColor;
}

.iw-gal__link-inner {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 4px;
	line-height: 0;
}

/* Thumbnail formats: single ratio (.iw-gal--format-*) or per breakpoint (.iw-gal--fmt-*). */
.iw-gal--format-square .iw-gal__link-inner,
.iw-gal--fmt-m-square .iw-gal__link-inner {
	aspect-ratio: 1 / 1;
}

.iw-gal--format-landscape .iw-gal__link-inner,
.iw-gal--fmt-m-landscape .iw-gal__link-inner {
	aspect-ratio: 16 / 9;
}

.iw-gal--format-vertical .iw-gal__link-inner,
.iw-gal--fmt-m-vertical .iw-gal__link-inner {
	aspect-ratio: 3 / 4;
}

@media (min-width: 640px) {
	.iw-gal--fmt-t-square .iw-gal__link-inner {
		aspect-ratio: 1 / 1;
	}
	.iw-gal--fmt-t-landscape .iw-gal__link-inner {
		aspect-ratio: 16 / 9;
	}
	.iw-gal--fmt-t-vertical .iw-gal__link-inner {
		aspect-ratio: 3 / 4;
	}
}

@media (min-width: 1024px) {
	.iw-gal--fmt-d-square .iw-gal__link-inner {
		aspect-ratio: 1 / 1;
	}
	.iw-gal--fmt-d-landscape .iw-gal__link-inner {
		aspect-ratio: 16 / 9;
	}
	.iw-gal--fmt-d-vertical .iw-gal__link-inner {
		aspect-ratio: 3 / 4;
	}
}

.iw-gal--thumb-crop .iw-gal__thumb,
.iw-gal--format-square .iw-gal__thumb,
.iw-gal--format-landscape .iw-gal__thumb,
.iw-gal--format-vertical .iw-gal__thumb {
	display: block;
	width: 100%;
	height: 100%;
	min-height: 0;
	object-fit: cover;
	vertical-align: middle;
}

/* Horizontal slider (single row) */
.iw-gal__carousel {
	position: relative;
	margin: 0 auto;
	padding: 0;
	width: 100%;
	max-width: min(100%, var(--wp--style--global--content-size, 72rem));
	box-sizing: border-box;
}

.iw-gal__carousel-viewport {
	overflow: hidden;
	margin: 0 clamp(10px, 3vw, 28px);
}

.iw-gal__carousel-track {
	display: flex;
	flex-wrap: nowrap;
	gap: 10px;
	overflow-x: auto;
	scroll-behavior: smooth;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding: 4px 0 12px;
}

.iw-gal__carousel-track::-webkit-scrollbar {
	display: none;
	height: 0;
}

.iw-gal--layout-slider .iw-gal__carousel-track .iw-gal__cell {
	flex: 0 0 calc(25% - 8px);
	scroll-snap-align: center;
}

@media (max-width: 1023px) {
	.iw-gal--layout-slider .iw-gal__carousel-track .iw-gal__cell {
		flex: 0 0 calc(33.333% - 7px);
	}
}

@media (max-width: 639px) {
	.iw-gal__carousel-viewport {
		margin: 0 clamp(6px, 2.5vw, 18px);
	}

	.iw-gal--layout-slider .iw-gal__carousel-track {
		padding-inline: 11vw;
		scroll-padding-inline: 11vw;
	}

	.iw-gal--layout-slider .iw-gal__carousel-track .iw-gal__cell {
		flex: 0 0 76vw;
		max-width: none;
	}
}

.iw-gal__carousel-icon {
	display: block;
	flex-shrink: 0;
}

.iw-gal__carousel-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 2;
	width: 42px;
	height: 42px;
	margin: 0;
	padding: 0;
	border: 1px solid rgba(0, 0, 0, 0.22);
	border-radius: 4px;
	background: #fff;
	color: #1d2327;
	cursor: pointer;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.12);
}

.iw-gal__carousel-btn:hover,
.iw-gal__carousel-btn:focus-visible {
	background: #fff;
	border-color: rgba(0, 0, 0, 0.22);
}

.iw-gal__carousel-btn:focus-visible {
	outline: 2px solid #2271b1;
	outline-offset: 2px;
}

.iw-gal__carousel-btn--prev {
	left: 0;
}

.iw-gal__carousel-btn--next {
	right: 0;
}

.iw-gal-pagination {
	margin-top: 1.75rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 8px;
}

.iw-gal-pagination--images {
	margin-top: 1rem;
}

.iw-gal-pagination__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	padding: 8px 14px;
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9rem;
	line-height: 1;
	border-radius: 4px;
	border: 1px solid rgba(0, 0, 0, 0.12);
	background: rgba(0, 0, 0, 0.04);
	color: inherit;
	transition: background 0.15s ease, border-color 0.15s ease;
}

.iw-gal-pagination__link:hover,
.iw-gal-pagination__link:focus-visible {
	background: rgba(0, 0, 0, 0.08);
	border-color: rgba(0, 0, 0, 0.2);
}

/* Active state: colors from inline CSS (Business information → Main color). */

/* Linked galleries block: stable anchor id for the shortcode wrapper. */
#iw-linked-galleries {
	scroll-margin-top: 1rem;
}

[id^='iw-gal-'] {
	scroll-margin-top: 1rem;
}

/* --- Hybrid layout (different grid/slider per breakpoint) --- */
.iw-gal--hybrid .iw-gal__carousel-btn {
	display: none !important;
}

@media (max-width: 639px) {
	.iw-gal--hybrid.iw-gal--bm-slider .iw-gal__carousel-track--hybrid {
		display: flex;
		flex-wrap: nowrap;
		gap: 10px;
		overflow-x: auto;
		scroll-behavior: smooth;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 4px 0 12px;
		padding-inline: 11vw;
		scroll-padding-inline: 11vw;
	}

	.iw-gal--hybrid.iw-gal--bm-slider .iw-gal__carousel-track--hybrid::-webkit-scrollbar {
		display: none;
		height: 0;
	}

	.iw-gal--hybrid.iw-gal--bm-slider .iw-gal__carousel-track--hybrid .iw-gal__cell {
		flex: 0 0 76vw;
		max-width: none;
		scroll-snap-align: center;
	}

	.iw-gal--hybrid.iw-gal--bm-slider .iw-gal__carousel-viewport {
		overflow: hidden;
		margin: 0 clamp(6px, 2.5vw, 18px);
	}

	.iw-gal--hybrid.iw-gal--bm-slider .iw-gal__carousel-btn {
		display: flex !important;
	}

	.iw-gal--hybrid.iw-gal--bm-grid .iw-gal__carousel-viewport {
		overflow: visible;
		margin: 0;
	}

	.iw-gal--hybrid.iw-gal--bm-grid .iw-gal__carousel-track--hybrid {
		display: grid;
		grid-template-columns: repeat(var(--iw-gal-cols-mobile, 2), minmax(0, 1fr));
		gap: 12px;
		overflow-x: visible;
		scroll-snap-type: none;
		padding: 0 0 12px;
	}

	.iw-gal--hybrid.iw-gal--bm-grid .iw-gal__carousel-track--hybrid .iw-gal__cell {
		min-width: 0;
	}
}

@media (min-width: 640px) and (max-width: 1023px) {
	.iw-gal--hybrid.iw-gal--bt-slider .iw-gal__carousel-track--hybrid {
		display: flex;
		flex-wrap: nowrap;
		gap: 10px;
		overflow-x: auto;
		scroll-behavior: smooth;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 4px 0 12px;
	}

	.iw-gal--hybrid.iw-gal--bt-slider .iw-gal__carousel-track--hybrid::-webkit-scrollbar {
		display: none;
		height: 0;
	}

	.iw-gal--hybrid.iw-gal--bt-slider .iw-gal__carousel-track--hybrid .iw-gal__cell {
		flex: 0 0 calc(33.333% - 7px);
		scroll-snap-align: center;
	}

	.iw-gal--hybrid.iw-gal--bt-slider .iw-gal__carousel-viewport {
		overflow: hidden;
	}

	.iw-gal--hybrid.iw-gal--bt-slider .iw-gal__carousel-btn {
		display: flex !important;
	}

	.iw-gal--hybrid.iw-gal--bt-grid .iw-gal__carousel-viewport {
		overflow: visible;
		margin: 0;
	}

	.iw-gal--hybrid.iw-gal--bt-grid .iw-gal__carousel-track--hybrid {
		display: grid;
		grid-template-columns: repeat(var(--iw-gal-cols-tablet, 3), minmax(0, 1fr));
		gap: 12px;
		overflow-x: visible;
		scroll-snap-type: none;
		padding: 0 0 12px;
	}

	.iw-gal--hybrid.iw-gal--bt-grid .iw-gal__carousel-track--hybrid .iw-gal__cell {
		min-width: 0;
	}
}

@media (min-width: 1024px) {
	.iw-gal--hybrid.iw-gal--bd-slider .iw-gal__carousel-track--hybrid {
		display: flex;
		flex-wrap: nowrap;
		gap: 10px;
		overflow-x: auto;
		scroll-behavior: smooth;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 4px 0 12px;
	}

	.iw-gal--hybrid.iw-gal--bd-slider .iw-gal__carousel-track--hybrid::-webkit-scrollbar {
		display: none;
		height: 0;
	}

	.iw-gal--hybrid.iw-gal--bd-slider .iw-gal__carousel-track--hybrid .iw-gal__cell {
		flex: 0 0 calc(25% - 8px);
		scroll-snap-align: center;
	}

	.iw-gal--hybrid.iw-gal--bd-slider .iw-gal__carousel-viewport {
		overflow: hidden;
	}

	.iw-gal--hybrid.iw-gal--bd-slider .iw-gal__carousel-btn {
		display: flex !important;
	}

	.iw-gal--hybrid.iw-gal--bd-grid .iw-gal__carousel-viewport {
		overflow: visible;
		margin: 0;
	}

	.iw-gal--hybrid.iw-gal--bd-grid .iw-gal__carousel-track--hybrid {
		display: grid;
		grid-template-columns: repeat(var(--iw-gal-cols-desktop, 4), minmax(0, 1fr));
		gap: 12px;
		overflow-x: visible;
		scroll-snap-type: none;
		padding: 0 0 12px;
	}

	.iw-gal--hybrid.iw-gal--bd-grid .iw-gal__carousel-track--hybrid .iw-gal__cell {
		min-width: 0;
	}
}

/**
 * Lightbox caption bar (GLightbox “description” slot): translucent black, white text.
 */
body.glightbox-open .glightbox-clean .gslide-description {
	background: transparent !important;
	padding-bottom: 1rem !important;
}

body.glightbox-open .glightbox-clean .gslide-title {
	display: none !important;
}

body.glightbox-open .glightbox-clean .gslide-desc {
	margin: 0 auto;
	max-width: 100%;
	padding: 0.65rem 0.9rem !important;
	background: rgba(0, 0, 0, 0.55) !important;
	color: #fff !important;
	font-size: 0.9375rem;
	line-height: 1.45;
	border-radius: 4px;
}

body.glightbox-open .glightbox-clean .gslide-desc a {
	color: #fff !important;
	font-weight: 600;
}

/**
 * GLightbox “clean” skin (default): below 769px prev/next are positioned at top:-100% (off-screen).
 */
@media (max-width: 768px) {
	.glightbox-clean .gprev:not(.glightbox-button-hidden),
	.glightbox-clean .gnext:not(.glightbox-button-hidden) {
		position: fixed !important;
		top: 50% !important;
		transform: translateY(-50%) !important;
		width: 44px !important;
		height: 44px !important;
		z-index: 1000010 !important;
		display: flex !important;
		opacity: 1 !important;
	}

	.glightbox-clean .gprev:not(.glightbox-button-hidden) {
		left: 6px !important;
		right: auto !important;
	}

	.glightbox-clean .gnext:not(.glightbox-button-hidden) {
		right: 6px !important;
		left: auto !important;
	}
}
