/* ============================================================
   Vista Silvestre — Hoja de estilos
   Paleta inspirada en bosque tropical + atardecer Vallarta
   ============================================================ */

:root{
  /* Colores */
  --bosque:      #1f3a2e;   /* Verde profundo, primario */
  --bosque-2:    #2d4a3e;   /* Verde medio */
  --hoja:        #3d6b50;   /* Verde claro / hoja */
  --musgo:       #5a7a5e;
  --bronce:      #b8884a;   /* Acento dorado / atardecer */
  --bronce-2:    #d4a574;   /* Bronce claro */
  --terracota:   #c2674a;   /* Toque cálido */
  --arena:       #f5efe4;   /* Fondo crema */
  --arena-2:     #ebe2cf;
  --niebla:      #faf7f1;   /* Off-white */
  --carbon:      #1a1a1a;
  --grafito:     #3a3a3a;
  --niebla-mute: #6b6b66;
  --linea:       rgba(31,58,46,.12);

  /* Tipografía */
  --serif:  "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:   "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --script: "Dancing Script", cursive;

  /* Layout */
  --maxw: 1200px;
  --gut: clamp(1rem, 2.5vw, 2rem);
  --radius: 4px;
  --shadow-soft: 0 6px 24px rgba(31,58,46,.08);
  --shadow-deep: 0 20px 60px rgba(31,58,46,.18);
  --ease: cubic-bezier(.2,.8,.2,1);
}

/* ---------- Reset suave ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  color:var(--grafito);
  background:var(--niebla);
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; height:auto; }
a{ color:var(--bosque); text-decoration:none; transition:color .25s var(--ease); }
a:hover{ color:var(--bronce); }
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  color:var(--bosque);
  line-height:1.15;
  letter-spacing:-.005em;
  margin:0 0 .6em;
}
h1{ font-size: clamp(2.4rem, 5.5vw, 4.6rem); font-weight:400; }
h2{ font-size: clamp(2rem, 3.6vw, 3.1rem); font-weight:400; }
h3{ font-size: clamp(1.4rem, 2vw, 1.8rem); }
h4{ font-size: 1.05rem; font-family:var(--sans); font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--bosque); }
p{ margin:0 0 1em; }
.muted{ color:var(--niebla-mute); }
.small{ font-size:.875rem; }
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }
.skip-link{ position:absolute; left:-9999px; top:0; background:var(--bosque); color:#fff; padding:.5rem 1rem; z-index:9999; }
.skip-link:focus{ left:0; }

/* ---------- Decoración: línea ornamental ---------- */
.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--bronce);
  margin-bottom:1rem;
  position:relative;
  padding-left:42px;
}
.eyebrow::before{
  content:"";
  position:absolute; left:0; top:50%;
  width:30px; height:1px; background:var(--bronce);
}
.script{
  font-family:var(--script);
  font-weight:500;
  color:var(--bronce);
  font-size:1.4em;
  display:inline-block;
}

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:100;
  background:rgba(250,247,241,.78);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom:1px solid transparent;
  transition: background .3s var(--ease), border-color .3s var(--ease), padding .3s var(--ease);
}
.site-header.scrolled{
  background:rgba(250,247,241,.96);
  border-bottom-color:var(--linea);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding: 1rem clamp(1.25rem, 3vw, 3rem);
  max-width: none;
  width: 100%;
  gap: 1.5rem;
}
.site-header .container.nav-row{ max-width: none; }
.brand{ display:flex; align-items:center; gap:.85rem; color:var(--bosque); }
.brand:hover{ color:var(--bosque); }
.brand-mark{
  width:42px; height:42px; border-radius:50%;
  background:var(--bosque); color:var(--bronce-2);
  display:grid; place-items:center;
  font-family:var(--serif); font-size:1.5rem; font-weight:600;
}
.brand-mark-img{
  width:48px; height:48px;
  object-fit:contain;
  display:block;
  transition: transform .3s var(--ease);
}
.brand:hover .brand-mark-img{ transform: rotate(-4deg) scale(1.05); }
.brand-text{ display:flex; flex-direction:column; line-height:1.1; }
.brand-name{ font-family:var(--serif); font-size:1.35rem; font-weight:600; letter-spacing:.02em; }
.brand-sub{ font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--niebla-mute); }

