/* ═══════════════════════════════════════════════════════════════
   KUXNAH LIVING CONDOS — v2 design system
   Cormorant Light typography · single-image-per-section · custom motion
   Lagos del Sol clarity + cinematic luxury
   ═══════════════════════════════════════════════════════════════ */

:root{
  /* Surfaces */
  --white: #FFFFFF;
  --bone:  #FAF8F5;
  --bone-deep: #F2EEE6;
  --ink:   #1C1F24;
  --ink-deep: #14171B;

  /* Text on light */
  --text:   #1C1F24;
  --text-2: #4E5056;
  --text-3: #6A6C72;
  --text-4: #8A8D93;

  /* Brand accents */
  --gold:    #C5A55A;
  --gold-hi: #D4B06A;
  --verde:   #1B5E4B;

  /* Lines */
  --hair:        rgba(197,165,90,.40);
  --hair-soft:   rgba(197,165,90,.18);
  --hair-ink:    rgba(28,31,36,.10);
  --hair-ink-2:  rgba(28,31,36,.06);

  /* Type */
  --serif:         'Cormorant Garamond', Georgia, serif;
  --serif-display: 'Playfair Display', Georgia, serif;
  --sans:          'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --mono:          'JetBrains Mono', ui-monospace, monospace;

  /* Easing */
  --ease-quint: cubic-bezier(.22,1,.36,1);
  --ease-expo:  cubic-bezier(.87,0,.13,1);
  --ease-clip:  cubic-bezier(.65,0,.35,1);

  /* Layout */
  --container: 1440px;
  --pad-x: 96px;
}

@media (max-width: 1080px){:root{--pad-x:48px;}}
@media (max-width: 720px){:root{--pad-x:24px;}}

/* ── Reset & body ── */
*{box-sizing:border-box;margin:0;padding:0;}
html,body{
  background:var(--white);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 bar{0%,100%{transform:scaleY(.4);}50%{transform:scaleY(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;}

.lang{display:flex;align-items:center;gap:6px;font-family:var(--sans);font-size:10.5px;
  font-weight:400;letter-spacing:.2em;color:rgba(255,255,255,.7);text-shadow:0 1px 8px rgba(0,0,0,.25);}
.lang-btn{background:none;border:none;color:inherit;font:inherit;cursor:pointer;padding:4px 2px;
  transition:color .3s ease;letter-spacing:.2em;}
.lang-btn.active{color:var(--white);}
.lang-btn:hover{color:var(--gold);}
.lang-sep{color:rgba(255,255,255,.35);}
.nav.scrolled .lang{color:var(--text-3);text-shadow:none;}
.nav.scrolled .lang-btn.active{color:var(--ink);}
.nav.scrolled .lang-sep{color:var(--text-4);}

.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(--white);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);}

/* Audio toggle */
.audio-toggle{position:absolute;right:var(--pad-x);bottom:36px;z-index:5;
  display:flex;align-items:center;gap:10px;
  background:rgba(0,0,0,.32);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.22);
  padding:9px 14px;border-radius:999px;cursor:pointer;
  font-family:var(--sans);font-size:9.5px;font-weight:400;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.85);transition:border-color .3s ease, color .3s ease, background-color .3s ease;
  opacity:0;animation:heroFadeUpSoft 1s ease 4.2s forwards;}
.audio-toggle:hover{border-color:var(--gold);color:var(--white);background:rgba(0,0,0,.45);}
.audio-bars{display:inline-flex;align-items:flex-end;gap:2px;height:10px;}
.audio-bars span{display:block;width:2px;background:var(--gold);border-radius:1px;
  animation:bar 1.2s ease-in-out infinite;animation-play-state:paused;}
.audio-bars span:nth-child(1){height:40%;animation-delay:0s;}
.audio-bars span:nth-child(2){height:90%;animation-delay:.15s;}
.audio-bars span:nth-child(3){height:60%;animation-delay:.3s;}
.audio-bars span:nth-child(4){height:75%;animation-delay:.45s;}
.audio-toggle.playing .audio-bars span{animation-play-state:running;}

