.fpg-gallery {
	width: 100%;
	max-width: 1130px;
	margin: 0 auto;
	--fpg-unit-size: 90px;
}

.fpg-gallery__canvas {
	width: 100%;
}

.fpg-gallery__row {
	display: grid;
	grid-template-columns: repeat(12, minmax(0, 1fr));
	gap: 8px;
	margin-bottom: 8px;
	height: calc(var(--fpg-unit-size) * var(--fpg-height-units));
}

.fpg-gallery__row:last-child {
	margin-bottom: 0;
}

.fpg-gallery__tile {
	position: relative;
	display: block;
	grid-column: span var(--fpg-span);
	overflow: hidden;
	color: #fff;
	text-decoration: none;
	background: #111;
}

.fpg-gallery__tile:focus-visible {
	outline: 3px solid #fff;
	outline-offset: -3px;
}

.fpg-gallery__image,
.fpg-gallery__overlay {
	position: absolute;
	inset: 0;
}

.fpg-gallery__image {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	filter: saturate(0.9);
	transform: scale(1.01);
	transition: transform 220ms ease;
}

.fpg-gallery__tile:hover .fpg-gallery__image,
.fpg-gallery__tile:focus-visible .fpg-gallery__image {
	transform: scale(1.05);
}

.fpg-gallery__overlay {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 4px;
	padding: 20px 18px;
	text-align: right;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.02) 60%, rgba(0, 0, 0, 0.86) 100%);
	transition: background 160ms ease-out;
}

.fpg-gallery__meta {
	display: flex;
	flex-direction: column;
	gap: 4px;
	transform: translateY(0);
	transition: transform 160ms ease-out;
}

.fpg-gallery__editor {
	display: block;
	font-size: 13px;
	line-height: 1.35;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.6);
}

.fpg-gallery__title {
	display: block;
	font-size: clamp(18px, 2vw, 22px);
	line-height: 1.08;
	font-weight: 700;
	text-shadow: 0 1px 2px rgba(0, 0, 0, 0.7);
}

.fpg-gallery__details {
	display: flex;
	flex-direction: column;
	gap: 10px;
	opacity: 0;
	max-height: 0;
	overflow: hidden;
	transform: translateY(10px);
	pointer-events: none;
	transition: opacity 500ms ease-out, transform 500ms ease-out, max-height 500ms ease-out;
}

.fpg-gallery__excerpt {
	font-size: 13px;
	line-height: 1.5;
	max-height: 4.5em;
	overflow: hidden;
}

.fpg-gallery__cta {
	align-self: flex-end;
	padding: 6px 18px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.9);
	font-size: 13px;
	line-height: 1.4;
	font-weight: 400;
	background: transparent;direction: rtl;
}

.fpg-gallery__tile:hover .fpg-gallery__overlay,
.fpg-gallery__tile:focus-visible .fpg-gallery__overlay {
	background: rgba(0, 0, 0, 0.75);
}

.fpg-gallery__tile:hover .fpg-gallery__meta,
.fpg-gallery__tile:focus-visible .fpg-gallery__meta {
	transform: translateY(-8px);
}

.fpg-gallery__tile:hover .fpg-gallery__details,
.fpg-gallery__tile:focus-visible .fpg-gallery__details {
	opacity: 1;
	max-height: 180px;
	transform: translateY(0);
	pointer-events: auto;
}

@media (max-width: 767px) {
	.fpg-gallery__row {
		display: flex;
		flex-direction: column;
		gap: 8px;
		height: auto;
	}

	.fpg-gallery__tile {
		min-height: 220px;
	}

	.fpg-gallery__tile::before {
		content: '';
		display: block;
		padding-top: 62%;
	}

	.fpg-gallery__editor {
		font-size: 12px;
	}

	.fpg-gallery__title {
		font-size: 20px;
	}
}
