/* Lightweight infinite map slider (Divi-friendly). */

.rt-map-slider,
.rt-map-slider * {
	box-sizing: border-box;
}

.rt-map-slider__empty {
	margin: 0.75rem 0;
	font-size: 0.95rem;
	color: #5c6b7f;
	text-align: center;
}

.rt-map-slider {
	--rtms-gap: clamp(10px, 1.8vw, 16px);
	--rtms-slide-max: 220px;
	width: 100%;
	max-width: 100%;
	margin: 0 0 1.5rem;
	overflow: hidden;
	overflow-x: hidden !important;
	position: relative;
	contain: layout paint;
	isolation: isolate;
	touch-action: pan-y;
	overscroll-behavior-x: none;
}

.rt-map-slider__viewport {
	width: 100%;
	max-width: 100%;
	overflow: hidden;
	overflow-x: hidden;
	position: relative;
	touch-action: pan-y;
	overscroll-behavior-x: none;
	/* Slide widths use cqi so they follow the column, not the whole viewport. */
	container-type: inline-size;
	container-name: rtms;
}

.rt-map-slider__track {
	display: inline-flex;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: var(--rtms-gap);
	width: auto;
	will-change: transform;
	max-width: none;
}

.rt-map-slider__slide {
	display: flex;
	flex-direction: column;
	flex: 0 0 min(var(--rtms-slide-max), calc(100vw - 2.5rem));
	width: min(var(--rtms-slide-max), calc(100vw - 2.5rem));
	min-width: 0;
	max-width: min(var(--rtms-slide-max), calc(100vw - 2.5rem));
	gap: 0.45rem;
}

@supports (width: 1cqi) {
	.rt-map-slider__slide {
		flex: 0 0 min(94cqi, var(--rtms-slide-max));
		width: min(94cqi, var(--rtms-slide-max));
		max-width: min(94cqi, var(--rtms-slide-max));
	}
}

.rt-map-slider__media {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 11;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid #d9e2ef;
	background: #e8eaef;
	box-shadow: 0 3px 12px rgba(15, 23, 42, 0.08);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.rt-map-slider__media:hover {
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(15, 23, 42, 0.14);
}

.rt-map-slider__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.rt-map-slider__title {
	margin: 0;
	min-height: 2.8em;
	padding: 0 2px;
	font-size: clamp(0.8rem, 1.6vw, 0.95rem);
	font-weight: 600;
	line-height: 1.35;
	text-align: center;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	overflow-wrap: anywhere;
	word-break: normal;
}

.rt-map-slider__title a {
	color: #cc6600;
	text-decoration: none;
}

.rt-map-slider__title a:hover,
.rt-map-slider__title a:focus {
	color: #b35400;
	text-decoration: underline;
}

@supports (width: 1cqi) {
	@container rtms (min-width: 520px) {
		.rt-map-slider__slide {
			flex: 0 0 min(calc((100cqi - var(--rtms-gap)) / 2), var(--rtms-slide-max));
			width: min(calc((100cqi - var(--rtms-gap)) / 2), var(--rtms-slide-max));
			max-width: min(calc((100cqi - var(--rtms-gap)) / 2), var(--rtms-slide-max));
		}
	}

	@container rtms (min-width: 820px) {
		.rt-map-slider__slide {
			flex: 0 0 min(calc((100cqi - 2 * var(--rtms-gap)) / 3), var(--rtms-slide-max));
			width: min(calc((100cqi - 2 * var(--rtms-gap)) / 3), var(--rtms-slide-max));
			max-width: min(calc((100cqi - 2 * var(--rtms-gap)) / 3), var(--rtms-slide-max));
		}
	}
}

@media (max-width: 1024px) {
	.rt-map-slider {
		--rtms-gap: 12px;
	}
}

/* Permanent page-level guard (enabled only when shortcode adds class via JS). */
html.rt-map-slider-lock-x,
body.rt-map-slider-lock-x {
	overflow-x: hidden !important;
	max-width: 100%;
}

/* Divi/Theme containers: hard-stop slider from expanding outside column width */
.et_pb_column .rt-map-slider,
.et_pb_column .rt-map-slider__viewport,
.et_pb_module .rt-map-slider,
.et_pb_module .rt-map-slider__viewport {
	width: 100% !important;
	max-width: 100% !important;
	overflow-x: hidden !important;
}