/* ═══════════════════════════════════════════════════════════════
   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(--white);}

/* 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(--white);
  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(--white);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(--bone);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(--white);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(--white);}

.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(--bone);}
.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:#246b56;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(--white);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:120px var(--pad-x) 100px;
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:32px;
  background:var(--bone);}
.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
   ═══════════════════════════════════════════════════════════════ */
.section-cierre{
  background:var(--ink);color:var(--bone);
  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:#22c55e;
  box-shadow:0 0 10px #22c55e;
  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(--bone);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(--bone);color:var(--ink);
  padding:96px var(--pad-x) 96px;
  --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(--white);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:#22c55e;
  box-shadow:0 0 12px #22c55e;
}
.invite-live-dot::before{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:2px solid #22c55e;
  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:#25D366;color:#fff;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(--white);
  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(--bone);
  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:#22c55e;
  box-shadow:0 0 8px #22c55e;
}

/* ── ACT III · GRUPO SALOMÓN — slim, compact strip ── */
.cierre-gs{
  position:relative;z-index:2;
  padding:48px var(--pad-x) 56px;
  background:var(--bone);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 carousel — slim panoramic strip, fast rotate */
.gs-portfolio{
  position:relative;
  background:var(--ink);
  border:1px solid var(--hair);
  overflow:hidden;
}
.gs-portfolio-track{
  position:relative;width:100%;
  aspect-ratio:32 / 9;
}
.gs-slide{
  position:absolute;inset:0;margin:0;
  opacity:0;visibility:hidden;
  transition:opacity .5s ease, visibility 0s linear .5s;
}
.gs-slide.is-active{
  opacity:1;visibility:visible;
  transition:opacity .5s ease, visibility 0s linear 0s;
}
.gs-slide img{
  width:100%;height:100%;object-fit:cover;display:block;
  transform:scale(1);transition:transform 4s linear;
}
.gs-slide.is-active img{transform:scale(1.04);}  /* Ken Burns subtle zoom */
.gs-slide figcaption{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
  padding:14px 20px;
  background:linear-gradient(180deg, transparent 0%, rgba(28,31,36,.5) 50%, rgba(28,31,36,.88) 100%);
  color:var(--bone);
}
.gs-slide-name{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(13px,1.2vw,16px);letter-spacing:.02em;color:var(--bone);
}
.gs-slide-meta{
  font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);
}

/* Carousel HUD — slim */
.gs-portfolio-controls{
  position:absolute;top:14px;right:14px;
  display:flex;align-items:center;gap:14px;
  padding:7px 12px;border-radius:999px;
  background:rgba(28,31,36,.65);backdrop-filter:blur(10px);
  font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.28em;
  text-transform:uppercase;color:var(--bone);
  z-index:3;
}
.gs-portfolio-label{color:var(--gold);}
.gs-portfolio-dots{display:flex;gap:8px;}
.gs-portfolio-dot{
  width:7px;height:7px;border-radius:50%;
  border:none;background:rgba(255,255,255,.32);cursor:pointer;
  transition:background .35s ease, width .55s var(--ease-quint), border-radius .35s ease;
}
.gs-portfolio-dot.is-active{
  background:var(--gold);width:24px;border-radius:4px;
  box-shadow:0 0 10px rgba(197,165,90,.55);
}
.gs-portfolio-dot:hover:not(.is-active){background:rgba(255,255,255,.6);}
.gs-portfolio-count{
  color:var(--ink-faint);
  font-variant-numeric:tabular-nums;
  font-family:var(--mono,monospace);font-size:10px;letter-spacing:.18em;
}
.gs-portfolio-count #gs-portfolio-current{color:var(--bone);font-weight:500;}

