/* ====================================================================
   Single tour /excursiones-moto-agua/{slug}/  — rediseño travel premium
   (boceto cliente 2026-05-07)
   ==================================================================== */

/* ---------------------------------------------------------------- */
/* 0. Wrapper "producto" — hero + galería miniaturas + card datos    */
/*    Las 3 piezas viven en un mismo container claro sand-50.        */
/* ---------------------------------------------------------------- */
.tour-product {
	background: var(--ijs-sand-50);
	/* padding-top respeta el header fijo (~81px) — mismo patrón que .zone-hero--compact */
	padding-block: clamp(92px, 11vh, 108px) clamp(2.5rem, 5vh, 4rem);
}

.tour-product__container {
	display: flex;
	flex-direction: column;
	gap: clamp(1rem, 2vw, 1.5rem);
}

/* ---------------------------------------------------------------- */
/* 1. Hero — contenido izq + foto dcha                              */
/* ---------------------------------------------------------------- */
.tour-hero {
	display: flex;
	flex-direction: column;
	gap: clamp(1rem, 2vw, 1.5rem);
}

.tour-hero__crumb {
	font-family: var(--ijs-font-body);
	font-size: 0.85rem;
	color: var(--ijs-ink-500);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
}

.tour-hero__crumb a {
	color: var(--ijs-ink-500);
	text-decoration: none;
}
.tour-hero__crumb a:hover,
.tour-hero__crumb a:focus-visible { color: var(--ijs-coral-700); text-decoration: underline; }
.tour-hero__crumb [aria-current="page"] {
	color: var(--ijs-navy-900);
	font-weight: 600;
}

.tour-hero__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1.5rem, 3vw, 2.5rem);
	align-items: stretch;
}

@media (min-width: 960px) {
	.tour-hero__grid {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
		gap: clamp(2rem, 4vw, 3.5rem);
	}
}

/* --- Columna principal (izq) --- */
.tour-hero__main {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: clamp(0.85rem, 1.6vw, 1.1rem);
}

.tour-hero__chip {
	display: inline-block;
	padding: 0.4em 1em;
	background: var(--ijs-turquoise-50);
	color: var(--ijs-turquoise-900);
	border-radius: 9999px;
	font-family: var(--ijs-font-body);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.tour-hero__title {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(2.75rem, 6.5vw + 0.5rem, 5.5rem);
	font-weight: 600;
	line-height: 0.92;
	letter-spacing: -0.035em;
	color: var(--ijs-navy-900);
	margin: 0;
	text-transform: uppercase;
}

.tour-hero__lead {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 72, "SOFT" 30;
	font-size: clamp(1.05rem, 0.5vw + 0.95rem, 1.25rem);
	font-style: italic;
	font-weight: 300;
	line-height: 1.4;
	color: var(--ijs-ink-900);
	margin: 0;
	max-width: 28rem;
}

.tour-hero__rating {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	font-family: var(--ijs-font-body);
	font-size: 0.95rem;
	color: var(--ijs-ink-500);
}

.tour-hero__stars {
	display: inline-flex;
	gap: 0.1rem;
	color: #F4B400;
}

.tour-hero__stars svg {
	width: 1.1em;
	height: 1.1em;
}

.tour-hero__rating-text strong { color: var(--ijs-navy-900); font-weight: 700; }

.tour-hero__usps {
	list-style: none;
	margin: 0.25rem 0 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0.85rem;
	width: 100%;
	max-width: 30rem;
}

@media (max-width: 560px) {
	.tour-hero__usps { grid-template-columns: repeat(2, 1fr); max-width: 22rem; }
}

.tour-hero__usp {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	text-align: center;
}

.tour-hero__usp-icon {
	width: 2.6rem;
	height: 2.6rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--ijs-turquoise-50);
	border-radius: 50%;
	color: var(--ijs-turquoise-600);
}

.tour-hero__usp-icon svg { width: 60%; height: 60%; }

.tour-hero__usp-label {
	font-family: var(--ijs-font-body);
	font-size: 0.78rem;
	line-height: 1.2;
	color: var(--ijs-ink-900);
}

/* Bloque "comprar": precio + CTA + nota.
   Desktop: una sola fila horizontal con precio izq y CTA+nota apilados a la dcha.
   Mobile: stack vertical. */
.tour-hero__buy {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 0.6rem;
	width: 100%;
}

@media (min-width: 700px) {
	.tour-hero__buy {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: 1.5rem;
		flex-wrap: wrap;
	}
}

/* DESDE en la izq · 256€ + /moto en la primera fila a la dcha · Antes 320€ debajo */
.tour-hero__pricing {
	display: grid;
	grid-template-columns: auto auto auto;
	column-gap: 0.4rem;
	row-gap: 0.15rem;
	align-items: baseline;
	flex-shrink: 0;
}

