:root{
  --bg:#ffffff;
  --panel: rgba(255,255,255,.70);
  --card:#ffffff;

  --text:#0f172a;
  --muted:#475569;
  --line: rgba(15,23,42,.12);

  --shadow: 0 14px 34px rgba(2,6,23,.10);
  --shadow2: 0 18px 46px rgba(2,6,23,.14);
  --shadow3: 0 7px 18px rgba(2,6,23,.06);
  --shadow4: 0 7px 20px rgba(2,6,23,.12);

  --r-sm:12px;
  --r-md:18px;
  --r-lg:26px;

  --max:1200px;
  --pad:24px;

  --nav-tint: rgba(10, 15, 22, .72); /* fallback */
  --font-base: 'Poppins', sans-serif;


  --brand: rgba(160, 62, 42, 0.92); /* usa aquí el color real de Rivello */

  --footer-bg: #2c2f34;

}

/* ===== Page Loader ===== */
.page-loader{
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #ffffff;
  display: grid;
  place-items: center;

  opacity: 1;
  visibility: visible;
  transition: opacity .35s ease, visibility 0s linear .35s;
}

.page-loader.is-hidden{
  opacity: 0;
  visibility: hidden;
}

.page-loader__inner{
  display: inline-flex;
  gap: 10px;
  align-items: center;
}

.page-loader__dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(15,23,42,.55);
  animation: loaderPulse .9s ease-in-out infinite;
}

.page-loader__dot:nth-child(2){ animation-delay: .12s; }
.page-loader__dot:nth-child(3){ animation-delay: .24s; }

@keyframes loaderPulse{
  0%, 100%{ transform: translateY(0); opacity: .35; }
  50%{ transform: translateY(-6px); opacity: 1; }
}

/* opcional: entrada suave del sitio */
body.is-loading main,
body.is-loading header,
body.is-loading footer{
  opacity: 0;
}

body.is-ready main,
body.is-ready header,
body.is-ready footer{
  opacity: 1;
  transition: opacity .45s ease;
}





/* flechita base */
.nav-btn .chev{
  display: inline-block;              /* clave para poder rotar */
  font-size: .85em;
  margin-left: 4px;
  transition: transform 220ms ease, color 220ms ease;
  transform-origin: 50% 55%;
  color: var(--brand);
}

/* cuando está abierto */
.nav-btn[aria-expanded="true"] .chev{
  transform: rotate(180deg);
}


.landing-nav::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  background: linear-gradient(
    to bottom,
    rgba(255,255,255,.12),
    rgba(255,255,255,.02)
  );
  pointer-events:none;
}


*{ box-sizing:border-box; }
html{
  scroll-behavior:smooth;
  font-family: var(--font-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
 }

body{
  margin:0;
  font-family: inherit;
  font-weight: 400;
  background: radial-gradient(1200px 700px at 70% -10%, rgba(120,180,255,.15), transparent 60%),
              radial-gradient(900px 600px at 10% 10%, rgba(180,120,255,.12), transparent 60%),
              var(--bg);
  color:var(--text);
}

h1,h2,h3{
  font-weight: 600;
  letter-spacing: -0.01em;
}

.container{
  width:min(var(--max), calc(100% - 48px));
  margin-inline:auto;
}









.site-header{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  transition: background .22s ease, box-shadow .22s ease, border-color .22s ease;
  border-bottom: 0px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.0); /* o muy bajo */
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  padding: 14px 0;
}


.logo{
  display: inline-flex;
  align-items: center;
  line-height: 0;
}

.logo .logo-svg{
  height: 38px;     /* ajusta a gusto */
  width: auto;
  display: block;
  flex: 0 0 auto;
}




.logo svg *{ fill: currentColor; }

/* arriba del hero */
.site-header{
  --logo-color: #fff;
}

.logo{
  color: var(--logo-color);
  display: inline-flex;
  align-items: center;
}

/* al scrollear */
.site-header.is-scrolled{
  --logo-color: var(--brand);
}




/* Unifica A y BUTTON del nav */
.nav .nav-link{
  color: rgba(255,255,255,.9);
  text-decoration: none;
  font-weight: 500;
  line-height: 1;
  padding: 6px 0;
}





/* Nav */
.nav{
  display:flex;
  align-items:center;
  gap: 26px;
}


.nav-link,
.nav-btn{
  text-decoration: none;
  border: 0;
  background: none;
  color: rgba(255,255,255,.9);
  font-weight: 500;
  padding: 6px 0;
  transition: opacity .25s ease;
}

/* Reset específico del botón (Residenciales) */
.nav .nav-btn{
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  font-weight: 500 !important;
  font: inherit;         /* CLAVE: hereda tipografía exacta */
  cursor: pointer;
}


/* activo */
.nav-link.is-active{
  opacity: 1;
  font-weight: 600;
}


/* hover */
.nav-link:hover,
.nav-btn:hover{
  opacity: .7;
}



.nav-cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 3px 14px;
  border-radius: 999px;

  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);

  color: #fff;
  text-decoration: none;
  font-weight: 500;

  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);

  transition: all .25s ease;

  /* micro sombra difusa */
  box-shadow:
    0 6px 18px rgba(0,0,0,.04),
    0 1px 3px rgba(0,0,0,.03);
}

/* site header */



/* =========================
   PAGE-SITE: Header glass + “tinta” oscura desde el inicio
   ========================= */

.page-site .site-header{
  /* glass */
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(0,0,0,.08);

  /* tinta */
  color: rgba(18,18,18,.92);

  /* IMPORTANT: el logo usa --logo-color */
  --logo-color: rgba(18,18,18,.92);
}

/* Nav links heredan */
.page-site .site-header .nav-link,
.page-site .site-header .nav-btn{
  color: inherit;
}

/* CTA WhatsApp en glass pero oscuro */
.page-site .site-header .nav-cta{
  color: rgba(18,18,18,.92);
  border: 1px solid rgba(18,18,18,.22);
  background: rgba(255,255,255,.14);
}

/* Mantener igual aunque haga scroll */
.page-site .site-header.is-scrolled,
.page-site .site-header.is-scrolled-soft{
  background: rgba(255,255,255,.10);
  color: rgba(18,18,18,.92);
  --logo-color: rgba(18,18,18,.92);
}


/*ajuste color logo*/

.page-site .site-header{
  /* glass */
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  /* tinta */
  color: rgba(18,18,18,.92);

  /* LOGO desde inicio en brand */
  --logo-color: var(--brand);
}

.page-site .site-header{
  /* glass */
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);

  /* tinta */
  color: rgba(18,18,18,.92);

  /* LOGO desde inicio en brand */
  --logo-color: var(--brand);
}







/*----------------*/



.btn-reset{
  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 8px 16px;
  border-radius: 999px;

  background: rgba(0,0,0,.00);
  border: 1px solid rgba(0,0,0,.12);

  font-weight: 500;
  color: #222;

  transition: all .2s ease;
}

.btn-reset {
    border: 1px solid #ddd;
    background: transparent;
    border-radius: 30px;
    padding: 4px 16px;
    cursor: pointer;
}

.btn-reset-ic svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    margin-top: 4px;
}

/* hover sutil */
.btn-reset:hover{
  background: rgba(0,0,0,.06);
  transform: translateY(-1px);
}

.btn-reset:active svg{
  transform: rotate(-20deg);
}



.nav-cta-ic svg{
  width: 20px;
  height: 20px;

  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  margin-top: 6px;
}

/* hover sutil */
.nav-cta:hover{
  background: rgba(255,255,255,.22);
  transform: translateY(-1px);
}



/* Dropdown base */
.has-drop{ position: relative; }
.nav-btn{
  background: transparent;
  border: 0;
  cursor: pointer;
  display:flex;
  align-items:center;
  gap: 6px;
  padding: 0;
}
.chev{ font-size: .85em; opacity: .85; }





.drop-link{
  display:block;
  padding: 10px 10px;
  border-radius: 10px;
  color: #0f172a;
}
.drop-link:hover{ background: rgba(2,6,23,.06); }


/* ===== Estado scrolled: fondo blanco ===== */
.site-header.is-scrolled{
  background: rgba(255,255,255,.62);
  border-bottom-color: rgba(15,23,42,.06);
  box-shadow: 0 10px 30px rgba(2,6,23,.12);
  backdrop-filter: blur(14px) saturate(130%);
  -webkit-backdrop-filter: blur(14px) saturate(130%);

}

.site-header.is-scrolled .nav-link{
  color: #0f172a;
  opacity: .86;
}
.site-header.is-scrolled .nav-link:hover{ opacity: 1; }

.site-header.is-scrolled .nav-cta{
  color: #0f172a;
  border-color: rgba(15,23,42,.14);
  background: rgba(2,6,23,.02);
}

/* Truco temporal: tu logo es blanco.
   En fondo blanco lo “invertimos” para que se vea oscuro. */
.site-header.is-scrolled .logo-img{
  filter: invert(1) saturate(0) brightness(.15);
}

/* Mobile (si aún no hay hamburguesa, solo ocultamos nav) */
@media (max-width: 900px){
  .nav{ display:none; }
}

.nav-item.has-drop .mega-inner{ display:grid !important; }

/* ===== Mega dropdown usando tu estructura (.has-drop .drop) ===== */
.nav-item.has-drop{ position: relative; }


/* ESTE ES EL NUEVO BLOQUE*/
@media (hover:hover){
  .nav-item.has-drop .drop{
    position: fixed;
    left: 50%;
    top: 72px; /* ajusta a tu header real */
    width: min(1240px, calc(100vw - 40px));
    z-index: 60;


    border: 1px solid rgba(0,0,0,.06);
    border-radius: 20px;
    padding: 32px 28px;
    box-shadow: 0 18px 46px rgba(2,6,23,.14);

    background: rgba(255,255,255,.68);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);

    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(10px);
    pointer-events: none;

    transition:
       background-color .28s ease,
      opacity .18s ease,
      transform .22s cubic-bezier(.2,.7,.2,1),
      visibility 0s linear .18s;
  }


  .nav-item.has-drop:hover .drop,
  .nav-item.has-drop.is-open .drop{
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
    transition-delay: 0s;
  }
}



.nav-item.has-drop .drop::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;

  background: linear-gradient(
    45deg,
    rgba(227,228,229,.92),
    rgba(220,221,222,.98)
  );

  opacity: 0;
  transition: opacity .28s ease;
  pointer-events:none;
  z-index: 0;
}

