/* ═══════════════════════════════════════════════════════════════
   KUXNAH LIVING CONDOS — main stylesheet
   v3.0 mayo 2026 · tokens consumidos desde /design-tokens.css
   ═══════════════════════════════════════════════════════════════ */

@import url("/design-tokens.css?v=2");

/* Tokens canónicos viven en design-tokens.css.
   Este archivo solo declara COMPONENTES y LAYOUTS — no tokens. */

/* ── Reset & body ── */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{
  background:var(--blanco-roto);color:var(--text);
  font-family:var(--sans);font-weight:300;
  -webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;
}
body{overflow-x:hidden;}
button{font-family:inherit;}
img{display:block;max-width:100%;height:auto;}
.hidden{display:none !important;}

/* ── Top scroll progress bar ── */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:200;
  background:rgba(28,31,36,.04);pointer-events:none;
}
.scroll-progress-fill{
  height:100%;width:0;background:var(--gold);
  box-shadow:0 0 8px rgba(197,165,90,.55);will-change:width;
}

/* ── Reveal-on-scroll base ── */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity 1s var(--ease-quint), transform 1s var(--ease-quint);}
.reveal.in{opacity:1;transform:translateY(0);}
.d1{transition-delay:.1s;} .d2{transition-delay:.2s;} .d3{transition-delay:.3s;}

/* ── Keyframes ── */
@keyframes pulse{0%,100%{opacity:.55;}50%{opacity:1;}}
@keyframes breathe{0%,100%{opacity:.6;}50%{opacity:1;}}
@keyframes drawLine{from{transform:scaleX(0);}to{transform:scaleX(1);}}
@keyframes rise{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
@keyframes heroFadeUpDeep{
  0%{opacity:0;transform:translateY(80px) scale(.92);filter:blur(14px);}
  35%{opacity:.25;filter:blur(9px);}
  65%{opacity:.7;filter:blur(2.5px);transform:translateY(10px) scale(.98);}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}
}
@keyframes heroFadeUpSoft{
  0%{opacity:0;transform:translateY(28px);}
  100%{opacity:1;transform:translateY(0);}
}
@keyframes heroFloat{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-7px);}
}
@keyframes scrollLineDrip{
  0%{transform:scaleY(0);transform-origin:top;}
  45%{transform:scaleY(1);transform-origin:top;}
  55%{transform:scaleY(1);transform-origin:bottom;}
  100%{transform:scaleY(0);transform-origin:bottom;}
}
@keyframes scrollArrowNudge{
  0%,100%{transform:translateY(0);opacity:.7;}
  50%{transform:translateY(4px);opacity:1;}
}
@keyframes slowZoomOut{from{transform:scale(1.10);}to{transform:scale(1);}}

/* ═══════════════════════════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 56px;
  transition:background-color 1.1s var(--ease-quint), padding .8s var(--ease-quint),
             border-color 1.1s ease, box-shadow 1.1s ease, backdrop-filter 1.1s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(250,248,245,.62);
  backdrop-filter:blur(32px) saturate(180%);
  -webkit-backdrop-filter:blur(32px) saturate(180%);
  padding:14px 56px;
  border-bottom:1px solid rgba(197,165,90,.32);
  box-shadow:0 1px 0 rgba(255,255,255,.55) inset, 0 12px 32px -20px rgba(28,31,36,.10);
}

.wordmark{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink);cursor:pointer;position:relative;}

.wordmark-symbol{position:relative;display:block;flex-shrink:0;width:114px;height:64px;
  transition:width .8s var(--ease-quint), height .8s var(--ease-quint);}
.wordmark-symbol-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;
  transition:opacity 1.1s var(--ease-quint), filter .8s ease;}
.wordmark-symbol-light{opacity:1;filter:drop-shadow(0 3px 10px rgba(0,0,0,.40));}
.wordmark-symbol-dark{opacity:0;filter:drop-shadow(0 2px 8px rgba(28,31,36,.10));}
.nav.scrolled .wordmark-symbol-light{opacity:0;}
.nav.scrolled .wordmark-symbol-dark{opacity:1;}
.nav.scrolled .wordmark-symbol{width:96px;height:54px;}

.wordmark-text{display:flex;flex-direction:column;align-items:flex-start;gap:5px;
  opacity:0;transform:translateX(-12px);pointer-events:none;
  max-width:0;overflow:hidden;
  transition:opacity 1.1s var(--ease-quint) .15s, transform 1.1s var(--ease-quint) .15s, max-width 1.1s var(--ease-quint) .15s;}
.nav.scrolled .wordmark-text{opacity:1;transform:translateX(0);pointer-events:auto;max-width:280px;}
.wordmark-text-main{font-family:var(--serif);font-weight:400;font-size:24px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);line-height:1;white-space:nowrap;}
.wordmark-text-sub{font-family:var(--sans);font-weight:400;font-size:9px;
  letter-spacing:.42em;text-transform:uppercase;color:var(--gold);line-height:1;white-space:nowrap;}

.nav-right{display:flex;align-items:center;gap:44px;}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none;}
.nav-links a{font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--white);text-decoration:none;position:relative;padding:6px 0;
  transition:color .3s ease;text-shadow:0 1px 8px rgba(0,0,0,.25);}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease-quint);}
.nav-links a:hover{color:var(--gold);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav.scrolled .nav-links a{color:var(--ink);text-shadow:none;}

/* ── Nav dropdown · Más ▾ · v2.2 ─────────────────────────────
   Pattern: trigger inline en nav-links, panel absolute below.
   Hidden enteramente bajo 1100px (donde nav-drawer toma control). */
.nav-links li.nav-link-dd{position:relative;list-style:none;display:inline-block;}
.nav-link-dd-trigger{
  display:inline-flex !important;align-items:center;gap:6px;
  font-family:var(--sans);font-size:11.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--white);
  background:none;border:0;cursor:pointer;padding:6px 0;line-height:1.2;
  transition:color .3s ease;text-shadow:0 1px 8px rgba(0,0,0,.25);
  white-space:nowrap;
}
.nav-link-dd-trigger > svg{transition:transform .3s var(--ease-quint);opacity:.7;flex:0 0 auto;}
.nav-link-dd-trigger:hover,
.nav-link-dd-trigger[aria-expanded="true"]{color:var(--gold);}
.nav-link-dd-trigger[aria-expanded="true"] svg{transform:rotate(180deg);}
.nav.scrolled .nav-link-dd-trigger{color:var(--ink);text-shadow:none;}

.nav-link-dd-panel{
  position:absolute;top:calc(100% + 18px);right:0;
  width:240px;
  background:var(--blanco-roto);
  border:1px solid rgba(28,31,36,.08);
  border-top:2px solid var(--gold);
  box-shadow:0 24px 60px -20px rgba(28,31,36,.30), 0 8px 18px -8px rgba(28,31,36,.15);
  padding:10px 0;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .25s ease, transform .3s var(--ease-quint), visibility 0s .3s;
  z-index:200;
  display:flex;flex-direction:column;
}
/* Triangle pointer top-right indicando el origen */
.nav-link-dd-panel::before{
  content:"";position:absolute;top:-7px;right:24px;
  width:12px;height:12px;background:var(--blanco-roto);
  border-top:2px solid var(--gold);border-left:1px solid rgba(28,31,36,.08);
  transform:rotate(45deg);
}
.nav-link-dd:hover .nav-link-dd-panel,
.nav-link-dd-trigger[aria-expanded="true"] + .nav-link-dd-panel{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .25s ease, transform .3s var(--ease-quint), visibility 0s 0s;
}
.nav-link-dd-panel a{
  display:block !important;width:100%;
  padding:12px 24px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.20em;
  text-transform:uppercase;color:var(--text-2);text-decoration:none;
  text-shadow:none;line-height:1.3;
  position:relative;
  transition:color .25s ease, background .25s ease, padding-left .25s var(--ease-quint);
}
/* Mata el subrayado gold heredado de .nav-links a */
.nav-link-dd-panel a::after{display:none !important;}
.nav-link-dd-panel a::before{
  content:"";position:absolute;left:14px;top:50%;
  width:0;height:1px;background:var(--gold);
  transform:translateY(-50%);
  transition:width .25s var(--ease-quint);
}
.nav-link-dd-panel a:hover{
  color:var(--ink);background:var(--chukum);padding-left:36px;
}
.nav-link-dd-panel a:hover::before{width:14px;}

/* En mobile (<1100px) el dropdown desaparece · vive en el drawer */
@media (max-width:1100px){
  .nav-links li.nav-link-dd{display:none !important;}
  .nav-link-dd-panel{display:none !important;}
  .nav-link-dd-trigger{display:none !important;}
}


.nav-lang{
  font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--white);text-decoration:none;
  padding:8px 12px;border:1px solid rgba(197,165,90,.40);
  border-radius:999px;
  transition:color .3s ease, border-color .3s ease, background .3s ease;
  text-shadow:0 1px 8px rgba(0,0,0,.25);
  margin-right:10px;
}
.nav-lang:hover{color:var(--gold);border-color:var(--gold);background:rgba(197,165,90,.08);}
.nav.scrolled .nav-lang{color:var(--ink);border-color:var(--hair-ink);text-shadow:none;}
.nav.scrolled .nav-lang:hover{color:var(--gold);border-color:var(--gold);}
@media (max-width:1100px){.nav-lang{display:none;}}

.nav-cta{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink);background:var(--gold);
  border:none;padding:13px 22px;border-radius:2px;cursor:pointer;text-decoration:none;display:inline-block;
  transition:background .3s ease, transform .3s ease, box-shadow .3s ease;
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px -10px rgba(197,165,90,.55);}
.nav-cta:hover{background:var(--gold-hi);transform:translateY(-1px);}

/* ═══════════════════════════════════════════════════════════════
   HERO  — Cinematic dark video, Cormorant centerpiece
   ═══════════════════════════════════════════════════════════════ */
.hero{position:relative;width:100%;height:100vh;min-height:760px;
  overflow:hidden;background:var(--blanco-roto);isolation:isolate;}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  background:url('images/hero-poster.jpg') center/cover no-repeat;}
@media (max-width:820px){.hero-video{display:none;}.hero{background:url('images/hero-poster.jpg') center/cover no-repeat;}}

.hero-render{position:absolute;inset:0;z-index:1;pointer-events:none;will-change:transform;
  background:
    radial-gradient(ellipse 100% 80% at 50% 35%, rgba(197,165,90,.08) 0%, transparent 75%),
    linear-gradient(180deg, rgba(28,31,36,.20) 0%, rgba(28,31,36,.30) 60%, rgba(28,31,36,.55) 88%, rgba(28,31,36,.78) 100%);
}
.hero-scrim{position:absolute;inset:0;pointer-events:none;z-index:3;
  background:linear-gradient(180deg, transparent 0%, transparent 60%, rgba(197,165,90,.05) 65%, transparent 70%, transparent 100%);}

.hero-content{position:absolute;left:0;right:0;bottom:0;z-index:5;
  padding:0 var(--pad-x) 110px;display:flex;flex-direction:column;align-items:flex-start;}

.hero-h1{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin:0 0 32px 0;font-weight:400;}
.hero-h1-mark{display:block;font-family:var(--serif-display);font-weight:400;
  font-size:clamp(58px, 9.6vw, 160px);letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.92);line-height:.92;
  text-shadow:0 6px 32px rgba(0,0,0,.55), 0 0 80px rgba(197,165,90,.18);
  opacity:0;animation:heroFadeUpDeep 2.4s var(--ease-quint) 1.6s forwards, heroFloat 9s ease-in-out 4.4s infinite;
  will-change:transform, opacity, filter;}
.hero-h1-sub{display:block;font-family:var(--sans);font-weight:300;
  font-size:clamp(11px,.95vw,14px);letter-spacing:.5em;text-transform:uppercase;
  color:var(--gold);text-shadow:0 2px 16px rgba(0,0,0,.5);
  opacity:0;animation:heroFadeUpSoft 1.4s var(--ease-quint) 2.6s forwards;}

.hero-rule{width:80px;height:1.5px;background:var(--gold);margin-bottom:28px;
  transform-origin:left;transform:scaleX(0);box-shadow:0 0 12px rgba(197,165,90,.5);
  animation:drawLine 1.4s var(--ease-quint) 3s forwards;}

.hero-tagline{font-family:var(--sans);font-weight:300;letter-spacing:.32em;text-transform:uppercase;
  color:var(--white);font-size:13px;margin-bottom:24px;
  text-shadow:0 1px 14px rgba(0,0,0,.5);
  opacity:0;animation:heroFadeUpSoft 1.2s var(--ease-quint) 3.2s forwards;}
.hero-body{font-family:var(--sans);font-weight:400;letter-spacing:.01em;
  color:rgba(255,255,255,.88);max-width:460px;font-size:15px;margin:0;
  text-shadow:0 1px 12px rgba(0,0,0,.45);
  opacity:0;animation:heroFadeUpSoft 1.2s var(--ease-quint) 3.6s forwards;}

.hero-meta{position:absolute;right:var(--pad-x);bottom:120px;
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;}
.hero-meta-row{display:flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:10.5px;font-weight:400;letter-spacing:.28em;
  text-transform:uppercase;color:rgba(255,255,255,.7);
  text-shadow:0 1px 10px rgba(0,0,0,.35);
  opacity:0;animation:heroFadeUpSoft 1s var(--ease-quint) forwards;}
.hero-meta-row:nth-child(1){animation-delay:2.4s;}
.hero-meta-row:nth-child(2){animation-delay:2.6s;}
.hero-meta-row:nth-child(3){animation-delay:2.8s;}
.hero-meta-row .dot{width:3px;height:3px;background:var(--gold);border-radius:50%;}
.hero-meta-row strong{color:var(--white);font-weight:500;}

/* Scroll cue */
.scroll-cue{position:absolute;left:50%;bottom:48px;z-index:5;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:14px;text-decoration:none;cursor:pointer;
  opacity:0;animation:heroFadeUpSoft 1.4s ease 4.2s forwards;}
.scroll-cue-label{font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:rgba(255,255,255,.85);text-shadow:0 1px 10px rgba(0,0,0,.4);
  transition:color .35s ease, letter-spacing .35s ease;}
.scroll-cue-line{display:block;width:1px;height:38px;
  background:linear-gradient(to bottom, transparent 0%, var(--gold) 60%, var(--gold) 100%);
  transform-origin:top;animation:scrollLineDrip 2.6s cubic-bezier(.4,0,.4,1) infinite;}
.scroll-cue-arrow{display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.25);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:var(--gold);animation:scrollArrowNudge 2.6s ease-in-out infinite;
  transition:background .35s ease, border-color .35s ease, color .35s ease;}
.scroll-cue:hover .scroll-cue-label{color:var(--white);letter-spacing:.5em;}
.scroll-cue:hover .scroll-cue-arrow{background:var(--gold);color:var(--ink);border-color:var(--gold);}

/* ═══════════════════════════════════════════════════════════════
   OPENER BAND — solid carbon, italic chapter number (used 4×)
   ═══════════════════════════════════════════════════════════════ */
.opener{position:relative;height:160px;background:var(--ink);
  display:flex;align-items:center;justify-content:center;}
.opener.reveal{opacity:1;transform:none;transition:none;}
.opener-inner{display:flex;flex-direction:column;align-items:center;gap:10px;}
.opener-rule{display:block;width:0;height:1px;background:var(--gold);opacity:0;
  transition:width 1.2s var(--ease-quint) .3s, opacity .8s ease .3s;}
.opener.in .opener-rule{width:40px;opacity:.5;}
.opener.in .opener-rule-bot{transition-delay:.7s;}
.opener-num{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(44px,4.5vw,60px);line-height:1;color:var(--gold);letter-spacing:.02em;
  opacity:0;transform:translateY(10px);
  transition:opacity 1.1s var(--ease-quint) .45s, transform 1.1s var(--ease-quint) .45s;}
.opener.in .opener-num{opacity:1;transform:translateY(0);}
.opener-label{font-family:var(--sans);font-weight:400;font-size:10.5px;letter-spacing:.42em;
  text-transform:uppercase;color:rgba(250,248,245,.78);
  opacity:0;transition:opacity .9s var(--ease-quint) .65s;}
.opener.in .opener-label{opacity:1;}
@media (max-width:720px){.opener{height:130px;}.opener-inner{gap:8px;}}

/* ═══════════════════════════════════════════════════════════════
   SECTION + SECTION HERO BAND (used 4×)
   ═══════════════════════════════════════════════════════════════ */
.section{position:relative;background:var(--blanco-roto);}
/* Variant: chukum cream para secciones editoriales (alternar con blanco-roto) */
.section.section-cream{background:var(--chukum);}

/* Image-based section hero */
.section-hero{position:relative;width:100%;height:62vh;min-height:480px;
  overflow:hidden;display:flex;align-items:flex-end;}
.section-hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  animation:slowZoomOut 22s ease-out forwards;}
.section-hero-scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, transparent 14%, transparent 50%, rgba(28,31,36,.55) 100%),
    linear-gradient(90deg, rgba(28,31,36,.55) 0%, rgba(28,31,36,.10) 50%, transparent 100%);}

/* Text-only section hero (used in Comparativa) */
.section-hero-text{height:auto;min-height:0;background:var(--blanco-roto);
  padding:140px 0 60px;align-items:center;}
.section-hero-text .section-hero-content{padding:0 var(--pad-x);position:relative;z-index:1;}
.section-hero-text .section-hero-title{color:var(--ink);text-shadow:none;}

.section-hero-content{position:relative;z-index:2;
  max-width:var(--container);width:100%;margin:0 auto;
  padding:0 var(--pad-x) 64px;}
.section-hero-centered{text-align:center;display:flex;flex-direction:column;align-items:center;}

.section-hero-title{font-family:var(--serif);font-weight:300;
  font-size:clamp(54px,7.5vw,112px);line-height:1;letter-spacing:.04em;text-transform:uppercase;
  color:var(--white);text-shadow:0 4px 32px rgba(0,0,0,.55);max-width:1100px;}
.section-hero-title em{font-style:italic;color:var(--gold);font-weight:300;letter-spacing:.02em;}

.section-hero-rule{width:80px;height:1.5px;background:var(--gold);margin-top:36px;
  box-shadow:0 0 14px rgba(197,165,90,.55);}
.section-hero-rule.center{margin-left:auto;margin-right:auto;}

.section-hero-sub{font-family:var(--sans);font-weight:300;
  font-size:clamp(15px,1.2vw,18px);line-height:1.65;
  color:rgba(250,248,245,.88);max-width:600px;margin-top:32px;
  text-shadow:0 1px 14px rgba(0,0,0,.4);}
.section-hero-text .section-hero-sub{color:var(--text-2);text-shadow:none;}

/* ═══════════════════════════════════════════════════════════════
   PILLAR — Section 01 component (4×)
   ═══════════════════════════════════════════════════════════════ */
.pillar{display:grid;grid-template-columns:60% 40%;align-items:stretch;
  background:var(--blanco-roto);min-height:540px;}
.pillar.alt{grid-template-columns:40% 60%;}
.pillar.alt .pillar-media{order:2;}
.pillar.alt .pillar-text{order:1;}

/* Sway-in reveal */
.pillar.reveal{opacity:0;transform:translateX(-90px);
  transition:opacity 1.4s var(--ease-quint), transform 1.4s var(--ease-quint);}
.pillar.alt.reveal{transform:translateX(90px);}
.pillar.reveal.in{opacity:1;transform:translateX(0);}