.tour-hero__pricing .tour-hero__price-eyebrow { grid-column: 1; grid-row: 1 / span 2; align-self: center; }
.tour-hero__pricing .tour-hero__price-amount  { grid-column: 2; grid-row: 1; }
.tour-hero__pricing .tour-hero__price-unit    { grid-column: 3; grid-row: 1; }
.tour-hero__pricing .tour-hero__price-before  { grid-column: 2 / span 2; grid-row: 2; margin-left: 0; }

.tour-hero__buy-action {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.3rem;
	min-width: 0;
}

@media (min-width: 700px) {
	/* CTA + nota descuento centrados horizontalmente y verticalmente respecto al bloque precio */
	.tour-hero__buy-action {
		align-items: center;
		text-align: center;
	}
}

.tour-hero__price-eyebrow {
	font-family: var(--ijs-font-body);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	color: var(--ijs-ink-500);
	text-transform: uppercase;
	margin-right: 0.25rem;
	align-self: center;
}

.tour-hero__price-amount {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 30;
	font-size: clamp(2.25rem, 3.5vw + 0.5rem, 3.25rem);
	font-weight: 600;
	line-height: 1;
	color: var(--ijs-coral-700);
	letter-spacing: -0.02em;
}

.tour-hero__price-currency { font-weight: 600; }

.tour-hero__price-unit {
	font-family: var(--ijs-font-body);
	font-size: 1rem;
	color: var(--ijs-ink-500);
	align-self: flex-end;
	padding-bottom: 0.35rem;
}

.tour-hero__price-before {
	font-family: var(--ijs-font-body);
	font-size: 0.95rem;
	color: var(--ijs-ink-500);
	text-decoration: line-through;
	margin-left: 0.4rem;
	align-self: center;
}

.tour-hero__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.9em 2rem;
	background: var(--ijs-turquoise-900);
	color: var(--ijs-white);
	font-family: var(--ijs-font-body);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
	border-radius: 9999px;
	box-shadow: 0 8px 20px -8px rgba(0, 85, 94, 0.5);
	transition: background 200ms ease, transform 200ms ease, box-shadow 200ms ease;
	white-space: nowrap;
}

/* Mobile: bloque buy centrado horizontalmente (precio + CTA + nota descuento). */
@media (max-width: 699px) {
	.tour-hero__buy {
		align-items: center;
		text-align: center;
	}
	.tour-hero__pricing {
		justify-content: center;
		width: max-content;
		max-width: 100%;
	}
	.tour-hero__pricing .tour-hero__price-before { justify-self: center; margin-left: 0; }
	.tour-hero__buy-action { align-items: center; width: 100%; }
	.tour-hero__cta { width: 100%; max-width: 22rem; }
	.tour-hero__cta-note { text-align: center; }
}

.tour-hero__cta:hover,
.tour-hero__cta:focus-visible {
	background: var(--ijs-navy-900);
	color: var(--ijs-white);
	transform: translateY(-1px);
	box-shadow: 0 12px 28px -10px rgba(11, 37, 69, 0.6);
}

.tour-hero__cta-note {
	font-family: var(--ijs-font-body);
	font-size: 0.8rem;
	color: var(--ijs-ink-500);
	margin: 0;
}

.tour-hero__cta-note strong {
	font-weight: 700;
	color: var(--ijs-coral-700);
	letter-spacing: 0.06em;
}

/* --- Columna media (dcha) — foto + chip avatares --- */
.tour-hero__media {
	position: relative;
	min-height: 24rem;
}

.tour-hero__figure {
	margin: 0;
	height: 100%;
	min-height: inherit;
	border-radius: 24px;
	overflow: hidden;
	box-shadow: 0 24px 48px -24px rgba(11, 37, 69, 0.3);
}

.tour-hero__photo {
	width: 100%;
	height: 100%;
	min-height: inherit;
	object-fit: cover;
	display: block;
}

.tour-hero__trust {
	position: absolute;
	right: 1rem;
	bottom: 1rem;
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.55rem 0.9rem 0.55rem 0.7rem;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 9999px;
	backdrop-filter: blur(8px);
	box-shadow: 0 8px 20px -8px rgba(11, 37, 69, 0.25);
	font-family: var(--ijs-font-body);
	font-size: 0.7rem;
	color: var(--ijs-navy-900);
	line-height: 1.2;
}

.tour-hero__trust-avatars { display: inline-flex; }
.tour-hero__avatar {
	width: 1.7rem;
	height: 1.7rem;
	border-radius: 50%;
	background: var(--bg, var(--ijs-turquoise-400));
	border: 2px solid var(--ijs-white);
	margin-right: -0.5rem;
}
.tour-hero__avatar:last-child { margin-right: 0; }

.tour-hero__trust-text { margin: 0; }

