  :root{
    --paper:#FAF8F5;
    --paper-2:#F1EEE8;
    --ink:#16171A;
    --ink-soft:#3A3B3E;
    --ink-mute:#86858230;
    --line:#1617171A;
    --bronze:#9A7B4F;
    --bronze-soft:#B79B73;
    --shadow:0 30px 80px -40px rgba(20,21,23,.45);
    --ease:cubic-bezier(.22,.61,.36,1);
    --maxw:1280px;
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--paper);
    color:var(--ink);
    font-family:'Manrope',system-ui,sans-serif;
    font-weight:400;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  ::selection{background:var(--ink);color:var(--paper);}
  img{display:block;max-width:100%;}
  a{color:inherit;text-decoration:none;}

  /* ---------- Typography ---------- */
  .serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;}
  .eyebrow{
    font-size:.72rem;
    font-weight:600;
    letter-spacing:.32em;
    text-transform:uppercase;
    color:var(--bronze);
    display:inline-flex;align-items:center;gap:.7em;
  }
  .eyebrow::before{
    content:"";width:1.6rem;height:1px;background:var(--bronze-soft);display:inline-block;
  }
  .eyebrow.center::after{
    content:"";width:1.6rem;height:1px;background:var(--bronze-soft);display:inline-block;
  }
  h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;line-height:1.04;letter-spacing:-.01em;}
  p{text-wrap:pretty;}

  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.4rem,5vw,4rem);}
  section{position:relative;}

  /* ---------- Reveal animation ---------- */
  .reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease);}
  .reveal.in{opacity:1;transform:none;}
  .reveal.d1{transition-delay:.08s;}
  .reveal.d2{transition-delay:.16s;}
  .reveal.d3{transition-delay:.24s;}
  .reveal.d4{transition-delay:.32s;}
  @media (prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;}}

  /* ---------- Top bar ---------- */
  header.bar{
    position:fixed;top:0;left:0;right:0;z-index:50;
    display:flex;align-items:center;justify-content:space-between;
    padding:1.5rem clamp(1.4rem,5vw,4rem);
    transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
    mix-blend-mode:normal;
  }
  header.bar .brand{
    font-family:'Cormorant Garamond',serif;font-size:1.4rem;letter-spacing:.02em;color:#fff;
    transition:color .5s var(--ease);display:flex;align-items:baseline;gap:.6rem;
  }
  header.bar .brand b{font-weight:500;}
  header.bar .brand .tag{
    font-family:'Manrope',sans-serif;font-size:.6rem;font-weight:600;letter-spacing:.28em;
    text-transform:uppercase;opacity:.7;
  }
  header.bar .nav{display:flex;align-items:center;gap:2.2rem;}
  header.bar .nav a{
    font-size:.78rem;font-weight:500;letter-spacing:.08em;color:#fff;opacity:.82;
    transition:color .5s var(--ease),opacity .3s;text-transform:uppercase;
  }
  header.bar .nav a:hover{opacity:1;}
  header.bar.scrolled{background:rgba(250,248,245,.86);backdrop-filter:blur(18px);padding-top:1rem;padding-bottom:1rem;box-shadow:0 1px 0 var(--line);}
  header.bar.scrolled .brand,header.bar.scrolled .nav a{color:var(--ink);}
  .nav-wpp{
    display:inline-flex!important;align-items:center;gap:.5rem;
    border:1px solid rgba(255,255,255,.5);border-radius:100px;padding:.55rem 1.1rem!important;
    opacity:1!important;transition:all .4s var(--ease);
  }
  .nav-wpp:hover{background:#fff;color:var(--ink)!important;border-color:#fff;}
  header.bar.scrolled .nav-wpp{border-color:var(--line);}
  header.bar.scrolled .nav-wpp:hover{background:var(--ink);color:var(--paper)!important;}
  @media(max-width:860px){header.bar .nav a:not(.nav-wpp){display:none;}}

  /* ---------- Hero ---------- */
  .hero{height:100svh;min-height:640px;position:relative;display:flex;align-items:flex-end;overflow:hidden;}
  .hero-img{position:absolute;inset:0;}
  .hero-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 14s var(--ease) forwards;}
  .hero-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.1s var(--ease);transform:scale(1.06);}
  .hero-vid.is-active{opacity:1;animation:heroZoom 12s var(--ease) forwards;}
  @keyframes heroZoom{to{transform:scale(1);}}
  .hero-progress{position:absolute;top:0;left:0;right:0;z-index:4;display:flex;gap:6px;padding:5.6rem clamp(1.4rem,5vw,4rem) 0;}
  .hero-progress .pg{flex:1;height:2px;background:rgba(255,255,255,.28);overflow:hidden;border-radius:2px;}
  .hero-progress .pg i{display:block;height:100%;width:0;background:rgba(255,255,255,.95);}
  .hero-progress .pg.done i{width:100%;}
  .hero-progress .pg.active i{animation:pgFill linear forwards;}
  @keyframes pgFill{from{width:0;}to{width:100%;}}
  .hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,16,18,.42) 0%,rgba(15,16,18,.12) 32%,rgba(15,16,18,.18) 62%,rgba(15,16,18,.82) 100%);}
  .hero-content{position:relative;z-index:2;width:100%;padding-bottom:clamp(2.6rem,6vh,5rem);color:#fff;}
  .hero-content .eyebrow{color:#E9D9BE;}
  .hero-content .eyebrow::before{background:#E9D9BE;}
  .hero h1{font-size:clamp(3.2rem,9vw,7.6rem);font-weight:300;color:#fff;margin:.7rem 0 .3rem;letter-spacing:-.02em;}
  .hero h1 em{font-style:italic;font-weight:300;}
  .hero .sub{font-size:clamp(1rem,1.5vw,1.18rem);font-weight:400;color:rgba(255,255,255,.88);max-width:46ch;letter-spacing:.01em;}
  .hero-meta{display:flex;flex-wrap:wrap;gap:2.6rem;align-items:flex-end;margin-top:2.4rem;}
  .hero-price{display:flex;flex-direction:column;gap:.1rem;}
  .hero-price .l{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:600;}
  .hero-price .v{font-family:'Cormorant Garamond',serif;font-size:clamp(1.8rem,3vw,2.4rem);color:#fff;font-weight:500;}
  .hero-price .v small{font-size:.5em;letter-spacing:.04em;opacity:.8;}
  .btn{
    display:inline-flex;align-items:center;gap:.7rem;
    font-family:'Manrope',sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.04em;
    padding:1rem 1.7rem;border-radius:100px;transition:all .4s var(--ease);cursor:pointer;border:none;
  }
  .btn-wpp{background:#fff;color:var(--ink);}
  .btn-wpp:hover{background:var(--bronze);color:#fff;transform:translateY(-2px);}
  .btn-wpp svg{width:18px;height:18px;}
  .btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--line);}
  .btn-ghost:hover{background:var(--ink);color:var(--paper);}
  .btn-dark{background:var(--ink);color:var(--paper);}
  .btn-dark:hover{background:var(--bronze);color:#fff;transform:translateY(-2px);}
  .scroll-cue{position:absolute;bottom:1.6rem;right:clamp(1.4rem,5vw,4rem);z-index:3;color:rgba(255,255,255,.7);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;display:flex;align-items:center;gap:.7rem;writing-mode:vertical-rl;}
  .scroll-cue .line{width:1px;height:48px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:cuePulse 2.2s var(--ease) infinite;}
  @keyframes cuePulse{0%,100%{opacity:.4;transform:scaleY(.7);}50%{opacity:1;transform:scaleY(1);}}

  /* ---------- Section heading ---------- */
  .sec{padding:clamp(5rem,12vh,9rem) 0;}
  .sec-head{max-width:62ch;}
  .sec-head h2{font-size:clamp(2.4rem,5.2vw,4.2rem);font-weight:300;margin:1.1rem 0 0;}
  .sec-head h2 em{font-style:italic;}
  .sec-head .lead{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--ink-soft);margin-top:1.5rem;font-weight:400;}

  /* ---------- Oportunidad (split) ---------- */
  .split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,6vw,5.5rem);align-items:center;}
  @media(max-width:880px){.split{grid-template-columns:1fr;}}
  .split-fig{position:relative;}
  .split-fig img{width:100%;height:clamp(380px,56vh,640px);object-fit:cover;}
  .split-fig .cap{position:absolute;left:1.4rem;bottom:1.4rem;background:rgba(250,248,245,.92);backdrop-filter:blur(6px);padding:.7rem 1.1rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:var(--ink-soft);}
  .stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:2.6rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
  .stats .st{background:var(--paper);padding:1.6rem .4rem 1.6rem 0;}
  .stats .st .n{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3rem);font-weight:500;line-height:1;}
  .stats .st .n small{font-size:.42em;font-weight:600;font-family:'Manrope';letter-spacing:.06em;vertical-align:super;}
  .stats .st .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:.6rem;font-weight:600;}

  /* ---------- Amenidades grid ---------- */
  .bg-ink{background:var(--ink);color:var(--paper);}
  .bg-ink .eyebrow{color:var(--bronze-soft);}
  .bg-ink .eyebrow::before,.bg-ink .eyebrow.center::after{background:var(--bronze-soft);}
  .bg-ink .sec-head .lead{color:rgba(250,248,245,.7);}
  .amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(250,248,245,.12);margin-top:3.4rem;border:1px solid rgba(250,248,245,.12);}
  @media(max-width:880px){.amen-grid{grid-template-columns:repeat(2,1fr);}}
  @media(max-width:520px){.amen-grid{grid-template-columns:1fr;}}
  .amen{background:var(--ink);padding:2.4rem 2rem 2.6rem;transition:background .5s var(--ease);position:relative;min-height:200px;display:flex;flex-direction:column;}
  .amen:hover{background:#1F2024;}
  .amen .ic{width:30px;height:30px;color:var(--bronze-soft);margin-bottom:1.6rem;}
  .amen .ic svg{width:100%;height:100%;stroke:currentColor;stroke-width:1.2;fill:none;}
  .amen h3{font-size:1.7rem;font-weight:500;color:var(--paper);}
  .amen p{font-size:.92rem;color:rgba(250,248,245,.62);margin-top:.5rem;}
  .amen .idx{position:absolute;top:1.6rem;right:1.8rem;font-size:.7rem;letter-spacing:.1em;color:rgba(250,248,245,.3);font-weight:600;}

  /* ---------- Galería ---------- */
  .gallery{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(180px,auto);gap:14px;margin-top:3.4rem;}
  .gallery figure{overflow:hidden;position:relative;background:var(--paper-2);}
  .gallery figure img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
  .gallery figure:hover img{transform:scale(1.05);}
  .g-a{grid-column:span 7;grid-row:span 2;}
  .g-b{grid-column:span 5;grid-row:span 1;}
  .g-c{grid-column:span 5;grid-row:span 1;}
  .g-d{grid-column:span 4;grid-row:span 1;}
  .g-e{grid-column:span 4;grid-row:span 1;}
  .g-f{grid-column:span 4;grid-row:span 1;}
  .g-g{grid-column:span 6;grid-row:span 1;}
  .g-h{grid-column:span 6;grid-row:span 1;}
  .g-i{grid-column:span 6;grid-row:span 1;}
  .g-j{grid-column:span 6;grid-row:span 1;}
  .g-k{grid-column:span 3;grid-row:span 1;}
  .g-l{grid-column:span 3;grid-row:span 1;}
  .g-m{grid-column:span 3;grid-row:span 1;}
  .g-n{grid-column:span 3;grid-row:span 1;}
  .g-o{grid-column:span 6;grid-row:span 1;}
  .g-p{grid-column:span 6;grid-row:span 1;}
  /* Puntos del carrusel (solo móvil) */
  .gal-dots{display:none;}
  @media(max-width:760px){
    /* La galería se convierte en carrusel horizontal con snap */
    .gallery{
      display:flex;position:relative;
      grid-template-columns:none;grid-auto-rows:auto;
      gap:12px;margin-top:2.6rem;
      overflow-x:auto;scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling:touch;scrollbar-width:none;
      scroll-padding:0 7%;
    }
    .gallery::-webkit-scrollbar{display:none;}
    .gallery figure{
      flex:0 0 86%;grid-column:auto!important;grid-row:auto!important;
      height:64vw;max-height:440px;
      scroll-snap-align:center;
      opacity:1!important;transform:none!important;
    }
    .gal-dots{display:flex;justify-content:center;flex-wrap:wrap;gap:7px;margin-top:1.2rem;}
    .gal-dots button{
      width:7px;height:7px;border-radius:50%;border:none;padding:0;cursor:pointer;
      background:var(--line);transition:width .3s var(--ease),background .3s var(--ease),border-radius .3s var(--ease);
    }
    .gal-dots button.active{background:var(--bronze);width:20px;border-radius:4px;}
  }
  /* placeholder fig */
  .ph{display:flex;align-items:center;justify-content:center;min-height:180px;background:
      repeating-linear-gradient(135deg,var(--paper-2),var(--paper-2) 10px,#E9E4DC 10px,#E9E4DC 20px);}
  .ph span{font-family:ui-monospace,'SF Mono',Menlo,monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:#9b948a;background:var(--paper);padding:.4rem .8rem;border:1px solid var(--line);}

  /* ---------- Video ---------- */
  .video-sec{padding:clamp(5rem,12vh,9rem) 0;}
  .video-shell{position:relative;margin-top:3rem;background:#0c0d0f;overflow:hidden;box-shadow:var(--shadow);}
  .video-shell video{width:100%;display:block;max-height:78vh;background:#0c0d0f;}

  /* ---------- Ficha técnica ---------- */
  .ficha{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:3rem;border-top:1px solid var(--line);}
  @media(max-width:760px){.ficha{grid-template-columns:1fr;}}
  .ficha .row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:1.25rem .4rem;border-bottom:1px solid var(--line);}
  .ficha .row:nth-child(odd){border-right:1px solid var(--line);padding-right:2.4rem;}
  @media(max-width:760px){.ficha .row:nth-child(odd){border-right:none;padding-right:.4rem;}}
  .ficha .row .k{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;}
  .ficha .row .v{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:500;text-align:right;}
  .ficha .row .v.tbd{font-family:'Manrope';font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bronze);font-weight:600;}

  /* ---------- Ubicación ---------- */
  .loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start;}
  @media(max-width:880px){.loc-grid{grid-template-columns:1fr;}}
  .loc-list{margin-top:2.4rem;}
  .loc-cat{border-top:1px solid var(--line);padding:1.6rem 0;}
  .loc-cat h4{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bronze);font-weight:600;margin-bottom:.9rem;display:flex;align-items:center;gap:.7rem;}
  .loc-cat ul{list-style:none;display:flex;flex-wrap:wrap;gap:.55rem;}
  .loc-cat li{font-size:.88rem;color:var(--ink-soft);border:1px solid var(--line);border-radius:100px;padding:.45rem 1rem;background:var(--paper);transition:all .35s var(--ease);}
  .loc-cat li:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);}
  .map-card{position:sticky;top:6rem;}
  .map-frame{width:100%;height:clamp(420px,62vh,620px);border:1px solid var(--line);filter:grayscale(1) contrast(1.04);transition:filter .6s var(--ease);}
  .map-card:hover .map-frame{filter:grayscale(0);}
  .addr-pin{display:flex;gap:.9rem;align-items:flex-start;margin-top:1.6rem;}
  .addr-pin svg{width:20px;height:20px;flex:none;color:var(--bronze);margin-top:.15rem;}
  .addr-pin .t{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500;line-height:1.2;}
  .addr-pin .s{font-size:.86rem;color:var(--ink-soft);}

  /* ---------- CTA final ---------- */
  .cta{position:relative;overflow:hidden;color:#fff;text-align:center;}
  .cta-bg{position:absolute;inset:0;}
  .cta-bg img{width:100%;height:100%;object-fit:cover;}
  .cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,16,18,.74),rgba(15,16,18,.86));}
  .cta-inner{position:relative;z-index:2;padding:clamp(6rem,15vh,11rem) 0;}
  .cta h2{font-size:clamp(2.6rem,6vw,5rem);font-weight:300;color:#fff;}
  .cta h2 em{font-style:italic;}
  .cta p{max-width:50ch;margin:1.6rem auto 0;color:rgba(255,255,255,.82);font-size:1.08rem;}
  .cta .actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:2.8rem;}

  /* ---------- Footer ---------- */
  footer{background:var(--ink);color:rgba(250,248,245,.6);padding:4rem 0 2.4rem;}
  footer .ft-top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:2rem;border-bottom:1px solid rgba(250,248,245,.12);padding-bottom:2.4rem;}
  footer .ft-brand{font-family:'Cormorant Garamond',serif;font-size:1.8rem;color:var(--paper);font-weight:400;}
  footer .ft-brand span{display:block;font-family:'Manrope';font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:var(--bronze-soft);margin-top:.4rem;font-weight:600;}
  footer .ft-links{display:flex;gap:2.4rem;flex-wrap:wrap;}
  footer .ft-col h5{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(250,248,245,.4);font-weight:600;margin-bottom:1rem;}
  footer .ft-col a,footer .ft-col p{display:block;font-size:.9rem;color:rgba(250,248,245,.78);margin-bottom:.5rem;transition:color .3s;}
  footer .ft-col a:hover{color:var(--bronze-soft);}
  footer .ft-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:2.4rem;font-size:.76rem;letter-spacing:.04em;}

  /* ---------- Floating WhatsApp ---------- */
  .float-wpp{position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:60;display:flex;align-items:center;gap:.7rem;background:#16171A;color:#fff;padding:.85rem 1.3rem .85rem 1rem;border-radius:100px;box-shadow:0 18px 40px -16px rgba(0,0,0,.5);font-size:.84rem;font-weight:600;letter-spacing:.02em;transform:translateY(140%);transition:transform .6s var(--ease),background .4s;}
  .float-wpp.show{transform:none;}
  .float-wpp:hover{background:var(--bronze);}
  .float-wpp svg{width:22px;height:22px;flex:none;}
  @media(max-width:520px){.float-wpp span{display:none;}.float-wpp{padding:.95rem;}}
