/* =========================================================
   1242bnb — Captación de PROPIETARIOS (Fase 1)
   Marca ROJA editorial (#ED1C24). Ritmo claro (hero) ↔ oscuro (editorial).
   Escala 4/8. Radio único. Motion sutil, easing cubic-bezier(.16,1,.3,1).
   Inspiración FIND/Renteo: ADAPTADA, no clonada.
   ========================================================= */

:root {
  /* Neutros limpios */
  --paper:        #ffffff;
  --paper-2:      #f6f6f5;
  --surface:      #ffffff;
  --ink:          #1a1a1a;
  --ink-soft:     #4a4a4a;
  --ink-faint:    #767676;
  --line:         #e7e7e6;
  --line-strong:  #d2d2d0;
  --ink-deep:     #141414;   /* superficies oscuras */
  --ink-deep-2:   #1d1d1d;   /* tarjeta sobre oscuro */

  /* Marca: UN SOLO rojo oficial 1242bnb (#ED1C24) en color base.
     --brand-deep ahora resuelve a --brand para unificar el rojo de marca. */
  --brand:        #ED1C24;
  --brand-deep:   var(--brand);   /* = #ED1C24 (color base unificado) */
  --brand-hover:  #c1141b;        /* solo hover de CTA (rojo más oscuro) */
  --brand-tint:   #fdeced;
  --brand-glow:   #ff5b61;   /* acento sobre oscuro (rojo aclarado, AA sobre #141414) */
  --on-brand:     #ffffff;

  /* Alias de compatibilidad */
  --accent:       var(--brand);
  --accent-deep:  var(--brand);
  --accent-tint:  var(--brand-tint);
  --on-accent:    var(--on-brand);

  /* Demanda (simulador de precios) */
  --dem-low:   #6b9e7a;  /* baja */
  --dem-mid:   #d6a23a;  /* media */
  --dem-high:  var(--brand-deep); /* alta */

  /* Radio único */
  --r:    14px;
  --r-sm: 10px;
  --r-pill: 999px;

  /* Espaciado 4/8 */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --s-9: 96px; --s-10: 128px;

  --font: "Helvetica Neue", "Segoe UI", system-ui, -apple-system, "Arial", sans-serif;

  --shadow-sm: 0 1px 2px rgba(20,20,20,.05), 0 2px 8px rgba(20,20,20,.04);
  --shadow-md: 0 10px 30px rgba(20,20,20,.08);
  --shadow-lg: 0 24px 60px rgba(20,20,20,.16);

  --ease: cubic-bezier(.16,1,.3,1);
  --maxw: 1180px;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  margin: 0;
  font-family: var(--font);
  background: var(--paper);
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden; /* refuerzo anti-overflow horizontal */
}

h1, h2, h3 { margin: 0; line-height: 1.06; letter-spacing: -.02em; font-weight: 700; }
p { margin: 0; }
ul, ol { margin: 0; padding: 0; list-style: none; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--s-5); }

/* ---------- Focus visible ---------- */
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

.skip-link {
  position: absolute; left: 50%; top: var(--s-3);
  transform: translate(-50%, calc(-100% - var(--s-3) - 8px));
  background: var(--accent); color: var(--on-accent);
  padding: var(--s-2) var(--s-4); border-radius: var(--r-sm);
  z-index: 200; transition: transform .2s var(--ease);
}
.skip-link:focus { transform: translate(-50%, 0); }

/* ---------- Iconos ---------- */
.ico {
  width: 20px; height: 20px; flex: none;
  fill: none; stroke: currentColor;
  stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round;
}
.ico--sm { width: 16px; height: 16px; }
.ico--lg { width: 26px; height: 26px; stroke-width: 1.6; }

/* ---------- Tipografía utilitaria ---------- */
.eyebrow {
  font-size: .78rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--accent);
  margin-bottom: var(--s-4);
}
.section-intro { color: var(--ink-soft); font-size: 1.06rem; max-width: 56ch; margin-top: var(--s-4); }
.note { color: var(--ink-faint); font-size: .85rem; margin-top: var(--s-3); }

/* Solo para lectores de pantalla (tablas de datos bajo las gráficas, etc.) */
.sr-only {
  /* display:block es clave: un <table> (display:table) ignora width:1px y se
     dimensiona por su propio algoritmo, ensanchando el scrollWidth de la página.
     Forzar block hace que respete width:1px + overflow:hidden y colapse a 1x1px. */
  display: block !important;
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Etiqueta honesta "Simulación / ejemplo" */
.sim-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-faint); background: var(--paper-2);
  border: 1px solid var(--line-strong);
  padding: 3px 9px; border-radius: var(--r-pill);
}
.sim-tag::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--brand); flex: none; }
.on-dark .sim-tag { color: rgba(255,255,255,.72); background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.18); }

/* =========================================================
   HEADER / NAV — sticky, condensa al hacer scroll
   ========================================================= */
.site-header {
  /* Fondo blanco SÓLIDO siempre (no transparente), en ambos estados. Al hacer
     scroll (.is-scrolled) sólo se condensa la altura y aparece el borde inferior. */
  position: sticky; top: 0; z-index: 60;
  background: #fff;
  border-bottom: 1px solid transparent;
  transition: border-color .3s var(--ease), height .3s var(--ease);
}
.site-header.is-scrolled { border-bottom-color: var(--line); }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; transition: height .3s var(--ease); }
.site-header.is-scrolled .header-inner { height: 60px; }

/* Wordmark de la marca: ROJO sobre el blanco del nav (sin sombra, sin caja). */
.brand { display: inline-flex; align-items: center; }
.brand-word {
  font-weight: 800; font-size: 1.32rem; letter-spacing: -.03em;
  color: var(--brand); line-height: 1; transition: font-size .3s var(--ease);
}
@media (min-width: 768px) { .brand-word { font-size: 1.5rem; } }
.site-header.is-scrolled .brand-word { font-size: 1.28rem; }

.nav { display: flex; align-items: center; gap: var(--s-5); }
.nav-menu { display: flex; align-items: center; gap: var(--s-6); }
.nav-menu a {
  font-size: .95rem; color: var(--ink); font-weight: 600;
  padding: var(--s-2) 0; position: relative; transition: color .2s var(--ease);
}
.nav-menu a::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1.5px;
  background: var(--accent); transform: scaleX(0); transform-origin: left;
  transition: transform .25s var(--ease);
}
.nav-menu a:hover { color: var(--brand); }
.nav-menu a:hover::after { transform: scaleX(1); }