.nav{ display:flex; align-items:center; }
.nav-toggle{ display:none; }
.nav-burger{ display:none; cursor:pointer; width:30px; height:22px; flex-direction:column; justify-content:space-between; }
.nav-burger span{ display:block; height:2px; background:var(--bosque); transition:transform .3s var(--ease), opacity .3s var(--ease); }
.nav-list{
  display:flex; gap: clamp(1rem, 1.8vw, 2.2rem); list-style:none; margin:0; padding:0;
  align-items:center;
  flex-wrap: nowrap;
}
@media (max-width: 1100px){
  .nav-list{ gap: 1rem; }
  .nav-list a{ font-size: .88rem; }
}
.nav-list a{
  font-size:.92rem;
  letter-spacing:.04em;
  color:var(--grafito);
  position:relative;
}
.nav-list a:not(.nav-cta)::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px;
  height:1px; background:var(--bronce);
  transform:scaleX(0); transform-origin:right;
  transition:transform .35s var(--ease);
}
.nav-list a:not(.nav-cta):hover::after{ transform:scaleX(1); transform-origin:left; }
.nav-cta{
  background:var(--bosque); color:#fff !important;
  padding:.7rem 1.4rem; border-radius:999px;
  letter-spacing:.06em; font-weight:500;
  transition: background .25s var(--ease), transform .25s var(--ease);
}
.nav-cta:hover{ background:var(--bronce); color:#fff !important; transform:translateY(-1px); }

@media (max-width: 880px){
  .nav-burger{ display:flex; z-index:120; position:relative; }
  .nav-list{
    position:fixed; inset:0;
    background: var(--niebla);
    background-image:
      linear-gradient(180deg, rgba(250,247,241,.97), rgba(245,239,228,.99)),
      url('/assets/img/asset.png');
    background-size: cover, 60% auto;
    background-position: center, right -10% bottom -8%;
    background-repeat: no-repeat, no-repeat;
    flex-direction:column;
    justify-content:center;
    gap:1.8rem;
    transform:translateX(100%);
    transition: transform .4s var(--ease);
    padding:2rem;
    z-index: 110;
  }
  .nav-list a{ font-size:1.4rem; font-family:var(--serif); color: var(--bosque); }
  .nav-toggle:checked ~ .nav-list{ transform:translateX(0); }
  .nav-toggle:checked ~ .nav-burger span:nth-child(1){ transform: translateY(10px) rotate(45deg); }
  .nav-toggle:checked ~ .nav-burger span:nth-child(2){ opacity:0; }
  .nav-toggle:checked ~ .nav-burger span:nth-child(3){ transform: translateY(-10px) rotate(-45deg); }
  /* Bloquear scroll del body cuando el menú está abierto */
  body:has(.nav-toggle:checked){ overflow:hidden; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height: clamp(760px, 108vh, 1080px);
  display:flex; align-items:center;
  padding: 10rem 0 12rem;
  overflow:hidden;
  background: var(--bosque);
}
@media (max-width: 720px){
  .hero{ padding: 9rem 0 14rem; min-height: 100vh; }
}
.hero-bg{
  position:absolute; inset:0;
  background-image:url('/assets/img/7.png');
  background-size:cover;
  background-position:center;
  filter: brightness(.55) saturate(1.1);
  transform: scale(1.04);
  animation: hero-kenburns 22s ease-in-out infinite alternate;
}
@keyframes hero-kenburns {
  from { transform: scale(1.04) translate(0,0); }
  to   { transform: scale(1.12) translate(-1%, -1.5%); }
}
.hero-bg::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 30% 50%, rgba(31,58,46,.35), transparent 60%),
    linear-gradient(180deg, rgba(31,58,46,.6) 0%, rgba(0,0,0,.15) 50%, rgba(31,58,46,.78) 100%);
}
.hero-leaf{
  position:absolute;
  pointer-events:none;
  z-index:2;
  opacity:.22;
  filter: brightness(0) invert(1);
}
.hero-leaf-1{ top:8%; right:-3%; width: clamp(180px, 22vw, 360px); transform: rotate(8deg); }
.hero-leaf-2{ bottom:14%; left:-5%; width: clamp(160px, 20vw, 320px); transform: rotate(-10deg); opacity:.18; }
.hero .container{ position:relative; z-index:3; color:#fff; }
.hero-logo{
  display:block;
  width: clamp(220px, 32vw, 380px);
  height:auto;
  margin-bottom:1.5rem;
  filter: brightness(0) invert(1) drop-shadow(0 4px 18px rgba(0,0,0,.3));
}
.hero h1{ color:#fff; max-width:18ch; }
.hero h1 .script{ color:var(--bronce-2); display:block; font-size:.55em; margin-bottom:.2em; }
@media (max-width: 720px){
  .hero-leaf{ display:none; }
  .hero-logo{ width: 70vw; }
}
.hero-sub{
  font-family:var(--serif);
  font-size: clamp(1.15rem, 1.8vw, 1.5rem);
  font-weight:400;
  max-width: 56ch;
  color:rgba(255,255,255,.92);
  margin: 1.2rem 0 2.4rem;
  line-height:1.45;
}
.hero-cta{ display:flex; gap:1rem; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  padding: 1rem 2.2rem;
  border-radius: 999px;
  font-family: var(--sans);
  font-size:.95rem;
  font-weight:500;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
  border:1px solid transparent;
  transition: background .25s var(--ease), color .25s var(--ease), transform .25s var(--ease), border-color .25s var(--ease);
}
.btn-primary{ background:var(--bronce); color:#fff; }
.btn-primary:hover{ background:#fff; color:var(--bosque); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:#fff; border-color:rgba(255,255,255,.5); }
.btn-ghost:hover{ background:#fff; color:var(--bosque); border-color:#fff; }
.btn-dark{ background:var(--bosque); color:#fff; }
.btn-dark:hover{ background:var(--bronce); color:#fff; transform:translateY(-2px); }
.btn-outline{ background:transparent; color:var(--bosque); border-color:var(--bosque); }
.btn-outline:hover{ background:var(--bosque); color:#fff; }

.hero-stats{
  position:absolute; bottom:0; left:0; right:0;
  background:rgba(31,58,46,.92);
  backdrop-filter: blur(10px);
  z-index:3;
  border-top:1px solid rgba(212,165,116,.25);
}
.hero-stats-grid{
  display:grid; grid-template-columns: repeat(4, 1fr);
  text-align:center;
}
.hero-stat{
  padding: 1.4rem 1rem;
  color:#fff;
  border-right:1px solid rgba(255,255,255,.08);
}
.hero-stat:last-child{ border-right:0; }
.hero-stat strong{
  display:block;
  font-family:var(--serif);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  color: var(--bronce-2);
  font-weight:500;
  line-height:1;
}
.hero-stat span{ font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; opacity:.85; }
@media (max-width: 720px){
  .hero-stats-grid{ grid-template-columns: repeat(2, 1fr); }
  .hero-stat{ border-bottom:1px solid rgba(255,255,255,.08); }
  .hero-stat:nth-last-child(-n+2){ border-bottom:0; }
  .hero-stat:nth-child(2n){ border-right:0; }
}

/* ---------- Secciones ---------- */
section{ padding: clamp(4rem, 9vw, 8rem) 0; position:relative; }
.section-head{ max-width: 760px; margin: 0 auto 4rem; text-align:center; }
.section-head.left{ margin-left:0; text-align:left; }
.section-head h2{ margin-bottom:.6em; }
.section-head p{ font-size:1.1rem; color:var(--niebla-mute); }

.bg-arena{ background:var(--arena); }
.bg-niebla{ background:var(--niebla); }
.bg-bosque{ background:var(--bosque); color:#fff; }
.bg-bosque h2,.bg-bosque h3,.bg-bosque h4{ color:#fff; }
.bg-bosque .muted{ color:rgba(255,255,255,.7); }

/* ---------- Filosofía ---------- */
.filosofia-grid{
  display:grid; grid-template-columns: 1.05fr 1fr;
  gap: clamp(2rem, 5vw, 5rem); align-items:center;
}
@media (max-width: 880px){ .filosofia-grid{ grid-template-columns:1fr; } }
.filosofia-img{
  position:relative;
  aspect-ratio: 4/5;
  background:url('/assets/img/6.png') center/cover;
  border-radius: 4px;
  overflow:hidden;
  box-shadow: var(--shadow-deep);
  transition: transform .6s var(--ease);
}
.filosofia-img:hover{ transform: scale(1.015); }
.filosofia-img::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(31,58,46,.05), rgba(31,58,46,.35));
}
.filosofia-tag{
  position:absolute; bottom:1.5rem; left:1.5rem; right:1.5rem;
  z-index:2; color:#fff;
  font-family:var(--script);
  font-size:1.7rem;
  text-shadow: 0 2px 18px rgba(0,0,0,.4);
}
.filosofia-quote{
  font-family:var(--serif);
  font-size: clamp(1.4rem, 2.1vw, 1.85rem);
  font-style: italic;
  color:var(--bosque);
  line-height:1.45;
  margin: 1.5rem 0;
  padding-left: 1.5rem;
  border-left: 2px solid var(--bronce);
}

/* ---------- Tarjetas (inversión) ---------- */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.5rem;
}
.card{
  background:#fff;
  padding: 2.2rem 1.8rem;
  border-radius: var(--radius);
  border: 1px solid var(--linea);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--bronce), var(--terracota));
  transform:scaleX(0); transform-origin:left;
  transition: transform .5s var(--ease);
}
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-deep); border-color:transparent; }
.card:hover::before{ transform:scaleX(1); }
.card-num{
  font-family:var(--serif);
  font-size: 3rem;
  color:var(--bronce);
  font-weight:400;
  line-height:1;
  display:block;
  margin-bottom:1rem;
}
.card h3{ font-size:1.25rem; margin-bottom:.6rem; }
.card p{ color:var(--niebla-mute); font-size:.95rem; margin:0; }

/* ---------- Master Plan ---------- */
.masterplan-wrap{
  background: var(--arena);
  padding: 2rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}
.masterplan-wrap embed,
.masterplan-wrap iframe{
  width:100%; height: 720px;
  border:0; border-radius: var(--radius);
  background:#fff;
}
.masterplan-actions{
  margin-top:1.5rem; display:flex; gap:1rem; flex-wrap:wrap; justify-content:center;
}
.masterplan-fallback{
  text-align:center; padding:2rem; color:var(--niebla-mute);
}

/* ---------- Amenidades ---------- */
.amen-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2rem;
}
.amen-item{
  text-align:center;
  padding: 1.5rem 1rem;
}
.amen-icon{
  width:72px; height:72px;
  border-radius:50%;
  background: rgba(212,165,116,.15);
  display:grid; place-items:center;
  margin: 0 auto 1.2rem;
  color: var(--bronce);
  transition: background .3s var(--ease), transform .3s var(--ease);
}
.amen-item:hover .amen-icon{ background: var(--bronce); color:#fff; transform: rotate(-8deg) scale(1.05); }
.amen-icon svg{ width:34px; height:34px; }
.amen-item h3{ font-size:1.15rem; margin:.3rem 0; }
.amen-item p{ font-size:.92rem; color:var(--niebla-mute); margin:0; }

/* ---------- Etapas ---------- */
.etapas-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:1.2rem;
}
@media (max-width: 880px){ .etapas-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .etapas-grid{ grid-template-columns: 1fr; } }
.etapa-card{
  background: rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  padding: 2rem 1.5rem;
  border-radius: var(--radius);
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.etapa-card:hover{ background:rgba(212,165,116,.08); border-color:var(--bronce); }
.etapa-num{
  font-family:var(--serif);
  font-size:1.05rem;
  color:var(--bronce-2);
  letter-spacing:.16em;
  text-transform:uppercase;
}
.etapa-card h3{ color:#fff; margin:.5rem 0 1rem; font-size:1.4rem; }
.etapa-card p{ color:rgba(255,255,255,.78); font-size:.92rem; margin:0; }
.etapa-meta{
  margin-top:1.4rem;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.1);
  font-size:.82rem;
  color:rgba(255,255,255,.6);
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* ---------- Ubicación ---------- */
.ubicacion-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap: 3rem;
  align-items:center;
}
@media (max-width: 880px){ .ubicacion-grid{ grid-template-columns:1fr; } }
.ubicacion-list{
  list-style:none; padding:0; margin: 1.5rem 0 0;
  display:grid; grid-template-columns: 1fr 1fr; gap: .5rem 1.5rem;
}
.ubicacion-list li{
  padding: .6rem 0;
  border-bottom: 1px dashed var(--linea);
  display:flex; justify-content:space-between; align-items:baseline; gap:1rem;
  font-size:.95rem;
}
.ubicacion-list strong{ color:var(--bosque); font-weight:500; }
.ubicacion-list span{ color:var(--bronce); font-family:var(--serif); font-size:1.05rem; }
.ubicacion-map{
  aspect-ratio: 4/3;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-soft);
  background: var(--arena);
}
.ubicacion-map iframe{ width:100%; height:100%; border:0; }

/* ---------- Sustentabilidad ---------- */
.sus-banner{
  position:relative;
  background: var(--bosque);
  color:#fff;
  padding: clamp(4rem, 8vw, 7rem) 0;
  overflow:hidden;
}
.sus-banner h2,
.sus-banner h3,
.sus-banner h4{ color:#fff; }
.sus-banner .script{ color: var(--bronce-2); }
.sus-banner .muted{ color: rgba(255,255,255,.78); }
.sus-banner::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 80% 20%, rgba(212,165,116,.18), transparent 50%),
    radial-gradient(circle at 10% 90%, rgba(61,107,80,.4), transparent 60%);
}
.sus-banner .container{ position:relative; z-index:2; }
.sus-grid{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:2.5rem;
  margin-top: 3rem;
}
@media (max-width: 880px){ .sus-grid{ grid-template-columns:1fr; } }
.sus-item h3{ color:var(--bronce-2); font-size:1.3rem; }
.sus-item p{ color:rgba(255,255,255,.82); margin:0; }

/* ---------- Contacto ---------- */
.contacto-wrap{
  display:grid; grid-template-columns: 1fr 1.1fr; gap: 4rem;
  align-items:start;
}
@media (max-width: 880px){ .contacto-wrap{ grid-template-columns:1fr; gap: 2.5rem; } }
.contacto-info h2{ margin-bottom: .6em; }
.contacto-detalle{
  margin-top: 2rem;
  padding: 1.8rem;
  background: var(--arena);
  border-radius: var(--radius);
  border-left: 3px solid var(--bronce);
}
.contacto-detalle p{ margin:.4rem 0; font-size:.95rem; }
.contacto-detalle strong{ color:var(--bosque); }

.form{
  background:#fff;
  padding: 2.5rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  border:1px solid var(--linea);
}
.field{ margin-bottom: 1.2rem; }
.field label{
  display:block;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--bosque);
  margin-bottom:.5rem;
  font-weight:500;
}
.field input,
.field select,
.field textarea{
  width:100%;
  padding: .85rem 1rem;
  border: 1px solid var(--linea);
  background: var(--niebla);
  border-radius: var(--radius);
  font-family: var(--sans);
  font-size: 1rem;
  color: var(--grafito);
  transition: border-color .25s var(--ease), background .25s var(--ease);
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:0;
  border-color: var(--bronce);
  background:#fff;
}
.field textarea{ resize:vertical; min-height: 110px; }
.field-row{ display:grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 480px){ .field-row{ grid-template-columns:1fr; } }
.form-msg{
  padding: .9rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 1.2rem;
  font-size:.92rem;
}
.form-msg.ok{ background: #e8f0e8; color:#2d4a3e; border:1px solid #b6cdb6; }
.form-msg.err{ background: #fbe9e3; color:#7a2f1a; border:1px solid #e8b8a4; }
.honey{ position:absolute; left:-9999px; opacity:0; }

/* ---------- Footer ---------- */
.site-footer{
  background: var(--carbon);
  color: rgba(255,255,255,.75);
  padding: 0 0 2rem;
}
.site-footer .footer-grid{ padding-top: .5rem; }
.site-footer h3{ color:#fff; font-family:var(--serif); margin: .8rem 0 .3rem; }
.site-footer h4{
  color:var(--bronce-2);
  font-size:.78rem; letter-spacing:.2em;
  margin-bottom:1.2rem;
}
.footer-grid{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:2.5rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
@media (max-width: 880px){ .footer-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px){ .footer-grid{ grid-template-columns: 1fr; } }
.footer-links{ list-style:none; padding:0; margin:0; }
.footer-links li{ margin-bottom:.55rem; }
.footer-links a{ color: rgba(255,255,255,.7); font-size:.92rem; }
.footer-links a:hover{ color: var(--bronce-2); }
.footer-bottom{
  padding-top:1.6rem;
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
  flex-wrap:wrap;
  font-size:.85rem; color:rgba(255,255,255,.5);
}
.footer-bottom p{ margin:0; }

/* ---------- WhatsApp flotante ---------- */
.float-wa{
  position:fixed;
  bottom: 1.5rem; right: 1.5rem;
  width: 58px; height: 58px;
  background: #25D366;
  color:#fff;
  border-radius: 50%;
  display:grid; place-items:center;
  box-shadow: 0 8px 28px rgba(37,211,102,.4);
  z-index: 90;
  transition: transform .3s var(--ease);
}
.float-wa:hover{ transform: scale(1.08); color:#fff; }

/* ---------- Animaciones de entrada ---------- */
.reveal{ opacity:0; transform: translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  html{ scroll-behavior:auto; }
}

/* ---------- Banners de imagen ---------- */
.img-banner{
  position:relative;
  margin: 0 0 3rem;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-deep);
}
.img-banner img{
  width:100%;
  height: clamp(280px, 42vw, 480px);
  object-fit:cover;
  display:block;
  transition: transform 1.2s var(--ease);
}
.img-banner:hover img{ transform: scale(1.03); }
.img-banner figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 1rem 1.5rem;
  background: linear-gradient(0deg, rgba(31,58,46,.85), transparent);
  color:#fff;
  font-family: var(--serif);
  font-size: 1.05rem;
  letter-spacing:.04em;
}
.img-banner-tall img{ height: clamp(320px, 50vw, 560px); }

/* ---------- Decoraciones vintage ---------- */
.section-with-decor{ position:relative; overflow:hidden; }
.decor-illustration{
  position:absolute;
  pointer-events:none;
  z-index:1;
  opacity:.12;
  filter: grayscale(1);
}
.bg-bosque .decor-illustration,
.sus-banner .decor-illustration{
  opacity:.16;
  filter: brightness(0) invert(1);
}
.section-with-decor > .container{ position:relative; z-index:2; }
.decor-tree-left{ top:8%; left:-3%; width: clamp(160px, 14vw, 260px); transform: rotate(-6deg); }
.decor-palm-right{ bottom:4%; right:-3%; width: clamp(150px, 13vw, 240px); transform: rotate(8deg); }
.decor-bird-top{ top:6%; right:6%; width: clamp(120px, 11vw, 200px); transform: rotate(4deg); opacity:.18; }
.decor-bamboo-left{ bottom:0; left:-4%; width: clamp(180px, 16vw, 300px); }
.decor-palm-bottom{ top:8%; right:-2%; width: clamp(150px, 14vw, 240px); transform: rotate(-4deg); }
@media (max-width: 720px){
  .decor-illustration{ display:none; }
}

/* ---------- Amenidad destacada (Casa Club) ---------- */
.amen-feature{
  position:relative;
  margin: 0 0 4rem;
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  background:#fff;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-deep);
}
.amen-feature img{
  width:100%; height:100%;
  min-height: 360px;
  object-fit: cover;
  display:block;
}
.amen-feature figcaption{
  padding: clamp(1.6rem, 3vw, 3rem);
  display:flex; flex-direction:column; justify-content:center;
  background: linear-gradient(135deg, var(--niebla), var(--arena));
}
.amen-feature-eyebrow{
  display:inline-block;
  font-size:.78rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--bronce);
  margin-bottom:.8rem;
  font-weight:500;
}
.amen-feature h3{
  font-size: clamp(1.4rem, 2.2vw, 2rem);
  margin-bottom:.6rem;
}
.amen-feature p{
  color: var(--niebla-mute);
  margin:0;
}
@media (max-width: 880px){
  .amen-feature{ grid-template-columns: 1fr; }
  .amen-feature img{ min-height: 260px; }
}

/* ---------- Galería ---------- */
.gallery-feature{
  margin:0;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-deep);
  position:relative;
}
.gallery-feature img{
  width:100%;
  height:auto;
  display:block;
  transition: transform 1.2s var(--ease);
}
.gallery-feature:hover img{ transform: scale(1.02); }

/* ---------- Foto Ubicación ---------- */
.ubicacion-photo{
  margin: 2rem 0 0;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-soft);
  position:relative;
}
.ubicacion-photo img{
  width:100%;
  height: clamp(180px, 26vw, 260px);
  object-fit: cover;
  display:block;
}
.ubicacion-photo figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: .7rem 1rem;
  background: linear-gradient(0deg, rgba(31,58,46,.85), transparent);
  color:#fff;
  font-family: var(--serif);
  font-size: .95rem;
  font-style: italic;
}