.pillar-media{position:relative;overflow:hidden;min-height:460px;}
.pillar-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  /* Image starts oversized + clipped (cinematic wipe) */
  transform:translate3d(0, var(--parallax-y, 0px), 0) scale(1.08);
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.6s var(--ease-clip);will-change:clip-path, transform;}
.pillar.reveal.in .pillar-media img{clip-path:inset(0 0 0 0);}
.pillar.alt .pillar-media img{clip-path:inset(0 0 0 100%);}
.pillar.alt.reveal.in .pillar-media img{clip-path:inset(0 0 0 0);}

.pillar-text{display:flex;flex-direction:column;justify-content:center;padding:64px 6vw;}
.pillar-eyebrow{display:flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);margin-bottom:24px;}
.pillar-eyebrow::before{content:"";display:block;width:28px;height:1px;background:var(--gold);}
.pillar-eyebrow em{font-style:normal;color:rgba(197,165,90,.5);font-weight:300;letter-spacing:.32em;text-transform:lowercase;}
.pillar-title{font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,4.4vw,62px);line-height:1.04;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
.pillar-title em{font-style:italic;color:var(--gold);font-weight:300;}
.pillar-rule{width:60px;height:1.5px;background:var(--gold);margin:24px 0;}
.pillar-body{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.7;
  color:var(--text-2);max-width:480px;margin-bottom:32px;}
.pillar-tags{display:flex;flex-wrap:wrap;gap:0;list-style:none;padding-top:22px;
  border-top:1px solid var(--hair-ink);}
.pillar-tags li{font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--text-3);
  padding:4px 16px;border-right:1px solid var(--hair-ink);}
.pillar-tags li:first-child{padding-left:0;}
.pillar-tags li:last-child{border-right:none;}

/* ═══════════════════════════════════════════════════════════════
   STATS BAND — used in Section 01
   ═══════════════════════════════════════════════════════════════ */
.stats{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:center;gap:0;
  background:var(--color-bg);padding:80px var(--pad-x);border-top:1px solid var(--hair-soft);}
.stat-cell{display:flex;flex-direction:column;align-items:center;text-align:center;gap:18px;}
.stat-num{font-family:var(--serif);font-weight:300;
  font-size:clamp(60px,7vw,108px);line-height:1;color:var(--ink);letter-spacing:.02em;}
.stat-num em{font-style:italic;color:var(--gold);font-weight:300;}
.stat-num small{font-family:var(--sans);font-size:.4em;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);margin-left:6px;}
.stat-label{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.34em;
  text-transform:uppercase;color:var(--text-3);}
.stat-sep{width:1px;height:80px;background:var(--hair-soft);}

/* ═══════════════════════════════════════════════════════════════
   TOWER — Section 02 component (Torre A + Torre B)
   ═══════════════════════════════════════════════════════════════ */
.tower{display:grid;grid-template-columns:55% 45%;align-items:stretch;
  background:var(--blanco-roto);min-height:78vh;}
.tower.alt{grid-template-columns:45% 55%;}
.tower.alt .tower-media{order:2;}
.tower.alt .tower-text{order:1;}

.tower.reveal{opacity:0;transform:translateY(36px);
  transition:opacity 1.4s var(--ease-quint), transform 1.4s var(--ease-quint);}
.tower.reveal.in{opacity:1;transform:translateY(0);}

.tower-media{position:relative;overflow:hidden;min-height:560px;}
.tower-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:translate3d(0, var(--parallax-y, 0px), 0) scale(1.08);
  clip-path:inset(0 100% 0 0);transition:clip-path 1.8s var(--ease-clip);}
.tower.reveal.in .tower-media img{clip-path:inset(0 0 0 0);}
.tower.alt .tower-media img{clip-path:inset(0 0 0 100%);}
.tower.alt.reveal.in .tower-media img{clip-path:inset(0 0 0 0);}

.tower-text{display:flex;flex-direction:column;justify-content:center;padding:80px 8vw;}
.tower-badge{align-self:flex-start;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;
  padding:8px 16px;border-radius:999px;margin-bottom:24px;white-space:nowrap;}
.tower-badge .dot{width:6px;height:6px;border-radius:50%;animation:pulse 2.4s ease-in-out infinite;}
.tower-badge-gold{background:var(--gold);color:var(--ink);}
.tower-badge-gold .dot{background:var(--ink);}
.tower-badge-verde{background:var(--verde);color:var(--white);}
.tower-badge-verde .dot{background:var(--blanco-roto);}

.tower-name{font-family:var(--serif);font-weight:300;
  font-size:clamp(72px,7vw,120px);line-height:1;letter-spacing:.05em;text-transform:uppercase;
  color:var(--ink);}
.tower-name em{font-style:italic;color:var(--gold);font-weight:300;}
.tower-name em.verde{color:var(--verde);}

.tower-rule{width:60px;height:1.5px;background:var(--gold);margin:28px 0;}
.tower-rule-verde{background:var(--verde);}

.tower-copy{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.7;
  color:var(--text-2);max-width:440px;margin-bottom:36px;}

.tower-stats{display:grid;grid-template-columns:1fr 1fr;gap:0;
  padding:24px 0;border-top:1px solid var(--hair-ink);border-bottom:1px solid var(--hair-ink);
  margin-bottom:18px;}
.tower-stat{display:flex;flex-direction:column;gap:10px;padding:0 28px;position:relative;}
.tower-stat:first-child{padding-left:0;}
.tower-stat:last-child{padding-right:0;}
.tower-stat + .tower-stat::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--hair-ink);}
.tower-stat-lbl{font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.3em;
  text-transform:uppercase;color:var(--text-3);}
.tower-stat-num{font-family:var(--serif);font-weight:300;font-size:clamp(28px,3vw,42px);line-height:1;
  color:var(--ink);letter-spacing:.01em;}
.tower-stat-num.gold{color:var(--gold);}
.tower-stat-num.verde{color:var(--verde);}

.tower-sidenote{font-family:var(--serif);font-style:italic;font-weight:300;font-size:15px;
  color:var(--gold);margin-bottom:24px;}
.tower-closing{font-family:var(--serif);font-style:italic;font-weight:300;font-size:18px;
  color:var(--ink);margin-bottom:24px;}
.tower-price{font-family:var(--serif);font-weight:300;font-size:24px;
  color:var(--gold);letter-spacing:.02em;margin-bottom:28px;}
.tower-price small{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--text-3);margin-left:8px;}

/* Phase divider */
.phase-divider{display:flex;align-items:center;justify-content:center;gap:18px;
  padding:64px var(--pad-x);background:var(--color-bg);}
.phase-divider-rule{display:block;width:60px;height:1px;background:var(--gold);opacity:.55;}
.phase-divider-label{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);}

/* ═══════════════════════════════════════════════════════════════
   CTA — universal button styles
   ═══════════════════════════════════════════════════════════════ */
.cta{display:inline-flex;align-items:center;gap:18px;
  font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;
  padding:20px 40px;border-radius:4px;border:none;cursor:pointer;text-decoration:none;
  align-self:flex-start;
  transition:transform .35s var(--ease-quint), background .35s ease, box-shadow .35s ease, gap .35s ease, color .35s ease;}
.cta-arrow{display:inline-block;transition:transform .35s var(--ease-quint);}
.cta:hover .cta-arrow{transform:translateX(4px);}
.cta-gold{background:var(--gold);color:var(--ink);
  box-shadow:0 18px 40px -16px rgba(197,165,90,.6);}
.cta-gold:hover{background:var(--gold-hi);transform:translateY(-2px);gap:24px;}
.cta-verde{background:var(--verde);color:var(--white);
  box-shadow:0 18px 40px -16px rgba(27,94,75,.4);}
.cta-verde:hover{background:var(--color-jade-hi);transform:translateY(-2px);gap:24px;}
.cta-outline{background:transparent;color:var(--gold);border:1px solid var(--gold);}
.cta-outline:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px);gap:24px;}
.cta-caption{font-family:var(--serif);font-style:italic;font-weight:300;font-size:13px;
  color:var(--text-3);margin-top:16px;}

/* ═══════════════════════════════════════════════════════════════
   COMPARATIVA — Section 03 rounds
   ═══════════════════════════════════════════════════════════════ */
.rounds{background:var(--blanco-roto);padding:0 var(--pad-x) 80px;max-width:var(--container);margin:0 auto;}
.round{display:grid;grid-template-columns:42% 58%;gap:64px;
  padding:80px 0;align-items:center;position:relative;
  border-top:1px solid var(--hair-soft);}
.round:first-child{border-top:none;}
.round-num{position:absolute;top:80px;right:0;
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:14px;
  color:var(--gold);opacity:.6;letter-spacing:.1em;}
.round-num em{color:rgba(197,165,90,.4);font-style:normal;}

.round-k{display:flex;flex-direction:column;gap:24px;padding-right:24px;}
.round-cat{display:flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold);}
.round-cat::before{content:"";width:28px;height:1px;background:var(--gold);}
.round-headline{font-family:var(--serif);font-weight:300;
  font-size:clamp(34px,3.8vw,52px);line-height:1.04;letter-spacing:.02em;color:var(--ink);}
.round-headline em{font-style:italic;color:var(--gold);font-weight:300;}
.round-support{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.65;
  color:var(--text-2);max-width:480px;}
.round-mark{display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.4em;text-transform:uppercase;
  color:var(--verde);margin-top:4px;}
.round-mark::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--verde);
  box-shadow:0 0 10px rgba(27,94,75,.45);}

.round-c{display:flex;flex-direction:column;gap:14px;
  padding-left:40px;border-left:1px solid var(--hair-soft);}
.round-c-label{font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.4em;
  text-transform:uppercase;color:var(--text-3);margin-bottom:10px;}
.round-c-row{display:grid;grid-template-columns:minmax(180px,220px) 1fr;
  gap:28px;align-items:baseline;padding:10px 0;
  border-bottom:1px dashed var(--hair-ink);}
.round-c-row:last-child{border-bottom:none;}
.round-c-name{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.14em;
  text-transform:uppercase;color:var(--text-3);
  filter:blur(3px);user-select:none;opacity:.85;}
.round-c-text{font-family:var(--sans);font-size:13.5px;font-weight:400;line-height:1.45;color:var(--text-2);}

/* Closing band of comparativa */
.closing-band{padding:var(--section-y) var(--pad-x);
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:32px;
  background:var(--color-bg);}
.closing-eyebrow{display:flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);}
.closing-eyebrow::before,.closing-eyebrow::after{content:"";width:28px;height:1px;background:var(--gold);opacity:.55;}
.closing-h{font-family:var(--serif);font-weight:300;
  font-size:clamp(36px,4.6vw,64px);line-height:1.15;letter-spacing:.04em;color:var(--ink);max-width:960px;}
.closing-h em{font-style:italic;color:var(--gold);font-weight:300;}
.closing-rule{width:60px;height:1.5px;background:var(--gold);}

/* ═══════════════════════════════════════════════════════════════
   SECTION 05 — CIERRE v2 · Cinematic dark closing experience
   • Act I  — Typographic opener (no photo)
   • Act II — Kicker price showdown (animated counters)
   • Act III— Two-doors CTA (WhatsApp · Visita privada)
   • Act IV — Inline form (dark, gold underlines)
   • Act V  — Grupo Salomón compact strip
   • Footer — minimal dark
   ═══════════════════════════════════════════════════════════════ */
/* ─── Testimonials ─── */
.section-testimonials{
  background:var(--color-bg);padding:90px 32px;
  border-top:1px solid var(--hair-soft);
}
.test-wrap{max-width:1200px;margin:0 auto;}
.test-eyebrow{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink-faint);margin-bottom:14px;
}
.test-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px, 4vw, 44px);color:var(--ink);
  margin-bottom:50px;
}
.test-grid{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:24px;
}
.test-card{
  background:var(--color-bg);border:1px solid var(--hair-soft);padding:28px;
  position:relative;
}
.test-card::before{
  content:'"';font-family:var(--serif);font-size:64px;
  font-style:italic;color:var(--gold);position:absolute;
  top:-2px;left:18px;line-height:1;opacity:.4;
}
.test-quote{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:17px;line-height:1.55;color:var(--ink);
  margin-bottom:22px;padding-top:6px;
}
.test-foot{
  display:flex;align-items:center;gap:12px;
  border-top:1px solid var(--hair-soft);padding-top:16px;
}
.test-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--gold);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:13px;font-weight:500;
  letter-spacing:.04em;flex-shrink:0;
}
.test-author{
  font-family:var(--mono);font-size:12px;color:var(--ink);
  letter-spacing:.04em;
}
.test-role{
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink-faint);margin-top:3px;
}
.test-rating{
  font-family:var(--mono);font-size:11px;color:var(--gold);
  letter-spacing:.16em;
}
@media (max-width:700px){
  .section-testimonials{padding:60px 20px;}
  .test-grid{grid-template-columns:1fr;gap:18px;}
  .test-card{padding:22px;}
  .test-quote{font-size:16px;}
}

.section-cierre{
  background:var(--ink);color:var(--color-bg);
  position:relative;overflow:hidden;
}
.section-cierre::before{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(197,165,90,.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 100%, rgba(197,165,90,.06) 0%, transparent 60%);
}

/* ── ACT I · COMPACT LIVE TICKER ── */
.visually-hidden{
  position:absolute !important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}
.cierre-ticker{
  position:relative;z-index:2;
  padding:32px var(--pad-x);
  border-bottom:1px solid rgba(197,165,90,.16);
}
.cierre-ticker-inner{
  display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;
  max-width:1280px;margin:0 auto;
  font-family:var(--sans);font-size:11.5px;letter-spacing:.32em;
  text-transform:uppercase;
}
.cierre-ticker-pill{
  display:inline-flex;align-items:center;gap:12px;
  padding:9px 18px;border:1px solid rgba(197,165,90,.32);
  border-radius:999px;
  background:rgba(255,255,255,.025);
}
.cierre-ticker-dot{
  width:7px;height:7px;border-radius:50%;background:var(--color-pulse);
  box-shadow:0 0 10px var(--color-pulse);
  animation:cierreLivePulse 2.2s ease-in-out infinite;
}
@keyframes cierreLivePulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(.82);}}
.cierre-ticker-num{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--gold);font-size:16px;letter-spacing:0;}
.cierre-ticker-of{color:var(--ink-faint);font-size:11px;margin-left:2px;}
.cierre-ticker-lbl{color:var(--color-bg);font-weight:300;letter-spacing:.32em;}
.cierre-ticker-meta{color:var(--ink-faint);font-weight:300;}
.cierre-ticker-sep{
  width:4px;height:4px;border-radius:50%;background:rgba(197,165,90,.5);
}

/* ── ACT II · CONVERGENCE PANEL — WARM/LIGHT, single decisive CTA ──
   Apple-clean. Mouse driven. Contrasts dark Comparativa above.
*/
.cierre-converge{
  position:relative;z-index:2;
  background:var(--color-bg);color:var(--ink);
  padding:var(--section-y) var(--pad-x);
  --mx:50%;--my:50%;
}
.cierre-converge .invite-sub{color:var(--ink-dim);}
.cierre-converge .invite-live-status{color:var(--ink);}
.cierre-converge .invite-wa-text{color:var(--ink);}
.cierre-converge .field-c-input,
.cierre-converge .field-c-select{color:var(--ink);}
.cierre-converge-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(
    520px circle at var(--mx) var(--my),
    rgba(197,165,90,.10),
    rgba(197,165,90,.03) 40%,
    transparent 70%
  );
  opacity:0;transition:opacity .6s ease;
}
.cierre-converge:hover .cierre-converge-glow{opacity:1;}

.cierre-converge-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:96px;
  max-width:1280px;margin:0 auto;align-items:center;
}

/* LEFT — invitation */
.cierre-invite{display:flex;flex-direction:column;gap:24px;}
.invite-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.invite-eyebrow::before{content:"";width:28px;height:1px;background:var(--gold);}
.invite-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.02em;
  color:var(--ink);margin-top:4px;
}
.invite-sub{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(17px,1.4vw,21px);line-height:1.5;color:var(--ink-dim);
  max-width:480px;
}
.invite-sub em{color:var(--gold);font-style:italic;}

/* Live availability indicator — pulse + clock */
.invite-live{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:8px;padding:14px 20px;
  background:var(--blanco-roto);border:1px solid var(--hair-soft);
  border-radius:999px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--ink-dim);
  width:fit-content;
  box-shadow:0 12px 28px -16px rgba(28,31,36,.18);
  transition:transform .35s var(--ease-quint), box-shadow .35s ease;
}
.invite-live:hover{transform:translateY(-2px);box-shadow:0 18px 36px -16px rgba(28,31,36,.22);}
.invite-live-dot{
  position:relative;width:9px;height:9px;border-radius:50%;background:var(--color-pulse);
  box-shadow:0 0 12px var(--color-pulse);
}
.invite-live-dot::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid var(--color-pulse);
  animation:invitePulse 2s ease-out infinite;
}
@keyframes invitePulse{0%{opacity:.7;transform:scale(.8);}100%{opacity:0;transform:scale(2.2);}}
.invite-live-status{color:var(--ink);font-weight:500;}
.invite-live-time{
  font-family:var(--mono,monospace);font-size:10px;font-weight:400;letter-spacing:.14em;
  color:var(--ink-faint);font-variant-numeric:tabular-nums;
}

/* WhatsApp inline secondary action */
.invite-wa{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:16px;padding:14px 0 16px;
  text-decoration:none;border-bottom:1px solid var(--hair);width:fit-content;
  transition:border-color .35s ease, gap .35s ease;
}
.invite-wa:hover{border-color:var(--gold);gap:20px;}
.invite-wa-icon{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:var(--color-whatsapp);color:var(--color-bg);flex:0 0 auto;
  box-shadow:0 6px 14px -6px rgba(37,211,102,.55);
  transition:transform .35s var(--ease-quint);
}
.invite-wa:hover .invite-wa-icon{transform:scale(1.06);}
.invite-wa-text{
  font-family:var(--mono,monospace);font-size:14px;font-weight:400;letter-spacing:.06em;
  color:var(--ink);
}
.invite-wa-hint{
  font-family:var(--sans);font-style:italic;font-size:11.5px;font-weight:300;letter-spacing:.04em;
  color:var(--ink-faint);text-transform:lowercase;
}

/* RIGHT — form card (Apple-clean) */
.cierre-form-card{
  position:relative;
  background:var(--blanco-roto);
  padding:48px 48px 36px;
  border:1px solid var(--hair-soft);
  box-shadow:
    0 1px 0 var(--hair-soft) inset,
    0 32px 80px -28px rgba(28,31,36,.18),
    0 12px 24px -12px rgba(28,31,36,.10);
  transition:box-shadow .55s ease, transform .55s var(--ease-quint);
}
.cierre-form-card:hover{
  transform:translateY(-2px);
  box-shadow:
    0 1px 0 var(--gold) inset,
    0 40px 100px -28px rgba(197,165,90,.22),
    0 12px 24px -12px rgba(28,31,36,.10);
}
.form-card-corner{
  position:absolute;top:0;left:0;width:80px;height:2px;background:var(--gold);
  transition:width .55s var(--ease-quint);
}
.cierre-form-card:hover .form-card-corner{width:100%;}
.form-card-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.form-card-eyebrow::before{content:"";width:20px;height:1px;background:var(--gold);}
.form-card-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2vw,30px);line-height:1.25;letter-spacing:.02em;
  color:var(--ink);margin:14px 0 32px;
}