.nav-toggle {
  display: none; width: 44px; height: 44px; border: 1px solid var(--line-strong);
  border-radius: var(--r-sm); background: var(--surface); cursor: pointer;
  align-items: center; justify-content: center;
}
.nav-toggle-bars { position: relative; width: 20px; height: 14px; }
.nav-toggle-bars span {
  position: absolute; left: 0; width: 100%; height: 2px; background: var(--ink); border-radius: 2px;
  transition: transform .25s var(--ease), opacity .2s var(--ease);
}
.nav-toggle-bars span:nth-child(1) { top: 0; }
.nav-toggle-bars span:nth-child(2) { top: 6px; }
.nav-toggle-bars span:nth-child(3) { top: 12px; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle-bars span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* =========================================================
   BOTONES
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  text-align: center; font-weight: 600; font-size: .98rem; line-height: 1.25;
  padding: 14px 24px; border-radius: var(--r-pill); border: 1.5px solid transparent;
  cursor: pointer; max-width: 100%; overflow-wrap: break-word;
  transition: transform .18s var(--ease), background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease), box-shadow .2s var(--ease);
}
.btn .ico { flex: none; }
.btn:active { transform: translateY(1px) scale(.99); }
.btn--sm { padding: 10px 16px; font-size: .9rem; }
.btn--lg { padding: 17px 30px; font-size: 1.05rem; }

/* CTA primario: rojo de marca #ED1C24. Texto blanco grande+bold para AA (≥19px, 700). */
.btn--primary { background: var(--brand); color: var(--on-accent); box-shadow: 0 6px 18px rgba(193,20,27,.28); }
.btn--primary:hover { background: var(--brand-hover); box-shadow: 0 10px 26px rgba(193,20,27,.34); }
/* Invariante AA: TODO primary (sm/base/lg) = blanco, 700, ≥19px (1.2rem). */
.btn--primary { font-size: 1.2rem; font-weight: 700; }

.btn--ghost { background: transparent; color: var(--accent); border-color: var(--accent); }
.btn--ghost:hover { background: var(--accent-tint); }

.btn--text { padding: 12px 2px; color: var(--accent); position: relative; border-radius: 4px; font-weight: 600; }
.btn--text::after { content: "→"; margin-left: var(--s-2); transition: transform .2s var(--ease); display: inline-block; }
.btn--text:hover::after { transform: translateX(4px); }

/* CTA sobre oscuro */
.on-dark .btn--ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.on-dark .btn--ghost:hover { background: rgba(255,255,255,.1); }
.on-dark .btn--text { color: #fff; }

/* =========================================================
   HERO — FOTO FULL-BLEED + PARALLAX (GSAP ScrollTrigger en main.js)
   Foto de la catedral a sangre completa con velo oscuro para
   legibilidad. El fondo y el texto se mueven vía GSAP (scrub);
   si GSAP/Lenis no cargan o prefers-reduced-motion: hero ESTÁTICO
   y COMPLETO (foto cover center top, texto legible, notificaciones visibles).
   ========================================================= */
.hero {
  position: relative; overflow: hidden;
  text-align: center;
  /* El nav es blanco sólido: el hero arranca LIMPIO debajo (sin pull-under). */
  /* Imagen anclada arriba; texto en la media-baja gracias al min-height + spacer. */
  min-height: clamp(640px, 100svh, 920px);
  padding: var(--s-7) 0 clamp(40px, 6vh, 80px);
  display: flex; flex-direction: column; justify-content: flex-start;
  isolation: isolate;
}

/* --- Fondo del hero: render frontal del edificio (v6) ---
   Anclado ARRIBA (top center), cover (sin distorsión), una sola vez (no-repeat).
   Cubre TODO el alto del hero para que la tarjeta quede SOBRE la imagen.
   La composición percibida es "imagen desde arriba ~66vh + contenido encima". */
.hero-bg {
  /* inset:0 fijaría top/bottom; lo neutralizamos para dar margen de movimiento
     vertical al parallax (height aplica solo con bottom:auto). El fondo es 116%
     del alto del hero, anclado 8% por encima => sin bordes vacíos al desplazar. */
  position: absolute; left: 0; right: 0; top: -8%; bottom: auto; height: 116%;
  z-index: -2; pointer-events: none;
  background-image: image-set(
    url("assets/img/hero/hero-v8-frontal-2400.webp") type("image/webp") 2x,
    url("assets/img/hero/hero-v8-frontal-1920.webp") type("image/webp") 1x,
    url("assets/img/hero/hero-v8-frontal-2400.jpg") 2x,
    url("assets/img/hero/hero-v8-frontal-1920.jpg") 1x);
  background-image: url("assets/img/hero/hero-v8-frontal-1920.jpg"); /* fallback */
  background-image: -webkit-image-set(
    url("assets/img/hero/hero-v8-frontal-2400.webp") 2x,
    url("assets/img/hero/hero-v8-frontal-1920.webp") 1x);
  background-image: image-set(
    url("assets/img/hero/hero-v8-frontal-2400.webp") type("image/webp") 2x,
    url("assets/img/hero/hero-v8-frontal-1920.webp") type("image/webp") 1x,
    url("assets/img/hero/hero-v8-frontal-2400.jpg") 2x,
    url("assets/img/hero/hero-v8-frontal-1920.jpg") 1x);
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}

/* Scrim negro 40%: sobre la imagen, bajo el contenido. Hace que el texto resalte. */
.hero-scrim {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background: rgba(0,0,0,.40);
}

/* Contenido del hero: spacer flexible empuja el texto a la media-baja; las
   notificaciones quedan debajo del CTA, todo sobre la imagen. */
.hero-inner {
  position: relative; z-index: 1; max-width: 880px; margin-inline: auto;
  flex: 1 1 auto;
  display: flex; flex-direction: column; align-items: center;
}
/* Spacer: empuja el bloque de texto a la media-baja del hero para que el friso
   "BOOM INMOBILIARIO" estampado en la imagen quede COMPLETO y asome sobre el H1. */
.hero-spacer { flex: 1 1 40%; min-height: clamp(180px, 32vh, 380px); }
.hero-lede { display: flex; flex-direction: column; align-items: center; width: 100%; }

/* Titular en una línea (desktop): "Maximiza tus" blanco + "ingresos" rojo + " de Airbnb" blanco. */
.hero-title {
  font-size: clamp(2.1rem, 5.6vw, 4rem); font-weight: 800; line-height: 1.05;
  letter-spacing: -.025em; color: #fff; margin: 0 auto; max-width: 22ch;
  text-shadow: 0 2px 26px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.5);
}
@media (min-width: 768px) { .hero-title { max-width: none; } }
.hero-title-accent { color: var(--brand); }
.hero-title-brand { color: #fff; }

/* Subtítulo en versales bajo el titular. */
.hero-sub {
  color: #fff;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: .06em;
  font-size: clamp(.85rem, 1.8vw, 1.05rem);
  margin: var(--s-3) auto var(--s-7);
  text-shadow: 0 1px 12px rgba(0,0,0,.45), 0 1px 2px rgba(0,0,0,.4);
}
.hero-actions { display: flex; justify-content: center; }

/* === Notificaciones del hero (glass, sin tarjeta-contenedor blanca) ===
   Cada mensaje es un rectángulo semi-transparente con blur que deja ver la
   foto detrás. Se apilan como notificaciones de móvil (loop en main.js). */
.hero-notifs {
  position: relative; width: 100%; max-width: 460px;
  margin: var(--s-5) auto 0; text-align: left;
}
/* Chip "Ejemplo": discreto pero legible, con su propio mini-fondo. */
.hero-notifs-tag {
  position: absolute; top: -10px; right: 4px; z-index: 2;
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .68rem; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
  color: rgba(255,255,255,.92); padding: 3px 9px; border-radius: 999px;
  background: rgba(20,20,22,.55); border: 1px solid rgba(255,255,255,.22);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}
.hero-notifs-tag::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--brand); flex: none; }