.site-header.is-scrolled .nav-item.has-drop .drop::before{
  opacity: 1;
}

.nav-item.has-drop .drop{

}
.site-header.is-scrolled .nav-item.has-drop .drop::before,
.site-header.is-scrolled-soft .nav-item.has-drop .drop::before{
  opacity: 1;
}




/* PAGE-SITE: overlay del drop activo desde el inicio */
.page-site .site-header .nav-item.has-drop .drop::before{
  opacity: 1;
}

@media (hover:hover){
  .page-site .site-header .nav-item.has-drop .drop{
    background: rgba(255,255,255,.68);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border: 1px solid rgba(0,0,0,.06);
    box-shadow: 0 18px 46px rgba(2,6,23,.14);
  }
}


/* PAGE-SITE: el logo siempre en brand, incluso al hacer scroll */
.page-site .site-header,
.page-site .site-header.is-scrolled,
.page-site .site-header.is-scrolled-soft{
  --logo-color: var(--brand);
}

/* AQUI TERMINA EL NUEVO BLOQUE*/






.nav-item.has-drop .mega-inner{
  width: 100%;
  margin: 0 auto;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  border-radius: 0;

  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  gap: 22px;

}


.nav-item.has-drop .mega-title{
  font-weight: 650;
  color: rgba(0,0,0,.72);
  margin-bottom: 14px;
}

.nav-item.has-drop .mega-col{
  display: grid;
  align-content: start;
  gap: 14px;
  position: relative;
  z-index: 1;
}

.mega-grid-2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.nav-item.has-drop .mega-inner{
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr; /* Hermosillo más ancho */
  gap: 22px;
}



.nav-item.has-drop .mega-card{
  display: grid;
  place-items: center;
  height: 86px;
  border-radius: 14px;


  text-decoration: none;



  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.05);
  backdrop-filter: blur(6px);
  transition: transform .16s ease,
              box-shadow .16s ease,
              border-color .16s ease,
              background .16s ease;
}



.nav-item.has-drop .mega-card img{
  max-width: 220px;
  max-height: 72px;
  width: auto;
  height: auto;
  object-fit: contain;
  opacity: .95;
}

@media (hover:hover){
  .nav-item.has-drop::after{
    content:"";
    position:absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 30px;       /* puente */
  }
}





.nav-item.has-drop .mega-card:hover{
  transform: translateY(-1px);


  background: rgba(255,255,255,.9);
  border-color: rgba(0,0,0,.08);
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}
/* Mobile: dropdown inline (sin hover) */
@media (max-width: 980px){
  .nav-item.has-drop .drop{
    position: static;
    width: 100%;
    margin-top: 10px;

    /* cerrando/abriendo con display está OK en mobile */
    display: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;

    /* en mobile el blur casi no aporta, pero no estorba */
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }

  .nav-item.has-drop.is-open .drop{ display: block; }

  .nav-item.has-drop .mega-inner{
    width: 100%;
    grid-template-columns: 1fr 1fr;
    border-radius: 16px;
  }
}


/*.hero{ padding: 52px 0 26px; }
.hero-inner{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 32px;
  align-items:center;
}
.hero-kicker{ color:var(--muted); margin:0 0 10px; }
.hero h1{ font-size: clamp(2rem, 3.4vw, 3.2rem); margin:0 0 12px; letter-spacing:-.02em; }
.hero-sub{ color:var(--muted); max-width: 52ch; margin:0 0 20px; }


.hero-visual{
  min-height: 280px;
  border-radius: var(--r-lg);
  background:
    radial-gradient(600px 280px at 30% 20%, rgba(255,255,255,.08), transparent 60%),
    linear-gradient(135deg, rgba(120,180,255,.12), rgba(180,120,255,.10));
  border:1px solid var(--line);
  box-shadow: var(--shadow);
}*/

/* ===== HERO SEARCH DOCK ===== */



/* ===== HERO (estructura limpia) ===== */
.page-home .hero{
  position: relative;
  /* altura del hero (no depende de absolute children) */
  min-height: clamp(500px, 78svh, 700px);
  color: #fff;

  /* espacio para que el dock NO choque con lo que sigue */
  margin-bottom: 44px;

  /* NO recortar aquí, para no cortar el dock */
  overflow: visible;
}



/* recorte SOLO del área visual */
.page-home .hero-clip{
  position: relative;
  min-height: inherit;
  overflow: hidden;
}

/* slides + overlay ocupan todo el clip */
.page-home .hero-slides,
.page-home .hero-overlay{
  position: absolute;
  inset: 0;
}

.page-home .hero-slides{ z-index: 1; }

.page-home .hero-overlay{
  z-index: 2;
  z-index:2;
  background:
  radial-gradient(900px 520px at 50% 40%, rgba(0,0,0,.16), rgba(0,0,0,.26)),
  linear-gradient(to bottom, rgba(0,0,0,.16), rgba(0,0,0,.26));
}


/* slides */
.page-home .hero-slide{
  position:absolute;
  inset:0;
  background-image: var(--bg);
  background-size: 110%;
  background-position:center;
  background-repeat:no-repeat;

  opacity:0;
  transform: scale(1);
  transition: opacity 1.2s ease;
  will-change: transform, opacity;
}

/* RIVELLO / LANDING: slider visible */
.page-dev .hero.hero--landing{
  position: relative;
  min-height: 72vh;       /* ajusta si quieres */
  overflow: hidden;
  color: #fff;
}

.page-dev .hero.hero--landing .hero-slides{
  position: absolute;
  inset: 0;
  z-index: 1;
}
/* Rivello: acepta --bg o background-image directo */
.page-dev .hero.hero--landing .hero-slide{
  background-image: var(--bg, none);
}
.page-dev .hero.hero--landing .hero-overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(to bottom, rgba(0,0,0,.11), rgba(0,0,0,.20));
}

/* si tu JS crea .hero-slide dentro de #heroSlides */
.page-dev .hero.hero--landing .hero-slide{
  position: absolute;
  inset: 0;
  background-size: cover;        /* o 110% si tu look es ken-burns */
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 900ms ease;
  will-change: opacity, transform;
}

.page-dev .hero.hero--landing .hero-slide.is-active{
  opacity: 1;
}

/* contenido arriba */
/*.page-dev .hero.hero--landing .hero-center{
  position: relative;
  z-index: 3;
}*/

.hero-slide.is-active{
  opacity:1;
  animation: heroZoom 12s linear forwards;
}

.hero-slide.is-leaving{
  opacity:0;
  animation-play-state: paused;
}

@keyframes heroZoom{
  from{ transform: scale(1); }
  to{ transform: scale(1.08); }
}

/* contenido (centrado y con aire real) */
.hero-content{
  position: relative;
  z-index: 3;
  min-height: inherit;

  display: flex;
  flex-direction: column;
  justify-content: center;

  max-width: 820px;
  padding-top: 0; /* si tu header está fijo, esto evita choque */
  align-items: center;
}

/* tipografía */
.hero-kicker{
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .75rem;
  opacity: .85;
  margin-bottom: 30px;
}

.hero h1{
  font-size: clamp(44px, 5.5vw, 74px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
}

.hero-sub{
  font-size: clamp(16px, 1.6vw, 20px);
  max-width: 46ch;
  opacity: .92;
  margin-top: 30px;
}

.hero-sub, .hero h1, .hero-kicker{
drop-shadow:
  0 12px 40px rgba(0,0,0,.09),
  0 2px 8px rgba(0,0,0,.07);
}

/* ===== HERO SEARCH DOCK (anclado al final del hero) ===== */



.hero-search select{
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  background-image: none;

}

.hero-search .dev-filter select{
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' stroke='%231e2a3b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 8 10 12 14 8'/%3E%3C/svg%3E");

  background-repeat: no-repeat;
  background-position: right 18px center;
  background-size: 14px;
}

.hero-search .dev-filter select{
  background-position: right 22px center;

}


.hero-search select#fCiudad{

  background-image:
    url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23B4533F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 21s-6-5.2-6-10a6 6 0 1112 0c0 4.8-6 10-6 10z'/%3E%3Ccircle cx='12' cy='11' r='2.5'/%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' stroke='%231e2a3b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 8 10 12 14 8'/%3E%3C/svg%3E");

    background-repeat: no-repeat, no-repeat;
    background-position: left 14px center, right 18px center;
    background-size: 19px, 14px;
}

.hero-search select#fPlantas{
  background-image:
  url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23B4533F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 10l9-7 9 7'/%3E%3Cpath d='M5 10v10h14V10'/%3E%3Cpath d='M9 20v-6h6v6'/%3E%3C/svg%3E"),
  url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' stroke='%231e2a3b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 8 10 12 14 8'/%3E%3C/svg%3E");

  background-repeat: no-repeat, no-repeat;
  background-position: left 14px center, right 18px center;
  background-size: 17px, 14px;
}

.hero-search select#fHabitaciones{
  background-image:
  url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23B4533F' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 12h18v6H3z'/%3E%3Cpath d='M3 12V9a3 3 0 013-3h3a3 3 0 013 3v3'/%3E%3Cpath d='M3 18v3M21 18v3'/%3E%3C/svg%3E"),
  url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' fill='none' stroke='%231e2a3b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolyline points='6 8 10 12 14 8'/%3E%3C/svg%3E");

  background-repeat: no-repeat, no-repeat;
  background-position: left 14px center, right 18px center;
  background-size: 17px, 14px;
}

.hero-search select:disabled{
  opacity: .55;
  cursor: not-allowed;
}


.hero-search{
  position: absolute;
  left: 0;
  right: 0;

  /* clave: que se “pegue” al borde inferior del hero */
  bottom: 0;

  /* lo bajamos un poquito para que “cuelgue” */
  transform: translateY(50%);

  z-index: 10;
  pointer-events: none; /* evita que capas del hero estorben */
}

.hero-search .container{ pointer-events: auto; }

.hero-search .section-filter{ margin: 0; }

.hero-search .dev-filter{
  display: grid;
  grid-template-columns: 0.9fr 0.6fr 0.6fr 2.6fr auto; /* precio un poco más ancho */

  gap: 12px;

  padding: 18px 19px;
  border-radius: 999px;

  background: rgba(255,255,255,.95);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow:
    0 12px 40px rgba(0,0,0,.07),
    0 2px 8px rgba(0,0,0,.03);

  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.hero-search .dev-filter select,
.hero-search .dev-filter input[type="range"]{
  border-radius: 999px;
}

.hero-search #btnBuscar{
  border-radius: 999px;
  padding-inline: 18px;
  white-space: nowrap;
}

