/* ==========================================================================
   Complejo Los Cedros · main.css
   Paleta serrana · Tipografía Playfair Display + Lora
   ========================================================================== */

:root {
	/* Paleta */
	--c-cedro:  #3A5A40;
	--c-olivo:  #626F47;
	--c-madera: #B88E6B;
	--c-marron: #5C4033;
	--c-crema:  #FDF7ED;
	--c-piedra: #A0AEC0;

	--c-ink:     #2C2A26;
	--c-ink-60:  #5A574F;
	--c-ink-40:  #8A8679;
	--c-line:    rgba(92, 64, 51, 0.14);
	--c-line-2:  rgba(58, 90, 64, 0.18);
	--c-bg:      #FDF7ED;
	--c-bg-soft: #F7EEDC;
	--c-white:   #FFFFFF;

	/* Tipografía */
	--font-display: "Playfair Display", "Cormorant Garamond", Georgia, serif;
	--font-body:    "Lora", Georgia, "Times New Roman", serif;

	/* Tamaños */
	--fs-xxl:  clamp(3rem, 7vw, 6rem);
	--fs-xl:   clamp(2.2rem, 5vw, 4rem);
	--fs-lg:   clamp(1.75rem, 3.2vw, 2.6rem);
	--fs-md:   clamp(1.35rem, 2vw, 1.75rem);
	--fs-body: 1.0625rem;  /* 17px */
	--fs-sm:   0.9375rem;
	--fs-xs:   0.8125rem;

	/* Layout */
	--container: 1280px;
	--gutter:    clamp(1.25rem, 4vw, 3rem);
	--radius:    6px;
	--radius-lg: 14px;

	/* Elevación */
	--shadow-sm: 0 2px 10px rgba(44, 42, 38, 0.06);
	--shadow-md: 0 12px 40px rgba(44, 42, 38, 0.10);
	--shadow-lg: 0 30px 80px rgba(44, 42, 38, 0.18);

	/* Motion */
	--ease:  cubic-bezier(0.22, 0.61, 0.36, 1);
	--fast:  200ms;
	--slow:  700ms;
}

