:root {
    --white: #FDFCF9;
    --black: #1C1B18;
    --gray-50: #F7F5F0;
    --gray-100: #EDE9E0;
    --gray-300: #CEC9BC;
    --gray-500: #9A9488;
    --gray-700: #5A5650;
    --accent: #B8935A;
    --accent-light: #EDE0CC;
    --beige: #F2EDE3;
    --beige-dark: #E8E0D0;
    --serif: 'Cormorant Garamond', Georgia, serif;
    --sans: 'DM Sans', sans-serif;
    --serif-num: 'Cormorant Infant', Georgia;
    --r: 4px;
    --ease: 0.35s cubic-bezier(0.4,0,0.2,1);
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--sans);background:var(--white);color:var(--black);overflow-x:hidden;-webkit-font-smoothing:antialiased}

  /* NAV */
  nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px 64px;background:rgba(250,250,248,.93);backdrop-filter:blur(14px);border-bottom:1px solid var(--gray-100);transition:padding var(--ease),box-shadow var(--ease)}
  nav.scrolled{padding:14px 64px;box-shadow:0 2px 20px rgba(0,0,0,.06)}
  .logo{font-family:var(--serif);font-size:1.3rem;font-weight:500;letter-spacing:.04em;color:var(--black);text-decoration:none;transition:opacity var(--ease)}
  .logo:hover{opacity:.75}
  .logo span{color:var(--accent)}
  .nav-links{display:flex;gap:32px;list-style:none}
  .nav-links a{font-size:.75rem;letter-spacing:.09em;text-transform:uppercase;color:var(--gray-700);text-decoration:none;transition:color var(--ease);position:relative;padding-bottom:2px}
  .nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--accent);transform:scaleX(0);transition:transform var(--ease)}
  .nav-links a:hover{color:var(--accent)}
  .nav-links a:hover::after{transform:scaleX(1)}
  .nav-btn{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;padding:11px 26px;background:var(--accent);color:var(--white);border:none;cursor:pointer;border-radius:var(--r);transition:background var(--ease),transform var(--ease);text-decoration:none}
  .nav-btn:hover{background:var(--black);transform:translateY(-1px)}
  .nav-btn:visited{color:var(--white)}
  .nav-btn:active{color:var(--white)}


  /* LABELS */
  .label{display:inline-flex;align-items:center;gap:10px;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:18px}
  .label::before{content:'';display:block;width:28px;height:1px;background:var(--accent)}
  .h2{font-family:var(--serif);font-size:clamp(2rem,3.6vw,3.4rem);font-weight:400;line-height:1.15;letter-spacing:-.01em;color:var(--black);margin-bottom:18px}
  .h2 em{font-style:italic;color:var(--accent)}
  .body-text{font-size:.92rem;line-height:1.78;color:var(--gray-700);font-weight:300;max-width:560px}

  /* BUTTONS */
  .btn{padding:14px 34px;font-family:var(--sans);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;border-radius:var(--r);text-decoration:none;display:inline-block;transition:all var(--ease);border:none;cursor:pointer}
  .btn-dark{background:var(--accent);color:var(--white)}
  .btn-dark:hover{background:var(--black);transform:translateY(-2px);box-shadow:0 8px 24px rgba(28,27,24,.15)}
  .btn-outline{background:transparent;color:var(--gray-700);border:1px solid var(--gray-300)}
  .btn-outline:hover{border-color:var(--black);color:var(--black);transform:translateY(-2px)}

  /* SECTION */
  .sec{padding:100px 80px}

  /* HERO */
  #hero{
    height:100vh;
    box-sizing:border-box;
    display:grid;
    grid-template-columns:1fr 1.05fr;
    padding-top:80px;
    overflow:hidden;
  }
  .hero-l{
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:60px 48px 60px 80px;
  }
  .hero-eye{
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-size:.7rem;
    letter-spacing:.15em;
    text-transform:uppercase;
    color:var(--accent);
    font-weight:500;
    margin-bottom:22px;
  }
  .hero-eye::before{content:'';width:28px;height:1px;background:var(--accent)}
  .hero-h1{
    font-family:var(--serif);
    font-size:clamp(2.6rem,4.2vw,4.6rem);
    font-weight:400;
    line-height:1.08;
    letter-spacing:-.02em;
    color:var(--black);
    margin-bottom:22px;
  }
  .hero-h1 em{font-style:italic;color:var(--accent)}
  .hero-sub{
    font-size:.92rem;
    line-height:1.75;
    color:var(--gray-700);
    font-weight:300;
    max-width:400px;
    margin-bottom:36px;
  }
  .hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}

  /* Mini stats row under buttons */
  .hero-stats-row{
    display:flex;
    align-items:center;
    gap:0;
    padding-top:28px;
    border-top:1px solid var(--gray-100);
  }
  .hstat{display:flex;flex-direction:column;gap:3px;flex:1}
  .hstat strong{
    font-family:var(--serif-num);
    font-size:1.4rem;
    font-weight:500;
    color:var(--black);
    letter-spacing:-.01em;
    line-height:1;
  }
  .hstat span{
    font-size:.62rem;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:var(--gray-500);
    font-weight:500;
  }
  .hstat-div{width:1px;height:36px;background:var(--gray-100);margin:0 20px;flex-shrink:0}

  /* HERO RIGHT — Video panel */
  .hero-r{
    position:relative;
    overflow:hidden;
    background:#1a1815;
    display:flex;
    align-items:center;
    justify-content:center;
  }
  /* Decorative warm gradient bg */
  .hero-r-bg{
    position:absolute;
    inset:0;
    background:
      radial-gradient(ellipse 80% 70% at 60% 40%, rgba(184,147,90,0.18) 0%, transparent 70%),
      radial-gradient(ellipse 60% 80% at 30% 80%, rgba(168,144,112,0.12) 0%, transparent 60%),
      #1a1815;
    z-index:0;
  }
  /* Subtle ring decoration */
  .hero-r-ring{
    position:absolute;
    top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:min(75%, 420px);
    aspect-ratio:9/16;
    border:1px solid rgba(184,147,90,0.2);
    border-radius:24px;
    z-index:1;
    pointer-events:none;
  }
  .hero-r-ring::before{
    content:'';
    position:absolute;
    inset:-14px;
    border:1px solid rgba(184,147,90,0.08);
    border-radius:30px;
  }
  /* Video wrapper — natural 9:16 container */
  .hero-video-wrap{
    position:relative;
    z-index:2;
    height:90%;
    max-height:min(88vh, 760px);
    aspect-ratio:9/16;
    border-radius:20px;
    overflow:hidden;
    box-shadow:
      0 0 0 1px rgba(184,147,90,0.25),
      0 24px 60px rgba(0,0,0,0.55),
      0 8px 20px rgba(0,0,0,0.35);
  }
  .hero-video{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
  }
  .hero-video-gradient{
    position:absolute;
    inset:0;
    background:linear-gradient(
      to top,
      rgba(20,18,14,0.75) 0%,
      rgba(20,18,14,0.1) 35%,
      transparent 55%
    );
    pointer-events:none;
  }
  /* Floating badge at bottom of video */
  .hero-video-badge{
    position:absolute;
    bottom:20px;
    left:14px;
    right:14px;
    background:rgba(253,252,249,0.12);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(253,252,249,0.18);
    padding:14px 16px;
    border-radius:12px;
    display:flex;
    align-items:center;
    gap:12px;
  }
  .hvb-dot{
    width:8px;height:8px;
    border-radius:50%;
    background:var(--accent);
    flex-shrink:0;
    box-shadow:0 0 0 3px rgba(184,147,90,0.3);
    animation:pulse-dot 2s ease-in-out infinite;
  }
  @keyframes pulse-dot{
    0%,100%{box-shadow:0 0 0 3px rgba(184,147,90,0.3)}
    50%{box-shadow:0 0 0 6px rgba(184,147,90,0.12)}
  }
  .hero-video-badge strong{
    display:block;
    font-family:var(--serif);
    font-size:.95rem;
    font-weight:500;
    color:#fff;
    letter-spacing:.02em;
    line-height:1.2;
  }
  .hero-video-badge span{
    font-size:.62rem;
    letter-spacing:.1em;
    text-transform:uppercase;
    color:rgba(255,255,255,0.55);
    font-weight:400;
  }
  /* Vertical text decoration on left edge of right panel */
  .hero-r-label{
    position:absolute;
    left:16px;
    top:50%;
    transform:translateY(-50%) rotate(-90deg);
    transform-origin:center center;
    font-size:.6rem;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(184,147,90,0.4);
    white-space:nowrap;
    z-index:3;
    font-weight:500;
  }

  /* RENDER SLOT */
  .rslot{background:var(--gray-100);border:none;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--gray-500);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;transition:all var(--ease);min-height:200px;position:relative;overflow:hidden;cursor:zoom-in}
  .rslot img{transition:transform 0.6s ease;width:100%;height:100%;object-fit:cover}
  .rslot:hover img{transform:scale(1.05)}
  .rslot::after{content:'⤢';position:absolute;top:12px;right:14px;font-size:1rem;color:rgba(255,255,255,.85);opacity:0;transition:opacity var(--ease);text-shadow:0 1px 4px rgba(0,0,0,.4)}
  .rslot:hover::after{opacity:1}
  .rslot svg{width:28px;opacity:.3}
  .rslot small{opacity:.55;font-size:.62rem;text-align:center;padding:0 16px;margin-top:-4px}

  /* LIGHTBOX */
  .lightbox{position:fixed;inset:0;z-index:1000;background:rgba(15,13,10,.94);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s ease;padding:20px}
  .lightbox.open{opacity:1;pointer-events:all}
  .lightbox-inner{position:relative;max-width:92vw;max-height:90vh}
  .lightbox img{max-width:100%;max-height:88vh;border-radius:6px;object-fit:contain;transform:scale(0.9);transition:transform 0.4s cubic-bezier(0.34,1.4,0.64,1);display:block;box-shadow:0 40px 100px rgba(0,0,0,.5)}
  .lightbox.open img{transform:scale(1)}
  .lightbox-close{position:fixed;top:20px;right:20px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:var(--white);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ease);font-size:1.3rem;backdrop-filter:blur(8px);line-height:1}
  .lightbox-close:hover{background:rgba(255,255,255,.25);transform:rotate(90deg)}
  .lightbox-caption{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);font-size:.72rem;color:rgba(255,255,255,.45);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;background:rgba(0,0,0,.3);padding:6px 16px;border-radius:20px;backdrop-filter:blur(8px)}
  .lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:var(--white);width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--ease);backdrop-filter:blur(8px);font-size:1.4rem;user-select:none}
  .lightbox-nav:hover{background:rgba(255,255,255,.2)}
  .lightbox-prev{left:16px}
  .lightbox-next{right:16px}

  /* ARQUITECTOS */
  #arquitectos{background:var(--white);padding:100px 80px}
  .arq-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .arq-img-wrap .arq-visual{aspect-ratio:4/5;background:linear-gradient(160deg,#D4C9B8,#8C7D6A);border-radius:8px;display:flex;align-items:flex-end;padding:28px;overflow:hidden;position:relative}
  .arq-img-wrap .arq-visual::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.35))}
  .arq-visual-lbl{position:relative;z-index:1;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.75);font-style:italic}
  .arq-right{display:flex;flex-direction:column;justify-content:center}
  .arq-quote-blk{margin:24px 0 28px;padding-left:18px;border-left:2px solid var(--accent)}
  .arq-quote-blk p{font-family:var(--serif);font-size:1.15rem;font-style:italic;font-weight:300;color:var(--accent);line-height:1.65}
  .arq-firma-card{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--beige);border-radius:6px;border:1px solid var(--gray-100);margin-top:8px}
  .arq-firma-logo{width:44px;height:44px;background:var(--accent);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:var(--serif);font-size:.95rem;font-weight:500;color:var(--white);letter-spacing:.06em}
  .arq-firma-logo img{width:100%;height:100%;object-fit:contain;display:block}
  .arq-firma-info strong{display:block;font-size:.86rem;font-weight:500;color:var(--black);margin-bottom:3px}
  .arq-firma-info span{font-size:.76rem;color:var(--gray-500)}

  /* STATS STRIP */
  .stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--gray-100);border:1px solid var(--gray-100);border-radius:8px;overflow:hidden;margin:0 80px}
  .scard{background:var(--white);padding:44px 32px;transition:background var(--ease)}
  .scard:hover{background:var(--gray-50)}
  .scard .n{font-family:var(--serif);font-size:2.8rem;font-weight:400;color:var(--black);line-height:1}
  .scard .n span{color:var(--accent)}
  .scard .l{font-size:.74rem;letter-spacing:.05em;color:var(--gray-500);margin-top:6px;line-height:1.45}

  /* PRESENTACIÓN */
  #presentacion{background:var(--beige);padding:100px 80px;display:grid;grid-template-columns:minmax(0,2fr) minmax(0,3fr);gap:72px;align-items:center}
  .pres-video{position:relative;aspect-ratio:9/16;max-height:600px;border-radius:14px;overflow:hidden;background:var(--beige-dark);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;cursor:pointer;transition:border-color var(--ease)}
  .pres-video:hover{border-color:var(--accent)}
  .pres-content{display:flex;flex-direction:column;justify-content:center}
  .pres-desc{font-size:.94rem;line-height:1.8;color:var(--gray-700);font-weight:300;max-width:520px;margin-bottom:44px}

  /* STATS — números negros, compactos */
  .pres-stats{display:flex;align-items:center;gap:0;border-top:1px solid var(--gray-300);padding-top:18px;flex-wrap:wrap}
  .pstat{flex:0 0 auto;padding:0 18px 0 0}
  .pstat-div{width:1px;height:32px;background:var(--gray-300);flex-shrink:0;margin-right:18px}
  .pstat-n{font-family:var(--serif-num);font-size:1.9rem;font-weight:400;color:var(--black) !important;line-height:1;margin-bottom:2px;letter-spacing:-.01em}
  .pstat-n *{color:var(--black) !important}
  .pstat-n .num{color:var(--black) !important}
  .pstat-l{font-size:.62rem;letter-spacing:.07em;text-transform:uppercase;color:var(--gray-500);line-height:1.3}

  /* GALLERY */
  #galeria{padding:100px 80px;background:var(--white)}
  .gal-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:52px}
  .gal-note{font-size:.76rem;color:var(--gray-500);letter-spacing:.04em;max-width:220px;text-align:right;line-height:1.6}
  .renders-grid{display:grid;gap:14px;margin:20px 0}
  .render-hero{min-height:420px}
  .render-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
  .render-row .rslot{min-height:220px}
  .render-duo{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .render-duo .rslot{min-height:260px}
  .drone-swipe-hint{display:none}
  .drone-head{margin-bottom:30px}
  .drone-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .dslot{aspect-ratio:9/16;background:var(--beige-dark);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;border:1.5px dashed var(--gray-300);transition:border-color var(--ease);overflow:hidden}
  .dslot:hover{border-color:var(--accent)}
  .play{width:48px;height:48px;border:1.5px solid rgba(184,147,90,.45);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all var(--ease)}
  .dslot:hover .play{background:var(--accent);border-color:var(--accent)}
  .play svg{width:15px;fill:rgba(90,86,80,.65);margin-left:2px}
  .dslot:hover .play svg{fill:var(--white)}
  .dlbl{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500);text-align:center;padding:0 14px}