/* para que el contenido de abajo deje espacio al dock */
.home-developments{
  padding-top: 120px;
}

/* responsive */
@media (max-width: 960px){
  .hero{ padding-bottom: 140px; }
  .hero-search{ transform: translateY(60%); }

  .hero-search .dev-filter{
    grid-template-columns: 1fr 1fr;
    border-radius: 24px;
  }
  .hero-search .precio-filter{ grid-column: 1 / -1; }
  .hero-search #btnBuscar{
    grid-column: 1 / -1;
    justify-self: stretch;
  }
}



/*   */
.hero-search .precio-filter{
  display: flex;
  align-items: center;
  gap: 16px;
  padding-inline: 8px;
  height: 40px
}

/* Label “Precio” al mismo nivel */
.hero-search .precio-label{
  margin: 0;
  font-size: .85rem;
  opacity: .8;
  white-space: nowrap;
  color: var(--text);
}

/* La barra (range) un poco más corta */
.hero-search .precio-range{
  flex: 1;
  min-width: 180px;     /* ajusta según se vea */
  max-width: 420px;     /* esto controla qué tan “corta” queda */
}

/* Texto de rango a la derecha, compacto */
.hero-search .precio-texto{
  margin: 0;
  font-size: .85rem;
  font-weight: 500;
  opacity: .75;
  white-space: nowrap;
  color: var(--text);
}



/* Track */
.hero-search input[type="range"]::-webkit-slider-runnable-track{
  height: 6px;
  background: rgba(0,0,0,.12);
  border-radius: 999px;
}

/* Parte activa (hack usando background) */
.hero-search input[type="range"]{
  accent-color: var(--brand); /* esto ya pinta thumb + track en modernos */
}

/* Thumb */
.hero-search input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--brand);
  border: none;
  box-shadow: 0 2px 6px rgba(0,0,0,.18);
  margin-top: -6px;
  cursor: pointer;
}
.hero-search input[type="range"]::-moz-range-track{
  height: 6px;
  background: rgba(0,0,0,.12);
  border-radius: 999px;
}

.hero-search input[type="range"]::-moz-range-thumb{
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--brand);
  border: none;
  box-shadow: 0 2px 6px rgba(0,0,0,.18);
  cursor: pointer;
}

/*   */


@media (max-width: 768px){
  .hero{ min-height: 480px; }
  .hero-content{ padding-top: 88px; }
}


/* */
.section-head{ margin: 28px 0 18px; }
.section-head h2{ margin:0 0 8px; font-size: clamp(1.5rem, 2.4vw, 2.1rem); }
.section-head p{ margin:0; color:var(--muted); max-width: 60ch; }



.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:42px;
  padding:0 16px;
  border-radius: 999px;
  border:1px solid var(--line);
  color:var(--text);
  text-decoration:none;
  background: transparent;
  cursor:pointer;
}
.btn-primary{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.16);
}
.btn-ghost{ background: transparent; }


.home-developments{
  padding: 10px 0 24px;
}

.section{
  padding: 56px 0;
}

.section-head{
  margin-bottom: 22px;
  align-items: center;
}
.section-head h2{
  margin:0 0 8px;
  font-size: clamp(1.5rem, 2.2vw, 2.1rem);
  letter-spacing: -.01em;
}
.section-head p{
  margin:0;
  color:var(--muted);
  max-width: 62ch;
}




.about{
  padding: 42px 0 64px;
}
.about-inner{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
  align-items:stretch;
}
.about-copy p{ color:var(--muted); max-width: 65ch; }
.about-points{ margin: 16px 0 0; padding-left: 18px; color:var(--text); }
.about-card{
  border-radius: var(--r-lg);
  border:1px solid var(--line);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow);
}

/* Responsive */
@media (max-width: 900px){
  .hero-inner, .about-inner{ grid-template-columns: 1fr; }
  .hero-visual{ min-height: 220px; }
}

/*.dev-filter{
display:flex;
gap:12px;
align-items:center;
flex-wrap:wrap;
}

/*.precio-placeholder{
margin-left:auto; /* empuja esto a la derecha */
/*padding:10px 12px;
border:1px solid #ddd;
border-radius:10px;
font-size:14px;
opacity:.7;
white-space:nowrap;
}*/


/* CSS DE FILTROS*/


.dev-filter{
  display:flex;
  gap:12px;
  align-items:end;
  flex-wrap:wrap;
  padding: 14px;
  border-radius: var(--r-lg);
  border: 1px solid var(--line);
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
}

/* Selects */
.dev-filter select{
  height: 44px;
  padding: 0 12px;
  padding-left: 38px;   /* espacio para el icono */
  padding-right: 36px !important; /* más espacio interno */
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  outline: none;
  min-width: 180px;
}
.dev-filter select:focus{
  border-color: rgba(59,130,246,.45);
  box-shadow: 0 0 0 4px rgba(59,130,246,.14);
}

/* Botón buscar */
#btnBuscar{
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: none;
  background: #2b2e33;     /* gris carbón elegante */
  color: #fff;
  cursor: pointer;
  white-space: nowrap;
  transition: transform .15s ease, opacity .15s ease;
}
#btnBuscar:hover{ transform: translateY(-1px);
background: #222529; }
#btnBuscar:active{ transform: translateY(0); opacity:.92; }



.precio-placeholder{
  margin-left:auto;
}


@media (max-width: 768px){
.precio-placeholder{ margin-left:0; width:100%; }
#btnBuscar{ width:100%; }
.dev-filter select{ width:100%; }
}

/*.dev-results{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
}*/
.dev-card{
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--card);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow3);
  transition: transform .22s ease, box-shadow .22s ease;
  }

  /* Carrusel: solo controla el ancho y snap */
.car-track .dev-card{
  flex: 0 0 clamp(240px, 28vw, 340px);
  scroll-snap-align: center;
  border-radius: 26px; /* si quieres mantenerlo más redondo en carrusel */
}
.dev-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow4);
}

.dev-card__img {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #eee;
}

.dev-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.dev-card__body {
  padding: 16px 18px 18px;
}


.dev-card__title{
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}
.dev-card__meta {
  font-size: .9rem;
  color: #666;
}

/*@media (max-width: 992px){ .dev-results{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width: 520px){ .dev-results{ grid-template-columns:1fr; } }*/

.results-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    z-index: 4;
    margin: 0 0;
    gap: 30px;
    padding-left: 20px;
    padding-right: 20px;
}

.no-results{padding:18px;border:1px solid #eee;border-radius:12px;opacity:.8}
.btn-reset {
    border: 1px solid #ddd;
    background: transparent;
    border-radius: 30px;
    padding: 4px 16px;
    cursor: pointer;
}

.results-carousel{
  position: relative;
  padding: 18px 24px;   /* antes 28px 56px */
  border-radius: 40px;
  background: rgba(0,0,0,.03);
  backdrop-filter: blur(10px);
}

.results-carousel{
  overflow: hidden;
}


  .car-viewport{
  overflow: visible;    /* antes hidden */
}


.car-track{
  display: flex;
  gap: 18px;
  padding: 18px 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}




.car-track::-webkit-scrollbar{ height: 10px; }
.car-track::-webkit-scrollbar-thumb{ background: rgba(0,0,0,.12); border-radius: 999px; }
.car-track::-webkit-scrollbar-track{ background: transparent; }

.dev-card{
  flex: 0 0 clamp(240px, 28vw, 340px);
  scroll-snap-align: center;
  border-radius: 26px;
}



/* flechas */
.car-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 999px;
  cursor: pointer;
  background: rgba(255,255,255,.92);
  border: none;
  box-shadow: var(--shadow);
  font-size: 26px;
  line-height: 1;
  display: grid;
  place-items: center;
  transition: transform .2s ease, opacity .2s ease;
  z-index: 4;
}

.car-btn:hover{ transform: translateY(-50%) scale(1.06); }

.car-prev{ left: 10px; }
.car-next{ right: 10px; }

.car-btn[disabled]{
  opacity: .35;
  cursor: default;
  box-shadow: none;
}



/* Contenedor del carrusel/cards */
.dev-results {
  transition: opacity 220ms ease, transform 220ms ease;
  will-change: opacity, transform;
}

/* Estado “salida” */
.dev-results.is-fading {
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
}


/* móvil: menos padding y flechas más chicas */
@media (max-width: 640px){
  .results-carousel{ padding: 20px 44px; border-radius: 28px; }
  .car-btn{ width: 38px; height: 38px; font-size: 24px; }
}


.precio-filter { min-width: 320px; }
.precio-label { font-size: 14px; margin-bottom: 8px; }
.precio-range { position: relative; height: 14px; }
.precio-range input[type="range"]{
  width: 100%;
  position: absolute;
  left: 0; top: 0;
  pointer-events: none; /* evita conflicto */
}
.precio-range input[type="range"]::-webkit-slider-thumb{
  pointer-events: all; /* solo el thumb sí recibe click */
}
.precio-texto { font-size: 14px; margin-top: 8px; opacity: .85; }



/*    FADES CAOUSEL  */
/* El contenedor debe ser relative */

/* Fade izquierdo */
.results-carousel::before,
.results-carousel::after{
  content:"";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 70px;                 /* controla intensidad */
  pointer-events: none;        /* no bloquea scroll */
  z-index: 3;
}

/* izquierda */
.results-carousel::before{
  left: 24px;
  background: linear-gradient(
    to right,
    rgba(247,247,247,1) 0%,
    rgba(247,247,247,.9) 40%,
    rgba(247,247,247,0) 100%
  );
}

/* derecha */
.results-carousel::after{
  right: 24px;
  background: linear-gradient(
    to left,
    rgba(247,247,247,1) 0%,
    rgba(247,247,247,.9) 40%,
    rgba(247,247,247,0) 100%
  );
}


/* Fade base oculto */
.results-carousel::before,
.results-carousel::after{
  opacity: 0;
  transition: opacity 220ms ease;
}

/* Cuando hay contenido a la izquierda */
.results-carousel.has-left::before{
  opacity: 1;
}

/* Cuando hay contenido a la derecha */
.results-carousel.has-right::after{
  opacity: 1;
}





/*banner about*/

.about-banner{
  margin-top: 86px;
}