/* ---------- Reset & base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--font-body);
	font-size: var(--fs-body);
	line-height: 1.7;
	color: var(--c-ink);
	background: var(--c-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--c-cedro); text-decoration: none; transition: color var(--fast) var(--ease); }
a:hover { color: var(--c-marron); }
button { font-family: inherit; cursor: pointer; border: 0; background: transparent; }
figure { margin: 0; }
p { margin: 0 0 1em; }

h1, h2, h3, h4, h5 {
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--c-marron);
	line-height: 1.12;
	letter-spacing: -0.01em;
	margin: 0 0 0.5em;
}

.skip-link {
	position: absolute; left: -9999px; top: 0;
	background: var(--c-cedro); color: #fff; padding: .6rem 1rem; z-index: 100;
}
.skip-link:focus { left: 1rem; top: 1rem; }
.screen-reader-text {
	position: absolute !important; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.muted { color: var(--c-ink-40); }

/* ---------- Utilities ---------- */
.container {
	width: 100%; max-width: var(--container);
	margin: 0 auto; padding-inline: var(--gutter);
}
.section { padding-block: clamp(4rem, 8vw, 7.5rem); }
.section--bg { background: var(--c-bg-soft); }
.section--dark { background: var(--c-cedro); color: #EEE8D7; }
.section--dark h2, .section--dark h3 { color: var(--c-crema); }

.eyebrow {
	display: inline-flex; align-items: center; gap: .6em;
	font-family: var(--font-body);
	font-size: .78rem; letter-spacing: .2em; text-transform: uppercase;
	color: var(--c-olivo); font-style: italic; font-weight: 500;
	margin-bottom: 1.1rem;
}
.eyebrow::before {
	content: ""; width: 38px; height: 1px; background: var(--c-olivo);
}
.section--dark .eyebrow { color: var(--c-madera); }
.section--dark .eyebrow::before { background: var(--c-madera); }

.lead {
	font-family: var(--font-display);
	font-style: italic;
	font-size: var(--fs-md);
	font-weight: 400;
	color: var(--c-ink-60);
	line-height: 1.45;
	max-width: 48ch;
}

.divider {
	display: flex; align-items: center; gap: 1rem;
	color: var(--c-madera);
}
.divider::before, .divider::after {
	content: ""; flex: 1; height: 1px; background: currentColor; opacity: .35;
}

/* ---------- Botones ---------- */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
	padding: .95rem 1.9rem;
	font-family: var(--font-body);
	font-size: .93rem; font-weight: 500; letter-spacing: .08em; text-transform: uppercase;
	border-radius: var(--radius);
	transition: all var(--fast) var(--ease);
	border: 1px solid transparent;
	white-space: nowrap;
}
.btn--primary {
	background: var(--c-cedro); color: #fff;
}
.btn--primary:hover { background: var(--c-marron); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-md); }
.btn--ghost {
	background: transparent; color: var(--c-marron); border-color: var(--c-marron);
}
.btn--ghost:hover { background: var(--c-marron); color: #fff; }
.btn--light {
	background: var(--c-crema); color: var(--c-marron);
}
.btn--light:hover { background: #fff; }
.btn--whatsapp {
	background: #25D366; color: #fff;
}
.btn--whatsapp:hover { background: #1DA851; color: #fff; }
.btn--lg { padding: 1.1rem 2.4rem; font-size: 1rem; }

/* ---------- Topbar ---------- */
.topbar {
	background: var(--c-marron); color: var(--c-crema);
	font-size: var(--fs-xs); letter-spacing: .05em;
}
.topbar__inner {
	max-width: var(--container); margin: 0 auto;
	padding: .55rem var(--gutter);
	display: flex; gap: 1.5rem; justify-content: space-between; align-items: center;
}
.topbar__item { display: inline-flex; align-items: center; gap: .5rem; }
.topbar__item--right { display: inline-flex; gap: .7rem; }
.topbar a { color: inherit; }
.topbar a:hover { color: var(--c-madera); }
.topbar__sep { opacity: .5; }
.topbar .icon { width: 14px; height: 14px; color: var(--c-madera); }
@media (max-width: 720px) {
	.topbar__item:first-child { display: none; }
	.topbar__inner { justify-content: center; }
}

/* ---------- Header ---------- */
.site-header {
	position: sticky; top: 0; z-index: 50;
	background: rgba(253, 247, 237, 0.88);
	backdrop-filter: saturate(140%) blur(12px);
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	border-bottom: 1px solid var(--c-line);
	transition: background var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
}
.site-header.is-scrolled {
	background: rgba(253, 247, 237, 0.98);
	box-shadow: var(--shadow-sm);
}
.site-header__inner {
	max-width: var(--container); margin: 0 auto;
	padding: 1rem var(--gutter);
	display: flex; align-items: center; flex-wrap: nowrap;
	gap: clamp(.9rem, 1.6vw, 1.75rem);
}
.brand {
	display: inline-flex; align-items: center; gap: .3rem;
	color: var(--c-marron); text-decoration: none; flex-shrink: 0;
}
.brand__mark {
	width: 72px; height: 72px;
	display: grid; place-items: center;
	flex-shrink: 0;
}
.brand__mark svg { width: 26px; height: 26px; color: var(--c-cedro); }
.brand__mark img { width: 100%; height: 100%; object-fit: contain; display: block; }
.site-footer .brand__mark { width: 72px; height: 72px; }
.site-footer .brand__mark img { width: 100%; height: 100%; object-fit: contain; display: block; }
.brand__text { display: flex; flex-direction: column; line-height: 1; min-width: 0; }
.brand__name {
	font-family: var(--font-display);
	font-size: clamp(1.05rem, 1.2vw, 1.3rem); font-weight: 600;
	color: var(--c-marron); letter-spacing: .01em;
	white-space: nowrap;
}
.brand__tag {
	font-size: .68rem; letter-spacing: .2em; text-transform: uppercase;
	color: var(--c-olivo); margin-top: .3rem; font-style: italic;
	white-space: nowrap;
}

.site-nav { margin-left: auto; min-width: 0; }
.nav-menu {
	list-style: none; margin: 0; padding: 0;
	display: flex; align-items: center; flex-wrap: nowrap;
	gap: clamp(.85rem, 1.4vw, 1.75rem);
}
.nav-menu li { flex-shrink: 0; }
.nav-menu a {
	font-family: var(--font-body);
	font-size: clamp(.82rem, .9vw, .92rem); letter-spacing: .05em;
	color: var(--c-marron); position: relative; padding: .25rem 0;
	white-space: nowrap;
}
.nav-menu a::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -4px;
	height: 1px; background: var(--c-cedro); transform: scaleX(0); transform-origin: left;
	transition: transform var(--fast) var(--ease);
}
.nav-menu a:hover, .nav-menu .current-menu-item > a { color: var(--c-cedro); }
.nav-menu a:hover::after, .nav-menu .current-menu-item > a::after { transform: scaleX(1); }

.site-header__cta { flex-shrink: 0; }
.site-header__cta .btn { padding: .7rem 1.3rem; font-size: .8rem; white-space: nowrap; }

.nav-toggle {
	display: none;
	width: 42px; height: 42px;
	flex-direction: column; justify-content: center; gap: 5px;
	padding: 0;
}
.nav-toggle span {
	display: block; height: 2px; width: 24px; margin: 0 auto;
	background: var(--c-marron);
	transition: transform var(--fast) var(--ease), opacity var(--fast) var(--ease);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 1100px) {
	.brand__tag { display: none; }
}
@media (max-width: 960px) {
	.site-header__inner { flex-wrap: wrap; }
	.site-header__cta { margin-left: auto; }
	.nav-toggle { display: flex; order: 3; }
	.site-nav {
		order: 4; width: 100%;
		max-height: 0; overflow: hidden;
		transition: max-height var(--fast) var(--ease);
	}
	.site-nav.is-open { max-height: 600px; }
	.nav-menu {
		flex-direction: column; gap: 0;
		padding: 1rem 0 1.5rem;
	}
	.nav-menu li { width: 100%; }
	.nav-menu a {
		display: block; padding: .75rem 0;
		border-bottom: 1px solid var(--c-line);
		font-size: 1rem;
	}
}
@media (max-width: 540px) {
	.site-header__cta .btn { padding: .55rem 1rem; font-size: .78rem; }
	.brand__tag { display: none; }
}

/* ---------- Hero ---------- */
.hero {
	position: relative;
	min-height: clamp(620px, 92vh, 880px);
	display: flex; align-items: flex-end;
	color: #fff;
	overflow: hidden;
	isolation: isolate;
}
.hero::before {
	content: "";
	position: absolute; inset: 0;
	background-image: linear-gradient(
			to bottom,
			rgba(44, 42, 38, 0.15) 0%,
			rgba(44, 42, 38, 0.25) 40%,
			rgba(44, 42, 38, 0.75) 100%
		),
		url("../images/hero.jpg");
	background-size: cover;
	background-position: center;
	z-index: -1;
	transform: scale(1.04);
	animation: heroZoom 16s var(--ease) forwards;
}
@keyframes heroZoom { to { transform: scale(1); } }
.hero__inner {
	max-width: var(--container); margin: 0 auto; width: 100%;
	padding: 4rem var(--gutter) 5rem;
}
.hero__kicker {
	display: inline-block;
	font-size: .78rem; letter-spacing: .35em; text-transform: uppercase;
	color: var(--c-madera); font-style: italic; margin-bottom: 1.5rem;
	opacity: 0; transform: translateY(14px);
	animation: fadeUp .9s var(--ease) .2s forwards;
}
.hero h1 {
	font-size: var(--fs-xxl);
	color: #fff;
	font-weight: 400;
	letter-spacing: -0.015em;
	max-width: 14ch;
	margin-bottom: 1.2rem;
	opacity: 0; transform: translateY(18px);
	animation: fadeUp .9s var(--ease) .35s forwards;
}
.hero h1 em {
	font-style: italic; color: var(--c-madera); font-weight: 400;
}
.hero__desc {
	font-family: var(--font-body);
	font-size: 1.1rem; max-width: 46ch; color: rgba(255,255,255,0.88);
	margin-bottom: 2.2rem;
	opacity: 0; transform: translateY(18px);
	animation: fadeUp .9s var(--ease) .5s forwards;
}
.hero__actions {
	display: flex; flex-wrap: wrap; gap: .8rem;
	opacity: 0; transform: translateY(18px);
	animation: fadeUp .9s var(--ease) .65s forwards;
}
.hero__actions .btn--ghost { color: #fff; border-color: rgba(255,255,255,.6); }
.hero__actions .btn--ghost:hover { background: #fff; color: var(--c-marron); border-color: #fff; }

.hero__meta {
	position: absolute; right: var(--gutter); bottom: 2rem;
	display: flex; gap: 2.5rem;
	color: rgba(255,255,255,.82);
	font-size: var(--fs-xs); letter-spacing: .2em; text-transform: uppercase;
}
.hero__meta span { display: flex; flex-direction: column; line-height: 1.4; }
.hero__meta strong { color: #fff; font-family: var(--font-display); font-size: 1.1rem; letter-spacing: 0; text-transform: none; font-weight: 500; }
@media (max-width: 780px) { .hero__meta { display: none; } }

@keyframes fadeUp { to { opacity: 1; transform: none; } }

/* ---------- Home — Intro ---------- */
.intro {
	display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}
@media (max-width: 900px) { .intro { grid-template-columns: 1fr; } }
.intro__title {
	font-size: var(--fs-xl);
	margin-bottom: 1.3rem;
}
.intro__title em { font-style: italic; color: var(--c-cedro); }
.intro__body p + p { margin-top: 1em; }
.intro__figure {
	position: relative; aspect-ratio: 4/5;
	background: var(--c-bg-soft) url("../images/familiar.jpg") center/cover no-repeat;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}
.intro__figure::after {
	content: "Desde el año 2000";
	position: absolute; left: 1.5rem; bottom: 1.5rem; right: 1.5rem;
	color: #fff; font-family: var(--font-display); font-style: italic; font-size: 1.1rem;
	text-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.intro__stats {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
	margin-top: 2.5rem; padding-top: 2rem;
	border-top: 1px solid var(--c-line);
}
.intro__stats div strong {
	display: block;
	font-family: var(--font-display);
	font-size: 2.2rem; color: var(--c-cedro); font-weight: 600;
	line-height: 1;
}
.intro__stats div span {
	display: block; margin-top: .4rem;
	font-size: .82rem; letter-spacing: .15em; text-transform: uppercase;
	color: var(--c-ink-40);
}

/* ---------- Sección heading ---------- */
.section-head { text-align: center; margin-bottom: 3.5rem; }
.section-head h2 { font-size: var(--fs-xl); margin-bottom: .6rem; }
.section-head h2 em { font-style: italic; color: var(--c-cedro); }
.section-head p { font-family: var(--font-display); font-style: italic; color: var(--c-ink-60); font-size: 1.15rem; max-width: 50ch; margin: 0 auto; }

/* ---------- Cabañas grid ---------- */
.cabanas {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
}
@media (max-width: 960px) { .cabanas { grid-template-columns: 1fr 1fr; } }
@media (max-width: 680px) { .cabanas { grid-template-columns: 1fr; } }

.cabana {
	background: #fff;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: transform var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
	display: flex; flex-direction: column;
	border: 1px solid var(--c-line);
}
.cabana:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.cabana__media {
	position: relative;
	aspect-ratio: 4/3;
	background: var(--c-bg-soft) center/cover no-repeat;
	overflow: hidden;
}
.cabana__media::after {
	content: ""; position: absolute; inset: 0;
	background: linear-gradient(to top, rgba(92,64,51,.25), transparent 50%);
}
.cabana__badge {
	position: absolute; top: 1rem; left: 1rem;
	background: rgba(253,247,237,.94);
	color: var(--c-marron);
	padding: .35rem .75rem;
	border-radius: 999px;
	font-size: .72rem; letter-spacing: .18em; text-transform: uppercase;
	z-index: 2;
}
.cabana__body { padding: 1.8rem 1.6rem 2rem; display: flex; flex-direction: column; flex: 1; }
.cabana__title { font-size: 1.7rem; margin-bottom: .3rem; }
.cabana__meta {
	display: flex; gap: 1rem; align-items: center;
	color: var(--c-olivo);
	font-size: .82rem; letter-spacing: .12em; text-transform: uppercase;
	margin-bottom: .9rem; font-weight: 500;
}
.cabana__meta span + span::before {
	content: "·"; margin-right: 1rem; color: var(--c-madera);
}
.cabana__desc { color: var(--c-ink-60); margin-bottom: 1.3rem; font-size: .98rem; }
.cabana__amenities {
	list-style: none; padding: 0; margin: 0 0 1.5rem;
	display: grid; grid-template-columns: 1fr 1fr; gap: .3rem .8rem;
	font-size: .86rem; color: var(--c-ink-60);
}
.cabana__amenities li {
	position: relative; padding-left: 1.1rem; line-height: 1.45;
}
.cabana__amenities li::before {
	content: "✦"; position: absolute; left: 0; top: 1px;
	color: var(--c-madera); font-size: .75rem;
}
.cabana__footer {
	margin-top: auto; padding-top: 1.2rem;
	border-top: 1px solid var(--c-line);
	display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
.cabana__footer .btn { padding: .6rem 1.2rem; font-size: .78rem; }

/* Galería de 4 fotos para single cabaña */
.gallery-4 {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: .6rem;
	aspect-ratio: 16/10;
}
.gallery-4 figure {
	position: relative; overflow: hidden;
	background: var(--c-bg-soft) center/cover no-repeat;
	border-radius: 4px;
}
.gallery-4 figure:nth-child(1) { grid-row: 1 / span 2; border-radius: var(--radius-lg) 4px 4px var(--radius-lg); }
.gallery-4 figure:nth-child(3) { border-top-right-radius: var(--radius-lg); }
.gallery-4 figure:nth-child(4),
.gallery-4 figure:nth-child(5) { display: none; }
.gallery-4 figure:nth-child(2) { grid-column: 2 / span 2; }
.gallery-4 figure:nth-child(3) { grid-column: 2; }
.gallery-4 figure:nth-child(4) { grid-column: 3; display: block; border-bottom-right-radius: var(--radius-lg); }

@media (max-width: 700px) {
	.gallery-4 { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; aspect-ratio: auto; }
	.gallery-4 figure { aspect-ratio: 4/3; border-radius: 6px !important; }
	.gallery-4 figure:nth-child(1) { grid-column: 1 / -1; }
	.gallery-4 figure:nth-child(2) { grid-column: auto; }
	.gallery-4 figure:nth-child(3) { grid-column: auto; }
}

/* ---------- Amenities / Servicios ---------- */
.features {
	display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem;
}
@media (max-width: 900px) { .features { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .features { grid-template-columns: 1fr; } }
.feature {
	background: var(--c-crema);
	border: 1px solid var(--c-line);
	border-radius: var(--radius-lg);
	padding: 2rem 1.6rem;
	transition: transform var(--fast) var(--ease);
}
.feature:hover { transform: translateY(-4px); }
.feature__icon {
	width: 48px; height: 48px; color: var(--c-cedro);
	margin-bottom: 1.1rem;
}
.feature__icon svg { width: 100%; height: 100%; }
.feature h3 { font-size: 1.3rem; margin-bottom: .5rem; }
.feature p { color: var(--c-ink-60); margin: 0; font-size: .95rem; }

.section--dark .feature {
	background: rgba(253,247,237,0.06);
	border-color: rgba(253,247,237,0.12);
}
.section--dark .feature h3 { color: var(--c-crema); }
.section--dark .feature p { color: rgba(253,247,237,0.72); }
.section--dark .feature__icon { color: var(--c-madera); }

/* ---------- Entorno — split ---------- */
.split {
	display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 5rem);
	align-items: center;
}
.split--reverse > :first-child { order: 2; }
@media (max-width: 900px) {
	.split { grid-template-columns: 1fr; }
	.split--reverse > :first-child { order: 0; }
}
.split__media {
	aspect-ratio: 5/6;
	background: var(--c-bg-soft) center/cover no-repeat;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}
.split__title { font-size: var(--fs-xl); margin-bottom: 1rem; }
.split__title em { font-style: italic; color: var(--c-cedro); }

/* ---------- Distancias ---------- */
.distances {
	margin-top: 2.5rem;
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
}
@media (max-width: 700px) { .distances { grid-template-columns: 1fr 1fr; } }
.distance {
	padding: 1rem 1.2rem;
	background: var(--c-crema);
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	display: flex; justify-content: space-between; align-items: baseline; gap: .5rem;
}
.distance__name { font-family: var(--font-display); font-size: 1.08rem; color: var(--c-marron); }
.distance__value { color: var(--c-olivo); font-weight: 500; font-size: .88rem; letter-spacing: .08em; }

/* ---------- Testimonios / Valores ---------- */
.values {
	display: grid; grid-template-columns: repeat(6, 1fr); gap: 1rem;
	margin-top: 3rem; padding-top: 3rem;
	border-top: 1px solid var(--c-line-2);
}
@media (max-width: 900px) { .values { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 520px) { .values { grid-template-columns: repeat(2, 1fr); } }
.value {
	text-align: center; padding: 1.2rem .6rem;
	font-family: var(--font-display); font-style: italic; color: var(--c-cedro);
	font-size: 1.15rem;
	border-right: 1px solid var(--c-line);
}
.value:last-child { border-right: 0; }

/* ---------- Formulario de reserva ---------- */
.reserve {
	background: linear-gradient(180deg, var(--c-bg-soft), var(--c-crema));
	position: relative; overflow: hidden;
}
.reserve::before {
	content: ""; position: absolute; inset: 0;
	background: url("../images/texture.svg") center/600px no-repeat;
	opacity: .04; pointer-events: none;
}
.reserve__grid {
	display: grid; grid-template-columns: 1fr 1.25fr; gap: clamp(2rem, 5vw, 5rem);
	align-items: stretch;
}
@media (max-width: 900px) { .reserve__grid { grid-template-columns: 1fr; } }

.reserve__info h2 { font-size: var(--fs-xl); margin-bottom: 1rem; }
.reserve__info h2 em { font-style: italic; color: var(--c-cedro); }
.reserve__info .lead { margin-bottom: 2rem; }
.reserve__info ul {
	list-style: none; padding: 0; margin: 2rem 0 0;
	border-top: 1px solid var(--c-line);
}
.reserve__info li {
	padding: 1rem 0; border-bottom: 1px solid var(--c-line);
	display: flex; align-items: center; gap: 1rem;
	font-family: var(--font-display); font-size: 1.1rem; color: var(--c-marron);
}
.reserve__info li svg { width: 22px; height: 22px; color: var(--c-cedro); flex-shrink: 0; }

.reserve__form {
	background: #fff;
	border: 1px solid var(--c-line);
	border-radius: var(--radius-lg);
	padding: clamp(1.8rem, 3vw, 2.8rem);
	box-shadow: var(--shadow-md);
}
.reserve__form h3 {
	font-size: var(--fs-lg);
	margin-bottom: .4rem;
}
.reserve__form > p.lead { margin-bottom: 2rem; font-size: 1.05rem; }

.form-grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem;
}
.form-grid .full { grid-column: 1 / -1; }
@media (max-width: 540px) { .form-grid { grid-template-columns: 1fr; } }

.field { display: flex; flex-direction: column; gap: .45rem; }
.field label {
	font-size: .78rem; letter-spacing: .18em; text-transform: uppercase;
	color: var(--c-olivo); font-weight: 500;
}
.field input, .field select, .field textarea {
	width: 100%;
	font: inherit;
	font-size: 1rem;
	padding: .85rem 1rem;
	background: var(--c-crema);
	border: 1px solid var(--c-line);
	border-radius: var(--radius);
	color: var(--c-ink);
	transition: border-color var(--fast) var(--ease), background var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
}
.field textarea { min-height: 120px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
	outline: none;
	border-color: var(--c-cedro);
	background: #fff;
	box-shadow: 0 0 0 3px rgba(58, 90, 64, 0.15);
}
.form-actions {
	margin-top: 1.8rem; display: flex; gap: 1rem; flex-wrap: wrap; align-items: center;
}
.form-note {
	font-size: .82rem; color: var(--c-ink-40);
}

/* ---------- Como llegar ---------- */
.map-wrap {
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-md);
	aspect-ratio: 16/9;
	background: var(--c-bg-soft);
}
.map-wrap iframe { width: 100%; height: 100%; border: 0; display: block; }

.steps {
	counter-reset: step;
	list-style: none; padding: 0; margin: 2.5rem 0 0;
	display: grid; gap: 1rem;
}
.steps li {
	counter-increment: step;
	padding: 1.3rem 1.5rem 1.3rem 4.5rem;
	position: relative;
	background: #fff; border: 1px solid var(--c-line);
	border-radius: var(--radius);
	font-size: 1.02rem; color: var(--c-ink-60);
}
.steps li::before {
	content: counter(step, decimal-leading-zero);
	position: absolute; left: 1.5rem; top: 1.15rem;
	font-family: var(--font-display); font-style: italic;
	font-size: 1.6rem; color: var(--c-cedro);
}

/* ---------- Contacto ---------- */
.contact-cards {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
	margin-bottom: 3rem;
}
@media (max-width: 780px) { .contact-cards { grid-template-columns: 1fr; } }
.contact-card {
	background: #fff; border: 1px solid var(--c-line);
	border-radius: var(--radius-lg);
	padding: 2rem 1.8rem;
}
.contact-card h3 { font-size: 1.3rem; margin-bottom: .8rem; }
.contact-card ul { list-style: none; padding: 0; margin: 0; }
.contact-card li { padding: .35rem 0; color: var(--c-ink-60); }
.contact-card svg {
	width: 32px; height: 32px; color: var(--c-cedro); margin-bottom: .8rem;
}

/* ---------- Page header ---------- */
.page-header {
	padding: clamp(5rem, 10vw, 8rem) 0 clamp(3rem, 6vw, 5rem);
	text-align: center;
	background: linear-gradient(180deg, var(--c-bg-soft) 0%, var(--c-bg) 100%);
	border-bottom: 1px solid var(--c-line);
}
.page-header h1 {
	font-size: var(--fs-xl);
	margin-bottom: .5rem;
}
.page-header h1 em { font-style: italic; color: var(--c-cedro); }
.page-header p {
	font-family: var(--font-display); font-style: italic;
	color: var(--c-ink-60); font-size: 1.15rem;
	max-width: 56ch; margin: 0 auto;
}
.page-header__crumb {
	font-size: .78rem; letter-spacing: .2em; text-transform: uppercase;
	color: var(--c-olivo); margin-bottom: 1.2rem;
}
.page-header__crumb a { color: inherit; }

/* ---------- Prose (páginas de contenido) ---------- */
.prose { max-width: 70ch; margin: 0 auto; font-size: 1.08rem; }
.prose p { margin: 0 0 1.4em; }
.prose h2 { font-size: var(--fs-lg); margin-top: 2.2em; }
.prose h3 { font-size: var(--fs-md); margin-top: 2em; }
.prose blockquote {
	border-left: 2px solid var(--c-madera);
	padding: .3rem 0 .3rem 1.4rem;
	margin: 1.6rem 0;
	font-family: var(--font-display); font-style: italic;
	color: var(--c-cedro); font-size: 1.3rem; line-height: 1.5;
}

/* ---------- Footer ---------- */
.site-footer {
	background: var(--c-marron); color: #E8DDC9;
	padding-top: clamp(3rem, 6vw, 5rem);
}
.site-footer__inner {
	max-width: var(--container); margin: 0 auto;
	padding: 0 var(--gutter) clamp(2rem, 5vw, 4rem);
	display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2.5rem;
}
@media (max-width: 900px) { .site-footer__inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .site-footer__inner { grid-template-columns: 1fr; } }

.site-footer .brand { color: #fff; }
.site-footer .brand__name { color: #fff; }
.site-footer .brand__tag { color: var(--c-madera); }
.site-footer .brand__mark {
	background: rgba(253,247,237,.08);
	border-color: rgba(253,247,237,.15);
	color: var(--c-madera);
}
.site-footer__desc {
	font-size: .95rem;
	color: rgba(232,221,201,.75);
	max-width: 34ch;
	margin-top: 1.2rem;
}
.site-footer__title {
	color: #fff;
	font-size: 1.1rem;
	margin-bottom: 1.1rem;
	letter-spacing: .02em;
}
.site-footer__list, .socials {
	list-style: none; padding: 0; margin: 0;
}
.site-footer__list li { padding: .2rem 0; font-size: .95rem; }
.site-footer a { color: #E8DDC9; }
.site-footer a:hover { color: var(--c-madera); }
.site-footer__address {
	font-style: normal; color: rgba(232,221,201,.85); line-height: 1.7; font-size: .95rem;
	margin-bottom: 1.2rem;
}
.site-footer__schedule {
	font-size: .88rem; color: rgba(232,221,201,.7); margin: 0;
}
.site-footer__schedule strong { color: var(--c-madera); font-weight: 500; }

.socials {
	display: flex; gap: .7rem; margin-bottom: 1.2rem;
}
.socials a {
	width: 40px; height: 40px; border-radius: 50%;
	display: grid; place-items: center;
	background: rgba(253,247,237,.08);
	border: 1px solid rgba(253,247,237,.15);
	transition: all var(--fast) var(--ease);
}
.socials a:hover { background: var(--c-madera); border-color: var(--c-madera); color: #fff; }
.socials svg { width: 16px; height: 16px; }

.site-footer__bottom {
	border-top: 1px solid rgba(253,247,237,.12);
	padding: 1.3rem var(--gutter);
	display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem;
	font-size: .82rem; color: rgba(232,221,201,.55);
	max-width: var(--container); margin: 0 auto;
}

/* ---------- FAB WhatsApp ---------- */
.wa-fab {
	position: fixed; right: 1.4rem; bottom: 1.4rem;
	width: 58px; height: 58px; border-radius: 50%;
	background: #25D366; color: #fff;
	display: grid; place-items: center;
	box-shadow: 0 10px 28px rgba(37, 211, 102, 0.45);
	z-index: 60;
	transition: transform var(--fast) var(--ease);
}
.wa-fab:hover { transform: scale(1.06); color: #fff; }
.wa-fab::after {
	content: ""; position: absolute; inset: 0; border-radius: inherit;
	box-shadow: 0 0 0 0 rgba(37, 211, 102, .5);
	animation: pulse 2.2s var(--ease) infinite;
}
@keyframes pulse {
	to { box-shadow: 0 0 0 18px rgba(37, 211, 102, 0); }
}

/* ---------- Reveal on scroll ---------- */
[data-reveal] {
	opacity: 0; transform: translateY(24px);
	transition: opacity var(--slow) var(--ease), transform var(--slow) var(--ease);
}
[data-reveal].is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation: none !important; transition-duration: 0.01ms !important; }
	.hero::before { animation: none; transform: none; }
}

/* ==========================================================================
   WhatsApp widget · intento de override tipográfico
   NOTA: si el widget usa Shadow DOM o iframe, estos estilos no aplican.
   ========================================================================== */
[id^="whatapp-people-widget-"],
[id^="whatapp-people-widget-"] *,
[id^="whatsapp-people-widget-"],
[id^="whatsapp-people-widget-"] *,
.reserve__form [id^="whatapp-people-widget-"],
.reserve__form [id^="whatapp-people-widget-"] * {
	font-family: "Playfair Display", "Cormorant Garamond", Georgia, serif !important;
	font-feature-settings: "liga" 1, "kern" 1 !important;
}

/* Por si el widget inyecta nodos hermanos fuera del div contenedor */
.reserve__form,
.reserve__form * {
	font-family: "Playfair Display", "Cormorant Garamond", Georgia, serif !important;
}

/* ==========================================================================
   MOBILE OPTIMIZATION · mobile-first fixes
   Objetivo: que la sección cabañas y el resto del sitio no se corte
   en pantallas < 768px.
   ========================================================================== */

/* Safety net: nada debe causar scroll horizontal */
html, body { overflow-x: clip; }
img { max-width: 100%; }

/* Hero: usar dvh para evitar el salto por la barra del navegador iOS */
@supports (height: 100dvh) {
	.hero { min-height: clamp(560px, 85dvh, 880px); }
}

/* ---------- Cabañas: cards ---------- */
@media (max-width: 680px) {
	/* Card body — reducir padding para ganar espacio útil */
	.cabana__body {
		padding: 1.4rem 1.2rem 1.5rem;
	}
	.cabana__title {
		font-size: 1.45rem;
	}
	/* Meta: permitir wrap + bajar letter-spacing para que no se corte */
	.cabana__meta {
		flex-wrap: wrap;
		gap: .25rem .9rem;
		letter-spacing: .08em;
		font-size: .76rem;
	}
	.cabana__meta span + span::before {
		margin-right: .9rem;
	}
	/* Amenities — en pantallas muy chicas, columna única evita corte */
	.cabana__amenities {
		font-size: .9rem;
		gap: .25rem .6rem;
	}
	/* Footer de card — stack vertical en narrow, botón full-width */
	.cabana__footer {
		flex-direction: column;
		align-items: stretch;
		gap: .75rem;
	}
	.cabana__footer .btn {
		width: 100%;
		padding: .8rem 1.2rem;
		font-size: .82rem;
		min-height: 44px;
	}
	.cabana__footer .muted {
		text-align: center;
	}
}

/* Amenities a 1 columna en pantallas muy chicas (< 380px) */
@media (max-width: 380px) {
	.cabana__amenities {
		grid-template-columns: 1fr;
	}
}

/* ---------- Detalle cabaña: split override mobile ---------- */
@media (max-width: 900px) {
	/* El HTML usa inline style grid-template-columns:1.4fr 1fr — forzamos 1col */
	.split[style*="grid-template-columns"] {
		grid-template-columns: 1fr !important;
	}
}

/* ---------- Gallery-4 → carrusel snap en mobile ---------- */
@media (max-width: 680px) {
	.gallery-4 {
		display: flex;
		flex-direction: row;
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		gap: .6rem;
		aspect-ratio: auto;
		/* Bleed hacia los bordes del viewport para que se vea edge-to-edge */
		margin-inline: calc(-1 * var(--gutter));
		padding-inline: var(--gutter);
		scroll-padding-inline: var(--gutter);
		padding-bottom: .25rem;
	}
	.gallery-4::-webkit-scrollbar { display: none; }

	.gallery-4 figure {
		flex: 0 0 86%;
		scroll-snap-align: center;
		aspect-ratio: 4/3;
		border-radius: var(--radius-lg) !important;
		/* Reset de las posiciones grid desktop */
		grid-row: auto !important;
		grid-column: auto !important;
		display: block !important;
	}
	.gallery-4 figure:last-child {
		scroll-snap-align: end;
	}

	/* Hint visual — subtle indicador de scroll */
	.gallery-4::after {
		content: "";
		flex: 0 0 1px;
	}
}

/* ---------- Section-head en mobile ---------- */
@media (max-width: 540px) {
	.section-head p {
		font-size: 1rem;
	}
	.section {
		padding-block: clamp(3rem, 10vw, 5rem);
	}
}

/* ---------- Touch targets: links del menú mobile ≥ 44px ---------- */
@media (max-width: 960px) {
	.nav-menu a {
		min-height: 44px;
		display: flex;
		align-items: center;
	}
	.nav-toggle {
		min-width: 44px;
		min-height: 44px;
	}
}

/* ---------- Botones: touch target mínimo en mobile ---------- */
@media (max-width: 540px) {
	.btn {
		min-height: 44px;
		padding: .85rem 1.5rem;
		font-size: .88rem;
	}
	.btn--lg {
		padding: 1rem 1.8rem;
		font-size: .95rem;
	}
}

/* ---------- Topbar mobile: acortar separador + reducir gap ---------- */
@media (max-width: 540px) {
	.topbar__item--right {
		flex-wrap: wrap;
		justify-content: center;
		gap: .4rem;
	}
	.topbar__sep {
		display: none;
	}
}

/* ---------- Form-grid y contact-cards ya tienen breakpoints correctos ---------- */

/* ---------- Evitar corte horizontal en containers con padding inline style ---------- */
.container > * {
	min-width: 0;
}

/* ---------- Cabana badge: no tan grande en mobile ---------- */
@media (max-width: 540px) {
	.cabana__badge {
		top: .75rem;
		left: .75rem;
		font-size: .65rem;
		padding: .3rem .6rem;
	}
}

/* ---------- Header CTA Reservar: asegurar visibilidad en mobile ---------- */
@media (max-width: 540px) {
	.site-header__cta .btn {
		padding: .55rem .9rem;
		font-size: .72rem;
		letter-spacing: .05em;
	}
}
