/**
 * Block: Галерея работ (горизонтальный слайдер, scroll-snap)
 */

.gallery-block__title {
	font-family: var(--font-serif);
	font-weight: 300;
	font-size: clamp(1.5rem, 4vw, 2.5rem);
	line-height: 1.2;
	margin: 0 0 0.5rem;
	color: rgb(var(--color-primary));
}

.gallery-block__subtitle {
	margin: 0 0 1.5rem;
	font-size: 1rem;
	color: rgb(var(--color-primary) / 0.8);
}

.gallery-block__scroll-wrap {
	overflow-x: auto;
	overflow-y: hidden;
	-webkit-overflow-scrolling: touch;
	scroll-snap-type: x mandatory;
	margin-left: calc(-1 * var(--container-padding-x));
	margin-right: calc(-1 * var(--container-padding-x));
	padding-left: var(--container-padding-x);
	padding-right: var(--container-padding-x);
	padding-bottom: 0.5rem;
}

.gallery-block__list {
	display: flex;
	gap: 1rem;
	list-style: none;
	margin: 0;
	padding: 0;
	width: max-content;
	min-width: 100%;
}

.gallery-block__item {
	flex: 0 0 auto;
	scroll-snap-align: start;
	width: 280px;
}

@media (min-width: 640px) {
	.gallery-block__item {
		width: 320px;
	}
}

.gallery-block__card {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
	border-radius: 8px;
	overflow: hidden;
	transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.gallery-block__card:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 28px -8px rgb(0 0 0 / 0.3);
}

.gallery-block__card-image-wrap {
	position: relative;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: rgb(var(--color-surface));
}

.gallery-block__card-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease-out;
}

.gallery-block__card:hover .gallery-block__card-image {
	transform: scale(1.05);
}

.gallery-block__card-placeholder {
	display: block;
	width: 100%;
	height: 100%;
	background: rgb(var(--color-line));
}

.gallery-block__card-title {
	display: block;
	padding: 1rem 1rem 0.25rem;
	font-family: var(--font-serif);
	font-size: 1.125rem;
	font-weight: 400;
	color: rgb(var(--color-primary));
}

.gallery-block__card-btn {
	display: inline-block;
	margin: 0 1rem 1rem;
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgb(var(--color-accent));
	transition: color var(--transition-base);
}

.gallery-block__card:hover .gallery-block__card-btn {
	color: rgb(var(--color-primary));
}

.gallery-block__footer {
	margin: 2rem 0 0;
	text-align: center;
}

.gallery-block__portfolio-link {
	font-size: 0.875rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: rgb(var(--color-accent));
}

.gallery-block__portfolio-link:hover {
	opacity: 0.9;
}

.gallery-block__empty {
	color: rgb(var(--color-primary) / 0.7);
}