@media (max-width: 760px) {
	.tour-hero__media { min-height: 18rem; }
	.tour-hero__trust { font-size: 0.65rem; }
	.tour-hero__cta { max-width: 100%; }
}

/* ---------------------------------------------------------------- */
/* 1b. Galería miniaturas — tira debajo del hero                    */
/* ---------------------------------------------------------------- */
.tour-thumbs {
	display: grid;
	/* --n se inyecta inline por el shortcode (count thumbs + ver-todas).
	   Con N exacto cada thumb ocupa 1fr y no quedan huecos. */
	grid-template-columns: repeat(var(--n, 8), minmax(0, 1fr));
	gap: 0.65rem;
}

@media (max-width: 760px) {
	.tour-thumbs {
		/* Mobile: 4 cuadros en 1 fila = 3 thumbs reales + "Ver todas las fotos" */
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}
	/* Ocultar thumbs reales >= posición 4 para dejar sitio al botón "Ver todas".
	   El lightbox sigue mostrando todas las fotos al pulsarlo. */
	.tour-thumbs > .tour-thumb:nth-child(n+4):not(.tour-thumb--more) {
		display: none;
	}
}

.tour-thumb {
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	padding: 0;
	margin: 0;
	background: var(--ijs-sand-100);
	border: 2px solid transparent;
	border-radius: 14px;
	overflow: hidden;
	cursor: pointer;
	transition: border-color 200ms ease, transform 200ms ease;
}

.tour-thumb__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.tour-thumb:hover { transform: translateY(-2px); }
.tour-thumb:focus-visible {
	outline: 2px solid var(--ijs-turquoise-600);
	outline-offset: 2px;
}

.tour-thumb--more {
	background: var(--ijs-navy-900);
	color: var(--ijs-white);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.4rem;
	font-family: var(--ijs-font-body);
}

.tour-thumb__more-label {
	font-size: 0.75rem;
	font-weight: 600;
	text-align: center;
	line-height: 1.2;
	color: var(--ijs-white);
}

.tour-thumb__more-plus {
	width: 1.8rem;
	height: 1.8rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1.5px solid var(--ijs-white);
	border-radius: 50%;
	font-size: 1.1rem;
	font-weight: 400;
	color: var(--ijs-white);
}

/* ---------------------------------------------------------------- */
/* 1c. Lightbox modal (<dialog>) — galería full-screen              */
/* ---------------------------------------------------------------- */
.tour-lightbox {
	border: 0;
	padding: 0;
	margin: 0;
	width: 100vw;
	height: 100vh;
	max-width: 100vw;
	max-height: 100vh;
	background: rgba(11, 37, 69, 0.96);
	color: var(--ijs-white);
}

.tour-lightbox::backdrop {
	background: rgba(11, 37, 69, 0.92);
}

.tour-lightbox[open] {
	display: flex;
	align-items: center;
	justify-content: center;
}

.tour-lightbox__figure {
	margin: 0;
	max-width: min(90vw, 1400px);
	max-height: 90vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
}

.tour-lightbox__img {
	max-width: 100%;
	max-height: 80vh;
	height: auto;
	width: auto;
	object-fit: contain;
	border-radius: 12px;
	box-shadow: 0 24px 48px -16px rgba(0, 0, 0, 0.6);
	background: var(--ijs-navy-900);
}

.tour-lightbox__counter {
	font-family: var(--ijs-font-body);
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.8);
	letter-spacing: 0.04em;
}

.tour-lightbox__close,
.tour-lightbox__nav {
	position: absolute;
	z-index: 2;
	width: 3rem;
	height: 3rem;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.12);
	color: var(--ijs-white);
	border: 0;
	border-radius: 50%;
	cursor: pointer;
	transition: background 200ms ease, transform 200ms ease;
}

.tour-lightbox__close:hover,
.tour-lightbox__nav:hover,
.tour-lightbox__close:focus-visible,
.tour-lightbox__nav:focus-visible {
	background: rgba(255, 255, 255, 0.25);
	transform: scale(1.05);
	outline: none;
}

.tour-lightbox__close { top: 1.25rem; right: 1.25rem; }
.tour-lightbox__nav--prev { left: 1.25rem; top: 50%; transform: translateY(-50%); }
.tour-lightbox__nav--next { right: 1.25rem; top: 50%; transform: translateY(-50%); }
.tour-lightbox__nav--prev:hover { transform: translateY(-50%) scale(1.05); }
.tour-lightbox__nav--next:hover { transform: translateY(-50%) scale(1.05); }

.tour-lightbox__close svg,
.tour-lightbox__nav svg { width: 1.4rem; height: 1.4rem; }

/* Evitar scroll del body cuando el lightbox está abierto */
body.has-lightbox-open { overflow: hidden; }

