/* Lekkerboats Instagram Reels - frontend
 *
 * Volledig responsive. Het aantal kolommen (--lbir-columns) geldt op grote
 * schermen; daaronder schaalt de grid automatisch mee dankzij een minimale
 * kaartbreedte (--lbir-min). Gaten en hoeken schalen vloeiend met clamp().
 */

.lbir-grid {
	--lbir-columns: 4;            /* overschreven via inline-style uit shortcode */
	--lbir-min: 200px;           /* minimale kaartbreedte voordat er kolommen afvallen */
	display: grid;
	grid-template-columns: repeat(
		var(--lbir-columns),
		minmax(0, 1fr)
	);
	gap: clamp(8px, 1.5vw, 16px);
	width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
}

/* Desktop: niet vastpinnen op 1100px, maar 80% van de breedte gebruiken. */
@media (min-width: 1025px) {
	.lbir-grid {
		max-width: 80%;
	}
}

/* Vanaf tablet en kleiner: horizontale swipe-slider i.p.v. grid.
   Scroll-snap zorgt dat elke reel netjes "inklikt"; de "peek" van de
   volgende kaart maakt duidelijk dat er doorgeswipet kan worden. */
@media (max-width: 1024px) {
	.lbir-grid {
		display: flex;
		align-items: flex-start;            /* behoud 9:16, niet uitrekken */
		grid-template-columns: none;        /* grid uitschakelen */
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		scroll-padding-left: clamp(12px, 4vw, 24px);
		-webkit-overflow-scrolling: touch;  /* soepel scrollen op iOS */
		/* Padding aan de zijkanten zodat de eerste/laatste reel niet plakt. */
		padding-inline: clamp(12px, 4vw, 24px);
		scroll-snap-align: none;
	}

	.lbir-card {
		flex: 0 0 var(--lbir-slide, 42%);   /* breedte per slide */
		scroll-snap-align: start;
	}

	/* Scrollbar volledig verbergen (swipen/scrollen blijft gewoon werken). */
	.lbir-grid {
		scrollbar-width: none;              /* Firefox */
		-ms-overflow-style: none;           /* oude Edge/IE */
	}
	.lbir-grid::-webkit-scrollbar {
		display: none;                      /* Chrome/Safari */
	}
}

.lbir-card {
	position: relative;
	display: block;
	aspect-ratio: 9 / 16;          /* verticaal, zoals een Reel */
	border-radius: clamp(8px, 1.2vw, 14px);
	overflow: hidden;
	background: #000;
	box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
	transition: transform .25s ease, box-shadow .25s ease;
}

/* Hover-effect alleen op apparaten met een echte muis. */
@media (hover: hover) {
	.lbir-card:hover {
		transform: translateY(-4px);
		box-shadow: 0 10px 24px rgba(0, 0, 0, 0.20);
	}
}

.lbir-video,
.lbir-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.lbir-badge {
	position: absolute;
	top: clamp(6px, 1vw, 10px);
	right: clamp(6px, 1vw, 10px);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: clamp(22px, 3vw, 26px);
	height: clamp(22px, 3vw, 26px);
	background: rgba(0, 0, 0, 0.55);
	color: #fff;
	font-size: clamp(10px, 1.4vw, 12px);
	border-radius: 50%;
	backdrop-filter: blur(2px);
}

.lbir-empty {
	text-align: center;
	color: #777;
	font-style: italic;
}

/* Slide-breedtes per scherm (regelen hoeveel reels je tegelijk ziet,
   inclusief een "peek" van de volgende). */

/* Tablet: ~3 reels in beeld. */
@media (max-width: 1024px) {
	.lbir-grid {
		--lbir-slide: 30%;
	}
}

/* Kleine tablet: ~2,5 reels in beeld. */
@media (max-width: 768px) {
	.lbir-grid {
		--lbir-slide: 40%;
	}

	/* Play-icoontje verbergen op mobiel. */
	.lbir-badge {
		display: none;
	}
}

/* Telefoon: ~1,8 reels in beeld (duidelijke peek). */
@media (max-width: 480px) {
	.lbir-grid {
		--lbir-slide: 58%;
		gap: 10px;
	}
}

/* Zeer smal: ~1,2 reel in beeld. */
@media (max-width: 360px) {
	.lbir-grid {
		--lbir-slide: 80%;
	}
}

/* Respecteer voorkeur voor minder beweging. */
@media (prefers-reduced-motion: reduce) {
	.lbir-card {
		transition: none;
	}
}