.about-banner__box{
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  min-height: 400px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

/* fondo ahora vive dentro del box */
.about-banner__bg{
  position:absolute;
  inset:0;
  background-image: url("../img/home/sobre_nosotros.jpg");
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
}

.about-banner__overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(
    90deg,
    rgba(0,0,0,.20) 0%,
    rgba(0,0,0,.12) 42%,
    rgba(0,0,0,.10) 100%
  );
}

.about-banner__content{
  position: relative;
  z-index: 1;
  max-width: 520px;
  padding: 56px 94px;
  color: #fff;
  text-align: left; /* mantenemos editorial */

}

.about-banner .btn-primary{
  background: var(--brand);
  border: none;
  color: #fff;

  border-radius: 999px;
  padding: 10px 22px;

  transition: transform .2s ease, box-shadow .2s ease;
  box-shadow:
    0 8px 20px rgba(0,0,0,.12),
    0 2px 6px rgba(0,0,0,.06);
}

.about-banner .btn-primary:hover{
  transform: translateY(-2px);
}

/* About banner: H2 con feel de hero */
.about-banner__content h2{
  font-size: clamp(30px, 3.6vw, 47px);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}

/* párrafo un poco más editorial */
.about-banner__content p{
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.75;
  max-width: 48ch;
  opacity: .92;
  margin: 0 0 18px;
}


/*         BLOG       */
.home-blog{
  padding: 64px 0;
}

.blog-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.blog-card{
  display: block;
  background: #fff;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  transition: transform .25s ease, box-shadow .25s ease;
}

.blog-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
}

.blog-card__img{
  aspect-ratio: 16/9;
  overflow: hidden;
}

.blog-card__img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition: transform .4s ease;
}

.blog-card:hover .blog-card__img img{
  transform: scale(1.05);
}

.blog-card__body{
  padding: 18px 20px 22px;
}

.blog-card__body h3{
  margin: 0 0 8px;
  font-size: 1.05rem;
  letter-spacing: -.01em;
}

.blog-card__body p{
  margin: 0 0 14px;
  font-size: .92rem;
  color: var(--muted);
}

.blog-read{
  font-size: .9rem;
  font-weight: 600;
  color: #0f172a;
}


@media (max-width: 992px){
  .blog-grid{
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px){
  .blog-grid{
    grid-template-columns: 1fr;
  }
}



.blog-card,
.blog-card:visited{
  text-decoration: none;
  color: var(--text);
}

.blog-card__body h3{
  color: var(--text);
}

.blog-card__body p{
  color: var(--muted);
}

.blog-card{
  text-decoration: none;
  color: var(--text);
}

.blog-card__body h3{
  color: var(--text);
}

.blog-card__body p{
  color: var(--muted);
}


/* REDES FEED*/

.social-feeds{ padding: 64px 0; }

.social-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

.social-card{
  background:#fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  box-shadow: var(--shadow);
  overflow:hidden;
}

.social-card__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 18px 18px 12px;
}

.social-card__head h3{ margin:0; font-size: 1.05rem; }
.social-card__head p{ margin:6px 0 0; color: var(--muted); font-size:.92rem; }

.social-embed{
  padding: 0 18px 18px;
}

.social-iframe{
  width:100%;
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.08);
  background:#fff;
  min-height: 520px;
}

.social-fallback{
  border-radius: 16px;
  border: 1px dashed rgba(15,23,42,.18);
  background: rgba(2,6,23,.03);
  color: var(--muted);
  padding: 16px;
  min-height: 220px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

@media (max-width: 900px){
  .social-grid{ grid-template-columns: 1fr; }
}
.social-embed{
  min-height: 420px;
}

.social-fallback[hidden]{
  display: none !important;
}





/*       FOOTER    */

.site-footer{
  margin-top: 80px;
  padding: 56px 0 28px;
  color: rgba(255,255,255,.86);
  background: linear-gradient(
    to bottom,
    #2f3237,
  #2c2f34 60%,
  #292c31
  );
  position: relative;
}


.page-site .site-footer {
    margin-top: 0;
}

.page-site .sec-about {
    padding-bottom: 0;
    margin-bottom: 0;
}


.site-footer::before{
  content:"";
  position:absolute;
  top:-60px;
  left:0;
  right:0;
  height:60px;
  background: linear-gradient(to bottom, transparent, #DCDDDE);
  pointer-events:none;
}


.footer-top{
  display:grid;
  grid-template-columns: 1.05fr 1.95fr;
  gap: 36px;
  align-items:start;
}

.footer-brand img{
  height: 38px;
  width:auto;
  display:block;
}

.footer-desc{
  margin: 14px 0 18px;
  max-width: 42ch;
  color: rgba(255,255,255,.70);
  line-height: 1.55;
}

.footer-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
}

.footer-cols{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

.footer-col h4{
  margin: 0 0 12px;
  font-size: .95rem;
  letter-spacing: .02em;
}

.footer-col ul{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap: 10px;
}

.footer-col a{
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: color .18s ease, opacity .18s ease;
}

.footer-col a:hover{
  color: #fff;
}

.footer-bottom{
  margin-top: 34px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 16px;
  flex-wrap: wrap;
}


.footer-legal{
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(255,255,255,.70);
}

.footer-legal a{
  color: rgba(255,255,255,.70);
  text-decoration:none;
}
.footer-legal a:hover{ color:#fff; }

.dot{ opacity:.55; }

/* Responsive */
@media (max-width: 900px){
  .footer-top{
    grid-template-columns: 1fr;
  }
  .footer-cols{
    grid-template-columns: 1fr;
  }
}


/* Botón acordeón */
.footer-acc-btn{
  width: 100%;
  display: none;                 /* desktop: oculto */
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  background: transparent;
  border: 0;
  padding: 14px 0;
  color: #fff;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
}

.footer-acc-ic{
  opacity: .8;
  transition: transform .18s ease;
}

/* Panel */
.footer-acc-panel{
  display: block;                /* desktop: siempre visible */
}

/* Mobile: activamos acordeón */
@media (max-width: 900px){
  .footer-col h4{ display:none; }              /* ya no usamos h4 */
  .footer-acc-btn{ display:flex; }

  .footer-col{
    border-top: 1px solid rgba(255,255,255,.10);
    padding-top: 2px;
  }

  .footer-acc-panel{
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height .28s ease, opacity .22s ease;
    will-change: max-height;
  }

  .footer-col.is-open .footer-acc-panel{
    max-height: 600px;  /* suficiente para listas */
    opacity: 1;
    padding-bottom: 14px;
  }

  .footer-col.is-open .footer-acc-ic{
    transform: rotate(180deg);
  }
}



.footer-city-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap: 10px;
}

.footer-city{
  position: relative;
}

.footer-city-btn{
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;

  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;

  color: rgba(255,255,255,.78);
  font: inherit;
  text-align: left;
}


.footer-city-btn:hover{ color:#fff; }

.footer-city-ic{
  opacity:.75;
  transition: transform .18s ease;
}

/* Submenu flotante */
.footer-submenu{
  position: absolute;
  left: 50%;
  top: -8px;
  margin-left: 12px;

  min-width: 220px;
  padding: 8px;
  border-radius: 14px;

  background: rgba(255,255,255,.94);
  border: 1px solid rgba(15,23,42,.12);
  box-shadow: 0 18px 46px rgba(2,6,23,.24);

  display: none;
  z-index: 60;
}

.footer-submenu a{
  display:block;
  padding: 10px 10px;
  border-radius: 10px;
  color: #0f172a;
  text-decoration:none;
  font-weight: 500;
}

.footer-submenu a:hover{
  background: rgba(2,6,23,.06);
}

/* Desktop: hover/focus abre */
@media (hover:hover){
  .footer-city.has-sub:hover .footer-submenu,
  .footer-city.has-sub:focus-within .footer-submenu{
    display:block;
  }

  .footer-city.has-sub:hover .footer-city-ic,
  .footer-city.has-sub:focus-within .footer-city-ic{
    transform: rotate(90deg);
  }
}

/* Mobile: el submenu ya NO flota a la derecha (se abre debajo) */
@media (max-width: 900px){
  .footer-submenu{
    position: static;
    margin: 10px 0 0;
    display: none;
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.10);
    box-shadow: none;
  }

  .footer-submenu a{
    color: rgba(255,255,255,.88);
  }
  .footer-submenu a:hover{
    background: rgba(255,255,255,.08);
  }

  .footer-city.is-open .footer-submenu{
    display:block;
  }

  .footer-city.is-open .footer-city-ic{
    transform: rotate(90deg);
  }
}

.footer-contact-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.footer-contact-list a{
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.78);
  text-decoration: none;
  transition: color .18s ease;
}

.footer-contact-list a:hover{
  color: #fff;
}

.footer-ic{
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: .8;
}

.footer-ic svg{
  width: 100%;
  height: 100%;
  fill: currentColor;
}


/* TERMINA FOOTER AQUI  */

/* LANDINGS*/


/* LANDING ONLY (Rivello) */
.page-dev .hero.hero--landing{
  position: relative;
  min-height: 72vh;          /* o el valor que quieras */
  overflow: hidden;          /* aquí sí recortas el slide */
  padding: 0;                /* mata padding del home */
  color: #fff;
}

.page-dev .hero.hero--landing .hero-slides,
.page-dev .hero.hero--landing .hero-overlay{
  position: absolute;
  inset: 0;
}

/*.page-dev .hero.hero--landing .hero-center{
  position: relative;
  z-index: 3;
  height: 100%;
  min-height: inherit;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 96px 0;           /* aire editorial
}*/

/* el nav se “sube” para quedar encimado al hero */
/* Encimado + sticky real */
/* wrap: solo controla el encimado */
./* sticky en wrapper */
./* wrapper sticky real */
.landing-nav-wrap{
  position: relative;
  top: 12px;
  z-index: 999;
}

.btn-whats{
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 12px 22px;
  border-radius: 999px;

  background: var(--nav-tint);
  color: #fff;

  /*background: color-mix(in srgb, var(--nav-tint) 85%, transparent);
  backdrop-filter: blur(8px);*/


  font-weight: 400;
  font-size: .95rem;
  letter-spacing: .02em;

  opacity: .82;
  transition: opacity .25s ease, transform .25s ease;
}

.btn-whats:hover{
  opacity: 1;
  transform: translateY(-2px);
}

.btn-whats .btn-ic{
  display:flex;
  align-items:center;
  justify-content:center;
}





/* compensación para que no tape la sección siguiente */
.landing-nav-wrap + .section{
  padding-top: 26px;
}

/* por si algún parent está creando stacking/clip raro */
body, html{ overflow: visible; }


/* sticky REAL lo hace el nav */



.landing-nav-wrap:has(.landing-nav){
  /* opcional, solo si quieres algo especial */
}


/* opcional: si tu nav es alto y tapa anchors */
:where(#resumen,#video,#galeria,#modelos,#mapa,#contacto){
  scroll-margin-top: 110px;
}

/* encimado visual (NO margin negativo) */
.landing-nav{
  transform: translateY(-40px);
  position: relative;
  z-index: 1000;

}


/*kjhdkusghfb*/









/* Navegación base */
.landing-nav{
  display:flex;
  align-items:center;
  position: relative;
  gap: 40px;
  justify-content: space-between;

  padding: 12px 16px;
  border-radius: 18px;

    background: color-mix(in srgb, var(--nav-tint) 84%, transparent);
    border: 1px solid rgba(255,255,255,.14);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 18px 54px rgba(2,6,23,.22);

    color: rgba(255,255,255,.92);

  transition: border-radius .18s ease, box-shadow .18s ease, background .18s ease;
}


.hero.hero--landing{ position: relative; }

/* deja espacio para el nav que está “colgando” */
.hero.hero--landing + .section{
  padding-top: 90px; /* ajusta 80–110 según tu nav */
}

/* z-index del nav por si acaso */
.hero-subnav-wrap{ z-index: 6; }


.landing-back{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  text-decoration:none;
  color:#0f172a;
  background: rgba(2,6,23,.06);
}
.landing-back:hover{ background: rgba(2,6,23,.10); }

/* izquierda: back + logo */
.landing-brand{
  display: inline-flex;
  align-items: center;
  margin-left: 6px; /* opcional */
}

.landing-brand img{
  height: 54px;
  width:auto;
  display:block;
}

/* centro perfecto */

.landing-links{
  display:flex;
  margin-left: auto;
  margin-right: auto;
  gap: 36px;
  flex: 1;
  min-width: 0;
  overflow:auto;
  scrollbar-width: none;

  align-items: center;
  white-space: nowrap;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);

}