/* Apple-clean fields — labels float, line under, gold focus */
.form-card-form{display:flex;flex-direction:column;gap:24px;}
.field-c{
  display:flex;flex-direction:column;gap:6px;
  padding:0 0 14px;
  border-bottom:1px solid var(--hair);
  position:relative;
  transition:border-color .35s ease;
}
.field-c::after{
  content:"";position:absolute;left:0;bottom:-1px;width:0;height:2px;
  background:var(--gold);
  transition:width .45s var(--ease-quint);
}
.field-c:focus-within::after{width:100%;}
.field-c:focus-within{border-bottom-color:transparent;}
.field-c-label{
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.4em;
  text-transform:uppercase;color:var(--ink-faint);
  transition:color .25s ease;
}
.field-c:focus-within .field-c-label{color:var(--gold);}
.field-c-input,.field-c-select{
  appearance:none;-webkit-appearance:none;
  background:transparent;border:none;outline:none;
  font-family:var(--sans);font-size:16px;font-weight:400;color:var(--ink);
  padding:4px 0 2px;width:100%;letter-spacing:.005em;
}
.field-c-input::placeholder{color:var(--ink-faint);font-weight:300;}
.field-c-tel{display:flex;align-items:baseline;gap:10px;width:100%;}
.field-c-prefix{font-family:var(--mono,monospace);font-size:14px;font-weight:400;color:var(--gold);letter-spacing:.04em;}
.field-c-select-wrap{position:relative;}
.field-c-select-wrap::after{content:"";position:absolute;right:0;top:50%;width:8px;height:8px;
  border-right:1px solid var(--gold);border-bottom:1px solid var(--gold);
  transform:translateY(-65%) rotate(45deg);pointer-events:none;
  transition:border-color .25s ease;}
.field-c-select{padding-right:24px;cursor:pointer;}

/* Big primary CTA — animated gleam, mouse hover */
.form-card-submit{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--ink);color:var(--color-bg);
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  padding:22px 32px;border:none;border-radius:0;cursor:pointer;
  margin-top:8px;
  box-shadow:0 18px 36px -14px rgba(28,31,36,.40);
  transition:transform .45s var(--ease-quint), background .35s ease, box-shadow .45s ease, gap .35s ease;
}
.form-card-submit:hover{
  background:var(--gold);color:var(--ink);
  transform:translateY(-2px);gap:18px;
  box-shadow:0 26px 48px -12px rgba(197,165,90,.55);
}
.form-card-submit-glow{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(105deg, transparent 35%, rgba(197,165,90,.45) 50%, transparent 65%);
  transform:translateX(-100%);
  transition:transform .9s var(--ease-quint);
}
.form-card-submit:hover .form-card-submit-glow{transform:translateX(100%);}
.form-card-submit-text{position:relative;z-index:1;}
.form-card-submit-arrow{
  position:relative;z-index:1;
  font-family:var(--serif);font-style:italic;font-size:22px;font-weight:300;
  transition:transform .35s var(--ease-quint);
}
.form-card-submit:hover .form-card-submit-arrow{transform:translateX(4px);}

.form-card-fine{
  display:inline-flex;align-items:center;gap:8px;margin-top:18px;
  font-family:var(--sans);font-size:10.5px;font-weight:300;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-faint);
}
.form-card-fine-dot{
  width:6px;height:6px;border-radius:50%;background:var(--color-pulse);
  box-shadow:0 0 8px var(--color-pulse);
}

/* ── ACT III · GRUPO SALOMÓN — slim, compact strip ── */
.cierre-gs{
  position:relative;z-index:2;
  padding:var(--section-y-sm) var(--pad-x);
  background:var(--color-bg);color:var(--ink);
  border-top:1px solid var(--hair-soft);
  max-width:1480px;margin:0 auto;
}

/* Identity row — tighter */
.gs-id-row{
  display:grid;grid-template-columns:auto 1fr;gap:48px;align-items:center;
  margin-bottom:28px;
}
.gs-id-mark{display:flex;align-items:center;gap:20px;}
.gs-logo{
  width:auto;height:46px;max-width:160px;object-fit:contain;
  flex:0 0 auto;
  filter:drop-shadow(0 4px 12px rgba(28,31,36,.15));
  transition:transform .55s var(--ease-quint), filter .35s ease;
}
.gs-logo:hover{transform:translateY(-2px);filter:drop-shadow(0 10px 24px rgba(28,31,36,.28));}
/* If image is missing, hide the slot (the wordmark text stands alone) */
.gs-logo.gs-logo-missing{display:none;}
.gs-id-text{display:flex;flex-direction:column;gap:6px;}
.gs-id-eyebrow{
  font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.gs-id-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2.4vw,32px);line-height:1;letter-spacing:.04em;
  color:var(--ink);text-transform:none;
}
.gs-id-name em{font-style:italic;color:var(--gold);font-weight:400;}
.gs-id-tag{
  font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:.36em;
  text-transform:uppercase;color:var(--gold);margin-top:4px;
}

.gs-id-metrics{
  display:flex;align-items:center;justify-content:flex-end;gap:28px;flex-wrap:wrap;
}
.gs-metric{display:flex;flex-direction:column;gap:2px;}
.gs-metric-num{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(20px,2vw,28px);line-height:1;color:var(--gold);
}
.gs-metric-lbl{
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ink-faint);
}
.gs-metric-sep{
  width:1px;height:28px;background:var(--hair);
}

/* Portfolio grid — 3 residenciales entregados, estático */
.gs-portfolio{
  position:relative;
}
.gs-portfolio-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);
  gap:18px;
}
.gs-tile{
  position:relative;margin:0;
  background:var(--ink);
  border:1px solid var(--hair);
  overflow:hidden;
  aspect-ratio:4 / 3;
}
.gs-tile img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease-quint);
}
.gs-tile:hover img{transform:scale(1.04);}
.gs-tile figcaption{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;flex-direction:column;gap:4px;
  padding:14px 18px;
  background:linear-gradient(180deg, transparent 0%, rgba(28,31,36,.55) 45%, rgba(28,31,36,.92) 100%);
  color:var(--color-bg);
}
.gs-tile-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(14px,1.2vw,17px);letter-spacing:.02em;color:var(--color-bg);
}
.gs-tile-name em{font-style:italic;color:var(--gold);}
.gs-tile-meta{
  font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);
}

/* Mission quote — slim, inline */
.gs-mission{
  position:relative;
  display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;
  margin:24px auto 0;max-width:none;
  padding:18px 0 0;
  border-top:1px solid var(--hair-soft);
  border-left:none;background:transparent;
}
.gs-mission-mark{display:none;}
.gs-mission-text{
  flex:1 1 auto;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(13px,1.05vw,16px);line-height:1.5;letter-spacing:.01em;
  color:var(--ink-dim);margin:0;
}
.gs-mission-text em{color:var(--gold);font-style:italic;}
.gs-mission-source{
  display:inline-flex;align-items:center;gap:10px;flex:0 0 auto;
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ink-faint);
}
.gs-mission-rule{display:block;width:20px;height:1px;background:var(--gold);}
.gs-mission-source a{
  color:var(--gold);text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .35s ease, color .35s ease;
}
.gs-mission-source a:hover{color:var(--gold-hi);border-color:var(--gold-hi);}

/* ── FOOTER (light bone) ── */
.section-cierre .footer{
  background:var(--color-bg);color:var(--ink);
  border-top:1px solid var(--hair-soft);
}
.section-cierre .footer-left{color:var(--ink-faint);}
.section-cierre .footer-link{color:var(--ink-faint);}
.section-cierre .footer-link:hover{color:var(--gold);}
.section-cierre .footer-sep{background:var(--gold);}
.section-cierre .footer-soc{color:var(--gold);}
.section-cierre .footer-soc:hover{color:var(--gold-hi);}

/* Footer (legacy white version remains for any other use) */
.footer{width:100%;background:var(--color-bg);padding:24px var(--pad-x);min-height:70px;
  display:grid;grid-template-columns:1fr 1fr 1fr;align-items:center;gap:24px;
  border-top:1px solid var(--hair-soft);}
.footer-left{font-family:var(--sans);font-size:12px;font-weight:400;color:var(--text-3);letter-spacing:.04em;}
.footer-center{display:flex;align-items:center;justify-content:center;gap:12px;}
.footer-link{font-family:var(--sans);font-size:11px;font-weight:400;color:var(--text-3);
  letter-spacing:.22em;text-transform:uppercase;text-decoration:none;transition:color .3s ease;}
.footer-link:hover{color:var(--gold);text-decoration:underline;text-underline-offset:4px;}
.footer-sep{width:3px;height:3px;border-radius:50%;background:var(--gold);opacity:.7;}
.footer-right{display:flex;align-items:center;justify-content:flex-end;gap:24px;}
.footer-soc{color:var(--gold);transition:color .3s ease, transform .3s ease;}
.footer-soc:hover{color:var(--gold-hi);transform:translateY(-1px);}

/* Footer secundario · legal/SEO · luxury minimal */
.footer-meta{
  width:100%;background:var(--ink-deep);
  padding:14px var(--pad-x);text-align:center;
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
}
.footer-meta-link{
  font-family:var(--sans);font-size:10px;font-weight:400;letter-spacing:.18em;
  text-transform:uppercase;color:rgba(250,247,240,.45);text-decoration:none;
  transition:color .25s ease;
}
.footer-meta-link:hover{color:var(--gold);}
.footer-meta-sep{color:rgba(197,165,90,.40);font-size:10px;}

/* ── Cierre responsive ── */
@media (max-width:980px){
  .cierre-ticker{padding:24px var(--pad-x);}
  .cierre-ticker-inner{gap:16px;font-size:10px;letter-spacing:.24em;}
  .cierre-converge{padding:64px var(--pad-x);}
  .cierre-converge-grid{grid-template-columns:1fr;gap:48px;}
  .invite-h{font-size:clamp(44px,11vw,72px);}
  .cierre-form-card{padding:32px 28px 28px;}
  .cierre-gs-row{grid-template-columns:1fr;gap:32px;}
  .cierre-gs-metrics{justify-content:flex-start;}
}
@media (max-width:560px){
  .cierre-gs-metrics{gap:20px;}
  .cierre-gs-metric-sep{display:none;}
  .invite-live{font-size:10px;letter-spacing:.24em;padding:12px 16px;}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:1100px){.nav-links{display:none;}}
@media (max-width:1080px){
  .pillar,.pillar.alt,.tower,.tower.alt{grid-template-columns:1fr;}
  .pillar.alt .pillar-media,.tower.alt .tower-media{order:1;}
  .pillar.alt .pillar-text,.tower.alt .tower-text{order:2;}
  .pillar-media,.tower-media{min-height:420px;}
  .pillar-text,.tower-text{padding:56px 32px;}
  .stats{grid-template-columns:1fr;gap:48px;padding:80px 32px;}
  .stat-sep{display:none;}
  .form-grid,.gs-grid{grid-template-columns:1fr;gap:48px;}
  .round{grid-template-columns:1fr;gap:40px;padding:56px 0;}
  .round-c{padding-left:0;border-left:none;border-top:1px solid var(--hair-soft);padding-top:32px;}
  .round-num{position:static;margin-bottom:4px;}
}
@media (max-width:820px){
  .nav{padding:20px 24px;}
  .nav.scrolled{padding:14px 24px;}
  .nav-cta{display:none;}
  .hero-content{padding:0 24px 96px;}
  .hero-meta{right:24px;bottom:96px;align-items:flex-start;left:24px;}
}
@media (max-width:720px){
  .hero{height:80vh;min-height:500px;}
  .pillar-media,.tower-media{min-height:320px;}
  .pillar-text,.tower-text{padding:48px 24px;}
  .form-section,.gs,.closing-band{padding-left:24px;padding-right:24px;}
  .gs-thumbs{grid-template-columns:repeat(2,80px);}
  .footer{grid-template-columns:1fr;text-align:center;padding:24px;gap:14px;}
  .footer-left,.footer-center,.footer-right{justify-content:center;}
}

/* ═══════════════════════════════════════════════════════════════
   v2.1 NEW COMPONENTS — Sticky CTA, Quick Stats, Manifesto, Pin-scroll, La Vida
   ═══════════════════════════════════════════════════════════════ */

/* ── Sticky WhatsApp pill · v2.2 oro mate + monograma K ──
   Pattern: discreto · luxury · aparece tras scroll
   Replaces verde default (#25D366) por gold mate del brand
   ─────────────────────────────────────────────────────── */
.wa-pill{
  position:fixed;bottom:28px;right:28px;z-index:150;
  display:inline-flex;align-items:center;gap:14px;
  padding:13px 22px 13px 16px;border-radius:999px;
  background:var(--ink);
  color:var(--blanco-roto);text-decoration:none;
  border:1px solid rgba(197,165,90,.30);
  font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;
  box-shadow:0 14px 36px -12px rgba(28,31,36,.45), 0 4px 12px -4px rgba(28,31,36,.20);
  transition:transform .35s var(--ease-quint), box-shadow .35s ease,
             background .35s ease, border-color .35s ease, padding .35s var(--ease-quint);
  /* Aparece a los 8s (no inmediato) o tras 20% scroll vía script.js */
  opacity:0;transform:translateY(20px) scale(.92);
  animation:waPillIn .9s var(--ease-quint) 8s forwards;
}
.wa-pill.wa-pill-visible{opacity:1;transform:translateY(0) scale(1);}
@keyframes waPillIn{
  to{opacity:1;transform:translateY(0) scale(1);}
}
.wa-pill:hover{
  transform:translateY(-3px);
  background:var(--ink-deep);
  border-color:var(--gold);
  box-shadow:0 22px 50px -12px rgba(28,31,36,.55), 0 6px 16px -4px rgba(28,31,36,.30);
}
.wa-pill .wa-pill-mono{
  display:flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:999px;
  background:var(--gold);color:var(--ink);
  font-family:var(--serif-display);font-style:italic;font-weight:400;font-size:18px;
  letter-spacing:0;text-transform:none;
  line-height:1;padding-bottom:1px;
  transition:background .35s ease;
}
.wa-pill:hover .wa-pill-mono{background:var(--gold-hi);}
.wa-pill-icon{display:none;}
.wa-pill-label{position:relative;top:.5px;}
.wa-pill::after{
  content:"";position:absolute;inset:-3px;border-radius:999px;
  border:1px solid rgba(197,165,90,.35);
  animation:waPulse 3.4s ease-in-out infinite;pointer-events:none;
}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.7;}
  70%{transform:scale(1.14);opacity:0;}
  100%{transform:scale(1.14);opacity:0;}
}
@media (max-width:720px){
  .wa-pill{padding:11px 18px 11px 13px;font-size:11px;bottom:18px;right:18px;
    letter-spacing:.16em;gap:10px;}
  .wa-pill .wa-pill-mono{width:26px;height:26px;font-size:15px;}
  .wa-pill-label{display:none;}
}

/* ═══════════════════════════════════════════════════════════════
   POR QUÉ KUXNAH · bento grid v2.2 · Apple Vision Pro pattern
   6 celdas asimétricas · proof concreto sin marketing
   ═══════════════════════════════════════════════════════════════ */
.pq-sec{
  padding:var(--section-y) var(--pad-x);
  background:var(--blanco-roto);
}
@media (max-width:820px){.pq-sec{padding:80px 20px 100px;}}
.pq-head{max-width:760px;margin:0 auto 64px;text-align:center;}
.pq-eyebrow{
  display:inline-block;
  font-family:var(--sans);font-size:10px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.pq-h{
  font-family:var(--serif-display);font-weight:400;
  font-size:clamp(36px,5.6vw,72px);line-height:1.04;letter-spacing:.005em;
  color:var(--ink);margin-bottom:18px;
}
.pq-h em{font-style:italic;color:var(--gold);}
.pq-deck{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(16px,1.8vw,21px);line-height:1.55;
  color:var(--taupe);max-width:560px;margin:0 auto;
}

/* ── Por qué · editorial ledger (v3) · reemplaza el bento SaaS ──
   Zigzag foto + texto · patrón comparativa cálida · 6 razones ── */
.pq-list{
  max-width:1120px;margin:0 auto;
  display:flex;flex-direction:column;
  gap:clamp(56px,7vw,104px);
}
.pq-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  align-items:center;
  gap:clamp(32px,5vw,72px);
}
.pq-row-flip .pq-media{order:2;}
@media (max-width:760px){
  .pq-row{grid-template-columns:1fr;gap:24px;}
  .pq-row-flip .pq-media{order:0;}
}

/* Media · foto real */
.pq-media{
  position:relative;margin:0;overflow:hidden;
  border-radius:2px;aspect-ratio:4/3;
  background:var(--ink);
  border:1px solid rgba(197,165,90,.22);
  box-shadow:0 30px 70px -36px rgba(28,31,36,.45);
}
.pq-media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s var(--ease-quint);
}
.pq-row:hover .pq-media img{transform:scale(1.04);}
.pq-media-tall{aspect-ratio:4/5;}
@media (max-width:760px){
  .pq-media,.pq-media-tall{aspect-ratio:16/10;}
}

/* Media · plate (cifra protagonista, sin foto: precio / fideicomiso) */
.pq-plate{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;text-align:center;padding:48px 32px;aspect-ratio:4/3;
  background:var(--chukum);
  border:1px solid rgba(28,31,36,.08);
  box-shadow:0 30px 70px -40px rgba(28,31,36,.28);
}
.pq-plate-kicker,.pq-plate-unit{
  font-family:var(--sans);font-size:10.5px;font-weight:500;
  letter-spacing:.26em;text-transform:uppercase;color:var(--taupe);
}
.pq-plate-stat{
  font-family:var(--serif-display);font-style:italic;font-weight:400;
  font-size:clamp(56px,8vw,108px);line-height:.9;color:var(--ink);
}
.pq-plate-stat em{font-style:italic;color:var(--color-gold-deep);}
.pq-plate-icn{color:var(--color-gold-deep);margin-bottom:4px;}
.pq-plate-word{
  font-family:var(--serif-display);font-style:italic;font-weight:400;
  font-size:clamp(40px,5.5vw,76px);line-height:1;color:var(--ink);
}

/* Body · texto */
.pq-body{display:flex;flex-direction:column;align-items:flex-start;gap:14px;}
.pq-meta{display:flex;align-items:baseline;gap:14px;}
.pq-num{
  font-family:var(--serif-display);font-style:italic;font-weight:400;
  font-size:clamp(26px,3vw,38px);line-height:1;color:rgba(197,165,90,.5);
}
.pq-kicker{
  font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;color:var(--color-gold-deep);
}
.pq-row-h{
  font-family:var(--serif-display);font-weight:400;
  font-size:clamp(28px,3.2vw,46px);line-height:1.08;letter-spacing:.005em;
  color:var(--ink);margin:2px 0;
}
.pq-row-h em{font-style:italic;color:var(--color-gold-deep);}
.pq-row-p{
  font-family:var(--sans);font-size:14.5px;font-weight:300;line-height:1.62;
  color:var(--taupe);max-width:46ch;
}
.pq-row-link{
  margin-top:6px;
  font-family:var(--sans);font-size:10.5px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--color-gold-deep);text-decoration:none;
  padding-bottom:4px;border-bottom:1px solid var(--color-gold-deep);
  transition:padding-right .3s var(--ease-quint),border-color .3s ease;
}
.pq-row-link:hover{padding-right:8px;border-color:var(--gold);}
.pq-row-src{
  font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--taupe);
}

/* ── Trust strip · v2.2 · proof concreto sobre chukum cream ──
   Cuatro hechos verificables · luxury restraint · sin emojis ── */