@media (max-width: 560px) {
	.tour-lightbox__nav { width: 2.4rem; height: 2.4rem; }
	.tour-lightbox__nav svg { width: 1.1rem; height: 1.1rem; }
	.tour-lightbox__close { top: 0.75rem; right: 0.75rem; }
	.tour-lightbox__nav--prev { left: 0.5rem; }
	.tour-lightbox__nav--next { right: 0.5rem; }
}

/* FAB Reservar mobile — visible solo en mobile, controlado por JS via .is-visible */
.tour-fab {
	display: none;
}

@media (max-width: 768px) {
	.tour-fab {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		gap: 0.5rem;
		position: fixed;
		left: max(1rem, env(safe-area-inset-left, 1rem));
		/* Dejar hueco al WhatsApp FAB (56px + 1rem margen) en el lado derecho */
		right: calc(56px + 1.5rem + env(safe-area-inset-right, 0px));
		bottom: max(1rem, env(safe-area-inset-bottom, 1rem));
		z-index: 90;
		padding: 0.95rem 1.4rem;
		background: var(--ijs-coral-700);
		color: var(--ijs-white);
		font-family: var(--ijs-font-body);
		font-size: 1rem;
		font-weight: 600;
		text-decoration: none;
		border-radius: 9999px;
		box-shadow: 0 8px 24px -6px rgba(11, 37, 69, 0.45);
		opacity: 0;
		transform: translateY(20px);
		pointer-events: none;
		transition: opacity 220ms ease, transform 220ms ease;
	}
	.tour-fab.is-visible {
		opacity: 1;
		transform: none;
		pointer-events: auto;
	}
	.tour-fab:hover,
	.tour-fab:focus-visible {
		background: var(--ijs-coral-800);
		color: var(--ijs-white);
	}
	.tour-fab__arrow {
		width: 18px;
		height: 18px;
		flex-shrink: 0;
		transition: transform 220ms ease;
	}
	/* Cuando el motor está por encima del viewport, voltear la flecha (↑). */
	.tour-fab--up .tour-fab__arrow {
		transform: rotate(180deg);
	}
}

@media (prefers-reduced-motion: reduce) {
	.tour-fab { transition: opacity 0.01ms; transform: none; }
	.tour-fab.is-visible { transform: none; }
}

/* Smooth scroll global cuando se navega a #reservar (respeta reduced-motion) */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
	html { scroll-behavior: auto; }
}

/* ---------------------------------------------------------------- */
/* 1.5. Card datos clave — 4 cols horizontal blanca                  */
/*       Mismos tokens que .zone-practical__card (landing zona) para */
/*       coherencia visual entre puntos de salida y single tour.     */
/* ---------------------------------------------------------------- */
.tour-spec {
	background: var(--ijs-white);
	border-radius: 1rem;
	padding: 1rem 1.125rem;
	box-shadow: 0 14px 36px rgba(11, 37, 69, 0.10);
}

.tour-spec__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.875rem;
	grid-template-columns: 1fr;
}

@media (min-width: 720px) {
	.tour-spec { padding: 1.25rem 1.5rem; }
	.tour-spec__list { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
	.tour-spec__list { grid-template-columns: repeat(4, 1fr); }
}

.tour-spec__item {
	display: flex;
	gap: 0.625rem;
	align-items: center;
	color: var(--ijs-navy-900);
}

.tour-spec__icon {
	flex-shrink: 0;
	width: 22px;
	height: 22px;
	color: var(--ijs-turquoise-600);
	display: inline-flex;
}

.tour-spec__icon svg { width: 100%; height: 100%; }

.tour-spec__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.tour-spec__label {
	font-family: var(--ijs-font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--ijs-ink-500);
	line-height: 1.2;
	margin: 0 0 0.125rem;
}

.tour-spec__value {
	font-family: var(--ijs-font-body);
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.35;
	color: var(--ijs-navy-900);
	margin: 0;
}

.tour-spec__hint {
	display: block;
	margin-top: 0.15rem;
	font-size: 0.72rem;
	font-weight: 400;
	color: var(--ijs-ink-500);
}

.tour-spec__value strong {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 72, "SOFT" 30;
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--ijs-coral-700);
	letter-spacing: -0.01em;
	display: inline-block;
	margin-right: 0.15rem;
}

.tour-spec__before {
	display: inline-block;
	margin-left: 0.35rem;
	font-size: 0.75rem;
	color: var(--ijs-ink-500);
	text-decoration: line-through;
}

/* ---------------------------------------------------------------- */
/* 2. Intro editorial                                               */
/* ---------------------------------------------------------------- */
.tour-intro {
	background: var(--ijs-sand-50);
	padding-block: clamp(56px, 9vh, 104px);
}

.tour-intro__body {
	max-width: 42rem;
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 72, "SOFT" 30;
	font-size: clamp(1.1rem, 0.5vw + 0.95rem, 1.3rem);
	line-height: 1.55;
	color: var(--ijs-navy-900);
}