/* Stack: los mensajes ocupan su lugar (layout estable, no saltan). */
.notif-stack { display: grid; gap: var(--s-3); }

/* Mensaje glass. Fallback opaco si no hay backdrop-filter. */
.notif {
  display: flex; align-items: center; gap: var(--s-3);
  padding: 14px var(--s-4); border-radius: 15px;
  background: rgba(20,20,22,.58);
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 30px rgba(0,0,0,.34), 0 1px 0 rgba(255,255,255,.05) inset;
  color: #fff; will-change: opacity, transform;
}
@supports ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  .notif {
    background: rgba(20,20,22,.42);
    -webkit-backdrop-filter: blur(10px) saturate(1.1);
    backdrop-filter: blur(10px) saturate(1.1);
  }
}
/* --- Apilado tipo notificación (enter -> dwell -> clear -> loop) ---
   Estado base oculto (abajo). JS añade .is-in (entra) y .is-out (sale). */
.notif.anim {
  opacity: 0; transform: translateY(16px) scale(.985);
  transition:
    opacity .46s cubic-bezier(.22,1,.36,1),
    transform .46s cubic-bezier(.22,1,.36,1);
}
.notif.anim.is-in  { opacity: 1; transform: translateY(0) scale(1); }
.notif.anim.is-out { opacity: 0; transform: translateY(16px) scale(.985); }
.notif-ico {
  width: 38px; height: 38px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.24);
  color: #fff; flex: none;
}
.notif-text { flex: 1; min-width: 0; }
.notif-text strong { display: block; font-size: .96rem; color: #fff; line-height: 1.25; }
.notif-text span { font-size: .82rem; color: rgba(255,255,255,.8); }
.notif-amt { font-weight: 700; font-size: 1.02rem; color: #fff; white-space: nowrap; font-variant-numeric: tabular-nums; }

/* Sin JS, los mensajes deben verse igualmente (fallback). */
.no-js .notif { opacity: 1; transform: none; }


/* =========================================================
   STATS BAR
   ========================================================= */
.stats {
  background: var(--ink-deep); color: #fff; padding: var(--s-7) 0;
  border-top: 1px solid rgba(255,255,255,.06);
}
.stats-grid { display: grid; gap: var(--s-6); grid-template-columns: repeat(2, 1fr); text-align: center; }
.stat { display: flex; flex-direction: column; gap: 6px; }
.stat-num { font-size: clamp(1.9rem, 5vw, 2.8rem); font-weight: 700; letter-spacing: -.03em; line-height: 1; font-variant-numeric: tabular-nums; }
.stat-num .unit { color: var(--brand-glow); }
.stat-label { font-size: .9rem; color: rgba(255,255,255,.72); }
.stat .sim-tag { margin: 4px auto 0; }

/* =========================================================
   SECCIONES — base + ritmo claro/oscuro
   ========================================================= */
.section { padding: var(--s-9) 0; }
.section--light  { background: var(--paper); }
.section--alt    { background: var(--paper-2); border-top: 1px solid var(--line); }
.section--dark   { background: var(--ink-deep); color: #fff; }
.on-dark { color: #fff; }
.on-dark .eyebrow { color: var(--brand-glow); }
.on-dark .section-intro { color: rgba(255,255,255,.8); }
.on-dark .note { color: rgba(255,255,255,.55); }

.section-head { max-width: 60ch; margin-bottom: var(--s-8); }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head h2 { font-size: clamp(1.9rem, 4.4vw, 3rem); }

/* =========================================================
   4. EDITORIAL OSCURO — "Cómo te ayuda" (el momento estrella)
   3 pilares apilados; cada uno = texto + su visual SIEMPRE visible.
   ========================================================= */
/* Editorial es el 3er bloque oscuro seguido (stats → servicios → editorial).
   Borde superior tenue para separarlos sin romper el ritmo oscuro. */
.editorial { background: var(--ink-deep); color: #fff; padding: var(--s-10) 0; overflow: hidden; border-top: 1px solid rgba(255,255,255,.08); }
.editorial-head { max-width: 60ch; margin-bottom: var(--s-8); }
.editorial-head h2 { font-size: clamp(1.9rem, 4.4vw, 2.9rem); }

/* Pilares apilados. Cada pilar = texto + visual; en móvil apilan, en desktop
   son 2 columnas y los pares invierten el orden para dar ritmo. */
.edi-pillars { display: grid; gap: var(--s-9); }
.edi-pillar {
  display: grid; grid-template-columns: 1fr; gap: var(--s-5);
  align-items: center;
  padding-top: var(--s-8); border-top: 1px solid rgba(255,255,255,.12);
}
.edi-pillar:first-child { padding-top: 0; border-top: none; }

.edi-pillar-text { display: grid; gap: var(--s-4); }
.edi-head { display: flex; align-items: center; gap: var(--s-4); flex-wrap: wrap; }
.edi-word {
  font-size: clamp(2.6rem, 11vw, 5.4rem); font-weight: 800; letter-spacing: -.04em; line-height: .92;
  color: #fff; transition: color .35s var(--ease);
}
/* Flecha del pilar: SIEMPRE debajo del texto y apuntando a la DERECHA (hacia el
   gráfico, que va a la derecha en los tres pilares). Hover la empuja a la derecha. */
.edi-arrow {
  color: var(--brand-glow); width: clamp(40px, 6vw, 60px); height: auto;
  margin-top: var(--s-2); justify-self: start;
  --nudge: 0px;
  transform: translateX(var(--nudge));
  transition: transform .35s var(--ease);
}
.edi-pillar:hover .edi-word { color: var(--brand-glow); }
/* El nudge se aplica en el espacio local de la flecha (después del scaleX),
   por eso siempre "empuja" hacia donde apunta la punta, en ambos sentidos. */
.edi-pillar:hover .edi-arrow { --nudge: 10px; }
.edi-sub { color: rgba(255,255,255,.72); font-size: 1.02rem; max-width: 46ch; }
.edi-index { font-size: .8rem; font-weight: 700; letter-spacing: .12em; color: rgba(255,255,255,.4); }

/* Visual de cada pilar: caja 3:2 con borde, siempre en el DOM (sin swap). */
.edi-pillar-visual {
  position: relative; margin: 0; border-radius: var(--r); overflow: hidden;
  border: 1px solid rgba(255,255,255,.12); background: var(--ink-deep-2);
}

/* Visual de diseño · plano esquemático real (contain, fondo negro) con callouts. */
.edi-visual--design { padding: var(--s-3); }
.edi-mosaic { display: flex; flex-direction: column; }

/* Contenedor posicionado del plano negro + callouts rojos superpuestos. */
.edi-plan-wrap { position: relative; display: block; }
.edi-plan {
  display: block; border-radius: calc(var(--r) - 4px); overflow: hidden;
  background: #000; /* el plano es PNG de fondo negro: encaja sin marco claro */
  border: 1px solid rgba(255,255,255,.10);
}
.edi-plan img {
  display: block; width: 100%; height: auto; object-fit: contain; background: #000;
}

/* Etiquetas-callout rojas sobre el plano, con guion-líder fino. */
.edi-callout {
  position: absolute; z-index: 3;
  font-size: clamp(.56rem, 1.4vw, .74rem); font-weight: 700; letter-spacing: .02em;
  color: #ED1C24; white-space: nowrap; pointer-events: none;
  text-shadow: 0 1px 3px rgba(0,0,0,.85), 0 0 2px rgba(0,0,0,.7);
}
.edi-callout::before {
  content: ""; position: absolute; top: 50%;
  width: 16px; height: 1.5px; background: #ED1C24;
}
/* líder a la derecha de la etiqueta (etiqueta a la izquierda de su zona) */
.edi-callout--social, .edi-callout--dorm { padding-right: 22px; }
.edi-callout--social::before, .edi-callout--dorm::before { right: 0; }
/* líder a la izquierda de la etiqueta (etiqueta a la derecha de su zona) */
.edi-callout--cocina, .edi-callout--bano { padding-left: 22px; }
.edi-callout--cocina::before, .edi-callout--bano::before { left: 0; }

.edi-callout--social { top: 20%; left: 4%; }
.edi-callout--cocina { top: 22%; right: 4%; }
.edi-callout--dorm   { top: 70%; left: 4%; }
.edi-callout--bano   { top: 72%; right: 4%; }

/* En slots estrechos el plano es pequeño: reduce a 2 callouts para no saturar. */
@media (max-width: 600px) {
  .edi-callout { font-size: .56rem; }
  .edi-callout::before { width: 11px; }
  .edi-callout--social, .edi-callout--dorm { padding-right: 15px; }
  .edi-callout--cocina, .edi-callout--bano { padding-left: 15px; }
  .edi-callout--cocina, .edi-callout--bano { display: none; }
}
.edi-mosaic-photos { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-3); }
.edi-photo {
  display: block; border-radius: calc(var(--r) - 4px); overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
}
.edi-photo img { display: block; width: 100%; height: 100%; aspect-ratio: 3 / 2; object-fit: cover; }

/* Etiqueta del mosaico de diseño: chip flotante abajo-izquierda. */
.edi-visual--design .edi-slot-tag {
  position: absolute; left: var(--s-4); bottom: var(--s-4); z-index: 2; margin: 0;
  width: fit-content;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: .68rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: #fff; background: rgba(0,0,0,.55); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.22); padding: 5px 11px; border-radius: var(--r-pill);
}

/* Visual de gráfica · el wrap llena la caja y deja sitio a la etiqueta. */
.edi-visual--chart { padding: var(--s-5); }
/* Arriba-derecha para NO solaparse con las etiquetas de los meses del eje X. */
.edi-slot-tag--sim { position: absolute; right: var(--s-5); top: var(--s-5); z-index: 2; margin: 0; }

/* CRÍTICO: los charts usan maintainAspectRatio:false → el wrap necesita alto
   explícito o la gráfica no se ve. Selector propio del editorial; NO toca la
   regla global .chart-canvas-wrap (usada por #resultados). */
.edi-pillar .chart-canvas-wrap { height: auto; min-height: clamp(260px, 32vw, 340px); }

@media (min-width: 880px) {
  /* Los TRES idénticos: TEXTO a la izquierda, GRÁFICO/imagen a la derecha. */
  .edi-pillar { grid-template-columns: 1fr 1fr; gap: var(--s-8); align-items: center; }
}

/* =========================================================
   5. SIMULADOR DE PRECIOS DINÁMICOS
   ========================================================= */
.sim-grid { display: grid; gap: var(--s-7); grid-template-columns: 1fr; align-items: start; }
.sim-cal {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  padding: var(--s-5); box-shadow: var(--shadow-sm);
}
.sim-cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s-4); }
.sim-cal-head h3 { font-size: 1.05rem; }
.cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--s-2); margin-bottom: var(--s-2); }
.cal-dow span { text-align: center; font-size: .7rem; font-weight: 700; letter-spacing: .04em; color: var(--ink-faint); text-transform: uppercase; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--s-2); }
.cal-cell { aspect-ratio: 1 / 1.05; }
.cal-cell.is-empty { visibility: hidden; }
.cal-day {
  width: 100%; height: 100%; border: 1px solid var(--line); border-radius: var(--r-sm);
  background: var(--surface); cursor: pointer; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 2px; padding: 2px;
  font-family: inherit; color: var(--ink); position: relative;
  transition: transform .15s var(--ease), box-shadow .2s var(--ease), border-color .2s var(--ease);
}
.cal-day:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.cal-day .d-num { font-size: .72rem; color: var(--ink-faint); font-weight: 600; }
.cal-day .d-price { font-size: .82rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.cal-day[data-dem="low"]  { border-color: #cfe2d5; }
.cal-day[data-dem="mid"]  { border-color: #ecd9af; }
.cal-day[data-dem="high"] { border-color: #f3c4c7; }
.cal-day[data-dem="low"]  .d-price { color: var(--dem-low); }
.cal-day[data-dem="mid"]  .d-price { color: #b07e1c; }
.cal-day[data-dem="high"] .d-price { color: var(--dem-high); font-weight: 700; }
.cal-day[aria-pressed="true"] { border-color: var(--brand-deep); box-shadow: 0 0 0 2px var(--brand-tint); }

.cal-legend { display: flex; flex-wrap: wrap; gap: var(--s-4); margin-top: var(--s-4); font-size: .82rem; color: var(--ink-soft); }
.cal-legend span { display: inline-flex; align-items: center; gap: 6px; }
.cal-legend i { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }
.cal-legend .l-low  { background: var(--dem-low); }
.cal-legend .l-mid  { background: var(--dem-mid); }
.cal-legend .l-high { background: var(--dem-high); }

.sim-aside h3 { font-size: clamp(1.5rem, 3vw, 2rem); margin-bottom: var(--s-4); }
.sim-compare {
  display: flex; align-items: stretch; gap: var(--s-3); margin: var(--s-5) 0; flex-wrap: wrap;
}
.sim-pill {
  flex: 1 1 130px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-sm);
  padding: var(--s-4); text-align: center;
}
.sim-pill .lbl { font-size: .78rem; color: var(--ink-faint); display: block; margin-bottom: 4px; }
.sim-pill .val { font-size: 1.3rem; font-weight: 700; font-variant-numeric: tabular-nums; display: block; }
.sim-pill .sim-tag { margin-top: var(--s-2); }
.sim-pill--win { background: var(--brand-tint); border-color: #f6c9cc; }
.sim-pill--win .val { color: var(--brand-deep); font-weight: 700; }
.sim-uplift { font-weight: 700; color: var(--brand-deep); display: inline-flex; align-items: center; }
.sim-feats { display: grid; gap: var(--s-3); margin-top: var(--s-5); }
.sim-feats li { display: flex; gap: var(--s-3); align-items: flex-start; color: var(--ink-soft); font-size: .96rem; }
.sim-feats .ico { color: var(--brand-deep); margin-top: 2px; }

/* =========================================================
   6. RESULTADOS — charts SVG + estimador de ingresos
   ========================================================= */
/* Fila de KPIs del mes (modelo Unidad 2A). */
.kpi-row {
  display: grid; gap: var(--s-4); grid-template-columns: repeat(2, 1fr);
  margin-bottom: var(--s-6);
}
.kpi-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  padding: var(--s-5); box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 4px;
}
.kpi-card .kpi-val {
  font-size: clamp(1.7rem, 4.6vw, 2.3rem); font-weight: 800; letter-spacing: -.03em;
  line-height: 1; color: var(--brand-deep); font-variant-numeric: tabular-nums;
}
.kpi-card .kpi-unit { font-size: .55em; font-weight: 700; color: var(--ink-faint); }
.kpi-card .kpi-lbl { font-size: .86rem; color: var(--ink-soft); }
.kpi-row-tag { grid-column: 1 / -1; display: flex; justify-content: center; }

.results-grid { display: grid; gap: var(--s-6); grid-template-columns: 1fr; margin-bottom: var(--s-4); }
.chart-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  padding: var(--s-5); box-shadow: var(--shadow-sm);
}
.chart-card-head { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); }
.chart-card h3 { font-size: 1.02rem; margin-bottom: 2px; }
.chart-card .chart-sub { font-size: .85rem; color: var(--ink-faint); margin-bottom: var(--s-4); }

/* Contenedor de altura fija para el canvas dinámico (Chart.js: maintainAspectRatio:false). */
.chart-canvas-wrap { position: relative; height: 220px; width: 100%; }
.chart-canvas-wrap canvas { display: block; width: 100% !important; height: 100% !important; }

/* Fallback SVG: oculto por defecto; se muestra si Chart.js no carga. */
.chart-fallback { display: none; width: 100%; height: 100%; }
.chart-canvas-wrap.is-fallback canvas { display: none; }
.chart-canvas-wrap.is-fallback .chart-fallback { display: block; }

.chart-bar { fill: var(--line-strong); transition: fill .3s var(--ease); }
.chart-bar--accent { fill: var(--brand-deep); }
.chart-line { fill: none; stroke: var(--brand-deep); stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round; }
.chart-line--muted { stroke: var(--line-strong); }
.chart-area { fill: var(--brand-tint); }
.chart-dot { fill: var(--brand-deep); }
.chart-axis { stroke: var(--line); stroke-width: 1; }
.chart-txt { fill: var(--ink-faint); font-size: 9px; font-family: var(--font); }
.results-note { text-align: center; margin: 0 auto var(--s-8); }

.estimator {
  background: var(--ink-deep); color: #fff; border-radius: var(--r); padding: var(--s-7);
  border: 1px solid rgba(255,255,255,.1);
}
.estimator h3 { font-size: clamp(1.4rem, 3vw, 1.9rem); }
.estimator .est-intro { color: rgba(255,255,255,.78); margin-top: var(--s-3); max-width: 48ch; }
.est-controls { display: grid; gap: var(--s-4); margin: var(--s-6) 0; grid-template-columns: 1fr; }
.est-field label { display: block; font-size: .82rem; font-weight: 600; color: rgba(255,255,255,.7); margin-bottom: var(--s-2); letter-spacing: .02em; }
.est-field select {
  width: 100%; font-family: inherit; font-size: 1rem; color: #fff;
  background: var(--ink-deep-2); border: 1px solid rgba(255,255,255,.22); border-radius: var(--r-sm);
  padding: 13px 14px; appearance: none; cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ff5b61' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; background-size: 18px;
}
.est-field select:focus-visible { outline: 2px solid var(--brand-glow); outline-offset: 2px; }
.est-result {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--r); padding: var(--s-5); text-align: center; margin-bottom: var(--s-5);
}
.est-result .est-label { font-size: .82rem; color: rgba(255,255,255,.65); letter-spacing: .04em; }
.est-result .est-amount { font-size: clamp(1.9rem, 6vw, 2.8rem); font-weight: 800; letter-spacing: -.03em; color: var(--brand-glow); margin: 4px 0; font-variant-numeric: tabular-nums; }
.est-result .est-assumes { font-size: .8rem; color: rgba(255,255,255,.6); }
.estimator .btn { width: 100%; }

/* =========================================================
   7. SERVICIOS — grid 8 (sobre oscuro, foto como textura)
   ========================================================= */
/* Servicios va entre stats y editorial (tres bloques oscuros seguidos);
   borde superior tenue para marcar la separación sin volver a fondo claro. */
.svc-section { position: relative; isolation: isolate; overflow: hidden; border-top: 1px solid rgba(255,255,255,.08); }
/* Foto de interior REAL como textura sutil; overlay oscuro fuerte la deja de fondo. */
.svc-texture {
  position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background-image:
    linear-gradient(180deg, rgba(15,15,15,.92) 0%, rgba(15,15,15,.86) 50%, rgba(15,15,15,.94) 100%),
    url("photo-edited/DSCF4537_edited.jpg");
  background-size: cover; background-position: center; background-repeat: no-repeat;
}
.svc-inner { position: relative; z-index: 1; }
.svc-grid { display: grid; gap: var(--s-4); grid-template-columns: repeat(2, 1fr); }
.svc-card {
  background: rgba(29,29,29,.62); border: 1px solid rgba(255,255,255,.12); border-radius: var(--r);
  padding: var(--s-5); min-height: 132px;
  display: flex; flex-direction: column; gap: var(--s-4);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: transform .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.svc-card:hover { transform: translateY(-4px); border-color: rgba(255,91,97,.55); background: rgba(29,29,29,.78); }
.svc-ico {
  width: 48px; height: 48px; border-radius: var(--r-sm); display: grid; place-items: center;
  background: rgba(255,255,255,.06); color: #fff; flex: none;
  border: 1px solid rgba(255,255,255,.14);
}
.svc-ico .ico { width: 24px; height: 24px; stroke: #fff; }
.svc-card h3 { font-size: 1.08rem; line-height: 1.22; text-wrap: balance; }
.svc-cta-wrap { display: flex; justify-content: center; margin-top: var(--s-8); }

/* =========================================================
   8. EL MÉTODO — 3 pasos, ritmo asimétrico
   ========================================================= */
.method { display: grid; gap: var(--s-5); grid-template-columns: 1fr; }
.method-step {
  position: relative; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  padding: var(--s-6); box-shadow: var(--shadow-sm);
}
.method-num { font-size: .85rem; font-weight: 700; letter-spacing: .1em; color: var(--accent); display: block; margin-bottom: var(--s-4); }
.method-body h3 { font-size: 1.6rem; margin-bottom: var(--s-3); }
.method-body p { color: var(--ink-soft); max-width: 48ch; }
.method-media { margin-top: var(--s-6); }
.method-media img { width: 100%; height: auto; aspect-ratio: 3/2; object-fit: cover; border-radius: var(--r-sm); border: 1px solid var(--line); }

/* =========================================================
   9. UNIDADES MALL DEL ALTO
   ========================================================= */
.unit-grid { display: grid; gap: var(--s-5); grid-template-columns: 1fr; }
.unit-card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r);
  overflow: hidden; box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
}
.unit-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.unit-media { position: relative; }
.unit-media img { width: 100%; height: auto; aspect-ratio: 3/2; object-fit: cover; border-bottom: 1px solid var(--line); }
.unit-body { padding: var(--s-5); }
.unit-head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--s-3); }
.unit-head h3 { font-size: 1.35rem; }
.unit-cap { font-size: .8rem; font-weight: 600; color: var(--accent); background: var(--accent-tint); padding: 4px 10px; border-radius: var(--r-pill); white-space: nowrap; }
.unit-loc { color: var(--ink-faint); font-size: .9rem; margin-top: var(--s-2); }
.unit-actions { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-top: var(--s-5); }

