/*!
 * landing.css — estilos non-critical de la home v2
 * @package nogal-landing-v2
 * @since   1.2.0
 *
 * Carga: enqueued condicional por is_page_template('page-home-v2.php')
 * El critical path (:root, nav, hero, btn, quickbook) vive inline en el template.
 */

/* ==========================================================================
 * HERO BOMBA NUCLEAR v1.2.3 — doble cobertura del critical CSS inline.
 * Si el usuario entra antes de que cargue landing.css, el inline ya lo cubre.
 * Acá duplicamos para sobrevivir cache layers y purgas de plugins agresivos.
 * ========================================================================== */
html body.page-template-page-home-v2 section.hero h1,
html body.home-v2 section.hero h1,
.home-v2 .hero h1 {
	color: #ffffff !important;
	text-shadow: 0 2px 20px rgba(0,0,0,0.7), 0 0 40px rgba(0,0,0,0.4) !important;
	-webkit-text-stroke: 0 !important;
	filter: none !important;
}
html body.page-template-page-home-v2 section.hero h1 em,
html body.home-v2 section.hero h1 em,
.home-v2 .hero h1 em {
	color: var(--gold, #c9a35a) !important;
	text-shadow: 0 2px 20px rgba(0,0,0,0.7) !important;
	font-style: italic;
	font-weight: 400;
}
html body.page-template-page-home-v2 .hero-bg::after,
html body.home-v2 .hero-bg::after {
	background: linear-gradient(180deg, rgba(0,0,0,0.5) 0%, rgba(0,0,0,0.75) 100%),
	            radial-gradient(ellipse at 80% 20%, rgba(110,2,0,0.25) 0%, transparent 55%) !important;
}

/* ---------- SECTIONS ---------- */
.home-v2 section { padding: 5.5rem 2rem; }
.home-v2 .wrap { max-width: 1280px; margin: 0 auto; }
.home-v2 .section-head { display: grid; gap: 1rem; margin-bottom: 3.5rem; }
.home-v2 .section-label { font-size: .7rem; letter-spacing: .3em; text-transform: uppercase; color: var(--granate); font-weight: 500; display: flex; align-items: center; gap: .75rem; }
.home-v2 .section-label::before { content: '—'; color: var(--granate); }
.home-v2 .section-title { font-family: var(--serif); font-size: clamp(2rem, 4.8vw, 3.5rem); font-weight: 400; line-height: 1.05; letter-spacing: -.01em; max-width: 820px; }
.home-v2 .section-title em { font-style: italic; color: var(--granate); font-weight: 400; }
.home-v2 .section-sub { color: var(--ink-soft); max-width: 620px; font-size: 1.02rem; }

/* ---------- INTRO ---------- */
.home-v2 .intro { background: var(--cream); }
.home-v2 .intro-grid { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: center; }
.home-v2 .intro-copy h2 { font-family: var(--serif); font-size: clamp(2rem, 4.5vw, 3.2rem); font-weight: 400; line-height: 1.1; margin-bottom: 1.5rem; }
.home-v2 .intro-copy h2 em { color: var(--granate); font-style: italic; }
.home-v2 .intro-copy p { color: var(--ink-soft); margin-bottom: 1rem; font-size: 1.02rem; }
.home-v2 .intro-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--line); }
.home-v2 .intro-stats .s strong { font-family: var(--serif); font-size: 2rem; font-weight: 500; color: var(--granate); display: block; line-height: 1; }
.home-v2 .intro-stats .s span { font-size: .7rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-soft); margin-top: .4rem; display: block; }
.home-v2 .intro-img { aspect-ratio: 4/5; position: relative; overflow: hidden; }
.home-v2 .intro-img img { width: 100%; height: 100%; object-fit: cover; }
.home-v2 .intro-img::before { content: ''; position: absolute; inset: -8px; border: 1px solid var(--granate); pointer-events: none; z-index: 2; }