/* LOCATION */
#ubicacion{background:var(--gray-50);padding:100px 80px}
.ubi-video-wrap video{width:100%;height:100%;object-fit:cover;display:block;border-radius:10px}

/* El Grid Principal */
.ubi-media {
  display: grid;
  /* Textos a la izquierda (60%), Video a la derecha (40%) */
  grid-template-columns: minmax(0, 6fr) minmax(0, 4fr);
  gap: 32px 80px; /* 32px de espacio hacia abajo, 80px hacia los lados */
  margin-top: 52px;
  margin-bottom: 52px;
  align-items: start; /* <-- LA MAGIA: Evita que se estiren y dejen ese hueco gigante */
}

/* Textos (Arriba a la Izquierda) */
.ubi-textos {
  grid-column: 1 / 2;
  grid-row: 1 / 2;
  margin-top: 20px; /* Un empujoncito ligero para alinearlo bonito con el top del video */
}

/* Tarjeta de Lugares (Abajo a la Izquierda, pegadita al texto) */
.ubi-poi-card {
  grid-column: 1 / 2;
  grid-row: 2 / 3;
  background: var(--white);
  border-radius: 10px;
  border: 1px solid var(--gray-100);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Video (Ocupa toda la Derecha) */
.ubi-video-wrap {
  grid-column: 2 / 3;
  grid-row: 1 / 3;
  width: 100%;
  max-width: 380px;
  margin: 0 auto; /* Centrado en su columna derecha */
  aspect-ratio: 9/16;
  border-radius: 10px;
  overflow: hidden;
  background: var(--black);
  box-shadow: 0 20px 40px rgba(0,0,0,0.08);
}
/* Ajustes para el panel derecho para que los textos respiren */
.ubi-poi-wrap{
  display:flex;
  flex-direction:column;
  justify-content: center;
}

/* Añadimos un margen debajo del h2 para separarlo de la tarjeta de lugares */
.ubi-poi-wrap .h2 {
  margin-bottom: 40px; 
}
  /* POI panel */
  .ubi-poi-wrap{display:flex;flex-direction:column}
  .ubi-poi-card{background:var(--white);border-radius:10px;border:1px solid var(--gray-100);display:flex;flex-direction:column;height:auto;overflow:hidden}
  .ubi-poi-list{flex:1;display:flex;flex-direction:column}
  .ubi-poi-item{display:flex;align-items:flex-start;gap:14px;padding:18px 22px;border-bottom:1px solid var(--gray-100);transition:background var(--ease)}
  .ubi-poi-item:hover{background:var(--gray-50)}
  .ubi-poi-ico{font-size:1.1rem;width:32px;height:32px;background:var(--gray-50);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
  .ubi-poi-txt{flex:1;min-width:0}
  .ubi-poi-txt strong{display:block;font-size:.83rem;font-weight:500;color:var(--black);margin-bottom:2px}
  .ubi-poi-txt span{font-size:.74rem;color:var(--gray-500);line-height:1.4}
  .ubi-poi-dist{font-size:.7rem;font-weight:500;color:var(--accent);letter-spacing:.04em;white-space:nowrap;text-align:right;flex-shrink:0;padding-top:2px;line-height:1.3}
  .ubi-maps-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px 22px;background:var(--black);color:var(--white);text-decoration:none;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;transition:background var(--ease);border-radius:0 0 10px 10px}
  .ubi-maps-btn:hover{background:var(--accent)}
  .ubi-maps-btn svg{flex-shrink:0}
  .pt{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--white);border-bottom:1px solid var(--gray-100);transition:background var(--ease),transform var(--ease)}
  .pt:last-child{border-bottom:none}
  .pt:hover{background:var(--gray-50);transform:translateX(4px)}
  .pt-ico{width:36px;height:36px;background:var(--gray-50);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem}
  .pt h5{font-size:.83rem;font-weight:500;color:var(--black);margin-bottom:2px}
  .pt span{font-size:.72rem;color:var(--gray-500)}
  .pt-d{margin-left:auto;font-size:.7rem;letter-spacing:.05em;color:var(--accent);font-weight:500;white-space:nowrap}
  .pin{position:absolute;width:14px;height:14px;background:var(--accent);border-radius:50%;border:3px solid #fff;top:50%;left:50%;transform:translate(-50%,-50%);animation:ping 2s ease-in-out infinite}
  @keyframes ping{0%,100%{box-shadow:0 0 0 5px rgba(201,169,110,.25)}50%{box-shadow:0 0 0 12px rgba(201,169,110,.08)}}

  /* BENEFICIOS */
  #beneficios{padding:100px 80px;background:var(--white)}
  .bene-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px}
  .bcard{padding:32px 26px;border:1px solid var(--gray-100);border-radius:6px;transition:all var(--ease);position:relative;overflow:hidden}
  .bcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--ease)}
  .bcard:hover::before{transform:scaleX(1)}
  .bcard:hover{border-color:var(--accent-light);transform:translateY(-4px);box-shadow:0 16px 44px rgba(0,0,0,.08)}
  .bico{width:42px;height:42px;background:var(--gray-50);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.1rem;transition:background var(--ease),transform var(--ease)}
  .bcard:hover .bico{background:var(--accent-light);transform:scale(1.1) rotate(-4deg)}
  .bcard h4{font-size:.85rem;font-weight:500;color:var(--black);margin-bottom:8px;letter-spacing:.02em}
  .bcard p{font-size:.78rem;line-height:1.65;color:var(--gray-500);font-weight:300}

  /* TESTIMONIAL */
  #testimonial{background:var(--gray-50);padding:80px}
  .testi-inner{max-width:620px;margin:0 auto;text-align:center}
  .stars{display:flex;justify-content:center;gap:4px;margin-bottom:24px;color:var(--accent);font-size:1rem}
  .testi-q{font-family:var(--serif);font-size:1.45rem;font-weight:300;font-style:italic;line-height:1.6;color:var(--black);margin-bottom:28px}
  .testi-a{font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}
  .testi-a strong{display:block;color:var(--black);font-weight:500;margin-bottom:3px;font-size:.8rem;letter-spacing:.05em}

  /* LOTES */
  #lotes{background:linear-gradient(180deg,#EAE5DA 0%,#F2EDE3 60%,var(--white) 100%);padding:100px 80px}
  .lotes-head{text-align:center;margin-bottom:64px}
  .lotes-diag{display:flex;justify-content:center;align-items:flex-end;gap:20px;margin-bottom:56px;flex-wrap:wrap}
  .lote-bar{display:flex;flex-direction:column;align-items:center;gap:12px}
  .lote-rect-inner{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-500);writing-mode:vertical-rl;transform:rotate(180deg);font-weight:400}
  .lote-dim{font-size:.78rem;font-weight:500;color:var(--black);letter-spacing:.02em;text-align:center}
  .lotes-summary{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gray-100);border:1px solid var(--gray-100);border-radius:8px;overflow:hidden;max-width:680px;margin:0 auto}
  .lote-container{width:100px;height:300px;border:1px dashed var(--gray-500);position:relative;display:flex;align-items:flex-end;justify-content:center;background:transparent}
  .lote-inner{width:calc(var(--w) * 1px);height:calc(var(--h) * 1px);border:1.5px solid var(--gray-500);background:transparent;display:flex;align-items:center;justify-content:center;text-align:center;font-size:0.6rem}
  .lote-inner.full{width:100%;height:100%;border:2px solid var(--accent)}
  .lscard{background:var(--white);padding:36px 40px}
  .lscard .ls-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-500);margin-bottom:10px}
  .lscard .ls-range{font-family:var(--serif);font-size:2.4rem;font-weight:400;color:var(--black);line-height:1;margin-bottom:6px}
  .lscard .ls-range span{color:var(--accent)}
  .lscard .ls-sub{font-size:.76rem;color:var(--gray-500);line-height:1.5}
  .lscard.featured{background:var(--accent-light);border-left:3px solid var(--accent)}
  .lotes-cta{text-align:center;margin-top:48px}
  .lotes-cta p{font-size:.86rem;color:var(--gray-500);margin-bottom:20px}

  /* ARQUITECTO */
  #arquitecto{background:var(--beige);padding:100px 80px}
  .arq-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
  .arq-firma{display:flex;align-items:center;gap:16px;padding:20px 24px;background:var(--accent-light);border-radius:8px;border:none;margin-top:32px;transition:box-shadow var(--ease);box-shadow:0 2px 16px rgba(0,0,0,.06)}
  .arq-firma:hover{box-shadow:0 8px 28px rgba(0,0,0,.1)}
  .arq-firma-logo-wrap{flex-shrink:0}
  .arq-logo-ph{width:64px;height:64px;border:none;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:8px;overflow:hidden}
  .arq-logo-ph img{width:120%;height:120%;object-fit:contain;border-radius:0}
  .arq-firma-info{display:flex;flex-direction:column;gap:3px}
  .arq-firma-info strong{font-size:.88rem;font-weight:500;color:var(--black)}
  .arq-firma-info span{font-size:.74rem;color:var(--gray-500)}
  .arq-ig{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;color:var(--accent);text-decoration:none;margin-top:4px;font-weight:500;transition:color var(--ease)}
  .arq-ig:hover{color:var(--black)}
  .arq-img-ph{aspect-ratio:4/3;background:var(--gray-100);border-radius:10px;border:none;overflow:hidden;position:relative}
  .arq-img-ph img{width:100%;height:100%;object-fit:cover;display:block;border-radius:0}

  /* LOTES CTA btns */
  .lotes-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

  /* FORM alt (llamada) */
  .fcierre-alt{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--gray-100)}
  .fcierre-alt span{font-size:.72rem;color:var(--gray-400,var(--gray-300));letter-spacing:.04em}
  .fcall{font-size:.88rem;font-weight:500;color:var(--black);text-decoration:none;transition:color var(--ease)}
  .fcall:hover{color:var(--accent)}

  /* CIERRE */
  #cierre{background:var(--beige);padding:100px 80px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
  .cierre-h2{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,2.9rem);font-weight:400;line-height:1.18;color:var(--black);margin-bottom:18px}
  .cierre-h2 em{font-style:italic;color:var(--accent)}
  .cierre-sub{font-size:.86rem;color:var(--gray-700);line-height:1.75;font-weight:300;max-width:400px;margin-bottom:36px}
  .disp-bar-wrap{display:flex;align-items:center;gap:14px}
  .disp-bar{flex:1;height:3px;background:var(--gray-100);border-radius:2px;overflow:hidden}
  .disp-fill{height:100%;width:35%;background:var(--accent);border-radius:2px;animation:fill 1.5s ease-out .5s both}
  @keyframes fill{from{width:0}to{width:35%}}
  .disp-lbl{font-size:.68rem;color:var(--gray-500);white-space:nowrap;letter-spacing:.05em}

  /* FORM */
  .fcard{background:var(--white);border-radius:8px;padding:44px 40px;box-shadow:0 8px 40px rgba(0,0,0,.06)}
  .ftitle{font-family:var(--serif);font-size:1.4rem;font-weight:500;color:var(--black);margin-bottom:6px}
  .fsub{font-size:.8rem;color:var(--gray-500);margin-bottom:28px;line-height:1.55}
  .fg{margin-bottom:16px}
  .fg label{display:block;font-size:.68rem;letter-spacing:.09em;text-transform:uppercase;color:var(--gray-700);margin-bottom:6px;font-weight:500}
  .fg input,.fg select,.fg textarea{width:100%;padding:12px 14px;border:1px solid var(--gray-100);border-radius:var(--r);font-family:var(--sans);font-size:.86rem;color:var(--black);background:var(--gray-50);outline:none;transition:border-color var(--ease),background var(--ease);-webkit-appearance:none}
  .fg input::placeholder,.fg textarea::placeholder{color:var(--gray-300)}
  .fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);background:var(--white)}
  .frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .fsubmit{width:100%;padding:15px;background:var(--accent);color:var(--white);border:none;cursor:pointer;font-family:var(--sans);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;border-radius:var(--r);transition:background var(--ease),transform var(--ease);display:flex;align-items:center;justify-content:center;gap:10px;margin-top:6px}
  .fsubmit:hover{background:#25D366;transform:translateY(-2px)}
  .fdiscl{margin-top:10px;font-size:.67rem;color:var(--gray-300);text-align:center;line-height:1.5}

  /* FOOTER */
  footer{background:var(--beige-dark);padding:52px 80px 28px}
  .ft-top{display:grid;grid-template-columns:1fr auto auto;align-items:start;gap:48px;margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--gray-300)}
  .ft-brand{display:flex;flex-direction:column;gap:4px}
  .ft-logo{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--black);text-decoration:none;display:block}
  .ft-logo span{color:var(--accent)}
  .ft-brand p{font-size:.76rem;line-height:1.6;color:var(--gray-500);max-width:340px;margin-top:4px}
  /* Espacio para logo en footer */
  .ft-logo-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-width:130px}
  .ft-logo-img{max-width:130px;max-height:64px;object-fit:contain;opacity:.8;transition:opacity var(--ease);display:block}
  .ft-logo-img:hover{opacity:1}
  .ft-logo-placeholder{width:130px;height:64px;border:1.5px dashed var(--gray-300);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-300);text-align:center;line-height:1.6;padding:8px}
  .ft-social{display:flex;gap:10px;flex-shrink:0;align-items:center;justify-content:flex-end}
  .ft-social a{width:36px;height:36px;border-radius:50%;border:1px solid var(--gray-300);display:flex;align-items:center;justify-content:center;color:var(--gray-700);text-decoration:none;transition:all var(--ease)}
  .ft-social a:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light);transform:translateY(-2px)}
  .ft-social svg{width:16px;height:16px;fill:currentColor}
  .ft-bot{display:flex;justify-content:space-between;align-items:center;font-size:.68rem;color:var(--gray-500);letter-spacing:.05em}

  /* FLOATING WA */
  .wa{position:fixed;bottom:30px;right:30px;z-index:200;width:54px;height:54px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(37,211,102,.35);transition:all var(--ease);text-decoration:none}
  .wa:hover{transform:scale(1.1) translateY(-3px);box-shadow:0 14px 36px rgba(37,211,102,.5)}
  .wa::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,211,102,.35);animation:wa-pulse 2.5s ease-in-out infinite}
  @keyframes wa-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0;transform:scale(1.45)}}

  /* FADE UP */
  .fu{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(0.4,0,0.2,1),transform .7s cubic-bezier(0.4,0,0.2,1)}
  .fu.vis{opacity:1;transform:none}

  /* ========== RESPONSIVE ========== */
  @media(max-width:1100px){
    nav{padding:18px 32px}
    nav.scrolled{padding:14px 32px}
    .nav-links{display:none}
    .nav-hamburger{display:flex}
    .nav-mobile-menu{display:flex}
    .sec,#arquitectos,#galeria,#ubicacion,#beneficios,#testimonial,#cierre,footer{padding-left:32px;padding-right:32px}
    .stats-strip{margin:0 32px;grid-template-columns:1fr 1fr}
    #hero{grid-template-columns:1fr}
    .hero-l{padding:48px 32px 36px}
    .hero-r{height:70vw;min-height:340px;max-height:480px}
    .arq-grid{grid-template-columns:1fr;gap:44px}
    .drone-grid{grid-template-columns:repeat(2,1fr)}
    .bene-grid{grid-template-columns:1fr 1fr}
    #presentacion{grid-template-columns:1fr;gap:44px;padding-left:32px;padding-right:32px}
    /* Dentro de @media(max-width:1100px) */
  .ubi-media {
      grid-template-columns: 1fr; /* Todo a una sola columna */
      gap: 32px;
    }
    
    /* Aquí dictamos el orden mágico para celulares */
    .ubi-textos {
      grid-column: 1;
      grid-row: 1; /* 1ro: Textos arriba */
    }
    .ubi-video-wrap {
      grid-column: 1;
      grid-row: 2; /* 2do: Video en medio */
      max-width: 400px;
    }
    .ubi-poi-card {
      grid-column: 1;
      grid-row: 3; /* 3ro: Tarjeta hasta abajo */
    }
    .pres-video{max-height:420px;aspect-ratio:9/16;width:min(260px,100%);margin:0 auto}

    #cierre{grid-template-columns:1fr;gap:44px;padding-left:32px;padding-right:32px}
    .ft-top{grid-template-columns:1fr 1fr;gap:28px}
    .gal-head{flex-direction:column;align-items:flex-start;gap:10px}
    .render-row{grid-template-columns:1fr 1fr}
    #arquitecto{padding:72px 32px}
    .arq-wrap{grid-template-columns:1fr;gap:40px}
  }

  @media(max-width:600px){
    nav{padding:15px 18px}
    nav.scrolled{padding:12px 18px}
    .nav-hamburger{display:flex}
    .nav-mobile-menu{display:flex}

    #hero{height:auto;min-height:100svh;padding-top:68px;grid-template-columns:1fr}
    .hero-l{padding:36px 20px 28px;order:2}
    .hero-h1{font-size:clamp(2rem,8vw,2.8rem)}
    .hero-sub{margin-bottom:24px}
    .hero-btns{flex-direction:column;gap:10px;margin-bottom:24px}
    .hero-btns .btn{text-align:center;width:100%;box-sizing:border-box}
    .hero-stats-row{gap:0;padding-top:20px}
    .hstat strong{font-size:1.2rem}
    .hstat-div{margin:0 14px}

    /* Video panel on mobile — top, full width, tall */
    .hero-r{order:1;height:72svh;min-height:380px;max-height:520px}
    .hero-video-wrap{
      height:92%;
      max-height:none;
    }
    .hero-r-label{display:none}
    .hero-r-ring{width:min(68%, 280px)}

    .stats-strip{margin:0 18px;grid-template-columns:1fr 1fr}
    .scard{padding:24px 16px}
    .scard .n{font-size:2rem}

    #presentacion{padding:64px 18px;gap:32px}
    .pres-video{width:100%;max-width:100%;aspect-ratio:9/16;max-height:80svh;height:auto}
    .pres-desc{font-size:.88rem;margin-bottom:28px}
    .pstat-n{font-size:2rem}

    #galeria{padding:64px 18px}
    .gal-head{margin-bottom:28px}
    .render-hero{min-height:240px}
    .render-row{grid-template-columns:1fr}
    .render-duo{grid-template-columns:1fr}
    .drone-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;padding-bottom:4px}
    .drone-grid::-webkit-scrollbar{display:none}
    .drone-grid video{flex:0 0 100%;width:100%;aspect-ratio:9/16;max-height:80svh;scroll-snap-align:start;border-radius:12px;object-fit:cover}
    .drone-swipe-hint{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:16px;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500);font-weight:500}
    .drone-swipe-hint::before{content:'';display:block;width:24px;height:1px;background:var(--gray-300)}
    .drone-swipe-hint .swipe-arrow{display:inline-flex;align-items:center;gap:4px;color:var(--accent);font-weight:600;animation:swipeHint 1.6s ease-in-out infinite}
    .drone-swipe-hint .swipe-arrow svg{width:18px;height:18px;fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
    @keyframes swipeHint{0%{transform:translateX(0);opacity:.5}40%{transform:translateX(10px);opacity:1}70%{transform:translateX(6px);opacity:1}100%{transform:translateX(0);opacity:.5}}
    .drone-swipe-hint::after{content:'';display:block;width:24px;height:1px;background:var(--gray-300)}
    .renders-grid{margin:10px 0}

  #ubicacion{padding:64px 18px}

  .ubi-video-wrap video{aspect-ratio:9/16;height:auto;max-height:75svh}

    #lotes{padding:64px 18px}
    .lotes-head{margin-bottom:36px}
    .lotes-diag{display:grid;grid-template-columns:1fr 1fr;gap:20px 12px;justify-items:center;align-items:end}
    .lote-container{width:68px;height:200px}
    .lote-inner{font-size:.48rem}
    .lotes-summary{grid-template-columns:1fr}
    .lscard{padding:24px 20px}
    .lotes-cta{margin-top:28px}

    #beneficios{padding:64px 18px}
    .bene-grid{grid-template-columns:1fr;gap:12px;margin-top:32px}
    .bcard{padding:22px 18px}

    #arquitecto{padding:64px 18px}
    .arq-wrap{gap:32px}
    .arq-img-ph{aspect-ratio:16/9}
    .lotes-cta-btns{flex-direction:column;align-items:center}
    .lotes-cta-btns .btn{width:100%;max-width:320px;text-align:center}
    .fcierre-alt{flex-direction:column;gap:6px}

    #cierre{padding:64px 18px;gap:32px}
    .fcard{padding:28px 18px}
    .frow{grid-template-columns:1fr}
    .cierre-sub{max-width:100%}

    footer{padding:40px 18px 88px}
    .ft-top{grid-template-columns:1fr;gap:24px}
    .ft-logo-wrap{align-items:flex-start}
    .ft-social{justify-content:flex-start}
    .ft-bot{flex-direction:column;gap:6px;text-align:center}

    .pstat-div{display:none}
    .pstat{min-width:45%;margin-bottom:16px}

    .wa{bottom:18px;right:14px;width:46px;height:46px}

    .lightbox-nav{width:36px;height:36px;font-size:1rem}
    .lightbox-prev{left:6px}
    .lightbox-next{right:6px}
    .lightbox-close{top:14px;right:14px;width:38px;height:38px;font-size:1.1rem}

    .h2{font-size:clamp(1.7rem,6vw,2.3rem)}
    .btn{padding:13px 26px;font-size:.72rem}
    .label{font-size:.6rem}
  }

  @media(max-width:380px){
    .hero-h1{font-size:1.8rem}

    .ft-bot{font-size:.62rem}
    .bene-grid .bcard{padding:20px 16px}
  }

/* ── Lotes: grid de imágenes ── */
.lotes-diag {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 24px;
  align-items: end;
  justify-content: center;
}
.lote-bar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.lote-img {
  width: 100%;
  max-width: 180px;
  height: auto;
  display: block;
  border-radius: 6px;
}

@media (max-width: 700px) {
  .lotes-diag {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 16px;
  }
  .lote-img {
    max-width: 100%;
  }
}
.wa-floating img {
  filter: brightness(0) invert(1);
}

/* ── WhatsApp flotante ── */
.wa-floating {
  position: fixed !important;
  bottom: 24px !important;
  right: 24px !important;
  z-index: 99999 !important;
  width: 56px;
  height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  transition: transform 0.2s, box-shadow 0.2s;
  text-decoration: none;
}
.wa-floating:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
}
.wa-floating svg {
  width: 30px;
  height: 30px;
  fill: #fff;
  display: block;
}

.lotes-diag {
  grid-template-columns: repeat(4, 120px) !important;
}

.lote-container {
  width: 100px !important;
  height: 260px !important;
}

@media (max-width: 700px) {
  .lotes-diag {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .lote-container {
    width: 68px !important;
    height: 200px !important;
  }
}