/* =========================================================
   ZONAS
   ========================================================= */
.zone-grid { display: grid; gap: var(--s-5); grid-template-columns: 1fr; margin-top: var(--s-8); }
.zone-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; box-shadow: var(--shadow-sm); }
.zone-media { position: relative; }
.zone-media img { width: 100%; height: auto; aspect-ratio: 3/2; object-fit: cover; border-bottom: 1px solid var(--line); }

/* Badge de honestidad: "Foto referencial" sobre fotos genéricas (no es la unidad/zona real). */
.ref-badge {
  position: absolute; top: var(--s-3); left: var(--s-3); z-index: 2;
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,.94); color: var(--brand);
  font-size: .72rem; font-weight: 700; letter-spacing: .01em;
  padding: 4px 9px; border-radius: var(--r-pill);
  border: 1px solid var(--line); box-shadow: var(--shadow-sm);
  backdrop-filter: saturate(1.2) blur(2px);
}
.ref-badge::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--brand); flex: none;
}
.zone-body { padding: var(--s-5); }
.zone-body h3 { font-size: 1.3rem; }
.zone-status { display: inline-block; margin: var(--s-3) 0; font-size: .8rem; font-weight: 600; letter-spacing: .04em; color: var(--ink-faint); background: var(--paper-2); padding: 4px 11px; border-radius: var(--r-pill); }
/* CTA único de propietario bajo el grid de zonas en preparación (refuerza el funnel). */
.zone-cta { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--s-4); margin-top: var(--s-7); }
.zone-cta p { margin: 0; max-width: 46ch; color: var(--ink-soft); }