/* ---------- UBICACION ---------- */
.home-v2 .ubicacion { background: var(--paper); }
.home-v2 .loc-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.home-v2 .loc-card { position: relative; overflow: hidden; aspect-ratio: 4/5; display: flex; align-items: flex-end; padding: 2rem 1.75rem; color: var(--paper); cursor: pointer; isolation: isolate; }
.home-v2 .loc-card::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 30%, rgba(20,8,6,.92) 100%); z-index: 2; }
.home-v2 .loc-card .loc-bg { position: absolute; inset: 0; z-index: 1; transition: transform .9s cubic-bezier(.2,.8,.2,1); }
.home-v2 .loc-card .loc-bg img { width: 100%; height: 100%; object-fit: cover; }
.home-v2 .loc-card:hover .loc-bg { transform: scale(1.08); }
.home-v2 .loc-card > div { position: relative; z-index: 3; }
.home-v2 .loc-card .dist { font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; color: var(--gold); margin-bottom: .75rem; display: inline-block; }
.home-v2 .loc-card h3 { font-family: var(--serif); font-size: 1.85rem; font-weight: 400; margin-bottom: .4rem; line-height: 1.1; }
.home-v2 .loc-card p { font-size: .92rem; opacity: .9; margin-bottom: .85rem; font-weight: 300; line-height: 1.5; }
.home-v2 .loc-card .link { font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; border-bottom: 1px solid rgba(255,255,255,.4); padding-bottom: 2px; display: inline-flex; gap: .5rem; }

/* ---------- HABITACIONES ---------- */
.home-v2 .habitaciones { background: var(--cream); }
.home-v2 .room-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
.home-v2 .room { display: grid; gap: 1.25rem; }
.home-v2 .room-img { position: relative; aspect-ratio: 4/3; overflow: hidden; background: #3a2818; }
.home-v2 .room-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s cubic-bezier(.2,.8,.2,1); }
.home-v2 .room:hover .room-img img { transform: scale(1.05); }
.home-v2 .room-tag { position: absolute; top: 1rem; left: 1rem; background: rgba(255,255,255,.97); padding: .45rem .8rem; font-size: .65rem; letter-spacing: .2em; text-transform: uppercase; color: var(--granate); font-weight: 500; z-index: 2; }
.home-v2 .room-body { padding: 0 .25rem; }
.home-v2 .room h3 { font-family: var(--serif); font-size: 1.75rem; font-weight: 400; margin-bottom: .4rem; }
.home-v2 .room-feat { color: var(--ink-soft); font-size: .88rem; margin-bottom: 1.25rem; letter-spacing: .02em; }

/* Precio público (sin label) */
.home-v2 .price-public { display: flex; align-items: baseline; flex-wrap: wrap; gap: .45rem; padding: .75rem 0 1rem; border-top: 1px solid var(--line); }
.home-v2 .price-public .price-amount { font-family: var(--serif); font-size: 1.45rem; font-weight: 500; color: var(--ink); }
.home-v2 .price-public .price-sep { color: var(--ink-soft); opacity: .6; }
.home-v2 .price-public .price-usd { font-size: .85rem; color: var(--ink-soft); font-family: var(--sans); font-weight: 400; letter-spacing: .02em; }
.home-v2 .price-public .price-per { font-size: .78rem; color: var(--ink-soft); letter-spacing: .05em; margin-left: .15rem; }

/* Bloque descuento (destacado en granate tenue con border-left) */
.home-v2 .price-promo-box { display: flex; flex-direction: column; gap: .25rem; padding: .85rem 1rem; margin: .85rem 0 1.25rem; background: var(--granate-tint); border-left: 3px solid var(--granate); border-radius: 2px; }
.home-v2 .price-promo-label { font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--granate); font-weight: 600; }
.home-v2 .price-promo-amount { font-family: var(--serif); font-size: 1.35rem; font-weight: 500; color: var(--granate); line-height: 1.2; }
.home-v2 .price-promo-amount .price-sep { opacity: .5; }

.home-v2 .room-note { font-size: .82rem; color: var(--ink-soft); margin: -.35rem 0 1rem; font-style: italic; line-height: 1.45; }
.home-v2 .room-note a { color: var(--granate); font-weight: 500; text-decoration: underline; text-decoration-color: rgba(110,2,0,.35); text-underline-offset: 3px; transition: text-decoration-color .3s ease; }
.home-v2 .room-note a:hover { text-decoration-color: var(--granate); }

