/* =============================================================
   LA JUNTA · RÍO PALENA — BKS PATAGONIA
   v3 · Editorial luxury · Aman / Rosewood / Explora tier
   ============================================================= */

:root{
  --black:   #0a0b0c;
  --black-2: #0f1011;
  --black-3: #16181a;
  --line:    rgba(255,255,255,.07);
  --line-2:  rgba(255,255,255,.13);
  --text:    #ecebe6;
  --text-dim:#a6a49d;
  --text-mute:#6c6a64;
  --gold:    #c3a35f;
  --gold-soft:#d8be8c;
  --purple:  #7a5cff;
  --purple-2:#5a3eff;
  --purple-glow:rgba(122,92,255,.30);
  --turquoise:#5fd8c4;
  --forest:  #6fae6a;

  --serif:"Cormorant Garamond","Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;

  --max:1340px;
  --gutter:clamp(24px,5vw,90px);
  --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --eo:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--sans); font-weight:300; color:var(--text);
  background:var(--black); line-height:1.7;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; overflow-x:hidden;
}
body.is-locked{ overflow:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:#000; }
.container{ max-width:var(--max); margin:0 auto; padding:0 var(--gutter); }

/* ---- FILM GRAIN ---- */
.grain{
  position:fixed; inset:-150%; z-index:9000; pointer-events:none; opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 8s steps(6) infinite;
}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-5%,3%)}40%{transform:translate(3%,-4%)}60%{transform:translate(-2%,5%)}80%{transform:translate(4%,2%)}100%{transform:translate(0,0)}}

/* ---- PRELOADER ---- */
.pre{ position:fixed; inset:0; z-index:10000; background:var(--black); display:flex; align-items:center; justify-content:center; transition:opacity 1.1s var(--ease), visibility 1.1s; }
.pre.is-done{ opacity:0; visibility:hidden; }
.pre__in{ text-align:center; display:flex; flex-direction:column; align-items:center; gap:18px; }
.pre__brand{ font-size:12px; letter-spacing:.46em; color:var(--text-mute); opacity:0; animation:pf .9s var(--ease) .1s forwards; }
.pre__mark{ font-family:var(--serif); font-weight:300; font-size:clamp(40px,7vw,72px); color:#fff; line-height:1; opacity:0; animation:pf 1.1s var(--ease) .25s forwards; }
.pre__bar{ width:180px; height:1px; background:var(--line-2); position:relative; overflow:hidden; margin-top:6px; }
.pre__bar span{ position:absolute; inset:0; left:-100%; background:linear-gradient(90deg,transparent,var(--gold),transparent); animation:pl 1.6s var(--ease) infinite; }
.pre__sub{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--gold); opacity:0; animation:pf .9s var(--ease) .45s forwards; }
@keyframes pf{ to{opacity:1} }
@keyframes pl{ 0%{left:-100%} 100%{left:100%} }