/* =========================================================
   10. PROTECCIÓN — AirCover + protocolos + reporte de limpieza
   ========================================================= */
.prot-grid { display: grid; gap: var(--s-6); grid-template-columns: 1fr; align-items: start; }
.prot-card {
  background: var(--ink-deep-2); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r); padding: var(--s-6);
}
.prot-card h3 { font-size: 1.2rem; margin-bottom: var(--s-4); }
.prot-figs { display: grid; gap: var(--s-3); }
.prot-fig { display: flex; gap: var(--s-3); align-items: baseline; padding-bottom: var(--s-3); border-bottom: 1px solid rgba(255,255,255,.08); }
.prot-fig:last-child { border-bottom: none; padding-bottom: 0; }
.prot-fig .fig-val { font-size: 1.15rem; font-weight: 700; color: var(--brand-glow); white-space: nowrap; font-variant-numeric: tabular-nums; }
.prot-fig .fig-txt { color: rgba(255,255,255,.78); font-size: .95rem; }
.prot-list { display: grid; gap: var(--s-3); }
.prot-list li { display: flex; gap: var(--s-3); align-items: flex-start; color: rgba(255,255,255,.82); font-size: .96rem; }
.prot-list .ico { color: var(--brand-glow); margin-top: 2px; }
.prot-disclaimer { color: rgba(255,255,255,.6); font-size: .85rem; margin-top: var(--s-4); max-width: 60ch; }
.prot-disclaimer a { color: var(--brand-glow); text-decoration: underline; text-underline-offset: 3px; }