.landing-links::-webkit-scrollbar{ display:none; }


/* botón back + logo */
.landing-back{
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.92);
}
.landing-back:hover{ background: rgba(255,255,255,.18); }




.landing-links a{
  text-decoration:none;
  color: rgba(255,255,255,.86);
    opacity: .92;
  font-weight: 600;
  font-size: .92rem;
  white-space: nowrap;
}
.landing-links a:hover{ opacity: 1; }

.landing-cta{
  text-decoration:none;
  font-weight: 700;
  font-size: .92rem;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  color: rgba(15,23,42,.92);
  white-space: nowrap;
  margin-left: auto;
}

/* back ya lo tienes, esto hace match */
.landing-cta--ghost{
  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 12px 18px;
  border-radius: 999px;

  background: rgba(255,255,255,.14);   /* mismo lenguaje glass */
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;

  font-weight: 400; /* regular */
  opacity: .85;

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transition: opacity .2s ease, transform .2s ease, background .2s ease;
}

.landing-cta--ghost:hover{
  opacity: 1;
  transform: translateY(-1px);
  background: rgba(255,255,255,.18);
}

.landing-cta--ghost .ic{
  display:grid;
  place-items:center;
  width: 28px;
  height: 28px;
}


/* Estado sticky: cuando llega al top */


.hero-subnav-wrap.is-sticky .landing-nav{
  border-radius: 18px;
  box-shadow: 0 18px 54px rgba(2,6,23,.20);
}

/* Mobile */
@media (max-width: 768px){
  .hero-subnav-wrap{ bottom: -18px; }
  .hero-subnav-wrap.is-sticky{ top: 10px; }
  .landing-cta{ display:none; } /* opcional: para compactar */
}





/* Overview 2 columnas */
.overview-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items:center;
}
.mini-slider{
  border-radius: 22px;
  overflow:hidden;
  background: rgba(2,6,23,.03);
  border: 1px solid var(--line);
  aspect-ratio: 16/10;
}
.overview-copy p{ color: var(--muted); line-height: 1.65; }
.overview-actions{ display:flex; gap: 12px; flex-wrap:wrap; margin-top: 18px; }






/* ===== VIDEO + AMENIDADES ===== */

.dev-video{
  padding: 80px 0;
}

/* Contenedor con fondo distinto */
.video-card{
  background: rgba(0,0,0,.04);
  border-radius: 32px;
  padding: 48px 40px;
  padding-bottom: 70px;
  /*box-shadow: 0 20px 60px rgba(2,6,23,.08);*/

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 42px;
}


/* ===== VIDEO ===== */

.video-embed{
  width: 100%;
  max-width: 980px;
  aspect-ratio: 16 / 9;
  border-radius: 22px;
  overflow: hidden;
  position: relative;
  background: rgba(0,0,0,.08);
}

.video-embed iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.amenities-block{
  width: 100%;
  max-width: 1100px;
}

.amenities-title{
  margin: 0 0 22px;
  text-align: center;
  font-size: clamp(1.15rem, 1.6vw, 1.35rem);
  font-weight: 500;
  letter-spacing: .06em;
  /*text-transform: uppercase;*/
  opacity: .9;
  margin-top:60px:
}

/* 4–5 por fila en desktop */
.amenities{
  display: grid !important; /* fuerza si algo te lo pisa */
  grid-template-columns: repeat(auto-fit, minmax(190px, 1fr));
  gap: 34px 36px;
  justify-items: center;
  width: 90%;
  max-width: 1100px;
}

.amenity{
  width: 100%;
  max-width: 240px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}

.amenity-icon{
  width: 44px;
  height: 44px;
  color: #C8573C;
  stroke-width: 1.5;
  opacity: .92;
  transition: transform .25s ease, opacity .25s ease;
}

.amenity span{
  font-size: .95rem;
  font-weight: 400;
  color: rgba(15,23,42,.86);
  line-height: 1.25;
}

/* micro-interacción premium */
.amenity:hover .amenity-icon{
  transform: translateY(-2px);
  opacity: 1;
}

/* responsive */
@media (max-width: 760px){
  .amenities{
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 26px 18px;
  }
  .amenity-icon{ width: 40px; height: 40px; }
}






/* Video + amenidades
.video-card{
  border-radius: 26px;
  overflow:hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background:#fff;
}
.video-embed{
  aspect-ratio: 16/9;
  background: #000;
}
.video-embed iframe{ width:100%; height:100%; border:0; display:block; }

.amenities{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  padding: 18px;
}
.amenity{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(2,6,23,.03);
  border: 1px solid rgba(15,23,42,.08);
}
.amenity .ic{
  width: 18px; height: 18px;
  display:grid; place-items:center;
  opacity: .75;
}
*/



/* ===== Cintillo fullwidth (marquee) ===== */
.section-band{
  padding: 0; /* sin padding visible */
}

/* full-bleed real */
.band-marquee{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  overflow: hidden;
  position: relative;
  background: #fff; /* opcional: evita “flash” si tarda en cargar */
}

/* franja */
.band-track{
  display: flex;
  flex-wrap: nowrap;
  will-change: transform;
  animation: bandScroll var(--band-dur, 42s) linear infinite;
}

/* item ocupa 1/3 del viewport => 3 visibles sin gaps */
.band-item{
  flex: 0 0 33.3333vw;
  height: clamp(220px, 28vw, 360px); /* ajusta altura aquí */
  overflow: hidden;
}

.band-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}

/* movimiento continuo */
@keyframes bandScroll{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); } /* porque duplicamos lista */
}

/* sin scrollbar */
.band-track{ scrollbar-width: none; }
.band-track::-webkit-scrollbar{ display:none; }

/* responsive: 2 visibles */
@media (max-width: 900px){
  .band-item{ flex-basis: 50vw; }
}

/* responsive: 1 visible */
@media (max-width: 560px){
  .band-item{ flex-basis: 100vw; }
}

/* Accesibilidad: respeta reduced motion */
@media (prefers-reduced-motion: reduce){
  .band-track{ animation: none; }
}



.band-marquee::before,
.band-marquee::after{
  content:"";
  position:absolute;
  top:0; bottom:0;
  width: 90px;
  pointer-events:none;
  z-index:2;
}
.band-marquee::before{
  left:0;
  background: linear-gradient(to right, rgba(225,225,225,.45), transparent);
}
.band-marquee::after{
  right:0;
  background: linear-gradient(to left, rgba(225,225,225,.45), transparent);
}



/* Fullwidth slider (simple track horizontal)
.full-slider{
  position: relative;
  padding: 26px 0 34px;
  background: rgba(2,6,23,.03);
}
.full-slider__track{
  display:flex;
  gap: 18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  padding: 0 18px;
}
.full-slide{
  flex: 0 0 min(1100px, 92vw);
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  scroll-snap-align: center;
}
.full-slide img{
  width:100%;
  height: 320px;
  object-fit: cover;
  border-radius: 22px;
  display:block;
}

.full-slider__nav .car-btn{
  top: 50%;
  transform: translateY(-50%);
  position:absolute;
}
.full-slider__nav .car-prev{ left: 18px; }
.full-slider__nav .car-next{ right: 18px; }*/





.map-box{
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid var(--line);
  min-height: 360px;
  background: rgba(2,6,23,.03);
}

/* Form */
.form-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
  align-items:start;
}
.form-card{
  background:#fff;
  border-radius: 22px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  padding: 18px;
  display:grid;
  gap: 12px;
}
.form-card label{ display:grid; gap: 8px; font-weight: 600; font-size: .9rem; }
.form-card input, .form-card textarea{
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.14);
  padding: 12px 12px;
  font: inherit;
}
.muted{ color: var(--muted); }

@media (max-width: 900px){
  .overview-grid, .form-grid{ grid-template-columns: 1fr; }
  .amenities{ grid-template-columns: 1fr; }
  .full-slide{ grid-template-columns: 1fr; }
  .full-slide img{ height: 240px; }
  .hero-subnav-wrap{ bottom: -18px; }
}


/* Desarollo tabs modelos */

/* ===== Modelos: mood oscuro ===== */

.dev-models .model-tabbar{
  position: relative;
  display: flex;
  gap: 26px;
  align-items: center;
  overflow-x: auto;
  padding: 6px 2px 14px;
}

