/**
 * Trip-aware listing detail blocks (mockup: rmr-mockups/listing-detail.html).
 */

/* Pills on listing pages (rmr-trip-match.css is not loaded here; vars live under .rmr-my-trips only). */
.rmr-listing-detail-pills {
	--rmr-coral: var(--e-global-color-accent, #e5577a);
	--rmr-navy: var(--e-global-color-primary, #0a1a3b);
	--rmr-peri-2: var(--e-global-color-38b03de, #e9ecf9);
}

.rmr-pill {
	display: inline-flex;
	align-items: center;
	padding: 5px 11px;
	border-radius: 999px;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	line-height: 1.2;
}

.rmr-listing-trip-badge {
	margin-bottom: 10px;
}

.rmr-listing-detail-pills .rmr-pill--coral,
.rmr-listing-trip-badge.rmr-pill--coral {
	background: var(--rmr-coral);
	color: #fff;
	border: 1px solid transparent;
}

.rmr-listing-detail-pills .rmr-pill--navy,
.rmr-listing-trip-badge.rmr-pill--navy {
	background: var(--rmr-navy);
	color: #fff;
	border: 1px solid var(--rmr-navy, #0a1a3b);
}

.rmr-listing-detail-pills .rmr-pill--soft {
	background: var(--rmr-peri-2);
	color: var(--rmr-navy);
	border: 1px solid transparent;
}

.rmr-listing-stat-bar {
	display: grid;
	grid-template-columns: repeat(var(--rmr-stat-cols, 5), minmax(0, 1fr));
	border: 1px solid var(--line, #e2e8f0);
	border-radius: var(--rb-radius-m, 12px);
	background: #fff;
	overflow: hidden;
	margin: 0 0 24px;
}

.rmr-listing-stat-bar__cell {
	padding: 18px 20px;
	border-right: 1px solid var(--line, #e2e8f0);
}

.rmr-listing-stat-bar__cell:last-child {
	border-right: 0;
}

.rmr-listing-stat-bar small {
	display: block;
	font-size: 0.72rem;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--mute, #64748b);
	margin-bottom: 6px;
}

.rmr-listing-stat-bar b {
	font-size: 1.6rem;
	font-weight: 800;
	color: var(--navy, #0a1a3b);
	display: block;
	line-height: 1.1;
}

.rmr-listing-stat-bar .sub {
	font-size: 0.82rem;
	color: var(--mute, #64748b);
	margin-top: 4px;
	font-weight: 500;
}

.rmr-listing-collection__lead,
.rmr-listing-compat__lead {
	color: var(--mute, #64748b);
	margin: 0 0 14px;
	font-size: 0.95rem;
}

.rmr-listing-mini-map {
	--rmr-collection-pin: var(--e-global-color-primary, var(--rmr-navy, #0a1a3b));
	position: relative;
	aspect-ratio: 16 / 9;
	min-height: 180px;
	border-radius: var(--rb-radius-m, 12px);
	background:
		radial-gradient(circle at 50% 48%, color-mix(in srgb, var(--rmr-collection-pin) 14%, transparent) 0%, transparent 48%),
		linear-gradient(135deg, #eef1f6 0%, #e2e8f0 100%);
	margin-bottom: 14px;
	overflow: hidden;
	border: 1px solid var(--line, #e2e8f0);
}

.rmr-listing-mini-map--has-tiles {
	background: var(--line, #e2e8f0);
}

.rmr-listing-mini-map__tiles {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}

.rmr-listing-mini-map__pin {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -100%);
	z-index: 2;
	line-height: 0;
	pointer-events: none;
	filter: drop-shadow(0 4px 10px color-mix(in srgb, var(--rmr-collection-pin) 35%, transparent));
}

/* Override Voxel commons :where(path) { fill: inherit } */
.rmr-listing-mini-map .rmr-map-pin-icon {
	display: block;
	width: 44px;
	height: auto;
}

.rmr-listing-mini-map .rmr-map-pin-icon__body {
	fill: var(--rmr-collection-pin);
}

.rmr-listing-mini-map .rmr-map-pin-icon__hole {
	fill: #fff;
}

.rmr-listing-mini-map__caption {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 3;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 14px;
	background: rgba(10, 26, 59, 0.92);
	color: #fff;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.02em;
}

.rmr-listing-mini-map__attrib {
	color: rgba(255, 255, 255, 0.75);
	font-size: 0.7rem;
	font-weight: 500;
	text-decoration: none;
	white-space: nowrap;
}

.rmr-listing-mini-map__attrib:hover {
	color: #fff;
	text-decoration: underline;
}

.rmr-listing-collection__callout {
	margin-top: 0;
	padding: 12px 14px;
	background: var(--cloud, #f4f7fb);
	border-radius: var(--rb-radius-s, 8px);
	font-size: 0.92rem;
	color: var(--mute, #64748b);
}

.rmr-listing-collection__callout b {
	color: var(--navy, #0a1a3b);
}

.rmr-listing-collection__trip-link {
	display: inline-block;
	margin-left: 6px;
	color: var(--action, #2447ff);
	font-weight: 600;
	text-decoration: none;
}

.rmr-listing-collection__trip-link:hover {
	text-decoration: underline;
}

.rmr-listing-compat-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 12px;
}

.rmr-compat-chip {
	display: inline-block;
	padding: 6px 12px;
	border-radius: 999px;
	font-size: 0.85rem;
	background: #fff;
	border: 1px solid var(--line, #e2e8f0);
	color: var(--navy, #0a1a3b);
}

.rmr-compat-chip.is-match {
	background: rgba(42, 157, 110, 0.12);
	border-color: #2a9d6e;
	font-weight: 600;
}

.rmr-listing-compat__foot {
	font-size: 0.88rem;
	color: var(--mute, #64748b);
	margin: 0;
}

.rmr-listing-compat__foot a {
	color: var(--action, #2447ff);
	font-weight: 600;
	text-decoration: none;
}

.rmr-listing-compat__foot a:hover {
	text-decoration: underline;
}

.rmr-listing-trip-booking {
	display: flex;
	align-items: baseline;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0 0 8px;
	padding: 0;
}

.rmr-listing-trip-booking__lead {
	margin: 0;
	font-size: 0.82rem;
	line-height: 1.4;
	color: var(--mute, #64748b);
}

.rmr-listing-trip-booking__link {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--action, #2447ff);
	text-decoration: none;
	white-space: nowrap;
}

.rmr-listing-trip-booking__link:hover {
	text-decoration: underline;
}


/* Elementor editor / preview placeholders (heavy shortcodes skipped) */
.rmr-listing-editor-placeholder {
	margin: 0 0 16px;
	padding: 16px;
	border: 2px dashed var(--line, #e2e8f0);
	border-radius: var(--rb-radius-m, 12px);
	background: var(--cloud, #f4f7fb);
	text-align: center;
}

.rmr-listing-editor-placeholder span {
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--mute, #64748b);
}

/* Collapsible trip blocks (mobile); always expanded on desktop */
.rmr-listing-fold {
	display: block;
	margin: 0 0 16px;
	border: 1px solid var(--line, #e2e8f0);
	border-radius: var(--rb-radius-m, 12px);
	background: #fff;
	overflow: hidden;
}

.rmr-listing-fold__summary {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 14px 16px;
	cursor: pointer;
	list-style: none;
	font-weight: 700;
	color: var(--navy, #0a1a3b);
	user-select: none;
}

.rmr-listing-fold__summary::-webkit-details-marker {
	display: none;
}

.rmr-listing-fold__summary::after {
	content: "";
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	border-right: 2px solid var(--mute, #64748b);
	border-bottom: 2px solid var(--mute, #64748b);
	transform: rotate(45deg);
	transition: transform 0.15s ease;
	margin-right: 4px;
}

.rmr-listing-fold[open] > .rmr-listing-fold__summary::after {
	transform: rotate(-135deg);
	margin-top: 4px;
}

.rmr-listing-fold__panel {
	padding: 0 16px 16px;
}

.rmr-listing-fold__panel > .lr-section {
	margin: 0;
	padding: 0;
	border: 0;
}

.rmr-listing-fold--fit > .rmr-listing-fold__panel > .rmr-fit-panel {
	margin-bottom: 0;
}

.rmr-listing-trip-secondary {
	margin: 0 0 24px;
}

.rmr-listing-booking-anchor {
	scroll-margin-top: 72px;
}

body.admin-bar .rmr-listing-booking-anchor {
	scroll-margin-top: 96px;
}

/* Voxel sticky booking sidebar (desktop) — see Voxel tab on sidebar container */
@media (min-width: 1024px) {
	.rmr-listing-fold > .rmr-listing-fold__summary {
		display: none;
	}

	/* Panel visibility requires [open] on <details> — set in listing-detail.js */
	.rmr-listing-fold[open] > .rmr-listing-fold__panel {
		display: block;
	}

	.rmr-listing-fold {
		border: 0;
		border-radius: 0;
		background: transparent;
		margin-bottom: 24px;
		overflow: visible;
	}

	.rmr-listing-fold__panel {
		padding: 0;
	}

	/*
	 * Voxel container sticky (Voxel tab → Sticky position) on the booking sidebar.
	 * Grid/flex parents default to align-items: stretch, which gives the sticky
	 * container the full row height and prevents position:sticky from engaging.
	 */
	body.single-products .e-grid > .e-con:has(.ts-product-form),
	body.single-products .e-grid > .e-con:has(.elementor-widget-ts-product-form) {
		align-self: start;
		max-height: calc(100dvh - 32px);
		overflow-y: auto;
		overscroll-behavior: contain;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: thin;
	}

	body.admin-bar.single-products .e-grid > .e-con:has(.ts-product-form),
	body.admin-bar.single-products .e-grid > .e-con:has(.elementor-widget-ts-product-form) {
		max-height: calc(100dvh - 64px);
	}
}

/* Mobile sticky book CTA (trip context only) */
.rmr-listing-mobile-cta {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 999;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	padding: 10px 16px max(10px, env(safe-area-inset-bottom));
	background: rgba(255, 255, 255, 0.96);
	border-top: 1px solid var(--line, #e2e8f0);
	box-shadow: 0 -6px 24px rgba(10, 26, 59, 0.1);
	backdrop-filter: blur(8px);
}

.rmr-listing-mobile-cta[hidden] {
	display: none !important;
}

.rmr-listing-mobile-cta__price {
	font-size: 1.1rem;
	font-weight: 800;
	color: var(--navy, #0a1a3b);
	white-space: nowrap;
}

.rmr-listing-mobile-cta__btn {
	flex: 1;
	max-width: 220px;
	margin-left: auto;
	padding: 12px 18px;
	border: 0;
	border-radius: 999px;
	background: var(--e-global-color-primary, #0a1a3b);
	color: #fff;
	font-size: 0.95rem;
	font-weight: 700;
	cursor: pointer;
}

body.rmr-listing-has-trip {
	--rmr-listing-cta-pad: 72px;
}

@media (max-width: 1023px) {
	body.rmr-listing-has-trip {
		padding-bottom: var(--rmr-listing-cta-pad, 72px);
	}

	.rmr-listing-mobile-cta {
		display: flex;
	}

	.rmr-listing-stat-bar {
		display: flex;
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x proximity;
		scrollbar-width: thin;
		margin-bottom: 16px;
	}

	.rmr-listing-stat-bar__cell {
		flex: 0 0 min(44vw, 168px);
		scroll-snap-align: start;
		border-right: 1px solid var(--line, #e2e8f0);
		border-bottom: 0;
		padding: 14px 16px;
	}

	.rmr-listing-stat-bar__cell:last-child {
		border-right: 0;
	}

	.rmr-listing-stat-bar b {
		font-size: 1.35rem;
	}

	.rmr-listing-trip-badge {
		margin-bottom: 8px;
	}

	.rmr-listing-mini-map {
		min-height: 140px;
	}

	.rmr-listing-fold--fit .rmr-fit-panel {
		padding: 16px;
		margin-bottom: 0;
	}

	/* When expanded on mobile, show only the active fit row to save height */
	.rmr-listing-fold--fit[open] .rmr-fit-panel__scale .rmr-fit-row:not(.is-active) {
		display: none;
	}
}

@media (min-width: 1024px) {
	.rmr-listing-mobile-cta {
		display: none !important;
	}
}

@media (max-width: 1023px) and (min-width: 768px) {
	.rmr-listing-stat-bar__cell {
		flex-basis: min(28vw, 180px);
	}
}