/* ---------- Calculadora de financiamiento ---------- */
.calc-wrap{
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 2.5rem;
  align-items:start;
}
@media (max-width: 980px){ .calc-wrap{ grid-template-columns: 1fr; } }

.calc-form{
  background:#fff;
  padding: 2.5rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  border: 1px solid var(--linea);
}
.calc-section-title{
  font-family: var(--sans);
  font-size: .82rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bronce);
  margin: 1.8rem 0 1rem;
  padding-bottom: .5rem;
  border-bottom: 1px dashed var(--linea);
}
.calc-section-title:first-of-type{ margin-top:0; }

.calc-form input[type="range"]{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--bronce) 0%, var(--bronce) var(--fill, 50%), var(--arena-2) var(--fill, 50%), var(--arena-2) 100%);
  outline:none;
  margin: .8rem 0 .3rem;
}
.calc-form input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;
  width:22px; height:22px; border-radius:50%;
  background: var(--bosque);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(31,58,46,.3);
  cursor: pointer;
  transition: transform .15s var(--ease);
}
.calc-form input[type="range"]::-webkit-slider-thumb:hover{ transform: scale(1.15); }
.calc-form input[type="range"]::-moz-range-thumb{
  width:22px; height:22px; border-radius:50%;
  background: var(--bosque);
  border: 3px solid #fff;
  box-shadow: 0 2px 8px rgba(31,58,46,.3);
  cursor: pointer;
}
.calc-value{
  float:right;
  font-family: var(--serif);
  font-size: 1.05rem;
  color: var(--bosque);
  letter-spacing: 0;
  text-transform: none;
  font-weight: 500;
}
.calc-range-meta{
  display:flex;
  justify-content: space-between;
  font-size: .72rem;
  color: var(--niebla-mute);
  letter-spacing: .08em;
  margin-top: .2rem;
}