section.dev-models {
    padding-bottom: 400px;
}

.dev-models .model-tab{
  font-size: calc(1rem + 2px); /* o pon 18px directo si prefieres */

  background: transparent;
  border: 0;
  color: rgba(15,23,42,.75);
  font-weight: 500;
  padding: 10px 4px;
  cursor: pointer;
  white-space: nowrap;
}

.dev-models .model-tab[aria-selected="true"]{
  color: rgba(15,23,42,1);
}

.dev-models .model-underline{
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
  background: #C8573C; /* acento Rivello */
  transition: transform .25s ease, width .25s ease;
}

/* Estructura nueva del panel */
.dev-models .model-panel{
  position: relative;
  overflow: visible;

  margin-top: 33px;
  border-radius: 34px;
  padding: 64px 72px;
  padding-right: 0 !important;

  /* fallback si no hay bg */
  background: #121821;
  color: rgba(255,255,255,.92);
  box-shadow: 0 26px 70px rgba(2,6,23,.35);
}



.dev-models .model-name{
  font-size: clamp(40px, 5.5vw, 66px);
  line-height: .95;
  letter-spacing: -0.02em;
  font-weight: 500 !important;
  margin: 0 0 0; /* este es el aire */
}



/* fondo por modelo (opcional) */
.dev-models .model-panel.has-bg::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  z-index: 0;

  background-image:
    linear-gradient(180deg, rgba(10,14,18,.75), rgba(10,14,18,.97)),
    var(--model-bg-url);
  background-size: cover;
  background-position: center;
}
.dev-models .model-panel > *{ position: relative; z-index: 1; }

.dev-models .model-mid{
  max-width: none;   /* ajusta a gusto */
  justify-self: end;  /* <- lo pega a la derecha de su columna */
  width: 100%;
  max-width: none;    /* opcional, deja que respire */
  padding-right: 0;
}




.dev-models .plan-card img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}




.share-icon{
  position:relative;
  width:24px;
  height:24px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid currentColor;
}

.icon-check{
  position:absolute;
  opacity:0;
  transform:scale(.6);
  transition:all .25s ease;
}

.icon-share{
  transition:all .25s ease;
}

.share-btn.is-copied .icon-share{
  opacity:0;
  transform:scale(.6);
}

.share-btn.is-copied .icon-check{
  opacity:1;
  transform:scale(1);
}

/* botón compartir (top-right del panel) */
.dev-models .share-btn{
  position: absolute;
  top: 0px;        /* igual que tu padding-top del panel */
  right: 32px;      /* igual que tu padding-right del panel */
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 6px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);
  cursor: pointer;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all .25s ease;

}
.dev-models .share-btn:hover{ background: rgba(255,255,255,.10); }
/*.dev-models .share-ic{
  width: 24px; height: 24px;
  border-radius: 999px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.14);
}

.dev-models .share-btn.is-copied{
  outline: 2px solid rgba(200,87,60,.55);
}
*/

/* nuevos*/
/* ===== Slider: 2 completas + 1 parcial ===== */


/* card visual */
.dev-models .model-card {
  /*height: clamp(220px, 26vw, 320px);*/
  --cut: 56px; /* 👈 ajusta aquí (ej. 44, 56, 72) */
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 16 / 11;


  position: relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);

  /* fallback: corte diagonal (sin round interno) */
  clip-path: polygon(
    0 0,
    100% 0,
    100% calc(100% - var(--cut)),
    calc(100% - var(--cut)) 100%,
    0 100%
  );
}


@supports (clip-path: path("M 0 0 H 100% V 100% Z")) {
  .dev-models .model-card{
    --cut: 56px;
    --cr: 18px; /* radio del redondeo del corte */

    clip-path: path(
      "M 0 0
       H 100%
       V calc(100% - var(--cut) - var(--cr))
       Q 100% calc(100% - var(--cut)) calc(100% - var(--cut)) calc(100% - var(--cr))
       L calc(100% - var(--cut)) 100%
       H 0
       Z"
    );
  }
}


.model-card{
  background: rgba(255,255,255,.06); /* o un gris editorial */
}

/* imagen */
.dev-models .model-card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
}

.model-card[data-photo],
.model-photo[data-photo]{
  cursor: pointer;
}


/* Mobile: 1 card + parcial */
@media (max-width: 740px){
  .dev-models .model-slide{
    flex-basis: min(78vw, 360px);
  }
  .dev-models .ms-prev{ left: 8px; }
  .dev-models .ms-next{ right: 8px; }
}


/*****/


/* =======================
   MODELOS: head + tabs
   ======================= */

.dev-models > .container > .section-head{
  text-align: center;
  max-width: 920px;     /* ajusta si quieres más ancho */
  margin-left: auto;
  margin-right: auto;
}

.section-head p {

    max-width: none !important;
}

.dev-models .model-tabs{
  /*display: flex;*/
  justify-content: center;
  margin-top: 22px;     /* separa del texto */
}

/* Tabbar centrada + más separación */
.dev-models .model-tabbar{
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 96px;            /* x2–x3 respecto a lo normal */
  flex-wrap: wrap;      /* por si en mobile no caben */
}

/* Tabs */
.dev-models .model-tab{
  font-size: 20px;
  line-height: 1.1;
  transform: translateY(0) scale(1);
  transform-origin: 50% 100%;
  transition: transform .18s ease, opacity .18s ease;
}

/* Activo ligeramente más grande */
.dev-models .model-tab[aria-selected="true"]{
  font-size: 22px;      /* +2px (cámbialo a 19px si quieres +1) */
  transform: translateY(-1px) scale(1.06); /* equivalente a +1–2px */
}

/* Opcional: que los no-activos se sientan un poquito más suaves */
.dev-models .model-tab[aria-selected="false"]{
  opacity: .68;
}





/* reemplaza la grid vieja */
.dev-models .model-stage{
  display:grid;
  grid-template-columns: .8fr 1.6fr; /* left + mid */
  grid-template-rows: auto 1fr;        /* head + content */
  gap: 22px 48px;
  align-items:start;
  overflow: visible;
  position: relative;

}


.dev-models .model-stage{
  marging-bottom: clamp(90px, 12vw, 140px);
}


/* Head ocupa ambas columnas */
.dev-models .model-head{
 grid-column: 1 / -1;
 display:flex;
 align-items:center;
 justify-content:space-between;
 gap:16px;
}


@media (max-width: 980px){
  .dev-models .model-stage{ grid-template-columns: 1fr; }
}

/* mata el look “card” por columna */
.dev-models .model-col{ background: transparent; border: 0; padding: 0; }

/* nuevos wrappers */
.dev-models .model-left{
  min-height: 420px; /* ajusta a ojo */
}

/* Opcional: que el slider empiece “pegado” debajo del head */
.dev-models .model-left{ grid-column: 1; }
.dev-models .model-mid{  grid-column: 2; }

/* empty slide */
.dev-models .model-empty{
  height:100%;
  display:grid;
  place-items:center;
  color: rgba(255,255,255,.7);
}

/* dots */
.dev-models .model-dots{
  display:flex;
  gap: 10px;
  justify-content: center;
  margin-top: 14px;
}
.dev-models .dot{
  width: 28px;
  height: 2px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
  cursor: pointer;
}
.dev-models .dot.is-active{
  background: #C8573C;
}


.dev-models .model-metrics{
  display:flex;
  gap: 26px;
  align-items:center;
  margin: 10px 0 18px;
}

.dev-models .model-metrics .metric{
  color: rgba(255,255,255,.7); /* 7% */
}

.dev-models .metric{
  display:flex;
  gap: 10px;
  align-items:center;
  font-size: 1.05rem;
}

.dev-models .m-ic{
  width: 26px;
  height: 26px;
  display:grid;
  place-items:center;
  border-radius: 8px;
  border: 0 solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.0);
  font-size: 14px;
}
.dev-models .model-metrics .m-ic{
  opacity: .7;
}

/* iconos SVG */

.dev-models .icon-btn svg{
  width: 34px;
  height: 34px;
  display: block;
}
button.icon-btn {
padding-block: 1px;
    padding-inline: 2px !important;
}
.dev-models .m-ic svg{
  width: 18px;
  height: 18px;
  display: block;
}

.dev-models .m-ic{
  color: rgba(255,255,255,.92); /* hace que svg con currentColor se vea */
}

.dev-models .icon-btn{
  color: rgba(255,255,255,.92);
}



.dev-models .btn.btn-ghost{
  color: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  background: rgba(255,255,255,.08) !important;
}

.dev-models .btn.btn-ghost:hover{
  background: rgba(255,255,255,.14) !important;
}

.dev-models .model-actions .btn{
  height: 44px;
  display: inline-flex;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  font-weight: 500;
}


.dev-models .model-mini{
  margin: 14px 0 16px;
  color: rgba(255,255,255,.82);
  line-height: 1.95;
  max-width: 44ch;
  font-size: 1.12rem;
}

.dev-models .model-actions{
  display:flex;
  align-items:center;
  gap: 12px;
  margin: 16px 0 12px;
}


.dev-models .icon-btn{
  width: 44px;
  height: 44px;
  position: relative;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: #fff;
  display:grid;
  place-items:center;
  cursor:pointer;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.dev-models .icon-btn:hover{
  background: rgba(255,255,255,.10);
}

.dev-models .icon-btn::after{
  content: attr(aria-label);
  position: absolute;
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,.55);
  color: #fff;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: .82rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .15s ease;
}

.dev-models .icon-btn:hover::after{ opacity: 1; }

.dev-models .plan-icbtn{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.20);
  background: rgba(255,255,255,.08);
  color: #fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.dev-models .plan-icbtn:hover{
  background: rgba(255,255,255,.14);
}
.dev-models .plan-ic{
  font-size: 18px;
  line-height: 1;
}



/* ===== MODAL (Plantas) ===== */



#planModal.modal{
  position: fixed;
  inset: 0;
  display: none;              /* asumo que lo abres con clase o aria */
  place-items: center;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 9999;



  opacity: 0;
  transition: opacity .18s ease;
  align-items: center;
  justify-content: center;

}

/* Si tú usas aria-hidden para mostrar/ocultar */
.modal[aria-hidden="false"]{
  display: grid;
}

#planModal.modal.is-open{
  display: flex;
opacity: 1;
}