.tour-intro__body p { margin: 0 0 1.25em; }
.tour-intro__body p:last-child { margin-bottom: 0; }
.tour-intro__body em { color: var(--ijs-coral-700); font-weight: 300; }

/* ---------------------------------------------------------------- */
/* 3. Matriz precio×ubicación                                        */
/* ---------------------------------------------------------------- */
.tour-pricing {
	background: var(--ijs-white);
	padding-block: clamp(64px, 10vh, 120px);
}

.tour-pricing__head {
	max-width: 42rem;
	margin: 0 0 clamp(2.5rem, 4vh, 3.5rem);
}

.tour-pricing__head .eyebrow { color: var(--ijs-coral-700); }

.tour-pricing__head h2 {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(2rem, 3vw + 0.75rem, 3rem);
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: var(--ijs-navy-900);
	margin: 0.5rem 0 0;
}

.tour-pricing__head h2 em {
	font-style: italic;
	font-weight: 300;
	font-variation-settings: "opsz" 144, "SOFT" 100;
	color: var(--ijs-coral-700);
}

/* Botón "Cambiar punto de salida" debajo del header */
.tour-pricing__change {
	display: inline-flex;
	align-items: center;
	gap: 0.4em;
	margin-top: 1rem;
	padding: 0;
	background: none;
	border: 0;
	font-family: var(--ijs-font-body);
	font-size: 0.95rem;
	font-weight: 500;
	color: var(--ijs-coral-700);
	text-decoration: underline;
	text-underline-offset: 0.3em;
	cursor: pointer;
}

.tour-pricing__change:hover,
.tour-pricing__change:focus-visible {
	color: var(--ijs-coral-800);
}

/* Fallback WhatsApp cuando no hay productId Turbnb para la zona activa */
.tour-pricing__wa-fallback {
	max-width: 32rem;
	background: var(--ijs-sand-50);
	border: 1px solid var(--ijs-sand-100);
	border-radius: var(--ijs-radius-lg);
	padding: clamp(1.5rem, 3vw, 2rem);
	text-align: center;
	margin: 0 auto;
}

.tour-pricing__wa-fallback p {
	font-family: var(--ijs-font-body);
	color: var(--ijs-ink-900);
	margin: 0 0 1.25rem;
	line-height: 1.5;
}

.tour-pricing__wa-btn { background: var(--ijs-navy-900); }
.tour-pricing__wa-btn:hover { background: var(--ijs-navy-600); }

.tour-pricing__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

/* Single-card layout: una sola card centrada con el botón "Cambiar" debajo.
   Evita que el usuario compare precios entre puntos de salida. */
.tour-pricing__single {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.25rem;
	max-width: 28rem;
	margin: 0 auto;
}

.tour-pricing-card--single {
	width: 100%;
	background: var(--ijs-white);
	border-color: var(--ijs-coral-700);
	box-shadow: var(--ijs-shadow-md);
	padding: clamp(1.75rem, 4vw, 2.5rem);
	gap: 0.6rem;
	text-align: center;
}

.tour-pricing-card--single .tour-pricing-card__zone {
	color: var(--ijs-coral-700);
}

.tour-pricing-card--single .tour-pricing-card__price {
	font-size: clamp(2.5rem, 5vw, 3.25rem);
}

.tour-pricing-card--single .tour-pricing-card__btn {
	margin-top: 0.5rem;
	align-self: stretch;
}

.tour-pricing-card {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	padding: 1.75rem;
	background: var(--ijs-sand-50);
	border: 1px solid var(--ijs-sand-100);
	border-radius: var(--ijs-radius-lg);
	transition: transform 220ms ease, box-shadow 220ms ease;
}

.tour-pricing-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--ijs-shadow-md);
}

.tour-pricing-card__zone {
	font-family: var(--ijs-font-body);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ijs-turquoise-900);
	margin: 0 0 0.25rem;
}

.tour-pricing-card__price {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 30;
	font-size: 2.5rem;
	font-weight: 600;
	color: var(--ijs-navy-900);
	line-height: 1;
	margin: 0;
}

.tour-pricing-card__duration {
	font-size: 0.95rem;
	color: var(--ijs-ink-500);
	margin: 0 0 1.5rem;
}

.tour-pricing-card__btn {
	margin-top: auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5em;
	padding: 0.85em 1.4em;
	background: var(--ijs-coral-700);
	color: var(--ijs-white);
	font-family: var(--ijs-font-body);
	font-size: 0.95rem;
	font-weight: 600;
	border-radius: 9999px;
	text-decoration: none;
	transition: background 0.2s ease;
}

.tour-pricing-card__btn:hover { background: var(--ijs-coral-800); color: var(--ijs-white); }

.tour-pricing-card__btn--wa {
	background: var(--ijs-navy-900);
}

