/* =========================================================================
   Playa Roja Tours — estilos base del theme
   Identidad: rojo #be2727 · Raleway · estilo catálogo (Civitatis / GetYourGuide)
   ========================================================================= */

:root {
	--pr-red: #be2727;
	--pr-red-dark: #9c1f1f;
	--pr-ink: #1a1c20;
	--pr-slate: #35363a;
	--pr-muted: #6b7280;
	--pr-line: #e5e8eb;
	--pr-bg: #ffffff;
	--pr-bg-soft: #f0f4f6;
	--pr-white: #ffffff;

	--pr-font: 'Raleway', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--pr-radius: 16px;
	--pr-radius-sm: 10px;
	--pr-shadow: 0 10px 30px rgba(26, 28, 32, .08);
	--pr-shadow-lg: 0 20px 50px rgba(26, 28, 32, .14);
	--pr-container: 1320px;
	--pr-header-h: 76px;
	--pr-transition: .3s cubic-bezier(.2, .7, .3, 1);
}

/* ---------- Reset suave ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	font-family: var(--pr-font);
	color: var(--pr-ink);
	background: var(--pr-bg);
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { line-height: 1.15; margin: 0 0 .4em; font-weight: 800; letter-spacing: -.01em; }

.container { width: 100%; max-width: var(--pr-container); margin: 0 auto; padding: 0 24px; }
.section { padding: 72px 0; }
.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px; overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px); white-space: nowrap;
}
.skip-link {
	position: absolute; left: -999px; top: 0; background: var(--pr-red); color: #fff;
	padding: 10px 16px; z-index: 1000;
}
.skip-link:focus { left: 8px; top: 8px; }

/* ---------- Botones ---------- */
.btn {
	display: inline-flex; align-items: center; gap: 8px;
	font-weight: 700; font-size: .95rem; line-height: 1;
	padding: 14px 22px; border-radius: 999px; border: 2px solid transparent;
	cursor: pointer; transition: var(--pr-transition); white-space: nowrap;
}
.btn--lg { padding: 17px 30px; font-size: 1.02rem; }
.btn--primary { background: var(--pr-red); color: #fff; }
.btn--primary:hover { background: var(--pr-red-dark); transform: translateY(-2px); box-shadow: var(--pr-shadow); }
.btn--outline { background: transparent; color: var(--pr-ink); border-color: var(--pr-line); }
.btn--outline:hover { border-color: var(--pr-red); color: var(--pr-red); }
.btn--whatsapp { background: var(--pr-red); color: #fff; }
.btn--whatsapp:hover { background: var(--pr-red-dark); }
.btn--whatsapp .btn__icon { display: inline-flex; align-items: center; }
.btn--whatsapp .btn__icon svg { width: 20px; height: 20px; display: block; }

/* ---------- Header ---------- */
.site-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(255, 255, 255, .92);
	backdrop-filter: saturate(180%) blur(12px);
	border-bottom: 1px solid var(--pr-line);
	transition: background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
}
.site-logo__img--light { display: none; } /* el header siempre va con fondo blanco */

.site-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 24px; min-height: var(--pr-header-h);
}
.site-logo img { height: 44px; width: auto; }
.site-logo__text { font-weight: 900; font-size: 1.25rem; color: var(--pr-red); }

.site-nav { margin-left: auto; } /* empuja el menú a la derecha (sin botón de reserva) */
.site-nav__menu {
	display: flex; align-items: center; gap: 4px; list-style: none; margin: 0; padding: 0;
}
.site-nav__menu a {
	display: block; padding: 10px 14px; font-weight: 600; font-size: .96rem;
	border-radius: var(--pr-radius-sm); transition: var(--pr-transition);
}
.site-nav__menu a:hover { color: var(--pr-red); background: var(--pr-bg-soft); }
.site-nav__menu .menu-item-has-children { position: relative; }
.site-nav__menu .sub-menu {
	position: absolute; top: calc(100% + 6px); left: 0; min-width: 200px;
	background: #fff; border: 1px solid var(--pr-line); border-radius: var(--pr-radius-sm);
	box-shadow: var(--pr-shadow); list-style: none; margin: 0; padding: 8px;
	opacity: 0; visibility: hidden; transform: translateY(8px); transition: var(--pr-transition);
}
.site-nav__menu .menu-item-has-children:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }

.site-header__actions { display: flex; align-items: center; gap: 12px; }

.nav-toggle {
	display: none; width: 44px; height: 44px; border: 1px solid var(--pr-line);
	background: #fff; border-radius: var(--pr-radius-sm); position: relative; cursor: pointer;
}
.nav-toggle__bar, .nav-toggle__bar::before, .nav-toggle__bar::after {
	content: ''; position: absolute; left: 50%; top: 50%; width: 20px; height: 2px;
	background: var(--pr-ink); transform: translate(-50%, -50%); transition: var(--pr-transition);
}
.nav-toggle__bar::before { top: -7px; }
.nav-toggle__bar::after { top: 7px; }

/* ---------- Hero (video / imágenes con efecto cinema) ---------- */
.hero {
	position: relative; min-height: min(86vh, 760px);
	display: flex; align-items: center; color: #fff; overflow: hidden;
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__video { width: 100%; height: 100%; object-fit: cover; }
.hero__slides { position: absolute; inset: 0; }
.hero__slide {
	position: absolute; inset: 0; background-size: cover; background-position: center;
	opacity: 0; transition: opacity 1.6s ease;
}
.hero__slide.is-active { opacity: 1; }
/* Efecto cinema (Ken Burns): zoom lento + paneo en la slide activa. */
.hero__slide.is-active { animation: pr-kenburns 12s ease-out forwards; }
.hero__slide--placeholder {
	background-image: linear-gradient(135deg, #2a2d33 0%, #be2727 120%);
	opacity: 1;
}
@keyframes pr-kenburns {
	from { transform: scale(1) translate(0, 0); }
	to   { transform: scale(1.12) translate(-1.5%, -1.5%); }
}
.hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(20, 22, 26, .25) 0%, rgba(20, 22, 26, .55) 100%);
}
.hero__content { position: relative; z-index: 2; max-width: 720px; }
.hero__title { font-size: clamp(2.2rem, 5vw, 3.6rem); font-weight: 900; text-shadow: 0 2px 20px rgba(0,0,0,.3); }
.hero__subtitle { font-size: clamp(1.05rem, 2vw, 1.3rem); margin-bottom: 28px; opacity: .95; }

@media (prefers-reduced-motion: reduce) {
	.hero__slide.is-active { animation: none; }
	html { scroll-behavior: auto; }
}