#planModal.modal.is-open .modal-card{
  transform: translateY(0) scale(1);
}


/*gjjgj*/

/* Card: sin marco, sin padding, tamaño por contenido */
.modal-card{
  position: relative;
  width: fit-content;
  height: fit-content;
  max-width: calc(100vw - 24px);
  max-height: calc(100vh - 24px);

  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;

  border-radius: 22px;
  overflow: hidden;
}

/* Ocultamos el head original (ya no lo queremos arriba) */
.modal-head{
  display: none;
}

/****/



/*#planModal .modal-card{
  width: min(980px, 96vw);
  max-height: 92vh;
  border-radius: 22px;
  overflow: hidden;
  background: #0b1220;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 28px 90px rgba(0,0,0,.55);
  transform: translateY(10px) scale(.985);
  transition: transform .22s ease;
}*/

/*#planModal .modal-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
}*/

/*#planModal .modal-close{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: #fff;
  cursor: pointer;
}*/

/* Close flotante (arriba derecha) */
.modal-close{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;

  width: 40px;
  height: 40px;
  border-radius: 999px;

  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.92);

  display: grid;
  place-items: center;
  cursor: pointer;
}

#planModal .modal-close:hover{ background: rgba(255,255,255,.10); }



/* Imagen: manda el tamaño del modal */
#modalImg{
  display: block;
  width: auto;
  height: auto;
  max-width: calc(100vw - 24px);
  max-height: calc(100vh - 24px);
  object-fit: contain;
}



#planModal .modal-body{
  position: relative;
  padding: 0;
  margin: 0;
}

#planModal .modal-body img{
  width: 100%;
  height: auto;
  max-height: calc(92vh - 90px);
  object-fit: contain;
  display: block;
  border-radius: 14px;
}

/* Título glass pill centrado abajo, sobre la imagen */
#modalTitle{
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  z-index: 2;

  padding: 3px 14px;
  border-radius: 999px;

  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  color: rgba(255,255,255,.92);
  font-size: 13px;
  letter-spacing: .02em;
  text-align: center;

  max-width: min(680px, calc(100% - 24px));
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.modal-cap-inner{
  display:flex;
  align-items:center;
  gap:8px;
}

.cap-ic svg{
  width:32px;
  height:32px;
  opacity:.9;
  maegin-top:4px;
}

.cap-text{
  font-size:13px;
  letter-spacing:.02em;
}
/*****/



/* ===== SLIDER MODELOS ===== */

.dev-models .model-slider{
  border-radius: 22px;
  overflow: visible; /* para que se vea el parcial */
  position: relative;
  /*aspect-ratio: 16 / 10;*/
  background: rgba(255,255,255,0);
  border: 0 solid rgba(255,255,255,.12);
  padding-right: 0;
}


.model-slider{
  position: relative;
}


/* overlay */
.ms-loader{
  position: absolute;
  inset: 0;
  border-radius: inherit; /* si tu slider tiene radio */
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  opacity: 0;
  visibility: hidden;
  pointer-events: none;

  transition: opacity .22s ease, visibility 0s linear .22s;
  z-index: 5;
}

/* shimmer */
.ms-shimmer{
  position: absolute;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
}

.ms-shimmer::before{
  content:"";
  position:absolute;
  inset: -30% -60%;
  transform: translateX(-30%);
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,.18) 35%,
    rgba(255,255,255,.06) 50%,
    rgba(255,255,255,.18) 65%,
    transparent 100%
  );
  animation: msShimmer 1.1s linear infinite;
  will-change: transform;
}

@keyframes msShimmer{
  from{ transform: translateX(-35%); }
  to  { transform: translateX(35%); }
}

/* estado loading activo */
.model-slider.is-loading .ms-loader{
  opacity: 1;
  visibility: visible;
  transition: opacity .22s ease;
}

.model-slider::after{
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;              /* ajustable */
  height: 100%;
  pointer-events: none;
  background: linear-gradient(
    to right,
    rgba(22,25,26,0) 0%,
    rgba(22,25,26,.8) 70%,
    rgba(22,25,26,1) 100%
  );
}





/* track */ /* Ajusta cuánto se asoma la 3ra card (0.28 a 0.40 típico) */
.dev-models .model-slider-track{
  --peek: .22;
  --gap: 14px;
  gap: var(--gap);
  --cardW: 520px;             /* JS lo recalcula */
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;

  padding-right: 0;           /* <- clave: pegado a la derecha */

  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  padding-left: 0;

}



.dev-models .model-slider-track::-webkit-scrollbar{ display:none; }

.dev-models .model-slide{
  flex: 0 0 var(--cardW);     /* <- ancho por tarjeta */
  scroll-snap-align: start;
}


.dev-models .model-slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Flechas */
.dev-models .ms-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.25);
  color: #fff;
  cursor: pointer;
  display: grid;
  place-items: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 6;
}
.dev-models .ms-prev{ left: -21px; }
.dev-models .ms-next{ right: 43px; }
.dev-models .ms-btn:hover{ background: rgba(0,0,0,.35); }




/* HERO INFO*/
.hero.hero--landing{ position: relative; min-height: 620px; }

/*.hero-center{
  position: absolute;
  inset: 0;
  z-index: 3;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 24px;
  gap: 8px; /* controla separación aquí
}*/

.hero-center{
  position: absolute;
  display: flex;
  flex-direction:column;
  inset: 0;
  z-index: 3; /* arriba de overlay */
  align-items:center;
  justify-content:center;
  padding: 24px;
  gap: 60px;
}

.hero-logo{
  height: clamp(74px, 9vw, 112px);
  width: auto;
  display: block;
  margin: 0 auto 0;
  filter: drop-shadow(0 18px 38px rgba(0,0,0,.35));
}


.hero-phrase{
  font-size: clamp(1.35rem, 2.7vw, 2.35rem);
  line-height: 1.1;
  /*letter-spacing: -0.015em;*/
  font-weight: 500;
  letter-spacing: .04em;
  color: rgba(255,255,255,.94);
  text-shadow: 0 18px 44px rgba(0,0,0,.35);
  max-width: 22ch;
}

/*NEW HERO*/
/* ===== Hero intro (logo + frase) ===== */
.hero-center .hero-logo,
.hero-center .hero-phrase{
  opacity: 0;
  transform: translateY(10px);
  filter: blur(6px);
  transition:
    opacity 700ms ease,
    transform 900ms cubic-bezier(.2,.7,.2,1),
    filter 900ms ease;
  will-change: opacity, transform, filter;
}

/* Logo: un toque extra de escala */
.hero-center .hero-logo{
  transform: translateY(6px) scale(.985);
  filter: blur(8px);
}

/* Frase entra un poquito después */
.hero-center .hero-phrase{
  transition-delay: 120ms;
}

/* Estado activo (cuando “arranca”) */
.hero-center.is-in .hero-logo,
.hero-center.is-in .hero-phrase{
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

/* Respeta accesibilidad */
@media (prefers-reduced-motion: reduce){
  .hero-center .hero-logo,
  .hero-center .hero-phrase{
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}
/* NEW*/

/* overlay un poquito más pro para lectura */


/* mobile */
@media (max-width: 768px){
  .hero.hero--landing{ min-height: 520px; }
  .hero-phrase{ max-width: 18ch; }
}

.hero-caption{
  position:absolute;
  left:18px;
  bottom:18px;
  z-index:4;
  padding:10px 12px;
  border-radius:14px;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  color: rgba(255,255,255,.92);
  font-weight: 650;
  font-size: .92rem;
  max-width: min(560px, 90vw);
}


/* INTRO */

.section-intro{ padding: 72px 0; }

.intro-grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 42px;
  align-items: center;
}

/* Gallery */
.intro-gallery{
  background: rgba(0,0,0,.03);
  border-radius: 28px;
  padding: 16px;
  box-shadow: 0 18px 50px rgba(2,6,23,.10);
}

.intro-main{
  border-radius: 22px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: rgba(0,0,0,.06);
  position: relative;
}

.intro-main img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.02);
}

.intro-thumbs{
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.intro-thumb{
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 1 / 1;
  cursor: pointer;
  background: rgba(0,0,0,.06);
  border: 1px solid rgba(0,0,0,.06);
  opacity: .9;
  transition: transform .2s ease, opacity .2s ease, border-color .2s ease;
}

.intro-thumb:hover{ transform: translateY(-2px); opacity: 1; }

.intro-thumb.is-active{
  opacity: 1;
  border-color: rgba(0,0,0,.18);
}

.intro-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

/* Copy */
.intro-copy h2{
  margin: 0 0 16px;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  letter-spacing: -0.02em;
}

.intro-bullets{
  margin: 0 0 22px;
  padding-left: 18px;
  color: rgba(15,23,42,.86);
  line-height: 1.55;
  font-size: 1.02rem;
}

.intro-bullets li{ margin: 10px 0; }

.intro-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* Responsive */
@media (max-width: 980px){
  .intro-grid{ grid-template-columns: 1fr; }
  .intro-thumbs{ grid-template-columns: repeat(6, minmax(0, 1fr)); }
}

@media (max-width: 520px){
  .intro-thumbs{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .intro-actions .btn{ width: 100%; justify-content: center; }
}


/* -----------FEATURES FLOTANTE----------*/
/* el bloque blanco flotante */


.dev-models .model-overlay{
  grid-column: 1 / -1; /* ocupa todo el ancho del bloque grande */

  position: absolute;
  left: 50%;
  transform: translateX(-50%);

  width: min(87%, 1100px);
  padding: 24px 28px; /* más lados */



  z-index: 20;
  margin: 0;                 /* ya no usamos auto */


  border-radius: 28px;           /* se ve más brochure */
  color: #1a1a1a;
  background: rgba(255,255,255,.96);

  box-shadow: 0 30px 70px rgba(0,0,0,.18);

  border: 1px solid rgba(0,0,0,.06);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 18px 18px;
  z-index: 20;
}

.mo-features {
  padding: 36px 50px 40px 50px;
}
@media (max-width: 820px){
.dev-models .model-overlay{ padding: 20px 18px; }
}


.dev-models .model-overlay{
  top: calc(1 * clamp(460px, 10vw, 470px));
}



.dev-models .mo-title{
  font-size: 12px;
  letter-spacing: .20em;
  text-transform: uppercase;
  color: rgba(0,0,0,.55);
  margin-bottom: 27px;
  text-align: center;
}

.dev-models .mo-list{
  list-style: none;
  margin: 0;
  padding: 0;

  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 18px 28px;
}


.dev-models  .mo-item{
  display:flex;
  align-items:flex-start;
  gap:16px;
  font-size: 14px;
  line-height: 1.35;
  color: rgba(0,0,0,.82);
}
.dev-models .mo-ic{
  flex: 0 0 auto;
}
.dev-models .mo-ic svg{
  width: 18px;
  height: 18px;
  stroke-width: 1.8;
  color: rgba(0,0,0,.65);
  flex-shrink: 0;
}






.dev-models .mo-map{
  margin-top: 6px;
}

.dev-models .mo-mapbox{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.06);
  height: clamp(240px, 30vw, 280px); /* 👈 en vez de min-height */
}


.dev-models #devMap{
  width: 100%;
  height: 100%;
}

