/* Gallery Section (Bear Sister)
   Uses lightGallery for the popup, but styles the grid responsively.
*/

.c-gallery {
	user-select: text;
}

.gallery-wrap {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 18px;
}

.gallery-head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin-bottom: 14px;
}

.gallery-title {
	font-family: 'UbuntuCondensed', sans-serif;
	font-weight: 600;
	font-size: calc(var(--basicFontSize) * 0.75);
	line-height: 1.05;
	color: var(--textColor);
}

.gallery-sub {
	font-family: 'UbuntuCondensed', sans-serif;
	font-size: calc(var(--basicFontSize) * 0.45);
	line-height: 1.25;
	opacity: 0.9;
}

.gallery-grid {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	grid-auto-rows: clamp(120px, 18vw, 230px);
	grid-auto-flow: dense;
}

.gallery-grid .g-item {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 14px;
	box-shadow: 0px 8px 22px rgba(0, 0, 0, 0.28);
	transform: translateZ(0);
}

.gallery-grid .g-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: saturate(1.02) contrast(1.03);
	transition: transform 380ms ease, filter 380ms ease;
}

.gallery-grid .g-item::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0,0,0,0.28), rgba(0,0,0,0));
	opacity: 0;
	transition: opacity 380ms ease;
}

/* Only animate on devices that actually have hover */
@media (hover: hover) and (pointer: fine) {
	.gallery-grid .g-item:hover img {
		transform: scale(1.06);
		filter: saturate(1.08) contrast(1.06);
	}
	.gallery-grid .g-item:hover::after {
		opacity: 1;
	}
}

.gallery-grid .g-tall {
	grid-row: span 2;
}

/* Mobile: more Luft, weniger Höhe */
@media (max-width: 768px) {
	.gallery-wrap {
		padding: 14px;
	}
	.gallery-grid {
		gap: 8px;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: 140px;
	}
	.gallery-title {
		font-size: calc(var(--basicFontSize) * 0.62);
	}
	.gallery-sub {
		font-size: calc(var(--basicFontSize) * 0.40);
	}
}

/* Very small phones */
@media (max-width: 420px) {
	.gallery-grid {
		grid-auto-rows: 120px;
	}
}
/* Saubere Section-Trennung */
.section-block {
    position: relative;
    width: 100%;
    clear: both;
    padding: 80px 20px;
    box-sizing: border-box;
}

/* Abstand zwischen Programm und Gallery */
#programm {
    margin-bottom: 120px;
}

#gallery {
    margin-top: 0;
}