/* 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(--bone);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(--bone);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);}

/* ── 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 — always visible, conversion booster ── */
.wa-pill{
  position:fixed;bottom:28px;right:28px;z-index:150;
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px 14px 18px;border-radius:999px;
  background:#25D366;color:#fff;text-decoration:none;
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;
  box-shadow:0 14px 40px -12px rgba(37,211,102,.55), 0 4px 12px -4px rgba(0,0,0,.20);
  transition:transform .35s var(--ease-quint), box-shadow .35s ease, padding .35s var(--ease-quint);
  opacity:0;transform:translateY(20px) scale(.92);
  animation:waPillIn .8s var(--ease-quint) 5s forwards;
}
@keyframes waPillIn{
  to{opacity:1;transform:translateY(0) scale(1);}
}
.wa-pill:hover{transform:translateY(-3px);padding-right:28px;
  box-shadow:0 20px 48px -10px rgba(37,211,102,.65), 0 6px 16px -4px rgba(0,0,0,.25);}
.wa-pill-icon{display:flex;align-items:center;justify-content:center;}
.wa-pill::after{content:"";position:absolute;inset:-3px;border-radius:999px;
  border:1px solid rgba(37,211,102,.4);
  animation:waPulse 2.4s ease-in-out infinite;pointer-events:none;}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.7;}
  70%{transform:scale(1.18);opacity:0;}
  100%{transform:scale(1.18);opacity:0;}
}
@media (max-width:720px){
  .wa-pill{padding:12px 16px;font-size:12px;bottom:18px;right:18px;}
  .wa-pill-label{display:none;}
}

/* ── Quick stats bar (after hero) ── */
.quick-stats{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  align-items:center;gap:0;
  background:var(--ink);
  padding:32px var(--pad-x);
  border-bottom:1px solid rgba(197,165,90,.18);
}
.quick-stats-cell{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;}
.quick-stats-num{font-family:var(--serif);font-weight:300;
  font-size:clamp(28px,3.4vw,44px);line-height:1;color:var(--white);letter-spacing:.02em;}
.quick-stats-num em{font-style:italic;color:var(--gold);font-weight:300;}
.quick-stats-num small{font-family:var(--sans);font-size:.5em;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-left:4px;}
.quick-stats-lbl{font-family:var(--sans);font-size:9.5px;font-weight:500;
  letter-spacing:.32em;text-transform:uppercase;color:rgba(250,248,245,.65);}
.quick-stats-sep{width:1px;height:48px;background:rgba(197,165,90,.25);}

/* ── Manifesto bridge ── */
.manifesto{
  background:var(--ink);padding:160px 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(--white);
}
.pinscroll-sticky{
  position:sticky;top:0;height:100vh;
  display:flex;align-items:center;justify-content:center;
  background:var(--bone);
}
.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(--white);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(--white);
}
.lavida-pin{
  position:sticky;top:0;
  height:100vh;
  overflow:hidden;
  display:flex;align-items:center;
  background:var(--white);
}