.home-v2 .room-disclaimer { text-align: center; margin-top: 3rem; color: var(--ink-soft); font-style: italic; max-width: 680px; margin-left: auto; margin-right: auto; line-height: 1.5; }

/* ---------- CORPORATIVO ---------- */
.home-v2 .corpo { background: linear-gradient(135deg, var(--granate-deep) 0%, var(--granate) 100%); color: var(--paper); position: relative; overflow: hidden; }
.home-v2 .corpo::before { content: ''; position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.08 0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E"); opacity: .5; mix-blend-mode: overlay; }
.home-v2 .corpo-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: center; position: relative; z-index: 2; }
.home-v2 .corpo h2 { font-family: var(--serif); font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 400; line-height: 1.1; margin-bottom: 1rem; }
.home-v2 .corpo h2 em { color: var(--gold); font-style: italic; }
.home-v2 .corpo p { font-size: 1rem; opacity: .9; margin-bottom: 1.5rem; max-width: 540px; }
.home-v2 .corpo-feats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; margin-bottom: 1.5rem; font-size: .88rem; }
.home-v2 .corpo-feats span::before { content: '— '; color: var(--gold); }
.home-v2 .corpo-img { aspect-ratio: 4/3; overflow: hidden; }
.home-v2 .corpo-img img { width: 100%; height: 100%; object-fit: cover; }
.home-v2 .corpo-wa { border-color: rgba(255,255,255,.5) !important; }

/* ==========================================================================
 * BOMBA NUCLEAR v1.2.4 — h2/titulos/párrafos en secciones con fondo oscuro
 * El problema: Astra + Elementor Kit 394 tienen reglas globales de color
 * para h2/h3/p que pisaban el `color: var(--paper)` heredado. Aplicamos
 * selector super-específico + !important en todas las secciones dark.
 * Cubiertas: .corpo (granate), .loc-card (overlay dark), footer (#120605)
 * ========================================================================== */

/* --- CORPO (banner granate) --- */
html body.home-v2 section.corpo h2,
html body.page-template-page-home-v2 section.corpo h2 {
	color: #ffffff !important;
	text-shadow: 0 2px 20px rgba(0,0,0,0.3) !important;
}
html body.home-v2 section.corpo h2 em,
html body.page-template-page-home-v2 section.corpo h2 em {
	color: var(--gold, #c9a35a) !important;
	text-shadow: 0 2px 20px rgba(0,0,0,0.3) !important;
}
html body.home-v2 section.corpo p,
html body.home-v2 section.corpo .corpo-feats,
html body.home-v2 section.corpo .corpo-feats span,
html body.page-template-page-home-v2 section.corpo p {
	color: rgba(255,255,255,0.92) !important;
}

/* --- UBICACION / LOC-CARDS (imagen + overlay dark) --- */
html body.home-v2 section.ubicacion .loc-card h3,
html body.home-v2 section.ubicacion .loc-card p,
html body.page-template-page-home-v2 section.ubicacion .loc-card h3,
html body.page-template-page-home-v2 section.ubicacion .loc-card p {
	color: #ffffff !important;
	text-shadow: 0 2px 12px rgba(0,0,0,0.5) !important;
}

/* --- FOOTER (fondo #120605, casi negro) --- */
html body.home-v2 footer h3,
html body.home-v2 footer h5,
html body.home-v2 footer .foot-brand h3,
html body.home-v2 footer .foot-col h5,
html body.page-template-page-home-v2 footer h3,
html body.page-template-page-home-v2 footer h5 {
	color: #ffffff !important;
}
html body.home-v2 footer .foot-col ul li,
html body.home-v2 footer .foot-col a,
html body.home-v2 footer .foot-brand p,
html body.page-template-page-home-v2 footer .foot-col a {
	color: rgba(255,255,255,0.7) !important;
}
html body.home-v2 footer .foot-col a:hover,
html body.page-template-page-home-v2 footer .foot-col a:hover {
	color: var(--gold, #c9a35a) !important;
}

/* ---------- AMENIDADES (6 cells: stack mobile → 2 cols tablet → 3 cols desktop) ---------- */
.home-v2 .amenidades { background: var(--paper); }
.home-v2 .amen-grid { display: grid; grid-template-columns: 1fr; gap: .75rem; }
.home-v2 .amen-cell { position: relative; overflow: hidden; aspect-ratio: 16/10; }
.home-v2 .amen-cell img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.home-v2 .amen-cell:hover img { transform: scale(1.06); }
.home-v2 .amen-label { position: absolute; bottom: 1rem; left: 1rem; color: var(--paper); font-family: var(--serif); font-size: 1.1rem; font-weight: 400; text-shadow: 0 2px 20px rgba(0,0,0,.7); z-index: 2; }
.home-v2 .amen-cell::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.5) 100%); pointer-events: none; }