.calc-result{
  position: sticky;
  top: 6rem;
  background: var(--bosque);
  color:#fff;
  padding: 2.5rem;
  border-radius: var(--radius);
  box-shadow: var(--shadow-deep);
  position: sticky;
}
.calc-result h3{ color:#fff; margin: .3rem 0 1rem; }
.calc-result-big{
  font-family: var(--serif);
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  color: var(--bronce-2);
  line-height: 1.1;
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.calc-result-list{
  list-style:none;
  padding:0;
  margin: 0 0 1.5rem;
}
.calc-result-list li{
  display:flex;
  justify-content: space-between;
  padding: .5rem 0;
  font-size: .92rem;
  border-bottom: 1px dashed rgba(255,255,255,.1);
}
.calc-result-list li:last-child{ border-bottom: 0; }
.calc-result-list span{ color: rgba(255,255,255,.7); }
.calc-result-list strong{ color:#fff; font-weight:500; }
.calc-result-list .calc-total{
  margin-top: .6rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(212,165,116,.3);
  border-bottom: 0;
}
.calc-result-list .calc-total span{ color: var(--bronce-2); letter-spacing:.1em; text-transform:uppercase; font-size:.78rem; }
.calc-result-list .calc-total strong{ font-family: var(--serif); font-size: 1.3rem; color: var(--bronce-2); }
.calc-result .muted{ color: rgba(255,255,255,.6); }

/* ---------- Asesores inmobiliarios ---------- */
.asesores-section{
  position:relative;
  background: var(--bosque);
  color:#fff;
  overflow:hidden;
  padding: clamp(4rem, 9vw, 7rem) 0;
}
.asesores-bg{
  position:absolute;
  inset:0;
  width:100%; height:100%;
  object-fit: cover;
  z-index: 0;
  opacity: .18;
  filter: saturate(.85);
}
.asesores-section::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(212,165,116,.18), transparent 55%),
    linear-gradient(135deg, rgba(31,58,46,.92), rgba(26,26,26,.85));
  z-index: 1;
}
.asesores-section .container{ position:relative; z-index: 2; }
.asesores-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items:start;
}
@media (max-width: 980px){
  .asesores-grid{ grid-template-columns: 1fr; gap: 2.5rem; }
}
.asesores-copy h2{ color:#fff; }
.asesores-copy .script{ color: var(--bronce-2); }
.asesores-copy p{ color: rgba(255,255,255,.85); font-size: 1.05rem; }
.asesores-benefits{
  list-style: none;
  padding: 0;
  margin: 2rem 0 0;
  display: grid;
  gap: 1rem;
}
.asesores-benefits li{
  padding: 1.1rem 1.3rem 1.1rem 3rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(212,165,116,.18);
  border-radius: var(--radius);
  position:relative;
  color: rgba(255,255,255,.82);
  font-size: .95rem;
  line-height: 1.5;
}
.asesores-benefits li::before{
  content: "✓";
  position:absolute;
  left: 1rem; top: 1rem;
  width: 26px; height: 26px;
  display:grid; place-items:center;
  border-radius: 50%;
  background: var(--bronce);
  color:#fff;
  font-size: .9rem;
  font-weight: 600;
}
.asesores-benefits strong{
  display:block;
  color: var(--bronce-2);
  margin-bottom: .15rem;
  font-weight: 500;
  letter-spacing: .03em;
}

.asesores-form{
  background: rgba(255,255,255,.96);
  color: var(--grafito);
}
.asesores-form h3{
  color: var(--bosque);
  font-size: 1.6rem;
  margin-bottom: .3rem;
}

/* ---------- Sustentabilidad — foto ---------- */
.sus-photo{
  margin: 3rem 0 0;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-deep);
  position:relative;
  border: 1px solid rgba(212,165,116,.25);
}
.sus-photo img{
  width:100%;
  height: clamp(240px, 36vw, 420px);
  object-fit: cover;
  display:block;
}
.sus-photo figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 1rem 1.5rem;
  background: linear-gradient(0deg, rgba(0,0,0,.75), transparent);
  color:#fff;
  font-family: var(--serif);
  font-style: italic;
  font-size: 1rem;
}