.tour-pricing-card__btn--wa:hover { background: var(--ijs-navy-600); }

.tour-pricing__note {
	margin-top: 2rem;
	font-size: 0.85rem;
	color: var(--ijs-ink-500);
	max-width: 42rem;
	line-height: 1.6;
}

/* ---------------------------------------------------------------- */
/* 4. Itinerario                                                    */
/* ---------------------------------------------------------------- */
.tour-itinerary {
	background: var(--ijs-sand-50);
	padding-block: clamp(64px, 10vh, 112px);
}

.tour-itinerary__head {
	max-width: 42rem;
	margin: 0 0 clamp(2rem, 4vh, 3rem);
}

.tour-itinerary__head .eyebrow { color: var(--ijs-coral-700); }

.tour-itinerary__head h2 {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(2rem, 3vw + 0.75rem, 2.75rem);
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: var(--ijs-navy-900);
	margin: 0.5rem 0 0;
}

.tour-itinerary__head h2 em {
	font-style: italic;
	font-weight: 300;
	font-variation-settings: "opsz" 144, "SOFT" 100;
	color: var(--ijs-coral-700);
}

.tour-itinerary__list {
	list-style: none;
	margin: 0;
	padding: 0;
	max-width: 48rem;
	border-left: 1px solid var(--ijs-sand-100);
}

.tour-itinerary__step {
	display: grid;
	grid-template-columns: 8rem 1fr;
	gap: 1.5rem;
	padding: 1.25rem 0 1.25rem 1.5rem;
	position: relative;
}

.tour-itinerary__step::before {
	content: "";
	position: absolute;
	left: -5px;
	top: 1.6rem;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--ijs-coral-600);
}

@media (max-width: 600px) {
	.tour-itinerary__step { grid-template-columns: 1fr; gap: 0.4rem; }
}

.tour-itinerary__time {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 72, "SOFT" 30;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--ijs-coral-700);
	letter-spacing: -0.01em;
	white-space: nowrap;
}

.tour-itinerary__text {
	font-size: 1rem;
	line-height: 1.55;
	color: var(--ijs-navy-900);
}

/* ---------------------------------------------------------------- */
/* 5. Incluye + qué llevar — 2 cols                                 */
/* ---------------------------------------------------------------- */
.tour-includes {
	background: var(--ijs-white);
	padding-block: clamp(64px, 10vh, 112px);
}

/* Colapsar padding entre secciones consecutivas con mismo bg blanco
   (pricing → includes → cross). Sin gallery en medio quedaba aire excesivo. */
.tour-pricing + .tour-includes,
.tour-includes + .tour-cross,
.tour-pricing + .tour-cross {
	padding-top: 0;
}
.tour-pricing:has(+ .tour-includes),
.tour-pricing:has(+ .tour-cross),
.tour-includes:has(+ .tour-cross) {
	padding-bottom: clamp(24px, 4vh, 40px);
}

.tour-includes__grid {
	display: grid;
	gap: clamp(2rem, 5vw, 4rem);
	grid-template-columns: 1fr 1fr;
}

@media (max-width: 760px) { .tour-includes__grid { grid-template-columns: 1fr; } }

.tour-includes__col header { margin-bottom: 1.5rem; }
.tour-includes__col header .eyebrow { color: var(--ijs-coral-700); }
.tour-includes__col--bring header .eyebrow { color: var(--ijs-coral-700); }

.tour-includes__col h2 {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(1.5rem, 2vw + 0.5rem, 2rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--ijs-navy-900);
	margin: 0.5rem 0 0;
}

.tour-includes__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.tour-includes__list li {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--ijs-sand-100);
	font-size: 1rem;
	color: var(--ijs-navy-900);
	line-height: 1.5;
}

.tour-includes__list li:last-child { border-bottom: none; }

.tour-includes__list svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
	margin-top: 2px;
}

.tour-includes__col--includes svg { color: var(--ijs-turquoise-600); }
.tour-includes__col--bring svg { color: var(--ijs-coral-600); }

/* ---------------------------------------------------------------- */
/* 7. Cross-sells (otros tours)                                     */
/* ---------------------------------------------------------------- */
.tour-cross {
	background: var(--ijs-white);
	padding-block: clamp(64px, 10vh, 112px);
}

.tour-cross__head {
	max-width: 42rem;
	margin: 0 0 clamp(2rem, 4vh, 3rem);
}

.tour-cross__head .eyebrow { color: var(--ijs-coral-700); }

.tour-cross__head h2 {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(1.75rem, 2.5vw + 0.75rem, 2.5rem);
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.025em;
	color: var(--ijs-navy-900);
	margin: 0.5rem 0 0;
}

.tour-cross__head h2 em {
	font-style: italic;
	font-weight: 300;
	font-variation-settings: "opsz" 144, "SOFT" 100;
	color: var(--ijs-coral-700);
}