/* ---- NAV ---- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; padding:24px 0; transition:background .55s var(--ease), padding .55s var(--ease); }
.nav.is-scrolled{ background:rgba(10,11,12,.72); backdrop-filter:saturate(160%) blur(18px); -webkit-backdrop-filter:saturate(160%) blur(18px); padding:14px 0; border-bottom:1px solid var(--line); }
.nav__inner{ max-width:var(--max); margin:0 auto; padding:0 var(--gutter); display:flex; align-items:center; gap:32px; }
.nav__brand{ display:flex; align-items:center; gap:10px; font-size:13px; letter-spacing:.24em; font-weight:500; }
.nav__brand-mark{ color:var(--text); }
.nav__brand-sep{ width:14px; height:1px; background:var(--text-mute); }
.nav__brand-text{ color:var(--text-dim); }
.nav__links{ margin-left:auto; display:flex; gap:36px; font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; }
.nav__links a{ color:var(--text-dim); transition:color .3s; position:relative; }
.nav__links a:hover{ color:var(--text); }
.nav__links a::after{ content:""; position:absolute; left:0; right:0; bottom:-7px; height:1px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .45s var(--ease); }
.nav__links a:hover::after{ transform:scaleX(1); }
.nav__cta{ font-size:11px; letter-spacing:.2em; text-transform:uppercase; padding:11px 21px; border:1px solid var(--line-2); border-radius:var(--radius); transition:all .4s var(--ease); }
.nav__cta:hover{ background:var(--text); color:var(--black); border-color:var(--text); }
.nav__burger{ display:none; background:none; border:none; cursor:pointer; padding:8px; margin-left:auto; }
.nav__burger span{ display:block; width:24px; height:1px; background:#fff; margin:5px 0; transition:transform .3s,opacity .3s; }
.nav__burger.is-open span:nth-child(1){ transform:translateY(6px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-6px) rotate(-45deg); }
.nav__mobile{ display:none; position:fixed; inset:0; z-index:99; background:rgba(10,11,12,.98); backdrop-filter:blur(24px); flex-direction:column; align-items:center; justify-content:center; gap:24px; font-family:var(--serif); font-size:32px; font-weight:300; }
.nav__mobile.is-open{ display:flex; }
.nav__mobile a{ color:var(--text); opacity:0; transform:translateY(12px); animation:mob .5s var(--ease) forwards; }
.nav__mobile.is-open a:nth-child(1){animation-delay:.05s}.nav__mobile.is-open a:nth-child(2){animation-delay:.1s}.nav__mobile.is-open a:nth-child(3){animation-delay:.15s}.nav__mobile.is-open a:nth-child(4){animation-delay:.2s}.nav__mobile.is-open a:nth-child(5){animation-delay:.25s}.nav__mobile.is-open a:nth-child(6){animation-delay:.3s}.nav__mobile.is-open a:nth-child(7){animation-delay:.35s}
@keyframes mob{ to{opacity:1;transform:translateY(0)} }
.nav__mobile a:hover{ color:var(--gold); }
.nav__mobile-cta{ margin-top:18px; font-family:var(--sans); font-size:12px; letter-spacing:.2em; text-transform:uppercase; padding:14px 28px; border:1px solid var(--gold); color:var(--gold)!important; }

/* ---- HERO ---- */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:flex-end; padding:0 0 max(90px,11vh); overflow:hidden; }
.hero__slides{ position:absolute; inset:0; background:#0a0b0c url('../img/hero/hero-1.jpg') center/cover no-repeat; }
.hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; opacity:0; transition:opacity 1.4s cubic-bezier(.16,1,.3,1); }
.hero__video.is-on{ opacity:1; }
.hero__slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transform:scale(1.08); transition:opacity 1.8s var(--ease); }
.hero__slide.is-active{ opacity:1; animation:kb 9s linear forwards; }
@keyframes kb{ from{transform:scale(1.08)} to{transform:scale(1)} }
.hero__veil{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,11,12,.5) 0%,rgba(10,11,12,0) 22%,rgba(10,11,12,0) 48%,rgba(10,11,12,.9) 100%),linear-gradient(90deg,rgba(10,11,12,.5) 0%,rgba(10,11,12,0) 58%); }
.hero__content{ position:relative; z-index:2; max-width:var(--max); margin:0 auto; padding:0 var(--gutter); width:100%; }
.hero__eyebrow{ display:flex; align-items:center; gap:11px; font-size:12px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); margin-bottom:28px; }
.hero__eyebrow .dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); box-shadow:0 0 12px var(--gold); animation:pulse 2.4s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
.hero__title{ font-family:var(--serif); font-weight:300; line-height:.98; margin:0 0 30px; letter-spacing:-.01em; }
.hero__title span{ display:block; font-size:clamp(44px,7.4vw,118px); color:#fff; text-shadow:0 4px 50px rgba(0,0,0,.4); }
.hero__lead{ font-family:var(--serif); font-size:clamp(19px,2.1vw,27px); font-weight:300; font-style:italic; color:var(--text); max-width:660px; margin:0 0 40px; line-height:1.45; }
.hero__cta-row{ display:flex; gap:14px; flex-wrap:wrap; }
.reveal-hero{ opacity:0; transform:translateY(28px); }
.hero.is-ready .reveal-hero{ animation:hr 1.2s var(--eo) forwards; }
.hero.is-ready .reveal-hero[data-d="1"]{animation-delay:.1s}.hero.is-ready .reveal-hero[data-d="2"]{animation-delay:.28s}.hero.is-ready .reveal-hero[data-d="3"]{animation-delay:.44s}.hero.is-ready .reveal-hero[data-d="4"]{animation-delay:.66s}.hero.is-ready .reveal-hero[data-d="5"]{animation-delay:.88s}
@keyframes hr{ to{opacity:1;transform:translateY(0)} }
.hero__scroll{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:10px; z-index:2; font-size:10px; letter-spacing:.4em; color:var(--text-dim); }
.hero__scroll i{ width:1px; height:54px; background:var(--text-dim); position:relative; overflow:hidden; }
.hero__scroll i::after{ content:""; position:absolute; left:0; top:-50%; width:1px; height:50%; background:#fff; animation:sd 2.2s ease-in-out infinite; }
@keyframes sd{ 0%{top:-50%} 100%{top:100%} }
.hero__dots{ position:absolute; right:var(--gutter); bottom:32px; z-index:3; display:flex; gap:10px; }
.hero__dots button{ width:32px; height:2px; background:rgba(255,255,255,.3); border:none; cursor:pointer; padding:0; transition:background .4s; }
.hero__dots button.is-active{ background:var(--gold); }

/* ---- BUTTONS ---- */
.btn{ display:inline-flex; align-items:center; justify-content:center; font-family:var(--sans); font-size:12px; letter-spacing:.22em; text-transform:uppercase; padding:18px 36px; border-radius:var(--radius); cursor:pointer; transition:all .4s var(--ease); border:1px solid transparent; white-space:nowrap; }
.btn--primary{ background:linear-gradient(135deg,var(--purple),var(--purple-2)); color:#fff; box-shadow:0 8px 30px var(--purple-glow); }
.btn--primary:hover{ transform:translateY(-2px); box-shadow:0 16px 44px var(--purple-glow); }
.btn--ghost{ background:transparent; color:var(--text); border-color:var(--line-2); }
.btn--ghost:hover{ background:#fff; color:var(--black); border-color:#fff; }
.btn--full{ width:100%; }

/* ---- OVERTURE ---- */
.overture{ padding:clamp(120px,20vh,240px) 0; text-align:center; background:var(--black); }
.overture__line{ font-family:var(--serif); font-weight:300; font-size:clamp(30px,5vw,62px); line-height:1.2; color:var(--text); margin:0 auto; max-width:1000px; letter-spacing:-.005em; }
.overture__line em{ font-style:italic; color:var(--gold); }
.overture__meta{ margin-top:48px; display:flex; gap:32px; justify-content:center; flex-wrap:wrap; font-size:11px; letter-spacing:.28em; text-transform:uppercase; color:var(--text-mute); }
.overture__meta span{ position:relative; }
.overture__meta span:not(:last-child)::after{ content:"·"; position:absolute; right:-18px; color:var(--gold); }

/* ---- EDITORIAL (alternating) ---- */
.ed{ display:grid; grid-template-columns:1fr 1fr; align-items:stretch; min-height:88vh; }
.ed--reverse .ed__media{ order:2; }
.ed__media{ position:relative; overflow:hidden; min-height:60vh; background:#0c0c0c; }
.ed__ph{ position:absolute; inset:0; background:linear-gradient(110deg,#111 30%,#1a1a1a 50%,#111 70%); background-size:200% 100%; animation:shim 1.6s linear infinite; }
@keyframes shim{ 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.ed__media img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transform:scale(1.06); transition:opacity 1.1s var(--ease), transform 7s var(--ease); filter:brightness(.95); }
.ed__media img.is-loaded{ opacity:1; transform:scale(1); }
.ed__text{ display:flex; flex-direction:column; justify-content:center; padding:clamp(48px,8vw,120px); }
.ed--reverse .ed__text{ order:1; }
.ed__num{ font-family:var(--serif); font-size:15px; letter-spacing:.4em; color:var(--gold); margin-bottom:8px; }
.ed__eyebrow{ font-size:11px; letter-spacing:.36em; text-transform:uppercase; color:var(--text-mute); margin-bottom:26px; }
.ed__text h2{ font-family:var(--serif); font-weight:300; font-size:clamp(36px,4.4vw,66px); line-height:1.04; margin:0 0 28px; letter-spacing:-.01em; color:#fff; }
.ed__text p{ font-size:clamp(15px,1.15vw,17.5px); color:var(--text-dim); line-height:1.85; margin:0 0 20px; max-width:30em; }
.ed__facts{ display:flex; gap:40px; margin-top:24px; padding-top:28px; border-top:1px solid var(--line); }
.ed__facts strong{ display:block; font-family:var(--serif); font-weight:400; font-size:34px; color:var(--text); line-height:1; }
.ed__facts span{ font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-mute); margin-top:8px; display:block; }
.ed__list{ list-style:none; margin:18px 0 0; padding:0; }
.ed__list li{ display:flex; gap:18px; align-items:baseline; padding:16px 0; border-bottom:1px solid var(--line); font-size:15.5px; color:var(--text-dim); }
.ed__list li:last-child{ border-bottom:none; }
.ed__list li span{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--gold); min-width:28px; }

/* ---- IMMERSIVE DIVIDER ---- */
.immersive{ position:relative; min-height:84vh; background-size:cover; background-position:center; background-attachment:fixed; display:flex; align-items:center; padding:120px 0; overflow:hidden; }
.immersive--tall{ min-height:92vh; }
.immersive--cierre{ min-height:80vh; }
.immersive__veil{ position:absolute; inset:0; background:linear-gradient(90deg,rgba(10,11,12,.82) 0%,rgba(10,11,12,.35) 60%,rgba(10,11,12,.1) 100%); }
.immersive__veil--soft{ background:linear-gradient(270deg,rgba(10,11,12,.84) 0%,rgba(10,11,12,.3) 60%,rgba(10,11,12,.05) 100%); }
.immersive__veil--strong{ background:radial-gradient(ellipse at center,rgba(10,11,12,.42) 0%,rgba(10,11,12,.9) 92%); }
.immersive__content{ position:relative; z-index:2; max-width:760px; margin:0 auto; padding:0 var(--gutter); width:100%; }
.immersive__content--right{ margin-left:auto; text-align:right; }
.immersive__content--center{ text-align:center; margin:0 auto; }
.immersive__eyebrow{ font-size:11px; letter-spacing:.38em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; display:inline-block; }
.immersive h3{ font-family:var(--serif); font-weight:300; font-size:clamp(34px,5vw,64px); line-height:1.06; margin:0 0 18px; color:#fff; letter-spacing:-.01em; }
.immersive p{ font-family:var(--serif); font-style:italic; font-size:clamp(17px,1.5vw,23px); color:var(--text-dim); max-width:580px; margin:0; }
.immersive__content--right p{ margin-left:auto; }
.immersive__content--center p{ margin:0 auto; }

/* ---- SECTION HEAD ---- */
.shead{ margin-bottom:64px; max-width:820px; }
.shead--center{ margin-left:auto; margin-right:auto; text-align:center; }
.shead__eyebrow{ font-size:11px; letter-spacing:.38em; text-transform:uppercase; color:var(--gold); margin-bottom:22px; display:inline-block; }
.shead h2{ font-family:var(--serif); font-weight:300; font-size:clamp(36px,5.2vw,64px); line-height:1.05; margin:0 0 20px; letter-spacing:-.01em; }
.shead__lead{ font-family:var(--serif); font-style:italic; font-size:clamp(17px,1.5vw,22px); color:var(--text-dim); max-width:640px; margin:0; }
.shead--center .shead__lead{ margin:0 auto; }

/* ---- FILM ---- */
.film{ padding:clamp(100px,15vh,180px) 0; background:radial-gradient(ellipse at center bottom,rgba(122,92,255,.05),transparent 60%),var(--black); }
.video-frame{ position:relative; margin:0; aspect-ratio:16/9; background:#000; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:0 50px 110px rgba(0,0,0,.6); }
.video-frame__embed{ position:absolute; inset:0; display:none; }
.video-frame__embed iframe{ width:100%; height:100%; border:0; }
.video-frame__embed.is-active{ display:block; }
.video-play{ position:absolute; inset:0; background:none; border:none; padding:0; cursor:pointer; color:#fff; overflow:hidden; z-index:2; transition:opacity .6s var(--ease), transform .6s var(--ease); }
.video-play.is-hidden{ opacity:0; pointer-events:none; transform:scale(1.015); }
.video-play__bg{ position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.04); transition:transform 1.4s var(--ease),filter .5s; filter:brightness(.8); }
.video-play:hover .video-play__bg{ transform:scale(1); filter:brightness(.95); }
.video-play__veil{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,.2) 0%,rgba(0,0,0,.55) 100%); }
.video-play__content{ position:relative; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; }
.video-play__content svg{ width:92px; height:92px; filter:drop-shadow(0 6px 30px rgba(0,0,0,.6)); transition:transform .45s var(--ease); }
.video-play:hover .video-play__content svg{ transform:scale(1.08); }
.video-play__eyebrow{ font-size:11px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); }
.video-play__title{ font-family:var(--serif); font-weight:300; font-size:clamp(26px,4vw,40px); color:#fff; }

/* ---- INVEST ---- */
.invest{ padding:clamp(100px,15vh,180px) 0; background:linear-gradient(180deg,var(--black) 0%,var(--black-2) 100%); }
.invest__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line); border-left:1px solid var(--line); margin-bottom:80px; }
.ipanel{ padding:46px 34px 52px; border-right:1px solid var(--line); border-bottom:1px solid var(--line); transition:background .5s var(--ease); }
.ipanel:hover{ background:rgba(122,92,255,.035); }
.ipanel__num{ font-family:var(--serif); font-size:14px; letter-spacing:.2em; color:var(--gold); margin-bottom:40px; }
.ipanel h4{ font-family:var(--serif); font-weight:400; font-size:25px; margin:0 0 14px; color:#fff; }
.ipanel p{ margin:0; font-size:14.5px; color:var(--text-dim); line-height:1.75; }
.thesis{ max-width:980px; margin:0 auto; text-align:center; }
.thesis__q p{ font-family:var(--serif); font-weight:300; font-style:italic; font-size:clamp(24px,3.2vw,40px); line-height:1.35; color:var(--text); margin:0 0 28px; }
.thesis__by{ font-size:12px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); }

/* ---- MAP EXPERIENCE ---- */
.mapx{ padding:clamp(100px,15vh,180px) 0 clamp(60px,8vh,90px); background:var(--black-2); }
.mapx__stage{ position:relative; width:100%; height:min(82vh,780px); overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#0c0c0c; margin-top:8px; }
.mapx__img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; transition:opacity 1.1s var(--ease); }
.mapx__img.is-loaded{ opacity:1; }
.mapx__ph{ position:absolute; inset:0; }
.mapx__veil{ position:absolute; inset:0; background:radial-gradient(ellipse at center,transparent 40%,rgba(10,11,12,.5) 100%); pointer-events:none; }
.hot{ position:absolute; transform:translate(-50%,-50%); background:none; border:none; cursor:pointer; z-index:3; padding:0; }
.hot__dot{ display:block; width:14px; height:14px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 0 rgba(195,163,95,.5); position:relative; }
.hot__dot::after{ content:""; position:absolute; inset:-8px; border:1px solid rgba(195,163,95,.5); border-radius:50%; animation:hotPulse 2.4s var(--ease) infinite; }
@keyframes hotPulse{ 0%{transform:scale(.6);opacity:1} 100%{transform:scale(1.6);opacity:0} }
.hot__card{ position:absolute; left:50%; bottom:calc(100% + 14px); transform:translateX(-50%) translateY(8px); min-width:200px; padding:16px 20px; background:rgba(16,18,20,.7); backdrop-filter:blur(16px) saturate(160%); -webkit-backdrop-filter:blur(16px) saturate(160%); border:1px solid rgba(255,255,255,.14); border-radius:4px; opacity:0; visibility:hidden; transition:opacity .4s var(--ease),transform .4s var(--ease); pointer-events:none; box-shadow:0 20px 50px rgba(0,0,0,.5); }
.hot__card::after{ content:""; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:7px solid transparent; border-top-color:rgba(16,18,20,.7); }
.hot__card strong{ display:block; font-family:var(--serif); font-weight:500; font-size:18px; color:#fff; margin-bottom:4px; }
.hot__card em{ font-style:normal; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.hot:hover .hot__card, .hot:focus-visible .hot__card, .hot.is-open .hot__card{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.hot:hover .hot__dot, .hot.is-open .hot__dot{ background:#fff; }
.mapx__facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-bottom:1px solid var(--line); margin-top:0; }
.mapx__facts > div{ padding:40px 24px 40px 0; border-right:1px solid var(--line); }
.mapx__facts > div:last-child{ border-right:none; }
.mapx__facts > div:nth-child(n+2){ padding-left:32px; }
.mapx__n{ font-family:var(--serif); font-weight:300; font-size:clamp(30px,3vw,46px); color:var(--text); margin-bottom:8px; letter-spacing:-.01em; }
.mapx__l{ font-size:13px; color:var(--text-dim); letter-spacing:.02em; }
.mapx__link{ margin-top:24px; }
.mapx__link a{ font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); transition:color .3s; }
.mapx__link a:hover{ color:#fff; }

/* ---- GALERIA ---- */
.galeria{ padding:clamp(100px,15vh,180px) 0; background:var(--black); }
.grid-gallery{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:200px; gap:8px; }
.g{ position:relative; overflow:hidden; cursor:pointer; border-radius:var(--radius); background:#0c0c0c; }
.g__ph{ position:absolute; inset:0; background:linear-gradient(110deg,#111 30%,#1a1a1a 50%,#111 70%); background-size:200% 100%; animation:shim 1.6s linear infinite; }
.g img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s var(--ease),filter .5s,opacity .8s var(--ease); filter:brightness(.92) saturate(1.05); opacity:0; }
.g img.is-loaded{ opacity:1; }
.g::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 58%,rgba(0,0,0,.42)); opacity:.5; transition:opacity .5s; pointer-events:none; }
.g:hover img{ transform:scale(1.07); filter:brightness(1) saturate(1.15); }
.g:hover::after{ opacity:.2; }
.g--xl{ grid-column:span 8; grid-row:span 3; }
.g--lg{ grid-column:span 6; grid-row:span 2; }
.g--md{ grid-column:span 4; grid-row:span 2; }

/* ---- STOCK ---- */
.dot{ display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:9px; vertical-align:middle; transform:translateY(-1px); }
.dot--gold{ background:var(--gold); box-shadow:0 0 8px rgba(195,163,95,.5); }
.dot--turquoise{ background:var(--turquoise); }
.dot--forest{ background:var(--forest); }
.stock{ padding:clamp(100px,15vh,180px) 0; background:var(--black); }
.stock-legend{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin:0 0 48px; }
.stock-legend__item{ display:flex; gap:14px; padding:26px 24px; background:rgba(255,255,255,.02); border:1px solid var(--line); border-radius:var(--radius); }
.stock-legend__item .dot{ margin-top:7px; flex-shrink:0; }
.stock-legend__item strong{ display:block; font-family:var(--serif); font-weight:500; font-size:18px; color:#fff; margin-bottom:6px; }
.stock-legend__item span{ display:block; font-size:13px; color:var(--text-dim); line-height:1.55; margin-bottom:8px; }
.stock-legend__item em{ font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); font-style:normal; }
.stock-filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.stock-chip{ font-family:var(--sans); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-dim); background:transparent; border:1px solid var(--line); border-radius:40px; padding:11px 20px; cursor:pointer; transition:all .3s var(--ease); display:inline-flex; align-items:center; }
.stock-chip:hover{ color:var(--text); border-color:var(--line-2); }
.stock-chip.is-active{ background:var(--gold); color:#000; border-color:var(--gold); }
.stock-chip.is-active .dot{ display:none; }
.stock-table-wrap{ overflow-x:auto; border:1px solid var(--line); border-radius:var(--radius); -webkit-overflow-scrolling:touch; }
.stock-table{ width:100%; border-collapse:collapse; min-width:680px; }
.stock-table thead th{ text-align:left; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-mute); font-weight:500; padding:20px 22px; border-bottom:1px solid var(--line); background:rgba(255,255,255,.015); }
.stock-table td{ padding:18px 22px; font-size:14.5px; color:var(--text-dim); border-bottom:1px solid var(--line); white-space:nowrap; }
.stock-table tbody tr{ transition:background .3s; }
.stock-table tbody tr:last-child td{ border-bottom:none; }
.stock-table tbody tr:hover{ background:rgba(122,92,255,.04); }
.stock-table td:first-child{ font-family:var(--serif); font-size:18px; color:var(--text); }
.stock-table td strong{ color:#fff; font-weight:500; font-size:16px; }
.stock-table tr.is-hidden{ display:none; }
.badge{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; padding:5px 11px; border-radius:30px; }
.badge--ok{ color:var(--forest); background:rgba(111,174,106,.1); border:1px solid rgba(111,174,106,.25); }
.badge--off{ color:var(--text-mute); background:rgba(255,255,255,.03); border:1px solid var(--line); }
.stock-notes{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin:48px 0 40px; }
.stock-note h5{ font-family:var(--serif); font-weight:500; font-size:17px; color:#fff; margin:0 0 10px; }
.stock-note p{ font-size:13.5px; color:var(--text-dim); line-height:1.65; margin:0; }
.stock-cta{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }

/* ---- TOUR ---- */
.tour{ padding:clamp(100px,15vh,180px) 0 0; background:var(--black-2); }
.tour360{ margin:48px 0 0; }
.tour360__frame{ position:relative; width:100%; height:min(80vh,760px); background:#000; overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.tour360__frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.tour360__loader{ position:absolute; inset:0; border:none; padding:0; cursor:pointer; color:#fff; z-index:5; overflow:hidden; transition:opacity .6s var(--ease),transform .6s var(--ease); }
.tour360__loader.is-hidden{ opacity:0; pointer-events:none; transform:scale(1.02); }
.tour360__loader-bg{ position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.06); transition:transform 1.2s var(--ease); }
.tour360__loader:hover .tour360__loader-bg{ transform:scale(1); }
.tour360__loader-veil{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,11,12,.5) 0%,rgba(10,11,12,.62) 100%); backdrop-filter:blur(2px); }
.tour360__loader-content{ position:relative; width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:18px; padding:24px; text-align:center; }
.tour360__loader-content svg{ width:78px; height:78px; color:var(--gold); filter:drop-shadow(0 4px 24px rgba(0,0,0,.5)); animation:spin 20s linear infinite; }
@keyframes spin{ from{transform:rotate(0)} to{transform:rotate(360deg)} }
.tour360__loader-eyebrow{ font-size:11px; letter-spacing:.36em; text-transform:uppercase; color:var(--gold); }
.tour360__loader-title{ font-family:var(--serif); font-weight:300; font-size:clamp(28px,4vw,46px); color:#fff; }
.tour360__loader-hint{ font-size:12px; letter-spacing:.2em; color:var(--text-dim); text-transform:uppercase; }
.tour360__actions{ display:flex; justify-content:center; padding:20px var(--gutter) 0; max-width:var(--max); margin:0 auto; }
.tour360__open{ display:inline-flex; align-items:center; gap:10px; font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--text-dim); padding:14px 24px; border:1px solid var(--line); border-radius:var(--radius); transition:all .35s var(--ease); }
.tour360__open:hover{ color:#fff; border-color:var(--gold); }
.tour360__open svg{ width:14px; height:14px; color:var(--gold); }

/* ---- CONTACTO ---- */
.contacto{ padding:clamp(100px,15vh,180px) 0; background:radial-gradient(ellipse at top,rgba(122,92,255,.08),transparent 60%),var(--black); }
.contacto__inner{ max-width:780px; margin:0 auto; text-align:center; }
.contacto h2{ font-family:var(--serif); font-weight:300; font-size:clamp(36px,5.2vw,60px); line-height:1.06; margin:0 0 20px; }
.contacto h2 em{ font-style:italic; color:var(--gold); }
.contacto__lead{ font-family:var(--serif); font-style:italic; font-size:clamp(17px,1.4vw,21px); color:var(--text-dim); max-width:580px; margin:0 auto 48px; }
.form{ text-align:left; display:flex; flex-direction:column; gap:20px; }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form label{ display:flex; flex-direction:column; gap:8px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--text-dim); }
.form__full{ width:100%; }
.form input,.form select,.form textarea{ font-family:var(--sans); font-size:15px; color:var(--text); background:rgba(255,255,255,.02); border:1px solid var(--line); border-radius:var(--radius); padding:14px 16px; transition:border-color .3s,background .3s; text-transform:none; letter-spacing:0; }
.form input:focus,.form select:focus,.form textarea:focus{ outline:none; border-color:var(--purple); background:rgba(122,92,255,.04); }
.form select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236c6a64' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 16px center; padding-right:40px; }
.form textarea{ resize:vertical; min-height:90px; }
.form__legal{ font-size:11px; color:var(--text-mute); text-align:center; margin:4px 0 0; }
.contacto__alt{ margin-top:36px; display:flex; gap:14px; justify-content:center; align-items:center; flex-wrap:wrap; font-size:13px; color:var(--text-mute); }
.contacto__mail{ color:var(--gold); transition:color .3s; }
.contacto__mail:hover{ color:#fff; }

/* ---- FOOTER ---- */
.footer{ padding:64px 0 32px; border-top:1px solid var(--line); background:var(--black); }
.footer__inner{ display:grid; grid-template-columns:1.3fr 2fr; gap:60px; }
.footer__brand p{ font-size:14px; color:var(--text-dim); max-width:340px; line-height:1.6; margin:14px 0 0; }
.footer__logo{ font-size:16px; letter-spacing:.22em; color:var(--text); }
.footer__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.footer__cols h6{ font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:var(--gold); margin:0 0 18px; }
.footer__cols a,.footer__small{ display:block; font-size:14px; color:var(--text-dim); margin-bottom:10px; transition:color .3s; }
.footer__cols a:hover{ color:#fff; }
.footer__small{ color:var(--text-mute); }

/* ---- LIGHTBOX ---- */
.lightbox{ position:fixed; inset:0; z-index:1000; background:rgba(10,11,12,.97); backdrop-filter:blur(16px); display:none; align-items:center; justify-content:center; padding:60px 80px; }
.lightbox.is-open{ display:flex; }
.lightbox__figure{ margin:0; max-width:100%; max-height:100%; display:flex; flex-direction:column; align-items:center; animation:lbIn .6s var(--eo); }
@keyframes lbIn{ from{opacity:0;transform:scale(.97)} to{opacity:1;transform:scale(1)} }
.lightbox__figure img{ max-width:100%; max-height:80vh; object-fit:contain; border-radius:var(--radius); box-shadow:0 30px 100px rgba(0,0,0,.6); }
.lightbox__figure figcaption{ margin-top:18px; font-family:var(--serif); font-style:italic; font-size:16px; color:var(--text-dim); letter-spacing:.04em; }
.lightbox__close,.lightbox__nav{ position:absolute; background:none; cursor:pointer; color:#fff; font-size:36px; width:56px; height:56px; display:flex; align-items:center; justify-content:center; border:1px solid rgba(255,255,255,.12); border-radius:50%; transition:background .3s,border-color .3s; }
.lightbox__close:hover,.lightbox__nav:hover{ background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.3); }
.lightbox__close{ top:24px; right:24px; font-size:32px; }
.lightbox__nav--prev{ left:24px; top:50%; transform:translateY(-50%); }
.lightbox__nav--next{ right:24px; top:50%; transform:translateY(-50%); }
.lightbox__counter{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); font-size:12px; letter-spacing:.32em; color:var(--text-mute); }

/* ---- REVEAL ---- */
.reveal{ opacity:0; transform:translateY(32px); transition:opacity 1.1s var(--eo),transform 1.1s var(--eo); }
.reveal.is-in{ opacity:1; transform:translateY(0); }

/* ---- RESPONSIVE ---- */
@media (max-width:980px){
  .nav__links,.nav__cta{ display:none; }
  .nav__burger{ display:block; }
  .overture__line{ font-size:clamp(26px,6vw,40px); }
  .ed{ grid-template-columns:1fr; min-height:0; }
  .ed--reverse .ed__media{ order:0; }
  .ed--reverse .ed__text{ order:0; }
  .ed__media{ min-height:62vh; }
  .ed__text{ padding:clamp(40px,9vw,70px) var(--gutter); }
  .invest__grid{ grid-template-columns:1fr 1fr; }
  .grid-gallery{ grid-template-columns:repeat(6,1fr); grid-auto-rows:150px; }
  .g--xl{ grid-column:span 6; grid-row:span 3; }
  .g--lg{ grid-column:span 6; grid-row:span 2; }
  .g--md{ grid-column:span 3; grid-row:span 2; }
  .stock-legend,.stock-notes{ grid-template-columns:1fr; }
  .mapx__facts{ grid-template-columns:1fr 1fr; }
  .mapx__facts > div:nth-child(2n){ border-right:none; }
  .mapx__facts > div{ padding:28px 20px; }
  .mapx__facts > div:nth-child(n+2){ padding-left:20px; }
  .footer__inner{ grid-template-columns:1fr; gap:40px; }
  .immersive{ background-attachment:scroll; min-height:62vh; padding:90px 0; }
  .immersive--tall{ min-height:72vh; }
  .immersive__content--right{ text-align:left; }
  .immersive__content--right p{ margin-left:0; }
  .tour360__frame{ height:68vh; }
  .mapx__stage{ height:62vh; }
  .lightbox{ padding:20px 12px; }
  .lightbox__close{ top:12px; right:12px; }
  .lightbox__nav--prev{ left:8px; }
  .lightbox__nav--next{ right:8px; }
  .hero__dots{ display:none; }
  .hot__card{ min-width:160px; padding:12px 16px; }
}

@media (max-width:640px){
  .hero{ padding-bottom:70px; }
  .hero__lead{ font-size:17px; }
  .hero__cta-row{ flex-direction:column; }
  .btn{ width:100%; }
  .invest__grid{ grid-template-columns:1fr; }
  .ed__facts{ gap:24px; flex-wrap:wrap; }
  .form__row{ grid-template-columns:1fr; }
  .grid-gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:150px; }
  .g--xl,.g--lg,.g--md{ grid-column:span 2; grid-row:span 2; }
  .g--xl{ grid-row:span 3; }
  .mapx__facts{ grid-template-columns:1fr; }
  .mapx__facts > div{ border-right:none; }
  .footer__cols{ grid-template-columns:1fr; gap:24px; }
  .stock-cta{ flex-direction:column; }
  .overture__meta{ gap:24px; }
  .overture__meta span:not(:last-child)::after{ display:none; }
  .tour360__loader-content svg{ width:56px; height:56px; }
  .tour360__loader-title{ font-size:26px; }
  .video-play__content svg{ width:62px; height:62px; }
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  .hero__slide.is-active{ animation:none; }
}

:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:2px; }