/* ---------- Secciones ---------- */
.section__head { text-align: center; max-width: 680px; margin: 0 auto 44px; }
.section__title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); }
.section__subtitle { color: var(--pr-muted); font-size: 1.1rem; }
.section__cta { text-align: center; margin-top: 44px; }
.section--tours { background: var(--pr-bg-soft); }

/* ---------- Grid de cards ---------- */
.cards-grid {
	display: grid; gap: 28px;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}
.card-tour {
	background: #fff; border-radius: var(--pr-radius); overflow: hidden;
	box-shadow: var(--pr-shadow); transition: var(--pr-transition);
}
.card-tour:hover { transform: translateY(-6px); box-shadow: var(--pr-shadow-lg); }
.card-tour__media { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
/* !important para ganarle al "height:auto" que WooCommerce aplica a las imágenes
   dentro de ul.products (relacionados/archivos) y mantener el marco 4:3 uniforme. */
.card-tour__media img { width: 100% !important; height: 100% !important; object-fit: cover !important; transition: transform .6s ease; }
.card-tour:hover .card-tour__media img { transform: scale(1.06); }
.card-tour__media--placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #e9edf0, #cdd5db); }
.card-tour__badge {
	position: absolute; top: 14px; left: 14px;
	background: rgba(255, 255, 255, .95); color: var(--pr-red);
	font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .04em;
	padding: 5px 11px; border-radius: 999px;
}
.card-tour__body { padding: 20px; }
.card-tour__title {
	font-size: 1.12rem; line-height: 1.3; margin-bottom: 12px; text-transform: uppercase;
	display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; line-clamp: 3;
	overflow: hidden; height: 3.9em; /* hasta 3 líneas; si excede, corta con "…". Alturas parejas. */
}
.card-tour__price { display: flex; align-items: baseline; gap: 6px; margin-bottom: 14px; }
.card-tour__price-label { font-size: .8rem; color: var(--pr-muted); }
.card-tour__price-value { font-size: 1.25rem; font-weight: 800; color: var(--pr-red); }
.card-tour__price-value .amount { color: var(--pr-red); }
.card-tour__cta { display: inline-flex; align-items: center; gap: 6px; font-weight: 700; color: var(--pr-ink); font-size: .92rem; }
.card-tour__cta::after { content: '→'; display: inline-block; transition: transform .25s ease; }
.card-tour:hover .card-tour__cta { color: var(--pr-red); }
.card-tour:hover .card-tour__cta::after { transform: translateX(5px); }

.section__head--left { text-align: left; margin-left: 0; }

/* ---------- Barra de confianza ---------- */
.confianza { border-bottom: 1px solid var(--pr-line); background: #fff; }
.confianza__grid {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
	padding: 26px 24px;
}
.confianza__item { display: flex; align-items: center; gap: 14px; justify-content: center; }
.confianza__item + .confianza__item { border-left: 1px solid var(--pr-line); }
.confianza__icon { font-size: 1.7rem; color: var(--pr-red); line-height: 1; display: inline-flex; }
.confianza__icon .dashicons { font-size: 1.7rem; width: auto; height: auto; }
.confianza__icon img { width: 40px; height: 40px; object-fit: contain; display: block; }

/* Íconos SVG animados (un solo color, según el título) */
.confianza__icon svg.pr-ico { width: 40px; height: 40px; overflow: visible; }
.pr-ico { transform-box: fill-box; transform-origin: center; }
.pr-ico--pin { animation: pr-bob 2.4s ease-in-out infinite; }
.pr-ico--trophy { animation: pr-pulse 2.8s ease-in-out infinite; }
.pr-ico--star, .pr-ico--diamond { animation: pr-twinkle 3s ease-in-out infinite; }
.pr-ico--transport { animation: pr-bob 2.2s ease-in-out infinite; }
.pr-ico--guide { animation: pr-sway 2.6s ease-in-out infinite; transform-origin: bottom center; }
.pr-ico--price { animation: pr-swing 3s ease-in-out infinite; transform-origin: top left; }
@keyframes pr-sway { 0%, 100% { transform: rotate(-4deg); } 50% { transform: rotate(4deg); } }
@keyframes pr-swing { 0%, 100% { transform: rotate(-6deg); } 50% { transform: rotate(6deg); } }
.pr-ico--clock .pr-ico__hand { transform-box: view-box; transform-origin: 12px 12px; animation: pr-spin 6s linear infinite; }
@keyframes pr-spin { to { transform: rotate(360deg); } }
.pr-ico__check { stroke-dasharray: 22; animation: pr-draw 3s ease-in-out infinite; }
.pr-ico--chat .pr-dot { transform-box: fill-box; transform-origin: center; }
.pr-ico--chat .pr-dot--1 { animation: pr-dot 1.4s ease-in-out infinite; }
.pr-ico--chat .pr-dot--2 { animation: pr-dot 1.4s ease-in-out .18s infinite; }
.pr-ico--chat .pr-dot--3 { animation: pr-dot 1.4s ease-in-out .36s infinite; }
@keyframes pr-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@keyframes pr-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.08); } }
@keyframes pr-twinkle { 0%, 100% { transform: rotate(0) scale(1); } 50% { transform: rotate(10deg) scale(1.06); } }
@keyframes pr-draw { 0% { stroke-dashoffset: 22; } 30%, 100% { stroke-dashoffset: 0; } }
@keyframes pr-dot { 0%, 100% { opacity: .3; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-2px); } }
@media (prefers-reduced-motion: reduce) {
	.pr-ico, .pr-ico * { animation: none !important; }
	.pr-ico__check { stroke-dashoffset: 0; }
}
.confianza__title { display: block; font-size: .98rem; }
.confianza__sub { display: block; font-size: .82rem; color: var(--pr-muted); }