/* ---------- Contacto — foto ---------- */
.contacto-photo{
  margin: 1.5rem 0;
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: var(--shadow-soft);
  position:relative;
}
.contacto-photo img{
  width:100%;
  height: clamp(200px, 28vw, 280px);
  object-fit: cover;
  display:block;
}
.contacto-photo figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: .7rem 1rem;
  background: linear-gradient(0deg, rgba(31,58,46,.85), transparent);
  color:#fff;
  font-family: var(--serif);
  font-size: .9rem;
  font-style: italic;
}

/* ---------- Footer hero banner ---------- */
.footer-hero{
  position:relative;
  width:100%;
  height: clamp(180px, 26vw, 260px);
  overflow:hidden;
  margin-bottom: 3rem;
}
.footer-hero-img{
  width:100%; height:100%;
  object-fit: cover;
  display:block;
  filter: brightness(.5) saturate(1.1);
}
.footer-hero-overlay{
  position:absolute; inset:0;
  display:grid; place-items:center;
  background:
    radial-gradient(ellipse at center, rgba(26,26,26,.1), rgba(26,26,26,.6) 80%),
    linear-gradient(180deg, rgba(31,58,46,.35), rgba(26,26,26,.85));
  padding: 0 1.5rem;
}
.footer-hero-logo{
  max-width: min(560px, 70vw);
  height:auto;
  filter: brightness(0) invert(1) drop-shadow(0 4px 22px rgba(0,0,0,.45));
  opacity: .96;
}

/* ---------- Footer brand ---------- */
.footer-logo{
  width:64px; height:64px;
  display:block;
  margin-bottom: .8rem;
  filter: brightness(0) invert(1);
  opacity:.95;
}
.footer-developer{
  display:flex;
  align-items:center;
  gap: .9rem;
  margin-top: 1.4rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(255,255,255,.08);
}
.footer-developer-logo{
  width:44px; height:44px;
  flex-shrink: 0;
  border-radius:50%;
  background: rgba(255,255,255,.04);
  padding: 4px;
}
.footer-developer p{ margin:0; line-height:1.4; }
.footer-developer strong{ color: var(--bronce-2); font-weight: 500; letter-spacing: .04em; }

/* ---------- Selección ---------- */
::selection{ background: var(--bronce); color:#fff; }