.trust-strip{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  align-items:center;gap:0;
  background:var(--chukum);
  padding:18px var(--pad-x);
  border-bottom:1px solid rgba(28,31,36,.06);
  border-top:1px solid rgba(28,31,36,.05);
}
.trust-strip-cell{
  display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:4px;line-height:1.1;
}
.trust-strip-num{
  font-family:var(--serif-display);font-style:italic;font-weight:400;
  font-size:clamp(20px,2.4vw,28px);color:var(--ink);letter-spacing:.01em;
}
.trust-strip-num em{font-style:italic;color:var(--ink);}
.trust-strip-num small{
  font-family:var(--sans);font-size:.6em;font-weight:400;
  letter-spacing:.04em;margin-left:1px;
}
.trust-strip-num-of{
  font-family:var(--sans);font-style:normal;font-weight:400;
  font-size:.55em;color:var(--taupe);letter-spacing:.04em;
  margin-left:2px;
}
.trust-strip-dot{
  width:6px;height:6px;border-radius:50%;background:var(--gold);
  display:inline-block;margin-bottom:3px;box-shadow:0 0 0 3px rgba(197,165,90,.18);
  animation:trustPulse 2.8s ease-in-out infinite;
}
@keyframes trustPulse{0%,100%{opacity:.9;}50%{opacity:.45;}}
.trust-strip-icn{
  display:flex;align-items:center;justify-content:center;
  color:var(--taupe);margin-bottom:2px;opacity:.85;
}
.trust-strip-lbl{
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.26em;
  text-transform:uppercase;color:var(--taupe);
}
.trust-strip-lbl-tall{line-height:1.35;}
.trust-strip-sep{
  width:1px;height:30px;background:rgba(28,31,36,.10);
}
@media (max-width:820px){
  .trust-strip{
    grid-template-columns:1fr 1fr;
    gap:18px 10px;padding:18px 24px;
  }
  .trust-strip-sep{display:none;}
  .trust-strip-num{font-size:18px;}
  .trust-strip-lbl{font-size:8.5px;letter-spacing:.22em;}
}

/* ── Manifesto bridge ── */
.manifesto{
  background:var(--ink);padding:var(--section-y-lg) var(--pad-x);
  display:flex;align-items:center;justify-content:center;
  text-align:center;min-height:60vh;
}
.manifesto-inner{display:flex;flex-direction:column;align-items:center;max-width:900px;}
.manifesto-eyebrow{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);margin-bottom:36px;}
.manifesto-h{font-family:var(--serif);font-weight:300;
  font-size:clamp(40px,5.6vw,80px);line-height:1.06;letter-spacing:.04em;
  color:var(--white);}
.manifesto-h em{font-style:italic;color:var(--gold);font-weight:300;}
.manifesto-rule{width:60px;height:1px;background:var(--gold);margin:48px auto;opacity:.55;}
.manifesto-sub{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(18px,1.6vw,24px);line-height:1.55;color:rgba(250,248,245,.82);max-width:680px;}

/* ── Pin-scroll Section 01 ── */
.pinscroll{
  position:relative;display:grid;grid-template-columns:1fr 1fr;
  background:var(--blanco-roto);
}
.pinscroll-sticky{
  position:sticky;top:0;height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--color-bg);
}
.pinscroll-media{
  position:relative;width:100%;height:100%;overflow:hidden;
}
.pinscroll-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transform:scale(1.05);
  transition:opacity 1s var(--ease-quint), transform 6s var(--ease-quint);
}
.pinscroll-img.active{opacity:1;transform:scale(1);}
/* Subtle dark vignette */
.pinscroll-media::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(135deg, rgba(28,31,36,.0) 50%, rgba(28,31,36,.18) 100%);
}
/* Counter overlay */
.pinscroll-counter{
  position:absolute;top:48px;left:48px;z-index:2;
  display:flex;align-items:baseline;gap:14px;
  font-family:var(--serif);font-style:italic;font-weight:300;color:var(--white);
  text-shadow:0 1px 12px rgba(0,0,0,.4);
}
.pinscroll-counter-num{font-size:clamp(42px,4vw,56px);line-height:1;color:var(--gold);
  transition:opacity .35s ease;}
.pinscroll-counter-divider{display:block;width:24px;height:1px;background:var(--gold);
  align-self:center;}
.pinscroll-counter-total{font-size:18px;color:rgba(250,248,245,.7);}

.pinscroll-content{position:relative;}
.pinscroll-chapter{
  min-height:100vh;display:flex;align-items:center;
  padding:0 8vw;
}
.pinscroll-text{display:flex;flex-direction:column;justify-content:center;max-width:480px;}
/* Reuse pillar typography */

@media (max-width:980px){
  .pinscroll{grid-template-columns:1fr;}
  .pinscroll-sticky{position:relative;height:60vh;}
  .pinscroll-chapter{min-height:60vh;padding:48px 24px;}
  .pinscroll-counter{top:24px;left:24px;}
}

/* ═══════════════════════════════════════════════════════════════
   LA VIDA · v2 — Pinned horizontal cinema gallery
   3 capítulos: Interiores · Amenidades · Showroom
   ═══════════════════════════════════════════════════════════════ */
.section-lavida{background:var(--blanco-roto);padding:120px 0 0;}
.lavida-head{
  max-width:var(--container);margin:0 auto 64px;padding:0 var(--pad-x);
}
.lavida-eyebrow{display:inline-flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);margin-bottom:24px;}
.lavida-eyebrow::before{content:"";display:block;width:32px;height:1px;background:var(--gold);}
.lavida-title{font-family:var(--serif);font-weight:300;
  font-size:clamp(44px,5.8vw,84px);line-height:1.04;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink);}
.lavida-title em{font-style:italic;color:var(--gold);font-weight:300;}
.lavida-rule{width:80px;height:1.5px;background:var(--gold);margin:36px 0 32px;
  box-shadow:0 0 12px rgba(197,165,90,.35);}
.lavida-sub{font-family:var(--sans);font-size:17px;font-weight:300;line-height:1.6;
  color:var(--text-2);max-width:600px;display:flex;flex-wrap:wrap;align-items:baseline;gap:14px;}
.lavida-sub-aside{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);opacity:.85;
  animation:lvNudge 2.4s ease-in-out infinite;}
@keyframes lvNudge{0%,100%{transform:translateX(0);}50%{transform:translateX(6px);}}

/* ── Pinned cinema container ──
   Total height = sticky panel (100vh) + horizontal scroll budget.
   Budget grows with content; tuned for ~14 cards.
*/
.lavida-cinema{
  position:relative;
  height:600vh;             /* 1vh sticky + 5vh scroll budget for horizontal pan */
  background:var(--blanco-roto);
}
.lavida-pin{
  position:sticky;top:0;
  height:100vh;
  overflow:hidden;
  display:flex;align-items:center;
  background:var(--blanco-roto);
}

/* HUD overlay — chapter label + progress + counter (bottom of viewport) */
.lavida-hud{
  position:absolute;bottom:0;left:0;right:0;
  z-index:3;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:20px var(--pad-x);
  pointer-events:none;
  background:var(--blanco-roto);
  border-top:1px solid var(--hair-ink);
}
.lavida-hud-left,.lavida-hud-right{flex:0 0 auto;min-width:180px;}
.lavida-hud-right{text-align:right;}
.lavida-hud-chapter{
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  transition:opacity .25s ease;
}
.lavida-hud-chapter::before{content:"";width:24px;height:1px;background:var(--gold);}
.lavida-hud-progress{flex:1 1 auto;display:flex;justify-content:center;}
.lavida-hud-bar{display:block;width:min(420px,46vw);height:1.5px;background:var(--hair-ink);position:relative;overflow:hidden;}
.lavida-hud-fill{display:block;height:100%;width:0%;background:var(--gold);transition:width .15s linear;
  box-shadow:0 0 12px rgba(197,165,90,.35);}
.lavida-hud-count{font-family:var(--mono,monospace);font-size:11px;font-weight:300;letter-spacing:.18em;
  color:var(--ink-ghost);font-variant-numeric:tabular-nums;}

/* ── Horizontal track ── */
.lavida-track{
  display:flex;align-items:center;gap:24px;
  height:68vh;
  padding:0 12vw 0 4vw;
  will-change:transform;
  transform:translate3d(var(--lv-x, 0px),0,0);
}
/* Pin holds track centered above HUD bar */
.lavida-pin{padding-bottom:96px;}

/* Card base */
.lv-card{
  position:relative;flex:0 0 auto;
  background:var(--color-bg);
  overflow:hidden;
  border-radius:0;
}
.lv-card img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(.95) saturate(.97);
  transition:transform 1.4s var(--ease-quint), filter .8s ease;
}
.lv-card:hover img{transform:scale(1.04);filter:brightness(1) saturate(1);}
.lv-card figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:20px 24px;
  display:flex;align-items:baseline;gap:14px;
  background:linear-gradient(180deg, transparent 0%, rgba(28,31,36,.45) 55%, rgba(28,31,36,.82) 100%);
  color:var(--white);z-index:2;
}
.lv-cap-num{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:22px;color:var(--gold);line-height:1;}
.lv-cap-lbl{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--white);}

/* Card sizes — heights match the 68vh track.
   Widths chosen so aspect ratios respect the source images:
   • lv-tall  = portrait (3:4)        → for vertical phone photos
   • lv-wide  = near 4:3              → for typical landscape renders
   • lv-pano  = 16:9 cinematic        → for hero/aerial shots
*/
.lv-tall{width:clamp(320px,30vw,500px); height:68vh;}
.lv-wide{width:clamp(540px,52vw,860px); height:68vh;}
.lv-pano{width:clamp(720px,68vw,1180px); height:68vh;}

/* Showroom photos: subtle "real photo" label */
.lv-real::after{
  content:"FOTO REAL · AGOSTO 2025";
  position:absolute;top:18px;left:18px;z-index:3;
  font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.4em;
  color:var(--white);background:rgba(28,31,36,.65);
  padding:8px 12px;border:1px solid rgba(255,255,255,.18);
  text-transform:uppercase;backdrop-filter:blur(8px);
}

/* Chapter divider card */
.lv-chapter-card{
  width:clamp(320px,30vw,440px);height:68vh;
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:48px;background:var(--color-bg);
  border-left:1px solid var(--hair);
  border-right:1px solid var(--hair);
}
/* Showroom chapter — darker treatment to mark the "real photo" register */
.lv-chapter-card-real{background:var(--ink);border-color:rgba(197,165,90,.35);}
.lv-chapter-card-real .lv-chapter-roman{color:var(--gold);}
.lv-chapter-card-real .lv-chapter-name{color:var(--white);}
.lv-chapter-card-real .lv-chapter-blurb{color:rgba(255,255,255,.78);}
.lv-chapter-card-real .lv-chapter-blurb em{color:var(--gold);font-style:italic;}
.lv-chapter-roman{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(80px,9vw,140px);line-height:1;color:var(--gold);
  margin-bottom:24px;
}
.lv-chapter-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(36px,4vw,56px);line-height:1.05;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink);
}
.lv-chapter-rule{display:block;width:60px;height:1.5px;background:var(--gold);margin:32px 0 24px;}
.lv-chapter-blurb{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(15px,1.2vw,18px);line-height:1.55;color:var(--ink-dim);
  max-width:300px;
}

/* Closing card — final CTA inside the cinema track */
.lv-end-card{
  width:clamp(380px,36vw,560px);height:68vh;
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:56px;background:var(--ink);color:var(--white);
}
.lv-end-line{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(22px,2vw,30px);line-height:1.25;color:var(--white);
  margin-bottom:14px;
}
.lv-end-line em{font-style:italic;color:var(--gold);}
.lv-end-line-strong{
  font-family:var(--serif);font-weight:300;font-style:normal;
  font-size:clamp(26px,2.6vw,40px);line-height:1.2;letter-spacing:.02em;
  color:var(--white);margin-top:8px;
}
.lv-end-cta{margin-top:36px;background:transparent;color:var(--white);border-color:var(--gold);}
.lv-end-cta:hover{background:var(--gold);color:var(--ink);}

/* ── Mobile fallback: turn cinema into vertical scroll-snap reel ── */
@media (max-width:980px){
  .lavida-cinema{height:auto;}
  .lavida-pin{position:static;height:auto;overflow-x:auto;overflow-y:hidden;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:24px 0;}
  .lavida-hud{position:static;padding:0 24px 16px;}
  .lavida-track{transform:none !important;height:auto;padding:0 24px;gap:16px;}
  .lv-tall,.lv-wide,.lv-pano{width:78vw;height:62vh;scroll-snap-align:center;}
  .lv-chapter-card{width:78vw;height:62vh;scroll-snap-align:center;padding:32px;}
  .lv-end-card{width:78vw;height:62vh;scroll-snap-align:center;padding:32px;}
  .lv-real::after{font-size:8px;padding:6px 10px;}
}

/* ═══════════════════════════════════════════════════════════════
   TIPOLOGÍAS v2 — Typography reveal + Interactive twin towers
   ═══════════════════════════════════════════════════════════════ */
.section-tip{background:var(--blanco-roto);}

/* ── Typography hero — SCROLL-TIED: as user scrolls, MISMA VISIÓN emerges from DOS TORRES ── */
.tip-hero{
  position:relative;
  /* Container is taller than the sticky pin — the extra space is the "scroll budget" for the animation */
  height:140vh;
  background:var(--blanco-roto);
}
.tip-pin{
  position:sticky;top:0;
  height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:0 var(--pad-x);
}
.tip-headline{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(48px,7vw,108px);line-height:.95;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
}
.tip-headline-line{
  display:block;overflow:hidden;line-height:1;
  padding-bottom:.08em;
}
.tip-headline-1{display:block;}
.tip-headline-2{
  display:block;
  /* Driven by JS via --reveal CSS variable (0 → 1 as user scrolls).
     Initially hidden ABOVE container, scrolls DOWN into view. */
  transform:translateY(calc(-100% + var(--reveal, 0) * 100%));
  opacity:var(--reveal, 0);
  /* Tiny transition smooths between scroll updates without lagging */
  transition:transform .15s linear, opacity .15s linear;
}
.tip-headline em{font-style:italic;color:var(--gold);font-weight:300;letter-spacing:.02em;}
.tip-headline-rule{
  width:60px;height:1.5px;background:var(--gold);margin:32px auto 20px;
  /* Rule + subtitle reveal in the second half of the scroll */
  transform:scaleX(var(--reveal-late, 0));transform-origin:center;
}
.tip-headline-sub{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(14px,1.2vw,18px);color:var(--text-2);max-width:680px;line-height:1.55;
  opacity:var(--reveal-late, 0);
  transition:opacity .2s linear;
}

/* ── Interactive twin-towers hero ── */
.towers{position:relative;width:100%;height:90vh;min-height:640px;overflow:hidden;
  background:var(--ink);display:flex;}
.towers-video, .towers-poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
}
.towers-poster{z-index:0;}
/* If the video loads, it stacks above the poster */
.towers-video{z-index:1;}
/* Subtle base scrim so the buttons read */
.towers::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(28,31,36,.45) 0%, rgba(28,31,36,.10) 30%, rgba(28,31,36,.30) 100%);
}
/* Center vertical divider (subtle) — animated gold fade-in on hover of either side */
.towers-divider{
  position:absolute;top:12%;bottom:12%;left:50%;width:1px;z-index:3;
  background:linear-gradient(180deg, transparent 0%, rgba(255,255,255,.18) 50%, transparent 100%);
  pointer-events:none;transform:translateX(-.5px);
  transition:background .5s ease;
}
.towers:hover .towers-divider{
  background:linear-gradient(180deg, transparent 0%, rgba(197,165,90,.5) 50%, transparent 100%);
}

/* Hover zones — two 50% buttons, no border, transparent until hover */
.towers-zone{
  position:relative;z-index:4;
  flex:1;height:100%;
  background:transparent;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;color:var(--white);font:inherit;
  overflow:hidden;
  transition:background-color .4s ease;
}
.towers-zone-scrim{
  position:absolute;inset:0;pointer-events:none;
  opacity:0;transition:opacity .6s var(--ease-quint);
}
.towers-zone-a .towers-zone-scrim{
  background:radial-gradient(ellipse 80% 90% at 50% 50%, rgba(197,165,90,.35) 0%, rgba(28,31,36,.55) 60%, transparent 100%);
}
.towers-zone-b .towers-zone-scrim{
  background:radial-gradient(ellipse 80% 90% at 50% 50%, rgba(27,94,75,.45) 0%, rgba(28,31,36,.55) 60%, transparent 100%);
}
.towers-zone:hover .towers-zone-scrim{opacity:1;}

/* The label inside each zone */
.towers-zone-label{
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:24px 32px;
  opacity:0;transform:translateY(18px);
  transition:opacity .55s var(--ease-quint), transform .55s var(--ease-quint);
  text-shadow:0 2px 16px rgba(0,0,0,.55);
}
.towers-zone:hover .towers-zone-label{opacity:1;transform:translateY(0);}
.towers-zone-eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.towers-zone-b .towers-zone-eyebrow{color:var(--color-jade-light);}
.towers-zone-name{
  font-family:var(--serif);font-weight:300;font-size:clamp(56px,7vw,108px);line-height:1;
  letter-spacing:.05em;text-transform:uppercase;color:var(--white);
}
.towers-zone-name em{font-style:italic;color:var(--gold);font-weight:300;}
.towers-zone-b .towers-zone-name em{color:var(--color-jade-light);}
.towers-zone-status{
  font-family:var(--sans);font-size:11.5px;font-weight:400;letter-spacing:.3em;
  text-transform:uppercase;color:rgba(255,255,255,.85);
}
.towers-zone-arrow{display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.4);color:var(--white);
  margin-top:14px;
  transition:transform .35s var(--ease-quint), background .35s ease, border-color .35s ease, color .35s ease;}
.towers-zone:hover .towers-zone-arrow{transform:translateY(4px);}
.towers-zone-a:hover .towers-zone-arrow{background:var(--gold);border-color:var(--gold);color:var(--ink);}
.towers-zone-b:hover .towers-zone-arrow{background:var(--verde);border-color:var(--verde);color:var(--white);}

/* Active state (after click) — keep label visible while detail is open */
.towers-zone.active .towers-zone-label{opacity:1;transform:translateY(0);}
.towers-zone.active .towers-zone-scrim{opacity:.7;}

/* ── Dynamic detail panel ── */
.towers-detail{
  position:relative;background:var(--blanco-roto);
  padding:96px var(--pad-x);min-height:80vh;
  display:flex;align-items:center;justify-content:center;
}
.tower-detail{
  position:absolute;inset:96px var(--pad-x);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transform:translateY(20px);
  transition:opacity .9s var(--ease-quint), transform .9s var(--ease-quint);
}
.tower-detail.active{opacity:1;pointer-events:auto;transform:translateY(0);
  position:relative;inset:auto;}

.tower-detail-inner{
  display:flex;flex-direction:column;align-items:flex-start;
  max-width:720px;width:100%;
}

.tower-detail-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(80px,9vw,160px);line-height:1;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink);
  margin:8px 0 0;
}
.tower-detail-name em{font-style:italic;color:var(--gold);font-weight:300;}
.tower-detail-name em.verde{color:var(--verde);}

.tower-detail-rule{width:60px;height:1.5px;background:var(--gold);margin:32px 0;}
.tower-detail-rule-verde{background:var(--verde);}

.tower-detail-copy{font-family:var(--sans);font-size:17px;font-weight:300;line-height:1.7;
  color:var(--text-2);max-width:560px;margin-bottom:40px;}

.tower-detail-stats{display:grid;grid-template-columns:repeat(3, 1fr);gap:0;
  padding:28px 0;
  border-top:1px solid var(--hair-soft);
  border-bottom:1px solid var(--hair-soft);
  margin-bottom:32px;width:100%;}