/* ---------- Bloque destacado ---------- */
.destacado { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; }
.destacado__media { background-size: cover; background-position: center; min-height: 380px; position: relative; }
.destacado__media-ph { position: absolute; inset: 0; background: linear-gradient(135deg, #cdd5db, #8a9299); }
.destacado__panel { background: #f6e3c4; display: flex; align-items: center; }
.destacado__inner { padding: 56px clamp(28px, 5vw, 72px); max-width: 560px; }
.destacado__badge {
	display: inline-flex; align-items: center; gap: 7px;
	background: #fff; color: var(--pr-red);
	font-size: .74rem; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
	padding: 7px 15px; border-radius: 999px; margin-bottom: 16px;
	box-shadow: 0 4px 14px rgba(0, 0, 0, .08);
}
.destacado__badge::before { content: '✓'; font-size: .95rem; line-height: 1; }
.destacado__eyebrow { display: block; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; font-weight: 800; color: var(--pr-red); margin-bottom: 10px; }
.destacado__title { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.destacado__text { color: #5b4a30; margin-bottom: 26px; }

/* ---------- Carrusel ---------- */
.carousel {
	display: grid; grid-auto-flow: column; grid-auto-columns: minmax(280px, 1fr);
	gap: 24px; overflow-x: auto; scroll-snap-type: x proximity;
	scrollbar-width: none; -webkit-overflow-scrolling: touch;
	/* Aire para que no se recorte la sombra de las cards (overflow-y queda en auto). */
	padding: 10px 0 26px;
}
.carousel::-webkit-scrollbar { display: none; }
.carousel__item { scroll-snap-align: start; }
.section--aventura { background: #fff; }

/* Carrusel "pro": flechas + barra de progreso (mismo lenguaje visual que la galería) */
.pr-carousel { position: relative; }
.pr-carousel__viewport { position: relative; }
.pr-carousel__nav {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 4;
	width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--pr-line);
	background: #fff; color: var(--pr-ink); display: grid; place-items: center;
	cursor: pointer; box-shadow: var(--pr-shadow); transition: var(--pr-transition);
}
.pr-carousel__nav svg { width: 18px; height: 18px; display: block; }
.pr-carousel__nav:hover:not(:disabled) { background: var(--pr-red); color: #fff; border-color: var(--pr-red); }
.pr-carousel__nav:disabled { opacity: 0; pointer-events: none; }
.pr-carousel__nav--prev { left: -14px; }
.pr-carousel__nav--next { right: -14px; }
.pr-carousel__progress { position: relative; height: 3px; background: var(--pr-line); border-radius: 99px; margin: 6px auto 0; max-width: 240px; }
.pr-carousel__progress span {
	position: absolute; top: 0; left: 0; height: 100%; width: 25%; min-width: 12%;
	background: var(--pr-red); border-radius: 99px; transition: left .12s linear, width .12s linear;
}
.pr-carousel.is-static .pr-carousel__nav,
.pr-carousel.is-static .pr-carousel__progress { display: none; }
@media (max-width: 560px) {
	.pr-carousel__nav { display: none; }
}

/* ---------- Banda roja (promos) ---------- */
.promos { background: var(--pr-red); }
.promos__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding: 56px 24px; }
.promo__media {
	position: relative; min-height: 300px; border-radius: var(--pr-radius); overflow: hidden;
	background-size: cover; background-position: center; background-color: #7a1a1a;
	display: flex; align-items: flex-end;
}
.promo__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.6)); }
.promo__content { position: relative; z-index: 2; padding: 28px; color: #fff; }
.promo__title { color: #fff; font-size: 1.5rem; }
.promo__text { opacity: .92; margin-bottom: 18px; }
.promo .btn--primary { background: #fff; color: var(--pr-red); }
.promo .btn--primary:hover { background: #f1f1f1; }

/* ---------- Destinos ---------- */
.section--destinos { background: var(--pr-ink); }
.section__title--light { color: #fff; }
.destinos__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.destino {
	position: relative; min-height: 200px; border-radius: var(--pr-radius); overflow: hidden;
	display: flex; align-items: center; justify-content: center;
}
.destino__media { position: absolute; inset: 0; background-size: cover; background-position: center; background-color: #2b2f36; transition: transform .6s ease; }
.destino:hover .destino__media { transform: scale(1.08); }
.destino__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.55)); }
.destino__name { position: relative; z-index: 2; color: #fff; font-size: 1.7rem; font-weight: 800; text-shadow: 0 2px 16px rgba(0,0,0,.5); }

/* ---------- TripAdvisor ---------- */
.section--tripadvisor { background: var(--pr-bg-soft); }
.tripadvisor { display: grid; grid-template-columns: 220px 1fr; gap: 40px; align-items: center; }
.tripadvisor__badge { display: flex; justify-content: center; }
.tripadvisor__badge img { width: 100%; max-width: 190px; height: auto; border-radius: 50%; filter: drop-shadow(0 8px 20px rgba(26, 28, 32, .12)); }
.tripadvisor__badge-ph {
	width: 180px; height: 180px; border-radius: 50%; background: #fff; box-shadow: var(--pr-shadow);
	display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 6px;
	border: 4px solid #00aa6c;
}
.tripadvisor__owl { font-size: 3rem; }
.tripadvisor__badge-ph small { color: #00aa6c; font-weight: 800; font-size: .72rem; }
.tripadvisor__title { font-size: clamp(1.5rem, 3vw, 2rem); color: #00765a; }
.tripadvisor__text { color: var(--pr-slate); }
.btn--tripadvisor { background: #00aa6c; color: #fff; }
.btn--tripadvisor:hover { background: #008f5a; }

@media (max-width: 880px) {
	.confianza__grid { grid-template-columns: 1fr 1fr; gap: 20px; }
	.confianza__item:nth-child(odd) { border-left: 0; }
	.destacado { grid-template-columns: 1fr; }
	.promos__grid { grid-template-columns: 1fr; }
	.destinos__grid { grid-template-columns: 1fr 1fr; }
	.tripadvisor { grid-template-columns: 1fr; text-align: center; }
}
@media (max-width: 560px) {
	.confianza__grid { grid-template-columns: 1fr; }
	.confianza__item { border-left: 0 !important; justify-content: flex-start; }
	.destinos__grid { grid-template-columns: 1fr; }
}

/* =========================================================================
   Etapa 4 — Ficha de tour y archivos WooCommerce
   ========================================================================= */

/* Archivo de tienda / categorías */
.woo-archive ul.products {
	list-style: none; margin: 0; padding: 0;
	display: grid; gap: 28px; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.woo-archive .page-title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); margin-bottom: 8px; }

/* Nombres de producto en mayúscula también en carrito y checkout */
.woocommerce td.product-name,
.woocommerce td.product-name a,
.woocommerce-checkout-review-order-table .product-name,
.woocommerce-order-details .product-name,
.woocommerce-order-details td.product-name a,
.wc-block-components-product-name { text-transform: uppercase; }
.woo-archive .term-description, .woo-archive .woocommerce-products-header__title + * { color: var(--pr-muted); max-width: 760px; }

/* Barra de herramientas: "Mostrando resultados" + orden */
.shop-toolbar {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px; flex-wrap: wrap; margin: 8px 0 28px; padding-bottom: 18px;
	border-bottom: 1px solid var(--pr-line);
}
.shop-toolbar .woocommerce-result-count { margin: 0; float: none; color: var(--pr-muted); font-size: .95rem; }
.shop-toolbar .woocommerce-ordering { margin: 0; float: none; }
.shop-toolbar .orderby {
	appearance: none; -webkit-appearance: none;
	border: 1px solid var(--pr-line); border-radius: 999px;
	padding: 11px 42px 11px 18px; font-family: inherit; font-size: .92rem; font-weight: 600;
	color: var(--pr-ink); background-color: #fff; cursor: pointer; line-height: 1;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
	background-repeat: no-repeat; background-position: right 14px center; background-size: 15px;
	transition: var(--pr-transition);
}
.shop-toolbar .orderby:hover { border-color: #c2c8ce; }
.shop-toolbar .orderby:focus { outline: none; border-color: var(--pr-red); box-shadow: 0 0 0 3px rgba(190, 39, 39, .12); }

/* Paginación (con !important + mayor especificidad para anular los bordes de WooCommerce) */
.woo-archive .woocommerce-pagination { margin-top: 48px; text-align: center; }
.woo-archive .woocommerce-pagination ul.page-numbers {
	display: inline-flex; flex-wrap: wrap; justify-content: center; gap: 8px;
	list-style: none; margin: 0; padding: 0;
	border: 0 !important; overflow: visible !important;
}
.woo-archive .woocommerce-pagination ul.page-numbers li {
	margin: 0 !important; border: 0 !important; display: inline-flex !important; overflow: visible;
}
.woo-archive .woocommerce-pagination .page-numbers {
	display: grid; place-items: center; min-width: 46px; height: 46px; padding: 0 14px;
	border-radius: 999px; border: 1px solid var(--pr-line) !important; background: #fff;
	font-weight: 700; font-size: .95rem; color: var(--pr-ink); box-sizing: border-box;
	transition: var(--pr-transition); text-decoration: none;
}
.woo-archive .woocommerce-pagination a.page-numbers:hover { border-color: var(--pr-red) !important; color: var(--pr-red); transform: translateY(-1px); }
.woo-archive .woocommerce-pagination .page-numbers.current { background: var(--pr-red); color: #fff; border-color: var(--pr-red) !important; }
.woo-archive .woocommerce-pagination .page-numbers.dots { border-color: transparent !important; background: transparent; min-width: auto; padding: 0 4px; }

@media (max-width: 480px) {
	.shop-toolbar { justify-content: center; }
	.shop-toolbar .woocommerce-ordering, .shop-toolbar .orderby { width: 100%; }
}

/* Hero de la ficha */
.tour-hero {
	position: relative; min-height: 360px; display: flex; align-items: flex-end;
	background-size: cover; background-position: center; color: #fff;
	background-color: var(--pr-slate);
}
.tour-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.65)); }
.tour-hero__inner { position: relative; z-index: 2; padding: 48px 24px; }
.tour-hero__crumbs { font-size: .85rem; opacity: .9; margin-bottom: 10px; }
.tour-hero__crumbs a { text-decoration: underline; }
.tour-hero__crumbs a, .tour-hero__crumbs span { color: #fff; }
.tour-hero__title { font-size: clamp(1.8rem, 4vw, 3rem); max-width: 900px; text-transform: uppercase; text-shadow: 0 2px 18px rgba(0,0,0,.4); }
.tour-chips { display: flex; flex-wrap: wrap; gap: 10px; list-style: none; padding: 0; margin: 16px 0 0; }
.tour-chip { background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.3); backdrop-filter: blur(4px); padding: 7px 14px; border-radius: 999px; font-size: .85rem; font-weight: 600; }

/* Layout de la ficha */
.tour-layout { display: grid; grid-template-columns: 1fr 380px; gap: 40px; padding-top: 48px; padding-bottom: 48px; align-items: start; }
/* Clave: permite que las columnas no se estiren por contenido ancho (evita scroll horizontal). */
.tour-main, .tour-booking { min-width: 0; }
.tour-intro { font-size: 1.12rem; color: var(--pr-slate); margin-bottom: 28px; }

/* Galería WooCommerce */
.tour-main .woocommerce-product-gallery { margin-bottom: 0; }

/* Proporción fija de la imagen principal: el layout no salta según la foto.
   Cambiá --tour-gallery-ratio para ajustar el encuadro (ej: 4/3, 16/9). */
.tour-single { --tour-gallery-ratio: 3 / 2; }
.tour-main .woocommerce-product-gallery__wrapper,
.tour-main .flex-viewport { height: auto !important; }
.tour-main .woocommerce-product-gallery__image,
.tour-main .woocommerce-product-gallery__image > a {
	display: block; overflow: hidden; border-radius: var(--pr-radius);
	aspect-ratio: var(--tour-gallery-ratio);
}
.tour-main .woocommerce-product-gallery__image img,
.tour-main .woocommerce-product-gallery__image > a > img {
	width: 100% !important; height: 100% !important;
	object-fit: cover !important; object-position: center; border-radius: var(--pr-radius);
}
.tour-main .woocommerce-product-gallery { position: relative; }

/* Quitar la lupa (trigger del lightbox). El clic en la imagen igual la abre completa. */
.tour-main .woocommerce-product-gallery__trigger { display: none !important; }

/* Flechas de navegación sobre la foto principal. */
.tour-main .flex-direction-nav { margin: 0; padding: 0; list-style: none; }
.tour-main .flex-direction-nav a {
	position: absolute; top: 50%; transform: translateY(-50%); z-index: 6;
	width: 46px; height: 46px; border-radius: 50%;
	background: rgba(255, 255, 255, .92); color: var(--pr-ink);
	display: block; font-size: 0; text-indent: 0; overflow: hidden;
	box-shadow: var(--pr-shadow); opacity: 0; transition: opacity .25s ease, background .2s ease, color .2s ease;
}
.tour-main .woocommerce-product-gallery:hover .flex-direction-nav a { opacity: 1; }
.tour-main .flex-direction-nav a:hover { background: var(--pr-red); color: #fff; }
.tour-main .flex-direction-nav .flex-prev { left: 16px; }
.tour-main .flex-direction-nav .flex-next { right: 16px; }
.tour-main .flex-direction-nav a.flex-disabled { opacity: 0 !important; pointer-events: none; }
/* Chevron como ícono SVG centrado (mask → hereda color, perfecto en el centro). */
.tour-main .flex-direction-nav a::before {
	content: ''; position: absolute; top: 50%; left: 50%;
	width: 22px; height: 22px; margin: -11px 0 0 -11px;
	background-color: currentColor;
	-webkit-mask: center / 22px 22px no-repeat;
	mask: center / 22px 22px no-repeat;
}
.tour-main .flex-direction-nav .flex-prev::before {
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 18 9 12 15 6'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='15 18 9 12 15 6'/%3E%3C/svg%3E");
}
.tour-main .flex-direction-nav .flex-next::before {
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 18 15 12 9 6'/%3E%3C/svg%3E");
}
/* En móvil/táctil las dejamos siempre visibles. */
@media (hover: none) {
	.tour-main .flex-direction-nav a { opacity: 1; }
}
/* Miniaturas: una sola fila con scroll horizontal. */
.tour-main .flex-control-thumbs {
	display: flex !important; flex-wrap: nowrap !important; gap: 10px;
	list-style: none; padding: 0; margin: 26px 0 0 !important;
	width: 100% !important; max-width: 100% !important; min-width: 0; box-sizing: border-box;
	overflow-x: auto !important; scroll-snap-type: x proximity;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none; /* la barra nativa se reemplaza por la de progreso */
}
.tour-main .flex-control-thumbs li {
	flex: 0 0 96px !important; width: 96px !important; margin: 0 !important;
	float: none !important; scroll-snap-align: start;
}
.tour-main .flex-control-thumbs img {
	width: 96px; height: 72px; object-fit: cover; border-radius: 8px;
	cursor: pointer; opacity: .65; transition: opacity .2s ease;
}
.tour-main .flex-control-thumbs img.flex-active, .tour-main .flex-control-thumbs img:hover { opacity: 1; }
.tour-main .flex-control-thumbs::-webkit-scrollbar { display: none; height: 0; }

/* Scroller "pro": flechas + barra de progreso */
.thumbs-scroller { margin: 28px 0 36px; }
.thumbs-scroller .flex-control-thumbs { margin: 0 !important; }
.thumbs-row { display: flex; align-items: center; gap: 12px; }
.thumbs-row .flex-control-thumbs { flex: 1 1 auto; }
.thumbs-nav {
	flex: 0 0 auto; width: 40px; height: 40px; border-radius: 50%;
	border: 1px solid var(--pr-line); background: #fff; color: var(--pr-ink);
	display: grid; place-items: center; cursor: pointer; box-shadow: var(--pr-shadow);
	transition: var(--pr-transition);
}
.thumbs-nav svg { width: 17px; height: 17px; display: block; }
.thumbs-nav:hover:not(:disabled) { background: var(--pr-red); color: #fff; border-color: var(--pr-red); transform: translateY(-1px); }
.thumbs-nav:disabled { opacity: .3; cursor: default; box-shadow: none; }
.thumbs-progress { position: relative; height: 3px; background: var(--pr-line); border-radius: 99px; margin: 16px 52px 0; }
.thumbs-progress__bar {
	position: absolute; top: 0; left: 0; height: 100%; width: 25%; min-width: 12%;
	background: var(--pr-red); border-radius: 99px;
	transition: left .12s linear, width .12s linear;
}
.thumbs-scroller.is-static .thumbs-nav,
.thumbs-scroller.is-static .thumbs-progress { display: none; }

/* Acordeón */
.tour-accordion { border: 1px solid var(--pr-line); border-radius: var(--pr-radius); overflow: hidden; margin-bottom: 28px; }
.tour-acc + .tour-acc { border-top: 1px solid var(--pr-line); }
.tour-acc__head {
	width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
	background: #fff; border: 0; padding: 18px 22px; cursor: pointer; text-align: left;
	font-family: inherit; font-size: 1.05rem; font-weight: 700; color: var(--pr-ink);
}
.tour-acc__head:hover { background: var(--pr-bg-soft); }
.tour-acc__plus { color: var(--pr-red); font-size: 1.4rem; line-height: 1; transition: transform .35s ease; }
.tour-acc.is-open .tour-acc__plus { transform: rotate(45deg); }
/* Apertura suave: animamos grid-template-rows de 0fr a 1fr (anima a la altura real). */
.tour-acc__body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .4s cubic-bezier(.4, 0, .2, 1); }
.tour-acc.is-open .tour-acc__body { grid-template-rows: 1fr; }
.tour-acc__inner { overflow: hidden; min-height: 0; }
.tour-acc__inner > *:first-child { margin-top: 0; }
.tour-acc.is-open .tour-acc__inner { padding: 2px 22px 22px; }
.tour-acc__inner img { display: inline; vertical-align: middle; }

.tour-block { margin-bottom: 32px; }
.tour-block__title { font-size: 1.5rem; margin-bottom: 18px; }

/* Video del tour (YouTube/Vimeo embed o MP4) — responsivo 16:9 */
.tour-video__frame {
	position: relative; aspect-ratio: 16 / 9; overflow: hidden;
	border-radius: var(--pr-radius); background: #000;
}
.tour-video__frame iframe,
.tour-video__frame video {
	position: absolute; inset: 0; width: 100% !important; height: 100% !important; border: 0;
}

/* Itinerario (timeline) */
.tour-timeline { list-style: none; margin: 0; padding: 0; border-left: 2px solid var(--pr-line); }
.tour-timeline__item { position: relative; padding: 0 0 22px 26px; }
.tour-timeline__item::before { content: ''; position: absolute; left: -7px; top: 4px; width: 12px; height: 12px; border-radius: 50%; background: var(--pr-red); }
.tour-timeline__time { font-weight: 800; color: var(--pr-red); margin-right: 10px; }

/* Caja de reserva (sticky) */
.tour-booking { position: sticky; top: calc(var(--pr-header-h) + 20px); }
.tour-booking__card { background: #fff; border: 1px solid var(--pr-line); border-radius: var(--pr-radius); box-shadow: var(--pr-shadow); padding: 24px; }
.tour-booking__price { display: flex; align-items: baseline; gap: 8px; margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid var(--pr-line); }
.tour-booking__price-label { color: var(--pr-muted); font-size: .9rem; }
.tour-booking__price-value { font-size: 1.8rem; font-weight: 800; color: var(--pr-red); }
.tour-booking__price-value .amount, .tour-booking__price-value bdi { color: var(--pr-red); }
.tour-booking .quantity input { padding: 10px; border: 1px solid var(--pr-line); border-radius: 8px; width: 80px; }
.tour-booking .single_add_to_cart_button,
.tour-booking .yith-wcbk-add-to-cart-button,
.tour-booking button.button,
.tour-booking button.button.alt,
.tour-booking input.button.alt {
	width: 100%; background: var(--pr-red) !important; color: #fff !important; border: 0 !important;
	padding: 15px; border-radius: 999px; font-weight: 800; font-size: 1rem; cursor: pointer;
	margin-top: 12px; transition: var(--pr-transition); text-transform: none;
}
.tour-booking .single_add_to_cart_button:hover,
.tour-booking .yith-wcbk-add-to-cart-button:hover,
.tour-booking button.button.alt:hover { background: var(--pr-red-dark) !important; }
.btn--block { width: 100%; justify-content: center; margin-top: 12px; }
.tour-booking__trust { list-style: none; margin: 18px 0 0; padding: 16px 0 0; border-top: 1px solid var(--pr-line); color: var(--pr-slate); font-size: .9rem; }
.tour-booking__trust li { margin-bottom: 8px; }

/* Más tours (banda gris full-width con aire arriba y abajo) */
.tour-related-band { background: var(--pr-bg-soft); margin-top: 48px; padding: 64px 0 80px; border-top: 1px solid var(--pr-line); }
.tour-related-band:not(:has(.related)) { display: none; } /* sin relacionados → no se muestra la banda */
.related.products > h2, .upsells > h2 { font-size: 1.7rem; margin: 0 0 28px; }
.related.products ul.products, .related ul.products {
	list-style: none; margin: 0; padding: 0; display: grid; gap: 28px;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

@media (max-width: 960px) {
	.tour-layout { grid-template-columns: 1fr; }
	.tour-booking { position: static; }
}

/* --- Neutralizar el layout por defecto de WooCommerce (floats / anchos %) --- */
/* La galería deja de flotar al 48%: ocupa su columna y el acordeón va debajo. */
.tour-single div.product .woocommerce-product-gallery,
.tour-single .woocommerce-product-gallery,
.tour-single div.images {
	float: none !important;
	width: 100% !important;
	max-width: 100%;
	margin: 0 0 28px !important;
}
.tour-single .woocommerce-product-gallery__wrapper { margin: 0; }
/* La galería ocupa su columna; el contenido ancho (thumbs) no debe desbordarla. */
.tour-main .woocommerce-product-gallery { max-width: 100%; overflow: hidden; }

/* Cards de archivos y relacionados: anular width:30.75% y float de WooCommerce. */
.woo-archive ul.products li.product,
.related ul.products li.product,
.upsells ul.products li.product {
	width: auto !important;
	float: none !important;
	margin: 0 !important;
	clear: none !important;
}
.woo-archive ul.products,
.related ul.products,
.upsells ul.products {
	display: grid !important;
	gap: 28px;
	/* auto-fit estira los ítems para llenar el ancho (4 columnas en desktop). */
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}
.woo-archive ul.products::before, .woo-archive ul.products::after,
.related ul.products::before, .related ul.products::after,
.upsells ul.products::before, .upsells ul.products::after { content: none !important; display: none !important; }
/* El badge de categoría no debe desbordar la card. */
.card-tour__badge { max-width: calc(100% - 28px); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* =========================================================================
   Etapa 5 — Páginas internas
   ========================================================================= */
.page-hero { position: relative; background: var(--pr-ink); color: #fff; padding: 64px 0; overflow: hidden; }
.page-hero--img { background-size: cover; background-position: center; }
.page-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,22,26,.5), rgba(20,22,26,.75)); }
.page-hero .container { position: relative; z-index: 2; }
.page-hero__eyebrow { display: block; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; font-weight: 800; color: #ff8a8a; margin-bottom: 8px; }
.page-hero__title { font-size: clamp(2rem, 4vw, 3rem); }
.page-hero__lead { font-size: 1.15rem; opacity: .92; max-width: 640px; margin-top: 10px; }

.prose { max-width: 820px; font-size: 1.05rem; color: var(--pr-slate); }
.prose h2, .prose h3 { color: var(--pr-ink); margin-top: 1.4em; }
.prose p { margin: 0 0 1.1em; }
.prose ul, .prose ol { margin: 0 0 1.1em; padding-left: 1.3em; }
.prose img { border-radius: var(--pr-radius); margin: 1em 0; }
.prose a { color: var(--pr-red); text-decoration: underline; }

/* Nosotros — intro con collage */
.nosotros__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 60px; align-items: center; }
.nosotros__collage { position: relative; }
.nosotros__collage-main { aspect-ratio: 4 / 3; border-radius: var(--pr-radius); overflow: hidden; box-shadow: var(--pr-shadow-lg); }
.nosotros__collage-main img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nosotros__collage-ph { width: 100%; height: 100%; background: linear-gradient(135deg, #e9edf0, #cdd5db); }
.nosotros__collage-sub { position: absolute; right: -22px; bottom: -28px; width: 45%; aspect-ratio: 1 / 1; border-radius: var(--pr-radius); overflow: hidden; border: 5px solid #fff; box-shadow: var(--pr-shadow-lg); }
.nosotros__collage-sub img { width: 100%; height: 100%; object-fit: cover; display: block; }
.nosotros__badge { position: absolute; left: -18px; top: 26px; display: flex; align-items: center; gap: 10px; background: var(--pr-red); color: #fff; padding: 12px 18px; border-radius: 16px; box-shadow: var(--pr-shadow-lg); }
.nosotros__badge-ico { font-size: 1.5rem; }
.nosotros__badge-txt strong { display: block; font-size: 1.3rem; line-height: 1; }
.nosotros__badge-txt small { display: block; font-size: .7rem; opacity: .92; margin-top: 2px; }
.nosotros__body .section__eyebrow { margin-bottom: 12px; }
.nosotros__body .prose { max-width: none; }
@media (max-width: 860px) {
	.nosotros__grid { grid-template-columns: 1fr; gap: 44px; }
	.nosotros__collage { margin-bottom: 26px; }
	.nosotros__collage-sub { width: 42%; right: 8px; bottom: -22px; }
	.nosotros__badge { left: 8px; top: 14px; }
}
.section--razones { background: #fff; }
.razones__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }

/* Fundador */
.fundador__grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 48px; align-items: center; }
.fundador__media img, .fundador__media-ph { width: 100%; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow-lg); display: block; }
.fundador__media-ph { aspect-ratio: 3 / 4; background: linear-gradient(135deg, #e9edf0, #cdd5db); }
.fundador__cargo { color: var(--pr-red); font-weight: 700; margin: -6px 0 16px; }
.fundador__text { color: var(--pr-slate); font-size: 1.06rem; }
@media (max-width: 860px) { .fundador__grid { grid-template-columns: 1fr; } }
.razon { background: #fff; border-radius: var(--pr-radius); padding: 30px 26px; box-shadow: var(--pr-shadow); text-align: center; }
.razon__icon { font-size: 2.2rem; display: block; margin-bottom: 12px; color: var(--pr-red); }
.razon__icon img { width: 52px; height: 52px; object-fit: contain; display: inline-block; }
.razon__icon svg.pr-ico { width: 50px; height: 50px; overflow: visible; }
.razon__title { font-size: 1.2rem; }
.razon__text { color: var(--pr-muted); }

/* Contacto */
.contacto__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 44px; align-items: start; }
.contacto__list { list-style: none; margin: 0 0 24px; padding: 0; font-size: 1.05rem; }
.contacto__list li { margin-bottom: 14px; display: flex; gap: 10px; }
.contacto__list a { color: var(--pr-red); }
.contacto__map { margin-top: 18px; }
.contacto__map iframe { width: 100%; min-height: 280px; border: 0; border-radius: var(--pr-radius); }
.contacto__form { background: #fff; border: 1px solid var(--pr-line); border-radius: var(--pr-radius); padding: 28px; box-shadow: var(--pr-shadow); }
.contacto__form label { display: block; margin-bottom: 16px; }
.contacto__form label > span { display: block; font-weight: 600; font-size: .9rem; margin-bottom: 6px; }
.contacto__form input, .contacto__form textarea {
	width: 100%; padding: 12px 14px; border: 1px solid var(--pr-line); border-radius: 10px;
	font-family: inherit; font-size: 1rem;
}
.contacto__form input:focus, .contacto__form textarea:focus { outline: 2px solid var(--pr-red); border-color: var(--pr-red); }
.contacto__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contacto__hp { position: absolute; left: -9999px; }
.contacto__feedback { margin: 14px 0 0; font-weight: 600; }
.contacto__feedback.is-ok { color: #1a8f4c; }
.contacto__feedback.is-error { color: var(--pr-red); }

@media (max-width: 860px) {
	.nosotros__grid--img, .contacto__grid, .razones__grid { grid-template-columns: 1fr; }
	.razones__grid { grid-template-columns: 1fr; }
	.nosotros__media img { position: static; }
}

/* =========================================================================
   Landing "Sombras Doradas"
   ========================================================================= */
.section--soft { background: var(--pr-bg-soft); }
.section__eyebrow { display: block; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; font-weight: 800; color: var(--pr-red); margin-bottom: 10px; }
.section__title--left { text-align: left; }

/* Hero */
.sd-hero {
	position: relative; min-height: min(60vh, 460px); display: flex; align-items: center;
	color: #fff; text-align: center; background-size: cover; background-position: center;
	background-color: var(--pr-slate); padding: 60px 0 90px;
}
.sd-hero__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,22,26,.25), rgba(20,22,26,.6)); }
.sd-hero__inner { position: relative; z-index: 2; }
.sd-hero__title { font-size: clamp(2rem, 5vw, 3.4rem); text-shadow: 0 2px 20px rgba(0,0,0,.4); }
.sd-hero__sub { font-size: clamp(1.05rem, 2vw, 1.3rem); opacity: .95; max-width: 680px; margin: 8px auto 0; }
.sd-hero__eyebrow { display: block; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; font-weight: 800; color: #ffb3b3; margin-bottom: 10px; }
/* Variante para páginas internas (sin tarjetas superpuestas): menos padding inferior. */
.sd-hero--compact { min-height: auto; padding: 74px 0; }

/* Beneficios (se superponen al hero) */
.sd-benefits { position: relative; z-index: 3; margin-top: -60px; }
.sd-benefits__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.sd-benefit { background: #fff; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow); padding: 30px 26px; text-align: center; }
.sd-benefit__icon { font-size: 2.2rem; display: block; margin-bottom: 12px; color: var(--pr-red); }
.sd-benefit__icon img { width: 56px; height: 56px; object-fit: contain; display: inline-block; }
.sd-benefit__icon svg.pr-ico { width: 54px; height: 54px; overflow: visible; }
.sd-benefit__title { font-size: 1.15rem; margin-bottom: 8px; }
.sd-benefit__text { color: var(--pr-muted); font-size: .95rem; }

.sd-benefits__grid--4 { grid-template-columns: repeat(4, 1fr); }

/* Traslados — galería simple (4 fotos por fila, mismo tamaño) */
.galeria-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.galeria-4__item { margin: 0; aspect-ratio: 4 / 3; border-radius: var(--pr-radius); overflow: hidden; box-shadow: var(--pr-shadow); }
.galeria-4__item img { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 860px) { .galeria-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .galeria-4 { grid-template-columns: 1fr; } }

/* Traslados — listado simple de rutas */
.rutas-lista {
	list-style: none; margin: 0 auto; padding: 0; max-width: 760px;
	display: grid; grid-template-columns: 1fr 1fr; gap: 2px 48px;
}
.rutas-lista__item {
	display: flex; align-items: center; gap: 12px; padding: 15px 4px;
	border-bottom: 1px solid var(--pr-line); font-size: 1.08rem;
}
.rutas-lista__from { font-weight: 700; color: var(--pr-ink); }
.rutas-lista__arrow { color: var(--pr-red); font-weight: 800; }
.rutas-lista__to { color: var(--pr-slate); }

/* Traslados — bloque "destinos a coordinar" */
.coordinar { position: relative; padding: 84px 0; text-align: center; color: #fff; background: var(--pr-red); overflow: hidden; }
.coordinar__overlay { position: absolute; inset: 0; background: radial-gradient(circle at 50% 0%, rgba(255,255,255,.12), transparent 60%); }
.coordinar__inner { position: relative; z-index: 2; }
.coordinar__title { font-size: clamp(1.7rem, 3.5vw, 2.5rem); color: #fff; }
.coordinar__text { font-size: 1.12rem; opacity: .95; max-width: 620px; margin: 8px auto 26px; }
.coordinar .btn--whatsapp { background: #fff; color: var(--pr-red); }
.coordinar .btn--whatsapp:hover { background: #f1f1f1; }

@media (max-width: 900px) {
	.sd-benefits__grid--4 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
	.rutas-lista { grid-template-columns: 1fr; }
}

/* Variantes */
.sd-variants__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.sd-variant { text-align: center; }
.sd-variant__media { aspect-ratio: 16 / 10; border-radius: var(--pr-radius); background-size: cover; background-position: center; background-color: #e9edf0; margin-bottom: 20px; box-shadow: var(--pr-shadow); }
.sd-variant__title { font-size: 1.35rem; margin-bottom: 10px; }
.sd-variant__text { color: var(--pr-slate); margin-bottom: 20px; }

/* Recorridos (mapa + itinerario, alternados) */
.sd-route { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; margin-bottom: 48px; }
.sd-route:last-child { margin-bottom: 0; }
.sd-route--reverse .sd-route__map { order: 2; }
.sd-route__map img { width: 100%; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow); }
.sd-route__map-ph { aspect-ratio: 4 / 3; border-radius: var(--pr-radius); background: #e3e8ec; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--pr-muted); }
.sd-route__map-ph span { font-size: 2.4rem; }
.sd-route__title { font-size: 1.5rem; margin-bottom: 20px; }
.sd-route__info .btn { margin-top: 22px; }

/* Galería (masonry) */
.sd-gallery { padding: 0; }
.sd-gallery__grid { columns: 4; column-gap: 8px; padding: 8px 0; }
.sd-gallery__item { margin: 0 0 8px; break-inside: avoid; }
.sd-gallery__item img { width: 100%; display: block; }

/* FAQ */
.sd-faq__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 44px; align-items: center; }
.sd-faq__media img, .sd-faq__media-ph { width: 100%; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow); }
.sd-faq__media-ph { aspect-ratio: 4 / 3; background: linear-gradient(135deg, #e9edf0, #cdd5db); }
.sd-faq__list .section__title { margin-bottom: 22px; }

@media (max-width: 900px) {
	.sd-benefits__grid { grid-template-columns: 1fr; }
	.sd-benefits { margin-top: -40px; }
	.sd-variants__grid, .sd-route, .sd-faq__grid { grid-template-columns: 1fr; }
	.sd-route--reverse .sd-route__map { order: 0; }
	.sd-gallery__grid { columns: 2; }
}

/* =========================================================================
   Home › Sección Nosotros + CTA final
   ========================================================================= */
.sobre-nosotros { background: var(--pr-bg-soft); border-top: 1px solid var(--pr-line); border-bottom: 1px solid var(--pr-line); }
.sobre-nosotros__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 48px; align-items: center; }
.sobre-nosotros__media img, .sobre-nosotros__media-ph { width: 100%; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow-lg); display: block; }
.sobre-nosotros__media-ph { aspect-ratio: 4 / 3; background: linear-gradient(135deg, #e9edf0, #cdd5db); }
.sobre-nosotros__text { color: var(--pr-slate); font-size: 1.08rem; margin-bottom: 28px; }
.sobre-nosotros__stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-bottom: 30px; }
.stat__num { display: block; font-size: 1.9rem; font-weight: 900; color: var(--pr-red); line-height: 1; }
.stat__label { display: block; font-size: .82rem; color: var(--pr-muted); margin-top: 5px; }

.cta-final {
	position: relative; padding: 92px 0; text-align: center; color: #fff;
	background-color: var(--pr-slate); background-size: cover; background-position: center;
}
.cta-final__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20, 22, 26, .55), rgba(190, 39, 39, .5)); }
.cta-final__inner { position: relative; z-index: 2; }
.cta-final__title { font-size: clamp(1.8rem, 4vw, 2.8rem); text-shadow: 0 2px 18px rgba(0, 0, 0, .35); }
.cta-final__text { font-size: 1.15rem; opacity: .95; max-width: 620px; margin: 8px auto 26px; }
.cta-final .btn--whatsapp { background: #fff; color: var(--pr-red); }
.cta-final .btn--whatsapp:hover { background: #f1f1f1; }

/* Cierre "Visitanos en Paracas" */
.visitanos__grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 44px; align-items: center; }
.visitanos__text { color: var(--pr-slate); font-size: 1.08rem; margin-bottom: 22px; }
.visitanos__list { list-style: none; margin: 0 0 26px; padding: 0; }
.visitanos__list li { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; font-size: 1.05rem; }
.visitanos__list a { color: var(--pr-ink); }
.visitanos__list a:hover { color: var(--pr-red); }
.visitanos__ico { font-size: 1.1rem; }
.visitanos__map iframe { width: 100%; min-height: 340px; border: 0; border-radius: var(--pr-radius); box-shadow: var(--pr-shadow); display: block; }
.visitanos__map-ph {
	min-height: 340px; border-radius: var(--pr-radius); background: #e3e8ec;
	display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px; color: var(--pr-muted);
}
.visitanos__map-ph span { font-size: 2.6rem; }

@media (max-width: 860px) {
	.visitanos__grid { grid-template-columns: 1fr; }
}

@media (max-width: 860px) {
	.sobre-nosotros__grid { grid-template-columns: 1fr; }
	.sobre-nosotros__stats { grid-template-columns: repeat(2, 1fr); }
}

/* Home › Mapa de cierre a todo el ancho */
.home-mapa { line-height: 0; }
.home-mapa iframe { width: 100%; height: 440px; border: 0; display: block; }
.home-mapa__ph {
	height: 300px; background: var(--pr-bg-soft); display: flex; flex-direction: column;
	align-items: center; justify-content: center; gap: 8px; color: var(--pr-muted); line-height: 1.4;
}
.home-mapa__ph span { font-size: 2.6rem; }

/* ---------- Footer ---------- */
.site-footer { background: var(--pr-ink); color: #cfd4da; margin-top: 0; }
.site-footer__grid {
	display: grid; gap: 36px; padding: 64px 24px;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
}
.site-footer__brand img { height: 46px; width: auto; filter: brightness(0) invert(1); opacity: .9; }
.site-footer__tagline { margin-top: 14px; color: #9aa1aa; font-size: .95rem; }
.footer-widget__title { color: #fff; font-size: 1rem; margin-bottom: 16px; }
.site-footer__menu, .site-footer__contact { list-style: none; margin: 0; padding: 0; }
.site-footer__menu li, .site-footer__contact li { margin-bottom: 10px; }
.site-footer a:hover { color: #fff; }
.site-footer__social { display: flex; gap: 16px; margin-top: 14px; font-weight: 600; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); }
.site-footer__bottom .container { padding-top: 20px; padding-bottom: 20px; }
.site-footer__bottom p { margin: 0; font-size: .85rem; color: #8b929b; }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
	.site-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
	.nav-toggle { display: inline-flex; }
	.btn--whatsapp .btn__label { display: none; }
	.site-nav {
		position: fixed; inset: var(--pr-header-h) 0 auto 0;
		background: #fff; border-bottom: 1px solid var(--pr-line);
		transform: translateY(-120%); transition: var(--pr-transition); padding: 16px 24px;
		max-height: calc(100vh - var(--pr-header-h)); overflow-y: auto;
	}
	.site-nav.is-open { transform: translateY(0); }
	.site-nav__menu { flex-direction: column; align-items: stretch; gap: 2px; }
	.site-nav__menu .sub-menu {
		position: static; opacity: 1; visibility: visible; transform: none;
		box-shadow: none; border: none; padding-left: 14px;
	}
	.nav-toggle[aria-expanded="true"] .nav-toggle__bar { background: transparent; }
	.nav-toggle[aria-expanded="true"] .nav-toggle__bar::before { top: 0; transform: rotate(45deg); }
	.nav-toggle[aria-expanded="true"] .nav-toggle__bar::after { top: 0; transform: rotate(-45deg); }
}
@media (max-width: 560px) {
	.site-footer__grid { grid-template-columns: 1fr; }
	.section { padding: 52px 0; }
}