/* Reporte de limpieza animado */
.clean-report {
  background: var(--surface); color: var(--ink); border-radius: var(--r); overflow: hidden;
  border: 1px solid var(--line); box-shadow: var(--shadow-md);
}
.clean-photo { position: relative; }
.clean-photo img { width: 100%; height: auto; aspect-ratio: 16/10; object-fit: cover; }
.clean-stamp {
  position: absolute; left: var(--s-4); bottom: var(--s-4);
  background: rgba(20,20,20,.82); color: #fff; font-size: .76rem; font-weight: 600;
  padding: 6px 11px; border-radius: var(--r-pill); backdrop-filter: blur(4px);
}
.clean-body { padding: var(--s-5); }
.clean-body h4 { font-size: 1.05rem; margin-bottom: var(--s-4); display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); }
.clean-checks { display: grid; gap: var(--s-2); }
.clean-check {
  display: flex; align-items: center; gap: var(--s-3); font-size: .94rem; color: var(--ink-soft);
  opacity: 0; transform: translateX(-8px);
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.clean-check.is-on { opacity: 1; transform: none; }
.no-js .clean-check { opacity: 1; transform: none; }
.clean-tick { width: 22px; height: 22px; border-radius: 50%; background: #e7f4ec; color: #2f8f55; display: grid; place-items: center; flex: none; }
.clean-tick .ico { width: 14px; height: 14px; stroke-width: 2.4; }

/* =========================================================
   11. TESTIMONIOS (placeholder honesto)
   ========================================================= */
.testi-note {
  display: flex; gap: var(--s-3); align-items: flex-start;
  background: var(--brand-tint); border: 1px solid #f6c9cc; border-radius: var(--r);
  padding: var(--s-5); color: var(--ink-soft); font-size: .96rem; max-width: 70ch;
}
.testi-note .ico { color: var(--brand-deep); margin-top: 2px; flex: none; }
.testi-grid { display: grid; gap: var(--s-5); grid-template-columns: 1fr; margin-top: var(--s-6); }
.testi-card { background: var(--surface); border: 1px dashed var(--line-strong); border-radius: var(--r); padding: var(--s-6); }
.testi-quote { font-size: 1.05rem; color: var(--ink); line-height: 1.5; }
.testi-meta { margin-top: var(--s-4); font-size: .85rem; color: var(--ink-faint); font-weight: 600; }

/* =========================================================
   12. FAQ
   ========================================================= */
.faq-grid { display: grid; gap: var(--s-7); grid-template-columns: 1fr; }
.faq-aside h2 { font-size: clamp(1.9rem, 4vw, 2.6rem); }
.faq-list { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; box-shadow: var(--shadow-sm); }
.faq-item + .faq-item { border-top: 1px solid var(--line); }
.faq-item summary {
  display: flex; align-items: center; justify-content: space-between; gap: var(--s-4);
  cursor: pointer; list-style: none; padding: var(--s-5) var(--s-6);
  font-weight: 600; font-size: 1.06rem; color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-chev { color: var(--accent); transition: transform .25s var(--ease); }
.faq-item[open] .faq-chev { transform: rotate(180deg); }
.faq-answer { padding: 0 var(--s-6) var(--s-5); }
.faq-answer p { color: var(--ink-soft); max-width: 62ch; }

/* =========================================================
   13. CTA FINAL
   ========================================================= */
.final-cta { background: var(--brand-deep); color: #fff; padding: var(--s-10) 0; position: relative; overflow: hidden; text-align: center; }
.final-cta::before {
  content: ""; position: absolute; inset: 0; opacity: .5;
  background: radial-gradient(60% 90% at 50% -10%, rgba(255,255,255,.22), transparent 70%);
}
.final-inner { position: relative; max-width: 720px; margin-inline: auto; }
.final-cta h2 { font-size: clamp(2rem, 5.5vw, 3.4rem); letter-spacing: -.03em; }
.final-cta h2 em { font-style: normal; color: #ffd9db; }
.final-cta p { color: rgba(255,255,255,.92); font-size: 1.1rem; margin: var(--s-5) auto var(--s-6); max-width: 48ch; }
.final-cta .btn--primary { background: #fff; color: var(--brand-deep); box-shadow: 0 12px 30px rgba(0,0,0,.18); }
.final-cta .btn--primary:hover { background: #fff; box-shadow: 0 16px 40px rgba(0,0,0,.26); }
.final-cta .note { color: rgba(255,255,255,.8); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { background: var(--ink-deep); color: #fff; border-top: 1px solid rgba(255,255,255,.1); padding: var(--s-8) 0 var(--s-7); }
.footer-inner { display: grid; gap: var(--s-7); grid-template-columns: 1fr; }
.footer-logo { height: 30px; width: auto; display: block; }
.footer-brand p { color: rgba(255,255,255,.7); margin-top: var(--s-4); font-size: .92rem; max-width: 40ch; }
.footer-news h3 { font-size: 1.05rem; margin-bottom: var(--s-3); }
.footer-news p { color: rgba(255,255,255,.7); font-size: .9rem; margin-bottom: var(--s-4); }
.news-form { display: flex; gap: var(--s-2); flex-wrap: wrap; }
.news-form input {
  flex: 1 1 180px; min-width: 0; font-family: inherit; font-size: .95rem; color: #fff;
  background: var(--ink-deep-2); border: 1px solid rgba(255,255,255,.22); border-radius: var(--r-pill);
  padding: 12px 18px;
}
.news-form input::placeholder { color: rgba(255,255,255,.5); }
.news-form input:focus-visible { outline: 2px solid var(--brand-glow); outline-offset: 2px; }
.footer-links { display: flex; flex-wrap: wrap; gap: var(--s-5); margin-top: var(--s-5); }
.footer-links a { display: inline-flex; align-items: center; gap: var(--s-2); color: rgba(255,255,255,.85); font-size: .94rem; }
.footer-links a:hover { color: #fff; }
.footer-links .ico { color: var(--brand-glow); }
.footer-copy { color: rgba(255,255,255,.55); font-size: .85rem; }

/* =========================================================
   BURBUJA FLOTANTE WHATSAPP (huésped) — persistente
   ========================================================= */
.wa-bubble {
  position: fixed; right: 18px; bottom: 18px; z-index: 90;
  display: inline-flex; align-items: center; gap: var(--s-3);
  background: #25D366; color: #06381c; font-weight: 700; font-size: .92rem;
  padding: 12px 18px 12px 14px; border-radius: var(--r-pill);
  box-shadow: 0 10px 30px rgba(0,0,0,.22); border: 2px solid #fff;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.wa-bubble:hover { transform: translateY(-3px); box-shadow: 0 16px 38px rgba(0,0,0,.28); }
.wa-bubble svg { width: 26px; height: 26px; flex: none; }
.wa-bubble .wa-txt { white-space: nowrap; }
/* En pantallas grandes solo se ve la etiqueta larga; la corta queda oculta. */
.wa-bubble .wa-txt--short { display: none; }
/* En móvil pequeño cambiamos a una etiqueta corta y compacta (no un ícono mudo). */
@media (max-width: 420px) {
  .wa-bubble { gap: var(--s-2); padding: 11px 15px 11px 12px; font-size: .78rem; }
  .wa-bubble svg { width: 22px; height: 22px; }
  .wa-bubble .wa-txt--full { display: none; }
  .wa-bubble .wa-txt--short { display: inline; }
}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
.no-js .reveal { opacity: 1; transform: none; }

/* =========================================================
   BREAKPOINTS
   ========================================================= */
@media (min-width: 600px) {
  .stats-grid { grid-template-columns: repeat(4, 1fr); }
  .unit-grid { grid-template-columns: repeat(2, 1fr); }
  .zone-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .est-controls { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 768px) {
  .container { padding-inline: var(--s-6); }
  .method { grid-template-columns: 1fr 1fr; grid-template-areas: "lg lg" "sm1 sm2"; }
  .method-step--lg { grid-area: lg; display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--s-6); align-items: center; }
  .method-step--lg .method-media { margin-top: 0; }
  .method-step--lg .method-media img { height: 100%; min-height: 220px; }
  .sim-grid { grid-template-columns: 1.05fr .95fr; }
  .kpi-row { grid-template-columns: repeat(4, 1fr); }
  .kpi-row-tag { grid-column: 1 / -1; justify-content: flex-end; }
  .svc-grid { grid-template-columns: repeat(3, 1fr); }  /* tablet: 3×2 */
  .results-grid { grid-template-columns: repeat(3, 1fr); }
  .prot-grid { grid-template-columns: 1fr 1fr; }
  .testi-grid { grid-template-columns: repeat(2, 1fr); }
  .faq-grid { grid-template-columns: .8fr 1.2fr; align-items: start; }
  .footer-inner { grid-template-columns: 1.3fr 1fr; }
}

@media (min-width: 1024px) {
  .hero { padding-top: var(--s-10); padding-bottom: var(--s-10); }
  .svc-grid { grid-template-columns: repeat(6, 1fr); }  /* desktop: 6 servicios en UNA fila */
  .unit-grid { grid-template-columns: repeat(3, 1fr); grid-auto-flow: dense; }
  .unit-card--feature { grid-column: span 2; }
  .unit-card--wide { grid-column: span 2; }
  .unit-card--feature .unit-media img,
  .unit-card--wide .unit-media img { aspect-ratio: 16 / 9; max-height: 420px; }
  .prot-grid { grid-template-columns: 1fr 1fr 1fr; }
  .footer-inner { grid-template-columns: 1.3fr 1fr 1.1fr; }
}

/* ---------- Hero en móvil (<= 768px): contenido CENTRADO + 1 mensaje rotativo ---------- */
@media (max-width: 768px) {
  /* Centrado vertical del bloque de contenido (texto + CTA + espacio del mensaje). */
  .hero { min-height: clamp(620px, 96svh, 760px); padding-top: var(--s-7); padding-bottom: var(--s-6); }
  /* Bajamos el bloque para que el friso "BOOM INMOBILIARIO" estampado en la imagen
     quede COMPLETO y asome ARRIBA del título; el texto cae sobre la fachada. */
  .hero-inner { justify-content: flex-start; transform: translateY(2vh); }
  .hero-title { white-space: normal; }
  /* Spacer reactivado (parcial) en móvil: empuja el bloque a la media-baja para
     revelar el friso arriba; el scrim local móvil mantiene la legibilidad. */
  .hero-spacer { display: block; flex: 0 0 auto; min-height: clamp(120px, 26vh, 240px); }
  .hero-notifs { margin-top: clamp(24px, 4vh, 36px); }

  /* --- Scrim LOCAL detrás del titular+subtítulo (solo móvil) ---
     Borra la franja "BOOM INMOBILIARIO" SOLO bajo el texto; el resto de la foto
     permanece visible. Blob radial de bordes suaves (sin rectángulo duro).
     .hero-lede es contexto de posición; el ::before va detrás del texto (z-index -1)
     pero por encima de la imagen/scrim global (porque .hero-inner es z-index 1). */
  .hero-lede { position: relative; }
  .hero-lede::before {
    content: ""; position: absolute; z-index: -1; pointer-events: none;
    left: 50%; transform: translateX(-50%);
    width: min(600px, 118vw);
    top: -2rem; bottom: -3.25rem;
    background: radial-gradient(ellipse 76% 82% at 50% 47%,
      rgba(0,0,0,.72) 0%,
      rgba(0,0,0,.60) 46%,
      rgba(0,0,0,.32) 70%,
      rgba(0,0,0,0) 88%);
  }

  /* Espacio FIJO para el mensaje rotativo: los 3 .notif superpuestos, solo 1 visible.
     min-height generosa que acomoda título 1 línea + subtítulo 1 línea SIN recorte. */
  .notif-stack {
    display: block; position: relative;
    min-height: 4.75rem; /* cubre el .notif más alto (icono 38px + 2 líneas de texto) */
  }
  .notif-stack .notif {
    position: absolute; top: 0; left: 0; right: 0;
    /* Estado base oculto (entra desde abajo). JS añade .is-show al activo. */
    opacity: 0; transform: translateY(16px) scale(.985);
    transition:
      opacity .46s cubic-bezier(.22,1,.36,1),
      transform .46s cubic-bezier(.22,1,.36,1);
    pointer-events: none;
  }
  .notif-stack .notif.is-show {
    opacity: 1; transform: translateY(0) scale(1);
    pointer-events: auto;
  }
  /* Saliente: se desvanece hacia arriba (estilo notificación). */
  .notif-stack .notif.is-leave {
    opacity: 0; transform: translateY(-12px) scale(.985);
  }
}

/* ---------- Mobile nav (<= 860px) ---------- */
@media (max-width: 860px) {
  .nav-toggle { display: inline-flex; }
  .nav-menu {
    position: fixed; inset: 72px 0 auto 0; flex-direction: column; align-items: stretch; gap: 0;
    background: var(--paper); border-bottom: 1px solid var(--line);
    padding: var(--s-3) var(--s-5) var(--s-6); box-shadow: var(--shadow-md);
    transform: translateY(-12px); opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
  }
  .site-header.is-scrolled .nav-menu { inset-block-start: 60px; }
  .nav-menu.is-open { transform: none; opacity: 1; visibility: visible; pointer-events: auto; }
  .nav-menu a { padding: var(--s-4) 0; border-bottom: 1px solid var(--line); font-size: 1.05rem; }
  .nav-menu li:last-child a { border-bottom: none; }
  .nav-menu a::after { display: none; }
}

/* =========================================================
   REDUCED MOTION — todo visible, sin transform, sin parallax
   ========================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  .reveal, .notif, .clean-check { opacity: 1 !important; transform: none !important; }
  .notif { will-change: auto; }
  /* Hero estático: imagen + scrim + texto + CTA + notificaciones (3 visibles). */
  .hero-inner { opacity: 1 !important; transform: none !important; }
}
/* Reduced-motion EN MÓVIL: un solo mensaje estático en el espacio fijo.
   Le gana a la regla global `.notif { opacity:1 !important }` con un selector
   más específico + posterior en cascada, dejando visible SOLO el primer .notif. */
@media (prefers-reduced-motion: reduce) and (max-width: 768px) {
  #flowSteps.notif-stack .notif { opacity: 1 !important; transform: none !important; }
  #flowSteps.notif-stack .notif:not(:first-child) { opacity: 0 !important; }
}