/* ---------- TESTIMONIOS ---------- */
.home-v2 .testimonios { background: var(--cream); position: relative; overflow: hidden; }
.home-v2 .testimonios::before { content: '"'; position: absolute; font-family: var(--serif); font-size: 28rem; color: rgba(110,2,0,.07); top: -4rem; left: -2rem; line-height: 1; font-style: italic; pointer-events: none; }
.home-v2 .tst-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; position: relative; z-index: 2; }
.home-v2 .tst { padding: 2rem 1.75rem; background: var(--paper); border-left: 2px solid var(--granate); }
.home-v2 .stars { color: var(--gold); font-size: .95rem; letter-spacing: .15em; margin-bottom: 1rem; }
.home-v2 .tst blockquote { font-family: var(--serif); font-size: 1.1rem; line-height: 1.45; font-style: italic; margin-bottom: 1.5rem; font-weight: 400; color: var(--ink); }
.home-v2 .tst-author { display: flex; align-items: center; gap: .9rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.home-v2 .tst-avatar { width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg, var(--gold), #8a6a3a); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 1rem; color: var(--paper); font-weight: 500; }
.home-v2 .tst-meta strong { display: block; font-weight: 500; font-size: .9rem; }
.home-v2 .tst-meta span { font-size: .75rem; color: var(--ink-soft); letter-spacing: .05em; }

/* Ajuste 4 — bloque links a reseñas reales */
.home-v2 .tst-reviews-link { margin-top: 3rem; text-align: center; position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 1rem; }
.home-v2 .tst-note { color: var(--ink-soft); font-size: .85rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: .5rem; }
.home-v2 .tst-reviews-link .btn-outline { color: var(--granate); border: 1px solid var(--granate); padding: .85rem 1.5rem; font-size: .78rem; letter-spacing: .14em; text-transform: uppercase; border-radius: 2px; transition: all .3s ease; font-weight: 500; display: inline-flex; align-items: center; gap: .75rem; }
.home-v2 .tst-reviews-link .btn-outline:hover { background: var(--granate); color: var(--paper); transform: translateY(-2px); }

/* ---------- CONTACTO ---------- */
.home-v2 .contacto { background: var(--paper); border-top: 1px solid var(--line); }
.home-v2 .contacto-grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; }
.home-v2 .info-block { display: grid; gap: 1.5rem; }
.home-v2 .info-item h4 { font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; color: var(--granate); margin-bottom: .4rem; font-weight: 500; }
.home-v2 .info-item p { font-family: var(--serif); font-size: 1.2rem; line-height: 1.35; color: var(--ink); }
.home-v2 .info-item p small { font-family: var(--sans); font-size: .85rem; color: var(--ink-soft); display: block; margin-top: .3rem; }
.home-v2 .info-item a { color: inherit; }
.home-v2 .info-item a:hover { color: var(--granate); }
.home-v2 .map-wrap { margin-top: 1.5rem; aspect-ratio: 16/10; background: var(--cream); overflow: hidden; border: 1px solid var(--line); }
.home-v2 .map-wrap iframe { width: 100%; height: 100%; border: 0; }
.home-v2 .form { display: grid; gap: 1.1rem; }
.home-v2 .form label { display: block; font-size: .7rem; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-soft); margin-bottom: .4rem; }
.home-v2 .form input, .home-v2 .form textarea { width: 100%; padding: .75rem 0; border: none; border-bottom: 1px solid var(--line); background: transparent; font-family: var(--sans); font-size: .95rem; color: var(--ink); transition: border-color .3s; }
.home-v2 .form input:focus, .home-v2 .form textarea:focus { outline: none; border-color: var(--granate); }
.home-v2 .form textarea { resize: vertical; min-height: 90px; }
.home-v2 .form .btn { margin-top: .75rem; justify-self: start; }