.dev-models #devMap iframe{
  width: 100%;
  height: 100%;
  border: 0;
  display: block; /* evita gaps raros */
}





/* CONTACT FORM */

/* CONTACTO — frame minimal */
.contact-section{
  padding: clamp(48px, 6vw, 90px) 0;
}

.contact-frame{
  width: min(1200px, calc(100% - 48px));
  margin: 0 auto;
  position: relative;
  border-radius: 36px;
  overflow: hidden;
  box-shadow: 0 40px 90px rgba(0,0,0,.14);
  min-height: 560px;
}

/*.contact-bg{
  position:absolute; inset:0;
  background-image: var(--contact-bg, url("../img/rivello/rivello-intro-02.jpg"));
  background-size: cover;
  background-position: center;
  transform: translateY(var(--cbg-y, 0px));
  will-change: transform;
}*/

.contact-bg{
  position:absolute;
  inset:0;
  background-image: var(--contact-bg);
  background-size: cover;
  background-position: center;
  transform: translateY(var(--cbg-y, 0px));
  will-change: transform;
  background-color:#0f172a;
}

.contact-overlay{
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(20,28,38,.35), rgba(20,28,38,.58));
}

.contact-grid{
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1.12fr;
  gap: clamp(18px, 2.6vw, 34px);
  padding: clamp(24px, 3vw, 44px);
  align-items: center;
}

/* INFO izquierda (contenida) */
.contact-info{
  color: rgba(255,255,255,.92);
  max-width: 420px;
}

.contact-title{
  margin: 0 0 10px;
  font-size: clamp(28px, 3.2vw, 44px);
  letter-spacing: -0.02em;
  font-weight: 650;
}

.contact-sub{
  margin: 0 0 26px;
  opacity: .82;
  line-height: 1.45;
}

.contact-items{ display: grid; gap: 14px; }

.citem{
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 12px;
  align-items: center;
  text-decoration: none;
  color: inherit;
  opacity: .92;
}
.citem:hover{ opacity: 1; }

.ci-ic{
  width: 34px; height: 34px;
  display:grid; place-items:center;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
}

/* CARD derecha (glass suave) */
.contact-card{
  justify-self: end;
  width: min(560px, 100%);
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 28px;
  box-shadow: 0 40px 80px rgba(0,0,0,.12);
  overflow: hidden;
}

/* inner para animar altura con suavidad */
.cc-inner{
  padding: 26px 26px;
}

.cc-title{
  margin: 0 0 18px;
  font-size: 28px;
  letter-spacing: -0.02em;
  color: rgba(0,0,0,.82);
}

/* form fields */
.cc-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}

.cc-field{
  display:grid;
  gap: 8px;
}

.cc-field--full{ margin-bottom: 14px; }

.cc-label{
  font-size: 13px;
  color: rgba(0,0,0,.62);
}

.cc-field input,
.cc-field textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.16);
  background: rgba(255,255,255,.7);
  padding: 12px 14px;
  outline: none;
  transition: border-color .25s ease, background-color .25s ease, box-shadow .25s ease;
}

.cc-field input:focus,
.cc-field textarea:focus{
  border-color: rgba(0,0,0,.30);
  background: rgba(255,255,255,.92);
  box-shadow: 0 0 0 4px rgba(0,0,0,.06);
}

.cc-consent{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin: 8px 0 16px;
  color: rgba(0,0,0,.62);
  font-size: 13px;
}

.cc-btn{
  width: 100%;
  border: 0;
  border-radius: 16px;
  padding: 14px 16px;
  font-weight: 650;
  cursor: pointer;
  /* tu color de marca aquí */
  background: #6b8f1a;
  color: #fff;
  transition: transform .18s ease, filter .18s ease;
}
.cc-btn:hover{ filter: brightness(1.03); }
.cc-btn:active{ transform: translateY(1px); }

/* SUCCESS state */
.cc-success{
  padding: 10px 0 6px;
}
.cc-success-inner{
  text-align: center;
  padding: 26px 10px 18px;
}
.cc-ok{
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: rgba(0,0,0,.82);
}
.cc-msg{
  margin-top: 10px;
  color: rgba(0,0,0,.62);
  line-height: 1.45;
}

/* responsive */
@media (max-width: 980px){
  .contact-grid{ grid-template-columns: 1fr; }
  .contact-card{ justify-self: stretch; }
  .contact-info{ max-width: none; }
}
@media (max-width: 640px){
  .cc-row{ grid-template-columns: 1fr; }
  .contact-frame{ width: calc(100% - 26px); border-radius: 28px; }
}



/* BG real Rivello */
/*.contact-frame{
  --contact-bg: url("../img/rivello/rivello-intro-02.jpg");
}*/

/* Entrada sutil (arquitectura japonesa) */
.contact-frame .contact-info,
.contact-frame .contact-card{
  opacity: 0;
  transform: translateY(18px) scale(.985);
  transition: opacity 600ms cubic-bezier(.22,.8,.2,1), transform 600ms cubic-bezier(.22,.8,.2,1);
  will-change: transform, opacity;
}

.contact-frame.is-inview .contact-info,
.contact-frame.is-inview .contact-card{
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Stagger mínimo: card entra un pelín después */
.contact-frame .contact-card{
  transition-delay: 90ms;
}

/* “Gelatina” sutil cuando cambie altura */
.cc-inner{
  height: auto; /* JS la controla cuando haga morph */
  overflow: hidden; /* 👈 clave para que se note el cambio de altura */
  transition: height 520ms cubic-bezier(0.22, 1.15, 0.36, 1);
  will-change: height;
}



/* Loading en botón */
.cc-btn.is-loading{
  opacity: .82;
  pointer-events: none;
  filter: grayscale(.1);
}

.hp-field{
  position:absolute;
  left:-9999px;
  width:1px;height:1px;
  opacity:0;
}


/* Sticky blindado */
body .landing-nav-wrap{
  position: sticky !important;
  top: 40px;
  z-index: 9999;
}



/* ABOUT SECTION — layout */


.sec-about { padding: clamp(48px, 6vw, 96px) 0; }
.about-heroText {
  max-width: 960px;
  margin: 0 auto;
  padding-top: 60px !important;
  text-align: center;
  padding: 0 12px; }

.about-breadcrumb{
  display:flex; justify-content:center; gap:10px;
  font-size: 12px; opacity:.75; margin-bottom: 10px;
}
.about-breadcrumb a { text-decoration:none; opacity:.9; }
.about-breadcrumb .sep { opacity:.5; }



.about-breadcrumb { display: none !important; }

.about-kicker{
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity:.85;
  margin: 0 0 60px;
}
.about-title{
  font-size: clamp(34px, 4.2vw, 56px);
  line-height: 1.06;
  margin: 0 0 12px;
}
.about-lead{
  font-size: clamp(16px, 1.6vw, 18px);
  opacity:.85;
  margin: 0 auto 38px;
  max-width: 780px;
}
.about-ctas{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom: 50px;
}

/* Hero image */
.about-heroMedia{
  margin: clamp(22px, 3vw, 30px) auto 0;
  max-width: 1120px;
  border-radius: 22px;
  overflow: hidden;
}
.about-heroMedia img{
  width:100%;
  height: auto;
  display:block;
  aspect-ratio: 16/7;
  object-fit: cover;
}

/* Story */
.about-story{
  margin: clamp(22px, 3vw, 34px) auto 0;
  max-width: 1120px;
  padding: clamp(18px, 2.4vw, 28px);
}



.story-text p{
  margin: 0 0 1.1em;
  line-height: 1.65;
}
.story-text p:last-child{ margin-bottom: 0; }



.mini-kicker{
  font-size: 12px;
  letter-spacing:.14em;
  text-transform: uppercase;
  opacity:.75;
  margin: 0 0 8px;
}
.h2{ font-size: clamp(22px, 2.6vw, 32px); margin:0 0 10px; line-height:1.12; }
.h3{ font-size: 18px; margin:0 0 8px; }
.p, .story-text{ opacity:.85; margin:0; line-height:1.55; }

/* Mission/Vision grid */
.about-mv{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin: 16px auto 0;
  max-width: 1120px;
}
.about-mv .glass-card{ padding: 18px; }

/* Stats */
.about-stats{
  margin: 16px auto 0;
  max-width: 1120px;
  padding: clamp(18px, 2.4vw, 28px);
  text-align: center;
}
.stats-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 14px;
}
.stat{
  padding: 14px;
  border-radius: 16px;
}
.stat .value{
  font-size: clamp(22px, 2.8vw, 34px);
  line-height:1.05;
  margin: 0 0 6px;
}
.stat .label{
  font-size: 13px;
  opacity:.8;
  margin:0;
}

/* Closing image parallax */
.about-closing{
  position: relative;
  overflow: hidden;

  margin-top: clamp(26px, 4vw, 44px);
  /*height: clamp(420px, 55vh, 680px);*/
  height: clamp(480px, 65vh, 760px);
  --lift-max: 280px; /* mismo valor que en JS */
}

.about-closing img{
  position:absolute;
  inset:0;

  width:100%;
  height:120%;
  object-fit:cover;
  object-position: center bottom;
  height: calc(100% + var(--lift-max));
  transform: translate3d(0,var(--lift-y,0px),0);
  will-change: transform;
}


/* Glass primitives (si ya existen, ignora esto) */
.glass-card, .glass-frame{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 18px;
}

/* Responsive */
@media (max-width: 900px){
  .about-mv{ grid-template-columns: 1fr; }
  .stats-grid{ grid-template-columns: 1fr; }
  .about-heroMedia img{ aspect-ratio: 16/10; }
}