.tower-detail-stat{display:flex;flex-direction:column;gap:10px;padding:0 24px;position:relative;}
.tower-detail-stat:first-child{padding-left:0;}
.tower-detail-stat:last-child{padding-right:0;}
.tower-detail-stat + .tower-detail-stat::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--hair-soft);}
.tower-detail-num{font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3vw,42px);line-height:1;color:var(--ink);letter-spacing:.01em;}
.tower-detail-num.gold{color:var(--gold);}
.tower-detail-num.verde{color:var(--verde);}
.tower-detail-lbl{font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.3em;
  text-transform:uppercase;color:var(--text-3);}

.tower-detail-price{font-family:var(--serif);font-weight:300;font-size:28px;
  color:var(--gold);letter-spacing:.02em;margin-bottom:14px;}
.tower-detail-price-verde{color:var(--verde);font-style:italic;}
.tower-detail-price small{font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--text-3);margin-left:8px;}
.tower-detail-side{font-family:var(--serif);font-style:italic;font-weight:300;font-size:15px;
  color:var(--gold);margin-bottom:32px;}

@media (max-width:980px){
  .tip-hero{padding:96px 24px 64px;}
  .towers{height:auto;min-height:500px;flex-direction:column;}
  .towers-zone{height:50%;min-height:280px;}
  .towers-zone-name{font-size:64px;}
  .towers-divider{display:none;}
  .towers-detail{padding:80px 24px;}
  .tower-detail{position:relative;inset:auto;}
  .tower-detail-name{font-size:80px;}
  .tower-detail-stats{grid-template-columns:1fr;gap:20px;}
  .tower-detail-stat + .tower-detail-stat::before{display:none;}
  .tower-detail-stat{padding:0;flex-direction:row;align-items:baseline;gap:18px;}
}

/* ═══════════════════════════════════════════════════════════════
   TIPOLOGÍAS · Floor plan cards (light theme, gold accents)
   Two-up. Tipología A has a frente/esquina toggle. Hover lift.
   ═══════════════════════════════════════════════════════════════ */
.tip-plans{
  position:relative;
  max-width:var(--container);margin:0 auto;
  padding:var(--section-y) var(--pad-x);
  border-top:1px solid var(--hair-soft);
}
.tip-plans-head{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
  margin-bottom:64px;
}
.tip-plans-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.tip-plans-eyebrow::before,.tip-plans-eyebrow::after{
  content:"";display:block;width:24px;height:1px;background:var(--gold);opacity:.6;
}
.tip-plans-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3vw,42px);line-height:1.1;letter-spacing:.03em;
  color:var(--ink);
}
.tip-plans-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;
}
.tip-plan{
  position:relative;
  display:grid;grid-template-rows:auto 1fr;
  background:var(--color-bg);
  border:1px solid var(--hair-soft);
  overflow:hidden;
  transition:transform .55s var(--ease-quint), box-shadow .55s ease, border-color .55s ease;
}
.tip-plan::after{
  content:"";position:absolute;top:0;left:0;width:0;height:2px;background:var(--gold);
  transition:width .65s var(--ease-quint);
}
.tip-plan:hover{
  transform:translateY(-4px);
  border-color:rgba(197,165,90,.55);
  box-shadow:0 36px 80px -28px rgba(28,31,36,.18);
}
.tip-plan:hover::after{width:100%;}
.tip-plan-num{
  position:absolute;top:18px;left:22px;z-index:3;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:42px;line-height:1;color:var(--gold);opacity:.7;
}
.tip-plan-media{
  position:relative;aspect-ratio:16/9;background:var(--ink);
  overflow:hidden;
  border-bottom:1px solid var(--hair-soft);
}
.tip-plan-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity .5s ease, transform 1s var(--ease-quint);
}
.tip-plan-img-2{opacity:0;}
.tip-plan-media[data-view="2"] .tip-plan-img-1{opacity:0;}
.tip-plan-media[data-view="2"] .tip-plan-img-2{opacity:1;}
.tip-plan:hover .tip-plan-img{transform:scale(1.02);}
.tip-plan-img.is-only{position:relative;}

/* Frente/Esquina toggle pill */
.tip-plan-media-toggle{
  position:absolute;bottom:16px;right:16px;z-index:4;
  display:inline-flex;align-items:center;gap:0;
  padding:4px;border-radius:999px;
  background:rgba(28,31,36,.78);backdrop-filter:blur(10px);
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;
}
.tip-plan-media-pill{
  padding:7px 14px;border-radius:999px;
  color:rgba(255,255,255,.62);cursor:pointer;
  transition:background .35s ease, color .35s ease;
}
.tip-plan-media-pill.is-active{
  background:var(--gold);color:var(--ink);
}
.tip-plan-media-pill:hover:not(.is-active){color:var(--color-bg);}

.tip-plan-body{
  padding:32px 32px 36px;
  display:flex;flex-direction:column;gap:18px;
}
.tip-plan-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);
}
.tip-plan-tag::before{content:"";width:20px;height:1px;background:var(--gold);}
.tip-plan-price{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(24px,2.4vw,34px);line-height:1.1;letter-spacing:.02em;
  color:var(--ink);
}
.tip-plan-price em{font-style:italic;color:var(--gold);font-weight:400;}
.tip-plan-price small{font-size:.5em;letter-spacing:.18em;color:var(--text-3);text-transform:uppercase;font-weight:500;font-family:var(--sans);margin-left:6px;}

.tip-plan-specs{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--hair-soft);
  border-bottom:1px solid var(--hair-soft);
}
.tip-plan-specs li{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  padding:18px 8px;
  position:relative;
  text-align:center;
}
.tip-plan-specs li + li::before{
  content:"";position:absolute;left:0;top:18px;bottom:18px;width:1px;background:var(--hair-soft);
}
.tip-plan-num-spec{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(22px,2.2vw,30px);line-height:1;color:var(--gold);
}
.tip-plan-specs li > span:last-child{
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--text-3);
}

.tip-plan-features{
  list-style:none;padding:0;margin:0;
  display:flex;flex-wrap:wrap;gap:8px 14px;
}
.tip-plan-features li{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:13px;font-weight:300;letter-spacing:.02em;
  color:var(--text-2);
}
.tip-plan-features li::before{
  content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);
}

.tip-plan-cta{
  display:inline-flex;align-items:center;gap:12px;align-self:flex-start;
  padding:6px 0;margin-top:6px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);text-decoration:none;
  border-bottom:1px solid rgba(197,165,90,.4);
  transition:gap .35s ease, color .35s ease, border-color .35s ease;
}
.tip-plan-cta:hover{gap:16px;color:var(--gold-hi);border-color:var(--gold-hi);}

.tip-plans-foot{
  text-align:center;margin-top:48px;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(13px,1.1vw,15px);color:var(--text-3);
}

@media (max-width:880px){
  .tip-plans{padding:64px 24px 80px;}
  .tip-plans-grid{grid-template-columns:1fr;gap:32px;}
  .tip-plan-body{padding:24px 24px 28px;gap:16px;}
}

/* ═══════════════════════════════════════════════════════════════
   COMPARATIVA · v4 — Tabbed dashboard with persistent A·B·C·D
   • Single sticky panel, swappable by clicking tabs
   • 4 competitors persist across all 6 rounds (codes stay the same)
   • Hover on a competitor row → glows, density badge brightens
   • Auto-rotate every 6s if user is idle, pause on hover
   ═══════════════════════════════════════════════════════════════ */
.section-comp{background:var(--color-bg-warm);color:var(--color-ink);position:relative;}
.section-comp .section-hero{background:transparent;}
.section-comp .section-hero-title{color:var(--color-ink);}
.section-comp .section-hero-title em{color:var(--color-gold-deep);font-style:italic;}
.section-comp .section-hero-sub{color:var(--color-text-2);}

/* Dashboard wrapper */
.comp-dash{
  position:relative;
  max-width:1320px;margin:0 auto;
  padding:24px var(--pad-x) 64px;
}
.comp-spotlight{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(
    520px circle at var(--mx,50%) var(--my,50%),
    rgba(197,165,90,.08),
    rgba(197,165,90,.025) 40%,
    transparent 70%
  );
  opacity:0;transition:opacity .6s ease;z-index:0;
}
.comp-dash:hover .comp-spotlight{opacity:1;}

/* ── Tab strip ── */
.comp-tabs{
  position:relative;
  display:flex;gap:0;justify-content:center;flex-wrap:wrap;
  padding:0 0 0;margin-bottom:48px;
  border-bottom:1px solid rgba(197,165,90,.16);
  z-index:2;
}
.comp-tab{
  position:relative;
  flex:0 0 auto;
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:18px 28px 22px;
  background:transparent;border:none;cursor:pointer;
  color:var(--color-text-3);
  font-family:var(--sans);
  transition:color .35s ease, transform .35s var(--ease-quint);
  text-align:center;
}
.comp-tab:hover{color:var(--color-ink);transform:translateY(-2px);}
.comp-tab.is-active{color:var(--color-gold-deep);}
.comp-tab-num{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:22px;line-height:1;
  color:inherit;
  transition:color .35s ease;
}
.comp-tab-name{
  font-size:10.5px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;
  color:inherit;
  transition:color .35s ease;
}
.comp-tab.is-active .comp-tab-num{color:var(--color-gold-deep);}
.comp-tab.is-active .comp-tab-name{color:var(--color-gold-deep);}

/* Tab progress underline — animates as autoplay countdown */
.comp-tab-progress{
  position:absolute;bottom:-1px;left:0;right:0;
  height:1.5px;background:transparent;
  overflow:hidden;pointer-events:none;
}
.comp-tab-fill{
  display:block;height:100%;background:var(--gold);
  width:calc(100% / 6);
  transform:translateX(0);
  transition:transform .55s var(--ease-quint);
  box-shadow:0 0 12px rgba(197,165,90,.4);
}

/* ── Slide panel — stack with fade swap ── */
.comp-panel{
  position:relative;
  min-height:520px;
  z-index:1;
}
.comp-slide{
  position:absolute;inset:0;
  display:grid;grid-template-columns:1.2fr 70px 1fr;gap:48px;align-items:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(12px);
  transition:opacity .35s ease, transform .55s var(--ease-quint), visibility 0s linear .35s;
}
.comp-slide.is-active{
  opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);
  transition:opacity .45s ease .12s, transform .55s var(--ease-quint) .12s, visibility 0s linear 0s;
}

/* ── KUXNAH side ── */
.comp-k{display:flex;gap:36px;align-items:center;}
.comp-k-thumb{
  position:relative;flex:0 0 220px;width:220px;height:300px;
  overflow:hidden;background:var(--ink);
  border:1px solid rgba(197,165,90,.32);
  box-shadow:0 24px 60px -28px rgba(197,165,90,.35);
}
.comp-k-thumb img{width:100%;height:100%;object-fit:cover;
  filter:saturate(1) brightness(.98);
  transition:transform 1.4s var(--ease-quint);}
.comp-slide.is-active .comp-k-thumb img{animation:compThumbZoom 1.4s var(--ease-quint);}
@keyframes compThumbZoom{from{transform:scale(1.08);}to{transform:scale(1);}}

.comp-k-text{flex:1 1 auto;display:flex;flex-direction:column;gap:12px;min-width:0;}
.comp-k-cat{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--color-gold-deep);
}
.comp-k-cat::before{content:"";width:24px;height:1px;background:var(--color-gold-deep);}
.comp-k-head{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(30px,3.4vw,52px);line-height:1.04;letter-spacing:.02em;
  color:var(--color-ink);margin:8px 0 4px;
}
.comp-k-head em{font-style:italic;color:var(--color-gold-deep);font-weight:300;}
.comp-k-spec{
  font-family:var(--sans);font-size:14.5px;font-weight:300;line-height:1.6;
  color:var(--color-text-2);max-width:520px;
}
.comp-k-mark{
  display:inline-flex;align-items:center;gap:10px;margin-top:16px;
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--color-gold-deep);
}
.comp-k-mark::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 14px rgba(197,165,90,.6);
}

/* ── VS pivot ── */
.comp-vs{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(28px,2.8vw,40px);line-height:1;
  color:rgba(197,165,90,.55);text-align:center;
  transition:transform .55s var(--ease-quint);
}
.comp-slide.is-active .comp-vs{animation:compVs .8s var(--ease-quint);}
@keyframes compVs{0%{transform:scale(.6) rotate(-12deg);opacity:0;}60%{transform:scale(1.15) rotate(2deg);opacity:1;}100%{transform:scale(1) rotate(0);opacity:1;}}

/* ── COMPETENCIA side ── */
.comp-c{
  display:flex;flex-direction:column;gap:0;
  padding-left:0;
}
.comp-c-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0;}
.comp-c-row{
  display:grid;grid-template-columns:minmax(116px,auto) 1.6fr;
  gap:22px;align-items:baseline;
  padding:16px 0;
  border-bottom:1px solid var(--line-ink);
  cursor:default;
  transition:padding-left .35s var(--ease-quint);
}
.comp-c-row:last-child{border-bottom:none;}
.comp-c-row:hover{padding-left:8px;}

/* Código A/B/C/D retirado · feel de dashboard SaaS. La identidad del
   desarrollo se da por su densidad real (data-units), editorial. */
.comp-c-code{display:none;}

/* Nombre del desarrollo del corredor · sin blur · densidad real visible */
.comp-c-name{
  position:relative;
  font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--color-text-3);
  transition:color .35s ease;
}
.comp-c-name::after{
  content:" · " attr(data-units);
  display:inline;color:var(--color-gold-deep);font-weight:500;
}
.comp-c-row:hover .comp-c-name{color:var(--color-ink);}

.comp-c-approach{
  font-family:var(--serif);font-size:16px;font-weight:400;line-height:1.45;
  color:var(--color-text-2);letter-spacing:.005em;
}
.comp-c-approach b{color:var(--color-ink);font-weight:500;font-style:italic;}
.comp-c-row:hover .comp-c-approach{color:var(--color-ink);}

/* ── Glossary footer ── */
.comp-glossary{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:24px 32px;
  margin-top:48px;padding:24px var(--pad-x);
  border-top:1px solid rgba(197,165,90,.18);
  font-family:var(--sans);font-size:11px;font-weight:300;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-ghost);
  text-align:center;
}
.comp-gloss-label{flex:1 1 100%;color:var(--ink-faint);max-width:680px;}
.comp-gloss-keys{display:inline-flex;gap:18px;flex-wrap:wrap;justify-content:center;}
.comp-gloss-key{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  user-select:none;
  transition:color .25s ease;
}
.comp-gloss-bubble{
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:50%;
  border:1px solid rgba(197,165,90,.55);
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:12px;color:var(--gold);
  transition:background .3s ease, color .3s ease;
}
.comp-gloss-name{
  font-size:10.5px;letter-spacing:.32em;color:var(--ink-ghost);
  filter:blur(2.5px);
  transition:filter .35s ease, color .35s ease;
  position:relative;
}
.comp-gloss-name::after{
  content:" · " attr(data-units);
  color:var(--gold);font-weight:500;
  opacity:0;transition:opacity .35s ease .1s;
}
.comp-gloss-key:hover .comp-gloss-bubble,
.comp-gloss-key.is-pressed .comp-gloss-bubble{background:var(--gold);color:var(--ink);}
.comp-gloss-key:hover .comp-gloss-name,
.comp-gloss-key.is-pressed .comp-gloss-name{filter:blur(0);color:var(--color-bg);}
.comp-gloss-key:hover .comp-gloss-name::after,
.comp-gloss-key.is-pressed .comp-gloss-name::after{opacity:1;}
.comp-gloss-hint{
  flex:1 1 100%;color:rgba(197,165,90,.65);font-style:italic;
  font-family:var(--serif);text-transform:none;letter-spacing:.04em;font-size:13px;
}

/* ── Closing band on dark ── */
.section-comp .closing-band{
  margin-top:0;padding:var(--section-y) var(--pad-x);
  background:transparent;color:var(--color-bg);
  text-align:center;display:flex;flex-direction:column;align-items:center;gap:32px;
  border-top:1px solid rgba(197,165,90,.18);
}
.section-comp .closing-eyebrow{color:var(--gold);}
.section-comp .closing-h{color:var(--color-bg);font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.4vw,44px);line-height:1.18;letter-spacing:.04em;max-width:920px;}
.section-comp .closing-h em{font-style:italic;color:var(--gold);font-weight:300;}
.section-comp .closing-rule{background:var(--gold);}
.section-comp .closing-band .cta{align-self:center;}
.section-comp .cta-outline{border-color:var(--gold);color:var(--gold);background:transparent;}
.section-comp .cta-outline:hover{background:var(--gold);color:var(--ink);}

