/**
 * Gallery template styles.
 *
 * Uses theme.json tokens:
 *   --wp--preset--color--theme-03 = #01666C (teal)
 *   --wp--preset--color--theme-06 = #FFEEEB (pink)
 *   --wp--preset--color--theme-07 = #448083 (lighter teal)
 *   --wp--preset--font-family--dm-sans
 */

/* ─── Hero gradient overlay ─── */
.gallery-hero .wp-block-cover__background {
	background: linear-gradient( 267deg, rgba( 5, 23, 9, 0 ) 10%, rgba( 0, 0, 0, 0.48 ) 95% ) !important;
	opacity: 1 !important;
}

/* ─── Filter tabs ─── */
.gallery-tabs {
	max-width: 1600px;
	margin: 0 auto var(--wp--preset--spacing--50);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}

.gallery-tabs::-webkit-scrollbar {
	display: none;
}

.gallery-tabs__list {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20);
}

.gallery-tabs__tab {
	font-family: var(--wp--preset--font-family--dm-sans);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 500;
	letter-spacing: var(--wp--custom--letter-spacing--wide);
	line-height: var(--wp--custom--line-height--normal);
	text-transform: uppercase;
	color: var(--wp--preset--color--theme-03);
	background: none;
	border: none;
	cursor: pointer;
	padding: var(--wp--custom--spacing--12) var(--wp--preset--spacing--30);
	border-radius: 0;
	transition: background-color 0.3s ease, border-radius 0.3s ease;
}

.gallery-tabs__tab:hover {
	background-color: color-mix(in srgb, var(--wp--preset--color--theme-06) 50%, transparent);
	border-radius: var(--wp--custom--border--rounded-full);
}

.gallery-tabs__tab.is-active {
	background-color: var(--wp--preset--color--theme-06);
	border-radius: var(--wp--custom--border--rounded-full);
}

.gallery-tabs__tab:focus-visible {
	outline: 2px solid var(--wp--preset--color--theme-03);
	outline-offset: 2px;
	border-radius: var(--wp--custom--border--rounded-full);
}

/* ─── Gallery grid ─── */
.gallery-grid {
	max-width: 1600px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wp--preset--spacing--40);
}

.gallery-grid__empty {
	grid-column: 1 / -1;
	text-align: center;
	font-family: var(--wp--preset--font-family--dm-sans);
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--theme-03);
	padding: var(--wp--preset--spacing--60) 0;
}

/* ─── Before/After card ─── */
.gallery-card {
	position: relative;
	cursor: pointer;
}

.gallery-card__images {
	position: relative;
	display: flex;
	aspect-ratio: 16 / 9;
	overflow: hidden;
}

.gallery-card__before {
	flex: 0 0 44%;
	overflow: hidden;
}

.gallery-card__after {
	flex: 1;
	overflow: hidden;
}

.gallery-card__before img,
.gallery-card__after img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.gallery-card__placeholder {
	width: 100%;
	height: 100%;
	background-color: #b7b7b7;
}

.gallery-card__after .gallery-card__placeholder {
	background-color: #e1e1e1;
}

/* Divider line between before and after */
.gallery-card__divider {
	position: absolute;
	top: 0;
	left: 44%;
	width: 2px;
	height: 100%;
	background-color: var(--wp--preset--color--theme-01, #fdfaf4);
	z-index: 1;
}

/* ─── Before/After labels ─── */
.gallery-card__labels {
	display: flex;
	position: absolute;
	bottom: 12px;
	left: 44%;
	transform: translateX(-50%);
	background: #fff;
	padding: 4px 12px;
	gap: 24px;
	z-index: 2;
}

.gallery-card__label {
	font-family: var(--wp--preset--font-family--dm-sans);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 2.73px;
	line-height: 22px;
	text-transform: uppercase;
	color: #000;
}

/* ─── Load More button ─── */
.gallery-load-more {
	max-width: 1600px;
	margin: var(--wp--preset--spacing--60) auto;
	text-align: center;
}

.gallery-load-more__btn {
	font-family: var(--wp--preset--font-family--dm-sans);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 700;
	letter-spacing: var(--wp--custom--letter-spacing--cta);
	line-height: var(--wp--custom--line-height--double);
	text-transform: uppercase;
	color: var(--wp--preset--color--theme-07);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	position: relative;
}

.gallery-load-more__btn::after {
	content: '';
	display: block;
	width: 100%;
	height: 1px;
	background-color: var(--wp--preset--color--theme-07);
	margin-top: 2px;
}

.gallery-load-more__btn:hover {
	opacity: 0.7;
}

.gallery-load-more__btn.is-loading {
	opacity: 0.5;
	pointer-events: none;
}

.gallery-load-more__btn.is-hidden {
	display: none;
}

/* ─── Responsive ─── */
@media (max-width: 1200px) {
	.gallery-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--wp--preset--spacing--30);
		margin-left: var(--wp--preset--spacing--40);
		margin-right: var(--wp--preset--spacing--40);
	}

	.gallery-tabs {
		margin-left: var(--wp--preset--spacing--40);
		margin-right: var(--wp--preset--spacing--40);
	}
}

@media (max-width: 768px) {
	.gallery-grid {
		grid-template-columns: 1fr;
	}

	.gallery-tabs__list {
		gap: var(--wp--custom--spacing--8);
	}

	.gallery-tabs__tab {
		font-size: var(--wp--preset--font-size--small);
		letter-spacing: var(--wp--custom--letter-spacing--cta);
		padding: var(--wp--custom--spacing--8) var(--wp--custom--spacing--16);
	}

	.gallery-card__images {
		aspect-ratio: 4 / 3;
	}
}