.tour-cross__grid {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.tour-cross-card {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 8px;
	color: var(--ijs-white);
	isolation: isolate;
	min-height: 14rem;
	text-decoration: none;
	transition: transform 280ms cubic-bezier(0.22, 0.61, 0.36, 1),
	            box-shadow 280ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.tour-cross-card:hover { transform: translateY(-3px); box-shadow: var(--ijs-shadow-md); }

.tour-cross-card__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
}
.tour-cross-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.tour-cross-card::after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background: linear-gradient(to top, rgba(11,37,69,0.92) 0%, rgba(11,37,69,0.4) 50%, rgba(11,37,69,0) 80%);
}

.tour-cross-card__inner {
	position: relative;
	z-index: 1;
	height: 100%;
	min-height: inherit;
	padding: 1.25rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	gap: 0.4rem;
}

.tour-cross-card h3 {
	font-family: var(--ijs-font-display);
	font-size: 1.4rem;
	font-weight: 500;
	color: var(--ijs-white);
	margin: 0;
	letter-spacing: -0.02em;
}

.tour-cross-card__price {
	font-family: var(--ijs-font-display);
	font-weight: 600;
	color: rgba(255, 255, 255, 0.9);
}

/* Stagger reveal items en grids del single tour. Patrón nth-child (más limpio
   que pintar transition-delay en PHP item a item). */
.tour-spec__list .reveal:nth-child(1)  { transition-delay: 0ms; }
.tour-spec__list .reveal:nth-child(2)  { transition-delay: 60ms; }
.tour-spec__list .reveal:nth-child(3)  { transition-delay: 120ms; }
.tour-spec__list .reveal:nth-child(4)  { transition-delay: 180ms; }
.tour-spec__list .reveal:nth-child(5)  { transition-delay: 240ms; }
.tour-spec__list .reveal:nth-child(6)  { transition-delay: 300ms; }

.tour-includes__list .reveal:nth-child(1)  { transition-delay: 0ms; }
.tour-includes__list .reveal:nth-child(2)  { transition-delay: 60ms; }
.tour-includes__list .reveal:nth-child(3)  { transition-delay: 120ms; }
.tour-includes__list .reveal:nth-child(4)  { transition-delay: 180ms; }
.tour-includes__list .reveal:nth-child(5)  { transition-delay: 240ms; }

.tour-gallery__grid .reveal:nth-child(1)  { transition-delay: 0ms; }
.tour-gallery__grid .reveal:nth-child(2)  { transition-delay: 80ms; }
.tour-gallery__grid .reveal:nth-child(3)  { transition-delay: 160ms; }
.tour-gallery__grid .reveal:nth-child(4)  { transition-delay: 240ms; }
.tour-gallery__grid .reveal:nth-child(5)  { transition-delay: 320ms; }
.tour-gallery__grid .reveal:nth-child(6)  { transition-delay: 400ms; }

.tour-cross__grid .reveal:nth-child(1) { transition-delay: 0ms; }
.tour-cross__grid .reveal:nth-child(2) { transition-delay: 80ms; }
.tour-cross__grid .reveal:nth-child(3) { transition-delay: 160ms; }

/* ====================================================================
   8. Booking — widget con marco premium (Fase B rediseño 2026-05)
   ==================================================================== */
.tour-booking {
	background: var(--ijs-white);
	padding-block: clamp(2.5rem, 5vh, 4rem);
}

.tour-booking__card {
	/* Sin caja exterior: header + widget cuelgan directos sobre el bg de la sección.
	   El widget Turbnb interno ya viene con su propia caja blanca, así que reducimos
	   las cajas anidadas a una sola (más ancho y más limpio, alineado con el boceto). */
	background: transparent;
	padding: 0;
}

.tour-booking__head {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: clamp(1.25rem, 2.5vw, 2rem);
	padding-bottom: clamp(1rem, 2vw, 1.5rem);
	border-bottom: 1px solid var(--ijs-sand-100);
}

.tour-booking__icon {
	flex-shrink: 0;
	width: 3rem;
	height: 3rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--ijs-turquoise-50);
	color: var(--ijs-turquoise-600);
	border-radius: 50%;
}
.tour-booking__icon svg { width: 60%; height: 60%; }

.tour-booking__head-text { flex: 1; min-width: 0; }

.tour-booking__title {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(1.5rem, 2vw + 0.75rem, 2rem);
	font-weight: 600;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--ijs-navy-900);
	margin: 0;
}

.tour-booking__sub {
	font-family: var(--ijs-font-body);
	font-size: 0.9rem;
	color: var(--ijs-ink-500);
	margin: 0.4rem 0 0;
}

.tour-booking__sub strong { color: var(--ijs-navy-900); }