/* ── Responsive ── */
@media (max-width:1080px){
  .comp-tab{padding:14px 18px 18px;}
  .comp-tab-name{font-size:9.5px;letter-spacing:.24em;}
  .comp-slide{grid-template-columns:1fr;gap:32px;}
  .comp-vs{display:none;}
  .comp-k{flex-direction:column;gap:24px;align-items:flex-start;}
  .comp-k-thumb{width:100%;flex-basis:auto;height:240px;}
}
@media (max-width:680px){
  .comp-dash{padding:24px 20px 48px;}
  .comp-tabs{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;
    scrollbar-width:none;}
  .comp-tabs::-webkit-scrollbar{display:none;}
  .comp-tab{padding:12px 14px 16px;}
  .comp-tab-num{font-size:18px;}
  .comp-c-row{grid-template-columns:32px 1fr;gap:12px;padding:12px 0;}
  .comp-c-approach{grid-column:1 / -1;padding-left:44px;font-size:12.5px;}
  .comp-c-name{grid-column:2;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE LAYER — comprehensive responsive overrides
   Applied below ~1100px (tablet) and ~720px (phone)
   ═══════════════════════════════════════════════════════════════ */

/* ── Hamburger toggle ── */
.nav-toggle{
  display:none;
  background:transparent;border:none;cursor:pointer;
  width:36px;height:36px;position:relative;padding:0;
  margin-left:6px;
}
.nav-toggle span{
  position:absolute;left:50%;width:24px;height:1.5px;
  background:var(--blanco-roto);transform:translateX(-50%);
  transition:top .35s var(--ease-quint), opacity .25s ease, transform .35s var(--ease-quint), background .35s ease;
}
.nav-toggle span:nth-child(1){top:11px;}
.nav-toggle span:nth-child(2){top:17px;}
.nav-toggle span:nth-child(3){top:23px;}
.nav.scrolled .nav-toggle span{background:var(--ink);}
.nav-toggle.is-open span{background:var(--color-bg);}
.nav-toggle.is-open span:nth-child(1){top:17px;transform:translateX(-50%) rotate(45deg);}
.nav-toggle.is-open span:nth-child(2){opacity:0;}
.nav-toggle.is-open span:nth-child(3){top:17px;transform:translateX(-50%) rotate(-45deg);}

/* ── Drawer ── */
.nav-drawer{
  position:fixed;inset:0;z-index:99;
  background:linear-gradient(180deg, rgba(22,24,28,.98) 0%, rgba(12,14,18,.98) 100%);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  opacity:0;visibility:hidden;
  transition:opacity .45s var(--ease-quint), visibility 0s linear .45s;
  overflow-y:auto;
}
.nav-drawer.is-open{
  opacity:1;visibility:visible;
  transition:opacity .45s var(--ease-quint), visibility 0s linear 0s;
}
.nav-drawer-inner{
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  height:100%;padding:96px 32px 56px;gap:18px;
}
.nav-drawer-link{
  display:flex;align-items:baseline;gap:18px;
  font-family:var(--serif);font-weight:300;
  font-size:38px;line-height:1.1;letter-spacing:.02em;
  color:var(--color-bg);text-decoration:none;
  transition:color .25s ease, padding-left .35s var(--ease-quint);
  opacity:0;transform:translateY(20px);
}
.nav-drawer.is-open .nav-drawer-link{
  opacity:1;transform:translateY(0);
  transition:opacity .5s ease, transform .55s var(--ease-quint);
}
.nav-drawer.is-open .nav-drawer-link:nth-child(1){transition-delay:.05s;}
.nav-drawer.is-open .nav-drawer-link:nth-child(2){transition-delay:.10s;}
.nav-drawer.is-open .nav-drawer-link:nth-child(3){transition-delay:.15s;}
.nav-drawer.is-open .nav-drawer-link:nth-child(4){transition-delay:.20s;}
.nav-drawer.is-open .nav-drawer-link:nth-child(5){transition-delay:.25s;}
.nav-drawer-link:hover{color:var(--gold);padding-left:6px;}
.nav-drawer-num{
  font-family:var(--mono,monospace);font-style:normal;font-size:11px;font-weight:300;
  letter-spacing:.32em;color:var(--gold);opacity:.7;width:28px;
}
.nav-drawer-rule{
  display:block;width:48px;height:1px;background:var(--gold);
  margin:28px 0 24px;opacity:.5;
}
.nav-drawer-wa{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--color-whatsapp);color:var(--color-bg);text-decoration:none;
  padding:14px 24px;border-radius:999px;
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;
  box-shadow:0 12px 28px -10px rgba(37,211,102,.45);
  transition:transform .35s var(--ease-quint);
}
.nav-drawer-wa:hover{transform:translateY(-2px);}
.nav-drawer-foot{
  margin-top:18px;
  font-family:var(--sans);font-size:10.5px;font-weight:300;letter-spacing:.32em;
  text-transform:uppercase;color:var(--ink-faint);
}

/* Show hamburger when nav-links hide */
@media (max-width:1100px){
  .nav-toggle{display:block;}
}

/* ─────────────────────────────────────────────────────────────
   PHONE — ≤720px comprehensive overrides
   ───────────────────────────────────────────────────────────── */
@media (max-width:720px){
  /* Nav · tighter, smaller logo */
  .nav{padding:14px 20px;}
  .nav.scrolled{padding:10px 20px;}
  .nav-right{gap:14px;}
  .nav-cta{padding:10px 14px;font-size:9.5px;letter-spacing:.14em;}
  .wordmark-symbol{width:78px;height:44px;}
  .nav.scrolled .wordmark-symbol{width:64px;height:36px;}
  .wordmark-text-main{font-size:18px;}
  .wordmark-text-sub{font-size:7.5px;letter-spacing:.34em;}

  /* Hero · stack everything cleanly, kill meta absolute positioning */
  .hero{height:auto;min-height:600px;height:92vh;}
  .hero-content{padding:0 22px 32px;}
  .hero-h1{margin:0 0 18px;gap:10px;}
  .hero-h1-mark{
    font-size:clamp(40px,13vw,68px);letter-spacing:.08em;
  }
  .hero-h1-sub{font-size:10px;letter-spacing:.36em;}
  .hero-rule{width:48px;margin-bottom:16px;}
  .hero-tagline{font-size:10px;letter-spacing:.22em;margin-bottom:12px;}
  .hero-body{font-size:13px;max-width:none;line-height:1.55;}
  /* Move hero-meta inline below the content instead of absolute */
  .hero-meta{
    position:static;right:auto;bottom:auto;
    margin-top:20px;align-items:flex-start;gap:8px;
  }
  .hero-meta-row{font-size:9px;letter-spacing:.18em;gap:10px;}
  /* Scroll cue smaller and tighter */
  .scroll-cue{bottom:14px;gap:8px;}
  .scroll-cue-label{font-size:8.5px;letter-spacing:.32em;}
  .scroll-cue-line{height:22px;}
  .scroll-cue-arrow{width:24px;height:24px;}

  /* Section openers · shorter */
  .opener{height:96px;}
  .opener-num{font-size:34px;}
  .opener-label{font-size:9px;letter-spacing:.32em;}

  /* Section hero text (each section's intro) */
  .section-hero-title{font-size:clamp(36px,9vw,52px) !important;letter-spacing:.02em !important;}
  .section-hero-sub{font-size:13px !important;letter-spacing:.04em !important;}

  /* Tipologías hero typography reveal · smaller */
  .tip-headline{font-size:clamp(36px,11vw,56px) !important;letter-spacing:.02em !important;}
  .tip-headline-sub{font-size:11px !important;letter-spacing:.22em !important;}

  /* Towers (twin towers stage) */
  .towers-zone-name{font-size:48px !important;}
  .tower-detail-name{font-size:60px !important;}

  /* Tipología plan cards */
  .tip-plan-num{font-size:32px;top:14px;left:18px;}
  .tip-plan-body{padding:22px 22px 24px;gap:14px;}
  .tip-plan-tag{font-size:9.5px;letter-spacing:.32em;}
  .tip-plan-price{font-size:24px;}
  .tip-plan-specs li{padding:14px 4px;}
  .tip-plan-num-spec{font-size:22px;}
  .tip-plan-specs li > span:last-child{font-size:8px;letter-spacing:.18em;}
  .tip-plan-features li{font-size:12px;}
  .tip-plan-cta{font-size:9.5px;letter-spacing:.24em;gap:10px;}

  /* La Vida cinema · vertical scroll-snap fallback styling */
  .lavida-head{margin-bottom:32px;padding:0 22px;}
  .lavida-title{font-size:clamp(32px,8vw,42px) !important;}
  .lavida-sub{font-size:14px;}

  /* Comparativa · tighter spacing */
  .section-comp .section-hero{padding:48px 22px;}
  .evidence-h,.comp-k-head{font-size:clamp(26px,7vw,34px) !important;line-height:1.15 !important;}

  /* Cierre conversion panel */
  .cierre-converge{padding:48px 22px;}
  .cierre-converge-grid{gap:36px;}
  .invite-h{font-size:clamp(40px,12vw,56px) !important;line-height:1 !important;}
  .invite-sub{font-size:15px;line-height:1.5;}
  .cierre-form-card{padding:28px 22px 24px;}
  .form-card-h{font-size:20px;margin:10px 0 24px;}
  .form-card-submit{padding:18px 24px;font-size:12px;letter-spacing:.16em;}

  /* Grupo Salomón strip · stack vertical */
  .cierre-gs{padding:32px 22px 40px;}
  .gs-id-row{gap:24px;margin-bottom:20px;}
  .gs-id-mark{gap:14px;flex-wrap:wrap;}
  .gs-logo{height:36px;max-width:120px;}
  .gs-id-name{font-size:20px;}
  .gs-id-tag{font-size:9.5px;letter-spacing:.28em;}
  .gs-id-metrics{gap:18px;}
  .gs-metric-num{font-size:18px;}
  .gs-metric-lbl{font-size:8px;letter-spacing:.22em;}
  .gs-portfolio-grid{grid-template-columns:1fr;gap:14px;}
  .gs-tile{aspect-ratio:16/10;}
  .gs-tile figcaption{padding:12px 14px;gap:6px;}
  .gs-tile-name{font-size:13px;}
  .gs-tile-meta{font-size:8.5px;letter-spacing:.22em;}
  .gs-mission{padding:14px 0 0;gap:12px;}
  .gs-mission-text{font-size:12px;line-height:1.5;}
  .gs-mission-source{font-size:9px;letter-spacing:.22em;}

  /* Cierre ticker · single column */
  .cierre-ticker{padding:16px 22px;}
  .cierre-ticker-inner{flex-direction:column;gap:10px;font-size:9.5px;letter-spacing:.24em;}
  .cierre-ticker-sep{display:none;}

  /* WhatsApp pill · keep tap target accessible */
  .wa-pill{bottom:14px;right:14px;}

  /* Sticky CTAs and tags */
  .stuck-cta-pill,.bottom-cta{font-size:11px;}
}

/* ─────────────────────────────────────────────────────────────
   EXTRA SMALL · ≤390px (iPhone SE / 12 mini)
   ───────────────────────────────────────────────────────────── */
@media (max-width:400px){
  .hero-h1-mark{font-size:42px;letter-spacing:.06em;}
  .hero-body{font-size:12px;}
  .nav-drawer-link{font-size:32px;}
  .opener-num{font-size:28px;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE LAYER · v2 — Aggressive section overrides
   Fixes: Tipologías pin, La Vida intro, Twin Towers, sticky CTA
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  /* ── Tipologías HERO · kill the 140vh sticky pin on mobile ── */
  .tip-hero{height:auto !important;}
  .tip-pin{
    position:static !important;
    height:auto !important;
    padding:64px 22px 56px !important;
  }
  .tip-headline-line-1,
  .tip-headline-line-2 em{
    transform:none !important;
    opacity:1 !important;
  }
  .tip-headline-line-2{display:block;}
  .tip-headline-rule{
    transform:scaleX(1) !important;
    margin:24px auto 16px !important;
  }
  .tip-headline-sub{opacity:1 !important;}

  /* ── Twin towers stage · stack cleanly ── */
  .towers{height:auto;min-height:0;flex-direction:column;}
  .towers-zone{
    height:auto;min-height:240px;
    flex:none;width:100%;
  }
  .towers-zone-content{padding:32px 22px;}
  .towers-zone-name{font-size:54px;letter-spacing:.06em;}
  .towers-zone-tag{font-size:10px;letter-spacing:.32em;}
  .towers-divider{display:none;}

  /* ── Tower details · stack & compact ── */
  .towers-detail{padding:48px 22px;gap:24px;}
  .tower-detail{padding:32px 22px;}
  .tower-detail-name{font-size:54px;}
  .tower-detail-copy{font-size:14px;line-height:1.55;}
  .tower-badge{font-size:10px;letter-spacing:.28em;padding:7px 12px;}

  /* ── Tipología plan cards · taller image area, bigger toggle ── */
  .tip-plans-head{margin-bottom:32px;}
  .tip-plan-media{aspect-ratio:1/1;}  /* squared for mobile, more visible */
  .tip-plan-media-toggle{
    bottom:12px;right:12px;
    padding:5px;
  }
  .tip-plan-media-pill{
    padding:9px 18px;
    font-size:10px;
    min-height:36px;display:inline-flex;align-items:center;
  }

  /* ── La Vida · tighten intro, the carousel handles itself ── */
  .section-lavida{padding:64px 0 0;}
  .lavida-head{margin-bottom:24px;padding:0 22px;}
  .lavida-eyebrow{font-size:10px;letter-spacing:.32em;margin-bottom:14px;}
  .lavida-rule{margin:20px 0 18px;}
  .lavida-cinema{height:auto;}

  /* ── Comparativa · tap-to-reveal competitors on mobile ── */
  .comp-c-row{
    -webkit-tap-highlight-color:transparent;
    cursor:pointer;
  }
  .comp-c-row.is-revealed .comp-c-name{
    filter:blur(0);color:var(--color-bg);letter-spacing:.18em;
  }
  .comp-c-row.is-revealed .comp-c-code{background:var(--gold);color:var(--ink);}
  .comp-c-row.is-revealed .comp-c-name::after{opacity:1;}
}

/* ═══════════════════════════════════════════════════════════════
   STICKY BOTTOM CTA BAR (mobile only)
   Aparece post-scroll 40% del documento · revealed por script.js
   ═══════════════════════════════════════════════════════════════ */
.mobile-cta-bar{
  display:none;
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  background:linear-gradient(180deg, rgba(28,31,36,.92) 0%, rgba(22,24,28,1) 100%);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(197,165,90,.32);
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  align-items:center;justify-content:space-between;gap:12px;
  box-shadow:0 -8px 24px rgba(0,0,0,.4);
  transform:translateY(110%);
  transition:transform .55s var(--ease-quint);
}
.mobile-cta-bar[hidden]{display:none !important;}
.mobile-cta-bar-visible{transform:translateY(0);}
.mobile-cta-lbl{
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--color-bg);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;
}
.mobile-cta-pulse{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  box-shadow:0 0 8px rgba(197,165,90,.7);flex:0 0 auto;
  animation:mobilePulse 2.4s ease-in-out infinite;
  align-self:center;
}
@keyframes mobilePulse{0%,100%{opacity:1;}50%{opacity:.4;}}
.mobile-cta-wa{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--gold);color:var(--ink);text-decoration:none;
  padding:12px 18px;border-radius:999px;
  font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;
  box-shadow:0 6px 18px -6px rgba(197,165,90,.55);
  min-height:44px;
  white-space:nowrap;flex:0 0 auto;
  transition:background .25s ease, box-shadow .25s ease;
}
.mobile-cta-wa:hover{background:var(--gold-hi);
  box-shadow:0 8px 22px -6px rgba(197,165,90,.65);}
.mobile-cta-wa:active{transform:scale(.96);}
.mobile-cta-wa svg{flex:0 0 auto;}

/* Show on mobile (display flex restored by JS removing [hidden]) */
@media (max-width:820px){
  .mobile-cta-bar{display:flex;}
  /* Push body content up so footer doesn't get covered */
  body{padding-bottom:74px;}
  /* Floating WA pill no convive con sticky bar */
  .wa-pill{display:none;}
}

/* ═══════════════════════════════════════════════════════════════
   TAP FEEDBACK (universal mobile UX polish)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  .cta, .cta-gold, .cta-verde, .cta-outline,
  .form-card-submit, .door, .tip-plan-cta,
  .nav-cta{
    -webkit-tap-highlight-color:rgba(197,165,90,.25);
    user-select:none;-webkit-user-select:none;
    transition:transform .15s ease;
  }
  .cta:active, .cta-gold:active, .cta-verde:active, .cta-outline:active,
  .form-card-submit:active, .tip-plan-cta:active, .nav-cta:active{
    transform:scale(.97);
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE FIX · Force Tipologías hero reset (overrides scroll-tied)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  .tip-hero{
    height:auto !important;
    min-height:0 !important;
    --reveal:1 !important;
    --reveal-late:1 !important;
  }
  .tip-pin{
    position:static !important;
    height:auto !important;
    min-height:0 !important;
    padding:48px 22px 40px !important;
    display:block !important;
    text-align:center;
  }
  .tip-headline{
    font-size:clamp(36px,11vw,52px) !important;
    line-height:1.04 !important;
    margin:0 auto !important;
  }
  /* Correct class names: tip-headline-1 / tip-headline-2 (no -line-) */
  .tip-headline-1,
  .tip-headline-2,
  .tip-headline-2 em{
    transform:none !important;
    opacity:1 !important;
    display:block !important;
  }
  .tip-headline-2{margin-top:6px;}
  .tip-headline-rule{
    transform:scaleX(1) !important;
    opacity:1 !important;
    width:48px !important;
    margin:20px auto 14px !important;
  }
  .tip-headline-sub{
    opacity:1 !important;
    font-size:11px !important;
    letter-spacing:.2em !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE · Hide desktop-only chrome (scroll cue, audio toggle)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  /* Scroll cue is decorative; on phones natural scrolling makes it redundant */
  .scroll-cue{display:none;}
  /* Tighten mobile-cta-bar so it doesn't truncate */
  .mobile-cta-lbl{font-size:8.5px;letter-spacing:.18em;}
  .mobile-cta-wa{font-size:10.5px;padding:11px 14px;}
  .mobile-cta-bar{padding:10px 14px calc(10px + env(safe-area-inset-bottom));}
  /* Reduce hero bottom padding now that no cues */
  .hero-content{padding-bottom:24px;}
  .hero-meta{margin-top:14px;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE REDESIGN · v3 — Native-feeling, not adapted
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){

  /* ═════════ TIPOLOGÍAS · stack both towers natively ═════════
     Hide the unintuitive twin-tower click zones.
     Show BOTH Torre A & B detail panels stacked vertically.    */
  .towers{display:none !important;}

  .towers-detail{
    position:relative !important;
    height:auto !important;
    min-height:0 !important;
    display:flex !important;flex-direction:column !important;
    gap:28px;
    padding:32px 18px 48px !important;
  }
  .tower-detail{
    position:relative !important;
    inset:auto !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:none !important;
    padding:28px 22px !important;
    background:rgba(255,255,255,.02);
    border:1px solid rgba(197,165,90,.18);
    border-radius:0;
  }
  .tower-detail-inner{padding:0 !important;max-width:none !important;}

  /* ═════════ COMPARATIVA · fix mobile flow ═════════ */
  .comp-panel{min-height:auto !important;}
  .comp-slide{
    position:absolute !important;
    pointer-events:none;
  }
  .comp-slide.is-active{
    position:relative !important;
    pointer-events:auto;
  }
  .comp-slide.is-active ~ .comp-slide,
  .comp-slide:not(.is-active){
    visibility:hidden !important;
    height:0;overflow:hidden;
  }
  .comp-k-thumb{
    flex:none !important;
    width:100% !important;
    aspect-ratio:16/10 !important;
    height:auto !important;
    margin-bottom:14px;
  }
  .comp-k-text{gap:8px;}
  .comp-c-list{margin-top:4px;}

  /* ═════════ EXCLUSIVIDAD · more visual punch ═════════ */
  /* Make pillar images full-bleed with text below — magazine-style */
  .section-hero{min-height:340px !important;}
  .section-hero-img{height:340px !important;}
  .pillar,.pillar.alt{
    grid-template-columns:1fr !important;
    gap:0 !important;
    margin:32px 0;
  }
  .pillar-media,.tower-media{
    min-height:280px !important;
    aspect-ratio:4/3;
  }
  .pillar-text,.tower-text{
    padding:36px 22px 48px !important;
    background:var(--color-bg);
  }
  .pillar-num{
    font-size:48px !important;
    color:var(--gold) !important;
  }
  .pillar-h{
    font-size:clamp(28px,7.5vw,36px) !important;
    line-height:1.1 !important;
    letter-spacing:.01em !important;
    margin:14px 0 18px !important;
  }
  .pillar-body{
    font-size:15px !important;
    line-height:1.65 !important;
    color:var(--text-2) !important;
  }
  .pillar-meta{
    font-size:10px !important;
    letter-spacing:.24em !important;
    gap:8px 12px !important;
    margin-top:24px !important;
    padding-top:20px !important;
  }

  /* Tipologías Plans — kill mix-blend, ensure full color render */
  .tip-plan-media{
    aspect-ratio:16/11 !important;
    background:var(--ink) !important;
  }
  .tip-plan-img{
    mix-blend-mode:normal !important;
    filter:none !important;
    object-fit:cover !important;
  }

  /* La Vida cinema · ensure horizontal swipe works smoothly on touch */
  .lavida-cinema{height:auto !important;}
  .lavida-pin{
    overflow-x:auto !important;
    overflow-y:hidden !important;
    -webkit-overflow-scrolling:touch !important;
    scroll-snap-type:x mandatory !important;
    padding:24px 0 !important;
  }
  .lavida-track{
    transform:none !important;
    gap:16px !important;
    padding:0 18px !important;
    height:auto !important;
  }
  .lv-card,.lv-chapter-card,.lv-end-card{
    scroll-snap-align:center !important;
    width:82vw !important;height:540px !important;
  }
  .lv-pano{width:90vw !important;}
  .lavida-hud{display:none !important;}  /* HUD requires JS sync that doesn't fit small phones */

  /* Cierre · stack converge grid + form full width */
  .cierre-converge{padding:40px 18px 48px !important;}
  .cierre-converge-grid{grid-template-columns:1fr !important;gap:32px !important;}
  .invite-h{font-size:clamp(42px,12vw,60px) !important;line-height:.98 !important;}
  .cierre-form-card{padding:24px 20px 22px !important;}
  .form-card-h{font-size:18px !important;}
  .form-card-submit{padding:18px 22px !important;font-size:11.5px !important;letter-spacing:.14em !important;}
  .field-c-input,.field-c-select{font-size:15px !important;}

  /* GS · stack ID row + metrics ── */
  .gs-id-row{grid-template-columns:1fr !important;gap:14px !important;}
  .gs-id-metrics{justify-content:flex-start !important;gap:18px !important;}
  .gs-metric-sep{display:none !important;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE SCROLL-REVEAL · Subtle motion on each section
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  .reveal{
    transform:translateY(28px) !important;
    transition:opacity .9s var(--ease-quint), transform 1.1s var(--ease-quint);
  }
  .reveal.in{transform:translateY(0) !important;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE-ONLY SECTIONS · v4 — From-scratch native mobile design
   Desktop sees nothing of these. Mobile sees ONLY these (not desktop versions).
   ═══════════════════════════════════════════════════════════════ */
.m-only{display:none;}
@media (max-width:820px){
  .m-only{display:block;}
  .d-only{display:none !important;}
  /* Hide leftover desktop section CSS triggers */
  .section-tip.d-only,.section-comp.d-only,#exclusividad.d-only,#tipologias.d-only,#comparativa.d-only{display:none !important;}
}

/* Section frames */
.m-section{
  background:var(--blanco-roto);
  padding:0;margin:0;position:relative;
}
.m-section + .m-section{border-top:1px solid var(--hair-soft);}

/* Section opener label */
.m-opener{
  display:flex;align-items:center;gap:14px;
  padding:24px 22px 12px;
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.42em;
  text-transform:uppercase;color:var(--ink-faint);
  background:var(--color-bg);
  border-bottom:1px solid var(--hair-soft);
}
.m-opener em{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:22px;color:var(--gold);letter-spacing:0;
}
.m-opener.dark{background:var(--ink);color:var(--ink-faint);border-bottom-color:rgba(197,165,90,.18);}

/* Eyebrow common */
.m-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.34em;
  text-transform:uppercase;color:var(--text-3);
}
.m-eyebrow.gold{color:var(--gold);}
.m-eyebrow::before{content:"";width:20px;height:1px;background:currentColor;opacity:.55;}

/* CTA common */
.m-cta{
  display:inline-flex;align-items:center;justify-content:space-between;gap:14px;width:100%;
  padding:16px 22px;text-decoration:none;
  font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;
  transition:transform .25s ease, background .35s ease;
}
.m-cta:active{transform:scale(.97);}
.m-cta-gold{background:var(--gold);color:var(--ink);}
.m-cta-gold:active{background:var(--gold-hi);}
.m-cta-verde{background:var(--verde);color:var(--white);}
.m-cta-outline{background:transparent;color:var(--gold);border:1px solid var(--gold);}
.m-cta-arrow{font-family:var(--serif);font-style:italic;font-size:18px;font-weight:300;}

/* ═════ EXCLUSIVIDAD (mobile) ═════ */
.m-exc{padding-bottom:32px;}
.m-bleed{
  position:relative;margin:0;padding:0;aspect-ratio:4/5;overflow:hidden;
  background:var(--ink);
}
.m-bleed img{width:100%;height:100%;object-fit:cover;filter:brightness(.85);}
.m-bleed figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:24px 22px 28px;
  background:linear-gradient(180deg, transparent 0%, rgba(28,31,36,.55) 50%, rgba(28,31,36,.92) 100%);
  color:var(--white);
}
.m-bleed-eyebrow{
  display:block;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold);margin-bottom:10px;
}
.m-bleed-h{
  font-family:var(--serif);font-weight:300;
  font-size:36px;line-height:1.05;letter-spacing:.01em;
  color:var(--white);
}
.m-bleed-h em{font-style:italic;color:var(--gold);font-weight:400;}

.m-exc-grid{display:flex;flex-direction:column;gap:24px;padding:32px 18px 0;}
.m-exc-card{
  position:relative;
  background:var(--color-bg);
  border:1px solid var(--hair-soft);
  overflow:hidden;
}
.m-exc-num{
  position:absolute;top:14px;left:18px;z-index:2;
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:24px;color:var(--gold);
  background:rgba(255,255,255,.92);padding:4px 10px;border-radius:2px;
  backdrop-filter:blur(8px);
}
.m-exc-card img{
  display:block;width:100%;height:240px;object-fit:cover;
}
.m-exc-card-body{padding:22px 22px 26px;}
.m-exc-card-body h3{
  font-family:var(--serif);font-weight:300;
  font-size:24px;line-height:1.15;letter-spacing:.01em;
  color:var(--ink);margin-bottom:10px;
}
.m-exc-card-body h3 em{font-style:italic;color:var(--gold);font-weight:400;}
.m-exc-card-body p{
  font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.55;
  color:var(--text-2);
}

/* ═════ TIPOLOGÍAS (mobile) ═════ */
.m-tip{padding-bottom:48px;}
.m-tip-head{
  padding:48px 22px 8px;text-align:center;
}
.m-tip-head-2{padding-top:48px;}
.m-tip-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(34px,9vw,46px);line-height:1.04;letter-spacing:.02em;
  color:var(--ink);
}
.m-tip-h em{font-style:italic;color:var(--gold);font-weight:300;}
.m-tip-sub{
  margin-top:14px;
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:14px;color:var(--text-3);
}
.m-tip-h2{
  font-family:var(--serif);font-weight:300;
  font-size:28px;line-height:1.1;letter-spacing:.01em;color:var(--ink);
  margin-top:8px;
}
.m-tip-h2 em,.m-eyebrow.gold em{font-style:italic;color:var(--gold);}