/* 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(--white);
  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(--bone);
  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(--bone);
  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(--white);}

/* ── 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(--white);
}
.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:#7BD7B6;}
.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:#7BD7B6;}
.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(--white);
  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:80px var(--pad-x) 120px;
  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(--bone);
  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(--bone);}

.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(--ink);color:var(--bone);position:relative;}
.section-comp .section-hero{background:transparent;}
.section-comp .section-hero-title{color:var(--bone);}
.section-comp .section-hero-title em{color:var(--gold);font-style:italic;}
.section-comp .section-hero-sub{color:var(--ink-faint);}

/* 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(--ink-faint);
  font-family:var(--sans);
  transition:color .35s ease, transform .35s var(--ease-quint);
  text-align:center;
}
.comp-tab:hover{color:var(--bone);transform:translateY(-2px);}
.comp-tab.is-active{color:var(--gold);}
.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(--gold);}
.comp-tab.is-active .comp-tab-name{color:var(--gold);}

/* 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(--gold);
}
.comp-k-cat::before{content:"";width:24px;height:1px;background:var(--gold);}
.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(--bone);margin:8px 0 4px;
}
.comp-k-head em{font-style:italic;color:var(--gold);font-weight:300;}
.comp-k-spec{
  font-family:var(--sans);font-size:14.5px;font-weight:300;line-height:1.6;
  color:var(--ink-faint);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(--gold);
}
.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:42px minmax(96px,1fr) 1.6fr;
  gap:18px;align-items:center;
  padding:14px 14px 14px 0;
  border-bottom:1px dashed rgba(255,255,255,.10);
  cursor:default;
  transition:background .3s ease, padding-left .3s ease;
}
.comp-c-row:last-child{border-bottom:none;}
.comp-c-row:hover{background:rgba(197,165,90,.05);padding-left:14px;}

/* Letter code bubble — A · B · C · D persistent across rounds */
.comp-c-code{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(197,165,90,.55);
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:16px;color:var(--gold);
  background:transparent;
  transition:background .3s ease, color .3s ease, transform .35s var(--ease-quint);
}
.comp-c-row:hover .comp-c-code{background:var(--gold);color:var(--ink);transform:scale(1.06);}

/* Blurred name — shows code initially. On hover row, reveals "·121u" density */
.comp-c-name{
  position:relative;
  font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-faint);
  filter:blur(2.5px);
  user-select:none;
  transition:filter .35s ease, color .35s ease, letter-spacing .35s ease;
}
.comp-c-row:hover .comp-c-name{
  filter:blur(0);color:var(--bone);letter-spacing:.18em;
}
/* On hover, append density badge from data-units attribute */
.comp-c-name::after{
  content:" · " attr(data-units);
  display:inline;color:var(--gold);font-weight:500;letter-spacing:.16em;
  opacity:0;transition:opacity .35s ease .1s;
}
.comp-c-row:hover .comp-c-name::after{opacity:1;}

.comp-c-approach{
  font-family:var(--sans);font-size:13.5px;font-weight:300;line-height:1.5;
  color:var(--ink-ghost);letter-spacing:.005em;
}
.comp-c-approach b{color:var(--bone);font-weight:500;font-family:var(--serif);font-style:italic;font-size:16px;letter-spacing:.02em;}
.comp-c-row:hover .comp-c-approach{color:var(--bone);}

/* ── 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(--bone);}
.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:96px var(--pad-x) 120px;
  background:transparent;color:var(--bone);
  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(--bone);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(--white);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(--bone);}
.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(--bone);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:#25D366;color:#fff;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, lang hidden, smaller logo */
  .nav{padding:14px 20px;}
  .nav.scrolled{padding:10px 20px;}
  .nav-right{gap:14px;}
  .lang{display:none;}
  .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;}
  /* Audio toggle compact */
  .audio-toggle{
    bottom:18px;right:18px;padding:6px 10px;
    font-size:8.5px;letter-spacing:.22em;gap:7px;
  }
  .audio-bars{height:8px;}
  /* 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;}

  /* Quick stats · 2×2 grid, separators removed */
  .quick-stats{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    gap:24px 14px;padding:26px 22px;
  }
  .quick-stats-sep{display:none;}
  .quick-stats-cell{gap:6px;}
  .quick-stats-num{font-size:22px;}
  .quick-stats-lbl{font-size:8px;letter-spacing:.18em;}

  /* 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-track{aspect-ratio:16/10;}
  .gs-slide figcaption{padding:12px 14px;gap:8px;}
  .gs-slide-name{font-size:12px;}
  .gs-slide-meta{font-size:8.5px;letter-spacing:.22em;}
  .gs-portfolio-controls{top:10px;right:10px;padding:6px 10px;gap:10px;font-size:8.5px;}
  .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;}
  .quick-stats-num{font-size:20px;}
  .nav-drawer-link{font-size:32px;}
  .opener-num{font-size:28px;}
}