/* ---------- FOOTER ---------- */
.home-v2 footer { background: #120605; color: rgba(255,255,255,.7); padding: 4rem 2rem 2rem; }
.home-v2 .foot-grid { max-width: 1280px; margin: 0 auto; display: grid; gap: 2.5rem; grid-template-columns: 1fr; }
.home-v2 .foot-brand h3 { font-family: var(--serif); color: var(--paper); font-size: 1.6rem; font-weight: 500; margin-bottom: .3rem; letter-spacing: .15em; }
.home-v2 .foot-brand .sub { font-size: .65rem; letter-spacing: .35em; text-transform: uppercase; color: var(--gold); margin-bottom: 1.25rem; display: block; }
.home-v2 .foot-brand p { font-size: .88rem; max-width: 320px; line-height: 1.6; }
.home-v2 .foot-col h5 { color: var(--paper); font-size: .7rem; letter-spacing: .25em; text-transform: uppercase; margin-bottom: 1.1rem; font-weight: 500; }
.home-v2 .foot-col ul { list-style: none; display: grid; gap: .55rem; font-size: .88rem; }
.home-v2 .foot-col a:hover { color: var(--gold); }
.home-v2 .foot-bottom { max-width: 1280px; margin: 3rem auto 0; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.1); font-size: .78rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; color: rgba(255,255,255,.5); }

/* ---------- STICKY CTA ---------- */
.home-v2 .sticky-cta { position: fixed; bottom: 1.5rem; left: 1.5rem; background: var(--granate); color: var(--paper); padding: .85rem 1.4rem; border-radius: 100px; font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; font-weight: 500; box-shadow: 0 8px 24px rgba(110,2,0,.4); z-index: 90; display: flex; align-items: center; gap: .5rem; opacity: 0; transform: translateY(20px); pointer-events: none; transition: all .4s ease; }
.home-v2 .sticky-cta.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.home-v2 .sticky-cta:hover { background: var(--granate-soft); transform: translateY(-2px); }

/* NOTA: el WhatsApp FAB lo inyecta el snippet migrado (inc/snippets-migrated.php) globalmente.
 * No se duplica acá — es el mismo .nogal-wa. Decision de Fase A del plan. */

/* ---------- RESPONSIVE ---------- */
@media (min-width: 640px) {
	.home-v2 .corpo-feats { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 640px) {
	.home-v2 .amen-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 860px) {
	.home-v2 .loc-grid { grid-template-columns: repeat(3, 1fr); }
	.home-v2 .room-grid { grid-template-columns: repeat(2, 1fr); gap: 3.5rem 3rem; }
	.home-v2 .tst-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
	.home-v2 .tst-reviews-link { flex-direction: row; justify-content: center; gap: 1.5rem; }
	.home-v2 .contacto-grid { grid-template-columns: 1fr 1fr; gap: 5rem; }
	.home-v2 .foot-grid { grid-template-columns: 2fr 1fr 1fr 1fr; }
	.home-v2 .intro-grid { grid-template-columns: 1.2fr 1fr; gap: 5rem; }
	.home-v2 .corpo-grid { grid-template-columns: 1.2fr 1fr; gap: 4rem; }
	.home-v2 .amen-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
	.home-v2 .amen-cell { aspect-ratio: 1/1; }
	.home-v2 section { padding: 7rem 3rem; }
}
@media (max-width: 480px) {
	.home-v2 section { padding: 4rem 1.25rem; }
	.home-v2 .sticky-cta { left: 50%; transform: translateX(-50%) translateY(20px); bottom: 5rem; }
	.home-v2 .sticky-cta.visible { transform: translateX(-50%) translateY(0); }
}