/* Torre A/B cards */
.m-torre{
  margin:32px 18px 0;
  background:var(--color-bg);
  border:1px solid var(--hair-soft);
  overflow:hidden;
}
.m-torre-media{position:relative;margin:0;aspect-ratio:16/10;background:var(--ink);}
.m-torre-media img{width:100%;height:100%;object-fit:cover;filter:brightness(.95);}
.m-torre-badge{
  position:absolute;top:14px;left:14px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 12px;border-radius:999px;
  background:rgba(0,0,0,.65);backdrop-filter:blur(10px);
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(197,165,90,.45);
}
.m-badge-verde{color:var(--white);border-color:rgba(27,94,75,.5);}

.m-torre-body{padding:24px 22px 26px;}
.m-torre-name{
  font-family:var(--serif);font-weight:300;
  font-size:48px;line-height:1;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);
}
.m-torre-name em{font-style:italic;color:var(--gold);font-weight:400;}
.m-torre-name em.verde{color:var(--verde);}
.m-torre-copy{
  margin-top:18px;
  font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.6;
  color:var(--text-2);
}
.m-torre-stats{
  list-style:none;padding:0;margin:24px 0;
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--hair-soft);
  border-bottom:1px solid var(--hair-soft);
}
.m-torre-stats li{
  padding:16px 4px;text-align:center;position:relative;
  display:flex;flex-direction:column;gap:4px;align-items:center;
}
.m-torre-stats li + li::before{
  content:"";position:absolute;left:0;top:14px;bottom:14px;width:1px;background:var(--hair-soft);
}
.m-num{
  font-family:var(--serif);font-weight:300;font-size:22px;line-height:1;color:var(--ink);
}
.m-num.gold{color:var(--gold);}
.m-num.verde{color:var(--verde);}
.m-lbl{
  font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--text-3);
}
.m-torre-status{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:13px;
  color:var(--gold);margin-bottom:18px;
}
.m-torre-b .m-torre-status{color:var(--verde);}

/* Plan cards */
.m-plan{
  margin:24px 18px 0;
  position:relative;
  background:var(--ink);color:var(--color-bg);
  overflow:hidden;
}
.m-plan-num{
  position:absolute;top:16px;left:18px;z-index:2;
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:34px;
  color:var(--gold);opacity:.85;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.m-plan-media{margin:0;aspect-ratio:4/3;background:var(--ink);}
.m-plan-media img{width:100%;height:100%;object-fit:cover;}
.m-plan-body{padding:22px 22px 26px;}
.m-plan-price{
  margin:10px 0 18px;
  font-family:var(--serif);font-weight:300;font-size:26px;line-height:1;
  color:var(--color-bg);
}
.m-plan-price em{font-style:italic;color:var(--gold);font-weight:400;}
.m-plan-price small{
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-faint);margin-left:6px;
}
.m-plan-specs{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(197,165,90,.25);
  border-bottom:1px solid rgba(197,165,90,.25);
}
.m-plan-specs li{
  padding:14px 4px;text-align:center;position:relative;
  display:flex;flex-direction:column;gap:3px;align-items:center;
}
.m-plan-specs li + li::before{
  content:"";position:absolute;left:0;top:12px;bottom:12px;width:1px;
  background:rgba(197,165,90,.18);
}
.m-spec-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:22px;line-height:1;color:var(--gold);
}
.m-plan-specs li > span:last-child{
  font-family:var(--sans);font-size:8.5px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-faint);
}
.m-plan-feats{
  list-style:none;padding:0;margin:18px 0 22px;
  display:flex;flex-wrap:wrap;gap:6px 14px;
}
.m-plan-feats li{
  display:flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:12.5px;font-weight:300;
  color:var(--ink-faint);
}
.m-plan-feats li::before{
  content:"";width:4px;height:4px;border-radius:50%;background:var(--gold);
}
.m-plan .m-cta-outline{margin-top:6px;}

/* ═════ COMPARATIVA (mobile · accordion) ═════ */
/* Comparativa móvil · v5 · cálida editorial (igualada a la desktop) */
.m-comp{background:var(--blanco-roto);color:var(--ink);padding-bottom:48px;}
.m-comp-head{padding:48px 22px 28px;text-align:center;}
.m-comp-h{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(34px,9vw,44px);line-height:1.05;letter-spacing:.02em;
  color:var(--ink);
}
.m-comp-h em{font-style:italic;color:var(--color-gold-deep);font-weight:300;}
.m-comp-sub{
  margin-top:12px;
  font-family:var(--sans);font-size:12.5px;font-weight:300;letter-spacing:.04em;
  color:var(--taupe);
}

.m-comp-list{list-style:none;padding:0;margin:0;border-top:1px solid rgba(28,31,36,.12);}
.m-round{border-bottom:1px solid rgba(28,31,36,.12);}
.m-round-toggle{
  display:grid;grid-template-columns:36px 1fr 24px;align-items:center;gap:14px;
  width:100%;padding:18px 22px;
  background:transparent;border:none;text-align:left;cursor:pointer;
  color:var(--ink);
  font-family:var(--sans);
}
.m-round-num{
  font-family:var(--serif);font-style:italic;font-weight:400;font-size:22px;
  color:var(--color-gold-deep);text-align:center;
}
.m-round-cat,.m-round-headline{display:block;}
.m-round-cat{
  font-size:9.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;
  color:var(--color-gold-deep);margin-bottom:4px;
}
.m-round-headline{
  font-family:var(--serif);font-weight:300;font-size:18px;line-height:1.25;
  color:var(--ink);
}
.m-round-headline em{font-style:italic;color:var(--color-gold-deep);font-weight:400;}
.m-round-chevron{
  font-family:var(--serif);font-weight:300;font-size:24px;color:var(--color-gold-deep);
  transition:transform .35s ease;display:flex;align-items:center;justify-content:center;
}
.m-round.is-open .m-round-chevron{transform:rotate(45deg);}

.m-round-body{
  max-height:0;overflow:hidden;
  transition:max-height .55s var(--ease-quint);
  padding:0 22px;
}
.m-round.is-open .m-round-body{
  max-height:1200px;padding-bottom:24px;
}
.m-round-thumb{
  margin:0 0 14px;aspect-ratio:16/10;background:var(--ink-deep);
  border:1px solid rgba(197,165,90,.28);overflow:hidden;
}
.m-round-thumb img{width:100%;height:100%;object-fit:cover;}
.m-round-spec{
  font-family:var(--serif);font-weight:300;font-size:14px;line-height:1.55;
  color:var(--taupe);margin-bottom:10px;
}
.m-round-mark{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--color-gold-deep);
}
.m-round-vs{
  display:flex;align-items:center;gap:12px;margin:18px 0 12px;
  font-family:var(--serif);font-style:italic;font-size:14px;color:var(--taupe);
}
.m-round-vs::before,.m-round-vs::after{
  content:"";flex:1;height:1px;background:rgba(28,31,36,.12);
}
.m-round-c-label{
  display:block;
  font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--taupe);margin-bottom:10px;
}
.m-round-c{list-style:none;padding:0;margin:0;}
.m-round-c li{
  display:grid;grid-template-columns:minmax(92px,auto) 1.5fr;gap:14px;
  align-items:baseline;padding:10px 0;
  border-bottom:1px dashed rgba(28,31,36,.12);
}
.m-round-c li:last-child{border-bottom:none;}
.m-c-name{
  font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--color-text-3);
}
.m-c-approach{
  font-family:var(--serif);font-size:13.5px;font-weight:400;line-height:1.4;
  color:var(--taupe);
}

.m-comp-foot{
  margin-top:36px;padding:0 22px;text-align:center;
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:16px;
  color:var(--ink);
}
.m-comp-foot em{font-style:italic;color:var(--color-gold-deep);}