.tour-booking__change {
	background: none;
	border: 0;
	padding: 0;
	font: inherit;
	color: var(--ijs-coral-700);
	text-decoration: underline;
	text-underline-offset: 0.2em;
	cursor: pointer;
}
.tour-booking__change:hover,
.tour-booking__change:focus-visible { color: var(--ijs-coral-800); }

/* Widget Turbnb: contenedor para que el bundle React se inserte aquí. */
.tour-booking__widget {
	min-height: 320px;
}
.tour-booking__widget[hidden] { display: none; }
.tour-booking__widget:not([hidden]) {
	display: block;
	background: var(--ijs-white);
	border-radius: 16px;
	overflow: hidden;
}

/* Fallback WhatsApp si el tour no tiene productId para la zona activa */
.tour-booking__wa {
	background: var(--ijs-white);
	border-radius: 16px;
	padding: clamp(1.5rem, 3vw, 2rem);
	text-align: center;
}

.tour-booking__wa-text {
	font-family: var(--ijs-font-body);
	color: var(--ijs-navy-900);
	margin: 0 0 1.25rem;
	line-height: 1.5;
}

.tour-booking__wa-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.9em 1.6em;
	background: #25D366;
	color: var(--ijs-white);
	font-family: var(--ijs-font-body);
	font-size: 0.95rem;
	font-weight: 600;
	border-radius: 9999px;
	text-decoration: none;
	transition: background 200ms ease, transform 200ms ease;
}
.tour-booking__wa-btn svg { width: 1.1rem; height: 1.1rem; fill: var(--ijs-white); }
.tour-booking__wa-btn:hover,
.tour-booking__wa-btn:focus-visible {
	background: #1FB658;
	color: var(--ijs-white);
	transform: translateY(-1px);
}

.tour-booking__foot {
	background: transparent;
	margin: clamp(1rem, 2vw, 1.5rem) 0 0;
	padding: clamp(1rem, 2vw, 1.5rem) 0 0;
	border-top: 1px solid var(--ijs-sand-100);
	text-align: center;
}

.tour-booking__trust {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--ijs-font-body);
	font-size: 0.85rem;
	color: var(--ijs-ink-500);
}

.tour-booking__trust-icon {
	width: 1.2rem;
	height: 1.2rem;
	color: var(--ijs-turquoise-600);
}
.tour-booking__trust-icon svg { width: 100%; height: 100%; }

/* ====================================================================
   9. Bloque SEO 60/40 — H2 + content izq · 4 features dcha
   ==================================================================== */
.tour-features {
	background: var(--ijs-white);
	padding-block: clamp(2rem, 5vh, 4rem) clamp(3rem, 6vh, 5rem);
}

.tour-features__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	max-width: 72rem;
	margin: 0 auto;
}

@media (min-width: 900px) {
	.tour-features__grid { grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr); }
	/* Sin post_content: el aside ocupa todo el ancho con 2 sublistas en row */
	.tour-features--no-copy .tour-features__grid { grid-template-columns: 1fr; }
	.tour-features--no-copy .tour-features__aside {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 2.5rem;
	}
}

.tour-features__title {
	font-family: var(--ijs-font-display);
	font-variation-settings: "opsz" 144, "SOFT" 50;
	font-size: clamp(1.75rem, 2.5vw + 0.75rem, 2.4rem);
	font-weight: 600;
	line-height: 1.1;
	letter-spacing: -0.025em;
	color: var(--ijs-navy-900);
	text-transform: uppercase;
	margin: 0 0 1.25rem;
}

.tour-features__body {
	font-family: var(--ijs-font-body);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--ijs-ink-900);
}

.tour-features__body > * { margin: 0 0 1em; }
.tour-features__body > *:last-child { margin-bottom: 0; }
.tour-features__body h2 {
	font-family: var(--ijs-font-display);
	font-size: 1.4rem;
	font-weight: 600;
	color: var(--ijs-navy-900);
	margin-top: 1.5em;
}
.tour-features__body strong { color: var(--ijs-navy-900); }
.tour-features__body em { color: var(--ijs-coral-700); font-style: italic; font-weight: 300; }

/* Sidebar 40%: 2 bloques apilados — "Qué incluye" + "Qué llevar" */
.tour-features__aside {
	display: flex;
	flex-direction: column;
	gap: 1.75rem;
}

.tour-features__block-title {
	font-family: var(--ijs-font-body);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--ijs-coral-700);
	margin: 0 0 0.85rem;
	line-height: 1.2;
}

.tour-features__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}

.tour-features__list li {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
	font-family: var(--ijs-font-body);
	font-size: 0.9rem;
	line-height: 1.45;
	color: var(--ijs-navy-900);
}

.tour-features__list svg {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	margin-top: 2px;
}

.tour-features__list--check svg { color: var(--ijs-turquoise-600); }
.tour-features__list--dot   svg { width: 10px; height: 10px; margin-top: 8px; color: var(--ijs-coral-700); }