/* ═══════════════════════════════════════════════════════════════
   MOBILE-ONLY v4 FIXES
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){

  /* Add proper offset so m-opener doesn't slip under fixed nav */
  .m-section{scroll-margin-top:64px;}

  /* Accordion grid — 3 cols only: num, text-wrapper, chevron */
  .m-round-toggle{
    grid-template-columns:40px 1fr 28px !important;
    align-items:start !important;
    padding:20px 20px !important;
  }
  .m-round-text{
    display:flex;flex-direction:column;gap:6px;min-width:0;
  }
  .m-round-num{
    font-size:28px;line-height:1;color:var(--color-gold-deep);
    padding-top:4px;
  }
  .m-round-cat{
    font-size:9px;letter-spacing:.32em;color:var(--color-gold-deep);
  }
  .m-round-headline{
    font-size:17px;line-height:1.25;color:var(--ink);
  }
  .m-round-chevron{
    width:28px;height:28px;border-radius:50%;
    border:1px solid rgba(197,165,90,.4);color:var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-size:18px;line-height:1;align-self:center;
    transition:transform .35s ease, background .35s ease;
  }
  .m-round.is-open .m-round-chevron{
    transform:rotate(45deg);
    background:var(--gold);color:var(--ink);
  }
  .m-round{
    border-bottom:1px solid rgba(197,165,90,.18);
    transition:background .25s ease;
  }
  .m-round.is-open{background:rgba(197,165,90,.03);}

  /* (Reveals móvil con stagger cinematic se definen en la capa MOBILE v5
     más abajo · esta regla se eliminó por contradictoria/código muerto.) */

  /* Bleed photo height tighter; brighter so text reads */
  .m-bleed{aspect-ratio:3/4 !important;}
  .m-bleed img{filter:brightness(.92) !important;}
  .m-bleed-h{font-size:32px !important;line-height:1.06 !important;}

  /* Opener band — solid bg so it doesn't collide with nav */
  .m-opener{
    padding-top:80px !important;  /* clear fixed nav */
  }

  /* Hide ALL desktop section openers when below mobile only */
  .opener.d-only{display:none !important;}

  /* Section-tip body inside d-only sometimes leaks — force hide */
  .section-tip.d-only,#exclusividad,#comparativa{display:none !important;}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE v5 · WOW LAYER — drama, motion, image-led, cinematic
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){

  /* ────────── Global mobile reveals (cinematic stagger) ────────── */
  .m-only .reveal{
    opacity:0 !important;
    transform:translateY(40px) !important;
    transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1.1s cubic-bezier(.2,.7,.2,1);
  }
  .m-only .reveal.in{
    opacity:1 !important;
    transform:translateY(0) !important;
  }
  .m-only .reveal.d1{transition-delay:.1s;}
  .m-only .reveal.d2{transition-delay:.2s;}
  .m-only .reveal.d3{transition-delay:.3s;}

  /* ────────── EXCLUSIVIDAD · Make WOW ────────── */
  .m-exc{padding-bottom:48px;background:linear-gradient(180deg, var(--white) 0%, var(--color-bg) 100%);}

  .m-bleed{
    aspect-ratio:3/4 !important;
    margin:0;
  }
  .m-bleed img{
    transform:scale(1.04);
    animation:mBleedZoom 18s ease-out infinite alternate;
    filter:brightness(.86) saturate(1.05);
  }
  @keyframes mBleedZoom{
    0%{transform:scale(1);}
    100%{transform:scale(1.12);}
  }
  .m-bleed figcaption{
    padding:32px 22px 36px !important;
    background:linear-gradient(180deg,transparent 0%,rgba(28,31,36,.35) 35%,rgba(28,31,36,.92) 100%) !important;
  }
  .m-bleed-eyebrow{
    font-size:11px !important;letter-spacing:.42em !important;
    margin-bottom:12px !important;
  }
  .m-bleed-h{
    font-size:42px !important;
    line-height:1 !important;
    letter-spacing:.005em !important;
  }
  .m-bleed-h em{
    font-size:1.15em;
    display:inline-block;
    text-shadow:0 0 40px rgba(197,165,90,.5);
  }

  /* Exc cards · BIGGER, MORE DRAMATIC */
  .m-exc-grid{
    padding:48px 16px 0 !important;
    gap:40px !important;
  }
  .m-exc-card{
    background:var(--blanco-roto) !important;
    border:none !important;
    box-shadow:0 18px 48px -20px rgba(28,31,36,.18), 0 1px 0 var(--hair-soft);
    overflow:hidden;
    transition:transform .35s var(--ease-quint), box-shadow .35s ease;
  }
  .m-exc-card:active{transform:scale(.98);}
  .m-exc-card img{
    height:280px !important;
    transition:transform 1.2s var(--ease-quint);
  }
  .m-exc-card.in img{
    animation:mCardKenBurns 14s ease-out infinite alternate;
  }
  @keyframes mCardKenBurns{
    0%{transform:scale(1);}
    100%{transform:scale(1.08);}
  }
  /* HUGE numeral floating watermark */
  .m-exc-num{
    position:absolute !important;
    top:auto !important;bottom:auto !important;left:auto !important;
    right:14px !important;top:14px !important;
    background:transparent !important;
    backdrop-filter:none !important;
    font-family:var(--serif) !important;
    font-style:italic !important;font-weight:400 !important;
    font-size:88px !important;line-height:.85 !important;
    color:rgba(255,255,255,.95) !important;
    padding:0 !important;border-radius:0 !important;
    text-shadow:0 4px 20px rgba(0,0,0,.55);
    letter-spacing:-.02em;
    pointer-events:none;
  }
  .m-exc-card-body{padding:28px 24px 32px !important;}
  .m-exc-card-body h3{
    font-size:30px !important;
    line-height:1.05 !important;
    letter-spacing:.01em !important;
    margin-bottom:14px !important;
  }
  .m-exc-card-body p{
    font-size:15px !important;
    line-height:1.6 !important;
  }

  /* ────────── TIPOLOGÍAS · Dramatic Torre cards ────────── */
  .m-tip{
    background:linear-gradient(180deg,var(--color-bg) 0%,var(--white) 50%,var(--color-bg) 100%);
    padding-bottom:64px !important;
  }
  .m-tip-head{padding:72px 22px 14px !important;}
  .m-tip-h{font-size:48px !important;line-height:1 !important;}
  .m-tip-h em{display:inline-block;text-shadow:0 0 30px rgba(197,165,90,.3);}
  .m-tip-sub{margin-top:18px !important;font-size:15px !important;}

  .m-torre{
    margin:32px 16px 0 !important;
    box-shadow:0 24px 56px -20px rgba(28,31,36,.22), 0 1px 0 var(--hair);
    background:var(--blanco-roto) !important;
    overflow:hidden;
  }
  .m-torre-media{aspect-ratio:4/3 !important;}
  .m-torre-media img{
    animation:mCardKenBurns 16s ease-out infinite alternate;
    filter:brightness(.95) saturate(1.05);
  }
  .m-torre-badge{
    padding:9px 14px !important;
    font-size:10px !important;
    letter-spacing:.28em !important;
    background:rgba(0,0,0,.78) !important;
    border:1px solid rgba(197,165,90,.5) !important;
    box-shadow:0 8px 20px -6px rgba(0,0,0,.5);
  }
  .m-torre-body{padding:32px 24px 36px !important;}
  .m-torre-name{
    font-size:64px !important;
    line-height:.95 !important;
    letter-spacing:.04em !important;
  }
  .m-torre-name em{
    font-size:1.2em;
    display:inline-block;
    margin-left:8px;
    text-shadow:0 0 40px rgba(197,165,90,.4);
  }
  .m-torre-name em.verde{text-shadow:0 0 40px rgba(27,94,75,.4);}
  .m-torre-copy{
    font-size:15px !important;
    line-height:1.65 !important;
    margin-top:24px !important;
  }
  .m-torre-stats{
    margin:32px 0 !important;
    padding:0;
  }
  .m-torre-stats li{padding:20px 4px !important;}
  .m-num{
    font-size:30px !important;
    font-weight:300 !important;
  }
  .m-lbl{
    font-size:9px !important;
    letter-spacing:.28em !important;
  }
  .m-cta{
    padding:18px 26px !important;
    font-size:11.5px !important;
    letter-spacing:.18em !important;
    box-shadow:0 14px 32px -10px rgba(197,165,90,.45);
  }
  .m-torre-b .m-cta-verde{
    box-shadow:0 14px 32px -10px rgba(27,94,75,.5);
  }

  /* Plan cards · floor plans more prominent */
  .m-plan{
    margin:32px 16px 0 !important;
    box-shadow:0 24px 56px -20px rgba(0,0,0,.45);
  }
  .m-plan-media{aspect-ratio:4/3 !important;}
  .m-plan-num{
    font-size:48px !important;
    background:rgba(0,0,0,.6);
    backdrop-filter:blur(8px);
    padding:6px 16px !important;
    border-radius:0 !important;
    top:14px !important;left:14px !important;
  }
  .m-plan-body{padding:28px 24px 32px !important;}
  .m-plan-price{
    font-size:32px !important;
    line-height:1 !important;
    margin:14px 0 24px !important;
  }
  .m-plan-price em{font-size:1.2em;}
  .m-spec-num{font-size:26px !important;}

  /* ────────── COMPARATIVA · accordion cálido (v6 · igualado a desktop) ────────── */
  .m-comp{
    background:var(--blanco-roto);
  }
  .m-comp-head{padding:80px 22px 32px !important;position:relative;}
  .m-comp-h{
    font-size:52px !important;
    line-height:.98 !important;
    letter-spacing:.005em !important;
  }
  .m-comp-h em{
    font-size:1.15em;
    display:inline-block;
  }
  .m-comp-sub{
    margin-top:20px !important;
    font-size:13px !important;
    letter-spacing:.06em !important;
  }
  .m-round{
    position:relative;
    border-bottom:1px solid rgba(28,31,36,.12);
  }
  .m-round-toggle{
    padding:24px 20px !important;
    -webkit-tap-highlight-color:rgba(197,165,90,.15);
  }
  .m-round-num{
    font-size:32px !important;
  }
  .m-round-headline{
    font-size:19px !important;
    line-height:1.25 !important;
  }
  .m-round-chevron{
    width:36px !important;height:36px !important;
    font-size:20px !important;
    border-width:1px;
    transition:all .45s var(--ease-quint);
  }
  .m-round.is-open{
    background:rgba(197,165,90,.06);
  }
  .m-round.is-open .m-round-chevron{
    background:var(--color-gold-deep);color:var(--blanco-roto);
    box-shadow:0 0 22px rgba(197,165,90,.22);
  }
  /* Animate the expand content */
  .m-round-body{
    transition:max-height .65s var(--ease-quint), padding .45s ease !important;
  }
  .m-round-body > *{
    opacity:0;transform:translateY(12px);
    transition:opacity .45s ease, transform .55s var(--ease-quint);
  }
  .m-round.is-open .m-round-body > *{opacity:1;transform:translateY(0);}
  .m-round.is-open .m-round-body > *:nth-child(1){transition-delay:.1s;}
  .m-round.is-open .m-round-body > *:nth-child(2){transition-delay:.15s;}
  .m-round.is-open .m-round-body > *:nth-child(3){transition-delay:.2s;}
  .m-round.is-open .m-round-body > *:nth-child(4){transition-delay:.25s;}
  .m-round.is-open .m-round-body > *:nth-child(5){transition-delay:.3s;}
  .m-round.is-open .m-round-body > *:nth-child(6){transition-delay:.35s;}
  .m-round-thumb{
    aspect-ratio:16/10 !important;
    box-shadow:0 16px 32px -16px rgba(28,31,36,.35);
  }
  .m-round-thumb img{
    animation:mCardKenBurns 12s ease-out infinite alternate;
  }
  .m-comp-foot{
    margin-top:48px !important;
    padding:32px 22px 0 !important;
    border-top:1px solid rgba(28,31,36,.12);
    font-size:17px !important;
    line-height:1.45 !important;
  }
  .m-comp-foot em{
    font-size:1.15em;
    display:inline-block;
  }

  /* ────────── Section dividers with subtle gold rule ────────── */
  .m-section{position:relative;}
  .m-section + .m-section::before{
    content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:48px;height:1px;background:var(--gold);
    box-shadow:0 0 12px rgba(197,165,90,.5);
  }

  /* ────────── Improved opener band (less generic) ────────── */
  .m-opener{
    padding:24px 22px 18px !important;
    background:transparent !important;
    border:none !important;
    font-size:9.5px !important;
    letter-spacing:.5em !important;
  }
  .m-opener em{
    font-size:36px !important;
    line-height:1 !important;
    margin-right:6px;
    text-shadow:0 0 18px rgba(197,165,90,.3);
  }
  .m-opener.dark{color:var(--ink-faint);}

  /* ────────── La Vida cinema mobile · big cinematic cards ────────── */
  .lv-card{
    box-shadow:0 24px 56px -24px rgba(0,0,0,.55) !important;
  }
  .lv-card img{
    animation:mCardKenBurns 16s ease-out infinite alternate;
  }

  /* ────────── Cierre hero · more cinematic ────────── */
  .invite-h{
    font-size:64px !important;
    line-height:.95 !important;
    letter-spacing:-.005em !important;
  }
  .invite-h em{
    font-size:1.25em;
    display:inline-block;
    text-shadow:0 0 40px rgba(197,165,90,.4);
  }

  /* ────────── Bottom CTA bar · more presence ────────── */
  .mobile-cta-bar{
    box-shadow:0 -12px 32px rgba(0,0,0,.5);
    border-top:1px solid rgba(197,165,90,.4);
  }
  .mobile-cta-wa{
    box-shadow:0 8px 20px -6px rgba(37,211,102,.55), 0 0 0 1px rgba(37,211,102,.2);
  }

  /* ────────── Hero · more atmospheric ────────── */
  .hero-h1-mark{
    text-shadow:0 8px 40px rgba(0,0,0,.6), 0 0 120px rgba(197,165,90,.25) !important;
    letter-spacing:.1em !important;
  }

  /* ────────── Brand color washes for visual rhythm ────────── */
  .m-tip-head::before,
  .m-comp-head::before{
    content:"";display:block;width:32px;height:1.5px;background:var(--gold);
    margin:0 auto 24px;
    box-shadow:0 0 14px rgba(197,165,90,.5);
  }
}

/* Reduce motion for users who prefer */
@media (prefers-reduced-motion:reduce){
  .m-bleed img,.m-exc-card.in img,.m-torre-media img,
  .m-round-thumb img,.lv-card img{
    animation:none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE v6 · CONVERSION + WOW LAYER
   ═══════════════════════════════════════════════════════════════ */

/* ── Side progress dots (mobile only) ── */
.m-progress{
  display:none;
  position:fixed;right:12px;top:50%;transform:translateY(-50%);
  z-index:50;
  flex-direction:column;gap:12px;
  padding:0;  /* sin caja flotante · solo los dots, sutiles */
}
@media (max-width:820px){.m-progress{display:flex;}}
.m-progress-dot{
  display:block;width:16px;height:16px;
  position:relative;
  text-decoration:none;
}
.m-progress-dot span{
  display:block;width:6px;height:6px;border-radius:50%;
  background:rgba(28,31,36,.22);  /* oscuro · visible sobre fondo claro */
  margin:5px auto;
  transition:background .35s ease, transform .35s var(--ease-quint);
}
.m-progress-dot.is-active span{
  background:var(--color-gold-deep);
  transform:scale(1.5);
  box-shadow:0 0 10px rgba(140,115,64,.45);
}

/* ── Floor plan lightbox ── */
.m-lightbox{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.92);
  backdrop-filter:blur(20px);
  opacity:0;visibility:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:24px;gap:18px;
  transition:opacity .35s ease, visibility 0s linear .35s;
}
.m-lightbox.is-open{opacity:1;visibility:visible;transition:opacity .35s ease;}
.m-lightbox-img{
  max-width:100%;max-height:78vh;
  width:auto;height:auto;
  border:1px solid rgba(197,165,90,.3);
  box-shadow:0 30px 80px rgba(0,0,0,.7);
  transform:scale(.96);transition:transform .55s var(--ease-quint);
}
.m-lightbox.is-open .m-lightbox-img{transform:scale(1);}
.m-lightbox-close{
  position:absolute;top:18px;right:18px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(197,165,90,.4);
  color:var(--color-bg);font-size:24px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(10px);
}
.m-lightbox-caption{
  font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);
}

/* ── Scarcity pulse pin (Torre A) ── */
.m-scarcity-pin{
  position:absolute;top:14px;right:14px;z-index:5;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  width:72px;height:72px;border-radius:50%;
  background:rgba(28,31,36,.85);
  border:1.5px solid var(--gold);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px -4px rgba(0,0,0,.5), 0 0 0 0 rgba(197,165,90,.7);
  animation:scarcityPulse 2.6s ease-out infinite;
}
@keyframes scarcityPulse{
  0%{box-shadow:0 8px 24px -4px rgba(0,0,0,.5), 0 0 0 0 rgba(197,165,90,.55);}
  70%{box-shadow:0 8px 24px -4px rgba(0,0,0,.5), 0 0 0 14px rgba(197,165,90,0);}
  100%{box-shadow:0 8px 24px -4px rgba(0,0,0,.5), 0 0 0 0 rgba(197,165,90,0);}
}
.m-scarcity-pulse{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:var(--color-pulse);top:8px;right:8px;
  box-shadow:0 0 10px var(--color-pulse);
  animation:scarcityDot 1.6s ease-in-out infinite;
}
@keyframes scarcityDot{0%,100%{opacity:1;}50%{opacity:.4;}}
.m-scarcity-num{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:28px;line-height:1;color:var(--gold);
  text-shadow:0 0 12px rgba(197,165,90,.4);
}
.m-scarcity-lbl{
  font-family:var(--sans);font-size:8px;font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--color-bg);margin-top:2px;
}

/* ── Magnetic pulse on CTA buttons ── */
@media (max-width:820px){
  .m-cta-gold,.mobile-cta-wa{
    position:relative;overflow:hidden;
  }
  .m-cta-gold::before,.mobile-cta-wa::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
    transform:translateX(-100%);
    animation:magneticShine 4s ease-in-out infinite;
    animation-delay:2s;
    pointer-events:none;
  }
  @keyframes magneticShine{
    0%{transform:translateX(-100%);}
    50%{transform:translateX(100%);}
    100%{transform:translateX(100%);}
  }
  .mobile-cta-wa{
    animation:magneticBreath 3s ease-in-out infinite;
    animation-delay:5s;
  }
  @keyframes magneticBreath{
    0%,100%{transform:scale(1);}
    50%{transform:scale(1.04);}
  }
}

/* ── Hero KUXNAH letter reveal · 6 letters slide up one by one ── */
@media (max-width:820px){
  .hero-h1-mark{
    display:inline-flex !important;gap:.02em;
  }
  .hero-h1-mark .l{
    display:inline-block;
    opacity:0;transform:translateY(60px) skewY(8deg);
    animation:heroLetter 1.4s cubic-bezier(.2,.7,.2,1) forwards;
  }
  .hero-h1-mark .l:nth-child(1){animation-delay:1.6s;}
  .hero-h1-mark .l:nth-child(2){animation-delay:1.75s;}
  .hero-h1-mark .l:nth-child(3){animation-delay:1.90s;}
  .hero-h1-mark .l:nth-child(4){animation-delay:2.05s;}
  .hero-h1-mark .l:nth-child(5){animation-delay:2.20s;}
  .hero-h1-mark .l:nth-child(6){animation-delay:2.35s;}
  @keyframes heroLetter{
    to{opacity:1;transform:translateY(0) skewY(0);}
  }
}

/* ── Smooth scroll for anchor jumps ── */
html{scroll-behavior:smooth;}
@media (max-width:820px){
  .m-section{scroll-margin-top:80px;}
}

/* ── Floor plan card · pinch-zoom hint icon ── */
@media (max-width:820px){
  .m-zoomable{
    position:relative;cursor:zoom-in;
  }
  .m-zoomable::after{
    content:"+";
    position:absolute;bottom:14px;right:14px;
    width:36px;height:36px;border-radius:50%;
    background:rgba(0,0,0,.7);color:var(--gold);
    display:flex;align-items:center;justify-content:center;
    font-family:var(--sans);font-size:22px;font-weight:300;
    border:1px solid rgba(197,165,90,.5);
    backdrop-filter:blur(8px);
    z-index:3;
    animation:zoomHint 3s ease-in-out infinite;
  }
  @keyframes zoomHint{
    0%,100%{transform:scale(1);}
    50%{transform:scale(1.12);}
  }
}

/* ── Sticky bottom bar · stronger presence ── */
@media (max-width:820px){
  .mobile-cta-bar{
    background:linear-gradient(180deg,rgba(28,31,36,.96) 0%,rgba(16,18,22,1) 100%) !important;
    border-top:1px solid rgba(197,165,90,.45) !important;
  }
  .mobile-cta-pulse{
    width:10px !important;height:10px !important;
    box-shadow:0 0 14px var(--color-pulse), 0 0 0 0 var(--color-pulse-glow) !important;
    animation:ctaPulse 2.2s ease-out infinite !important;
  }
  @keyframes ctaPulse{
    0%{box-shadow:0 0 14px var(--color-pulse), 0 0 0 0 var(--color-pulse-glow);}
    70%{box-shadow:0 0 14px var(--color-pulse), 0 0 0 12px transparent;}
    100%{box-shadow:0 0 14px var(--color-pulse), 0 0 0 0 transparent;}
  }
}

/* ── Floating "Showroom abierto" hint on Torre A media ── */
@media (max-width:820px){
  .m-torre-a .m-torre-media::after{
    content:"● Showroom abierto · Hoy";
    position:absolute;bottom:14px;left:14px;
    background:rgba(28,31,36,.85);backdrop-filter:blur(10px);
    border:1px solid rgba(34,197,94,.5);
    color:var(--color-bg);
    padding:7px 12px;border-radius:999px;
    font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.24em;
    text-transform:uppercase;z-index:2;
    box-shadow:0 8px 20px -4px rgba(0,0,0,.55);
  }
}

/* ── Better card entrance with clip-path reveal ── */
@media (max-width:820px){
  .m-torre,.m-plan,.m-exc-card{
    clip-path:inset(0 0 100% 0);
    opacity:0;
    transition:clip-path 1.2s cubic-bezier(.2,.7,.2,1), opacity 1.2s ease;
  }
  .m-torre.in,.m-plan.in,.m-exc-card.in{
    clip-path:inset(0);
    opacity:1;
  }
}

/* ── Gradient text on key italic-gold words for extra pop ── */
@media (max-width:820px){
  .m-bleed-h em,
  .m-tip-h em,
  .m-comp-h em,
  .invite-h em,
  .m-comp-foot em{
    background:linear-gradient(135deg,var(--gold-hi) 0%,var(--gold) 50%,var(--color-gold-deep) 100%);
    -webkit-background-clip:text;
    background-clip:text;
    color:transparent;
    -webkit-text-fill-color:transparent;
    /* Re-add text-shadow via filter since text-shadow doesn't work with bg-clip */
    filter:drop-shadow(0 0 16px rgba(197,165,90,.35));
  }
}

/* ═══════════════════════════════════════════════════════════════════
   Cookie consent banner · LFPDPPP compliance · bottom-fixed, dismissable
   ═══════════════════════════════════════════════════════════════════ */
.cookie-banner {
  position: fixed;
  left: 16px; right: 16px; bottom: 16px;
  z-index: 9999;
  background: rgba(28, 31, 36, 0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(197, 165, 90, 0.3);
  border-radius: 4px;
  padding: 14px 18px;
  box-shadow: 0 8px 30px rgba(0,0,0,.18);
  animation: cookie-rise .4s cubic-bezier(.2,.7,.2,1) both;
}
.cookie-banner[hidden] { display: none; }
@keyframes cookie-rise {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cookie-banner-inner {
  max-width: 1080px; margin: 0 auto;
  display: flex; align-items: center; gap: 18px;
  flex-wrap: wrap; justify-content: space-between;
}
.cookie-banner-text {
  font-family: var(--sans); font-size: 13px; font-weight: 300;
  color: var(--color-bg); line-height: 1.5; margin: 0;
  flex: 1 1 320px;
}
.cookie-banner-text a {
  color: var(--gold); text-decoration: underline; text-underline-offset: 2px;
}
.cookie-banner-text a:hover { color: var(--gold-hi); }
.cookie-banner-actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-btn {
  font-family: var(--sans); font-size: 12px; font-weight: 400;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 9px 18px; border-radius: 2px; cursor: pointer;
  transition: all .2s ease;
  border: 1px solid transparent;
}
.cookie-btn-reject {
  background: transparent; color: var(--color-bg);
  border-color: rgba(250, 248, 245, 0.3);
}
.cookie-btn-reject:hover { border-color: var(--color-bg); }
.cookie-btn-accept {
  background: var(--gold); color: var(--ink);
}
.cookie-btn-accept:hover { background: var(--gold-hi); }
@media (max-width: 520px) {
  .cookie-banner { left: 8px; right: 8px; bottom: 80px; padding: 12px 14px; }
  .cookie-banner-inner { gap: 12px; }
  .cookie-banner-text { font-size: 12px; }
  .cookie-banner-actions { width: 100%; }
  .cookie-btn { flex: 1; padding: 10px 12px; font-size: 11px; }
}

/* ═══════════════════════════════════════════════════════════════
   A11y · skip-to-content + focus-visible polish (WCAG 2.1 AA)
   ═══════════════════════════════════════════════════════════════ */
.skip-link {
  position: absolute;
  top: -100px; left: 16px;
  z-index: 10000;
  padding: 12px 20px;
  background: var(--ink); color: var(--gold);
  font-family: var(--sans); font-size: 12px; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase;
  text-decoration: none;
  border: 1px solid var(--gold); border-radius: 2px;
  transition: top .2s cubic-bezier(.2,.7,.2,1);
}
.skip-link:focus,
.skip-link:focus-visible {
  top: 16px;
  outline: none;
  box-shadow: 0 4px 18px rgba(0,0,0,.22);
}

/* Focus visible global · solo cuando navega por teclado, no por click */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
  border-radius: 2px;
}
/* Botones e inputs deben mantener su estilo propio en focus también */
button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* Respeto a prefers-reduced-motion · WCAG 2.3.3 */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
