/* Residencial Santángel - estilos */
:root{--bg:#f8f9fb;--text:#1a1d23;--muted:#5e6675;--card:#ffffff;--border:#e4e7ef;--primary:#ae7f56;--accent:#d9b77d}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto;line-height:1.5;color:var(--text);background:var(--bg)}
img{max-width:100%;display:block}
.section{padding:64px 24px;max-width:1200px;margin:0 auto}
h1,h2,h3{margin:0 0 12px}
h2{font-size:32px}
h3{font-size:22px}
p{margin:0 0 16px;color:var(--muted)}
.section-title{text-align:center}
.section-description{text-align:center;max-width:800px;margin:0 auto 24px}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--border);padding:12px 24px}
.site-header .header-content{display:flex;align-items:center;gap:24px;justify-content:space-between;max-width:1200px;margin:0 auto}
.logo{display:flex;align-items:center;color:var(--text);text-decoration:none}
.logo img{height:60px}
.main-nav{display:flex;gap:18px;flex:1;margin:0 24px}
.main-nav a{color:var(--muted);text-decoration:none;padding:6px 8px;border-radius:6px}
.main-nav a:hover{color:var(--text);background:rgba(0,0,0,.06)}
.btn{display:inline-block;border:1px solid var(--border);padding:10px 16px;border-radius:10px;text-decoration:none;color:var(--text);background:transparent;cursor:pointer;text-align:center;transition:background-color .15s ease,border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#ffffff}

/* Hover para botones */
.btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,0.08)}
.btn-primary:not(:disabled):hover{background:#a37352;border-color:#a37352}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}

/* Hero slider */
.hero-section{background-color:white;width:100%}
.hero{position:relative;width:100%;height:60vh;min-height:420px;margin:0}
.slides{position:absolute;inset:0;overflow:hidden}
.slides img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s ease}
.slides img.is-active{animation:heroKenBurns 6s ease-out forwards;will-change:transform;transform-origin:center center}
.slides img.is-active.is-leaving{animation:heroFadeOut .9s ease-out forwards}

@keyframes heroFadeOut{
  from{opacity:1}
  to{opacity:0}
}

@keyframes heroKenBurns{
  from{transform:scale(1) translate(0,0)}
  to{transform:scale(1.06) translate(1.5%,0.5%)}
}
.hero-copy{position:absolute;left:6%;bottom:8%;max-width:560px;background:rgba(255,255,255,.85);padding:18px 20px;border-radius:12px;border:1px solid var(--border)}
.hero-copy h1{font-size:42px}
.hero-copy p{font-size:16px}

/* Intro */
.hero-highlight{text-align:center;background:#ffffff;padding:64px 0}
.hero-highlight .section{padding:0 24px;max-width:1200px;margin:0 auto}
.hero-highlight h2{font-size:32px;margin-bottom:8px}
.hero-highlight p{max-width:820px;margin:0 auto;color:var(--muted)}

/* CTA */
.cta{background:#ae7f56;color:#fff}
.cta-actions{display:flex;justify-content:center;gap:12px}
.btn-white{background:transparent;border-color:#fff;color:#fff}
.btn-white:hover{background:rgba(255,255,255,.15)}

/* Features */
.features{background:#262626;color:#fff}
.features h2{color:#fff}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.feature{background:transparent;border:0;border-radius:0;padding:16px;text-align:center}
.feature h3{color:#fff}
.features p{color:#fff}
.feature .icon{margin:0 auto 20px}
.feature .icon svg{width:64px;height:64px;stroke:var(--accent);stroke-width:0.8}
.feature .icon img{width:64px;height:64px;display:block;margin:0 auto}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.card-body{padding:14px}

/* Tours section */
.tours{text-align:center;background:#ffffff;padding:64px 0}
.tours .section{padding:0 24px;max-width:1200px;margin:0 auto}
.tours h2{margin-bottom:8px}
.tours p{max-width:820px;margin:0 auto 32px}
.tours-cards{grid-template-columns:repeat(3,1fr);row-gap:8px}
.tour-card{text-decoration:none;color:inherit;transition:transform 0.2s ease, box-shadow 0.2s ease}
.tour-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.card-subtitle{margin-bottom:4px}
.tours .card-body h3{margin-bottom:4px}
.tours .card-subtitle{margin-top:4px;margin-bottom:4px;font-style:italic}

/* Viviendas */
.viviendas{background:#f8f9fb;text-align:center}
.viviendas h2{margin-bottom:8px}
.units{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.unit{background:white;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,0.1);min-height:280px;display:flex;flex-direction:column}

.unit-info{flex-grow:1;display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.unit-info h3{margin-bottom:6px;font-size:18px;font-weight:600}
.unit-info p{font-size:14px;line-height:1.4;color:#666}
.unit-media{position:relative;height:160px;margin-bottom:16px;overflow:hidden;border-radius:8px;flex-shrink:0}
.unit-slider{display:flex;transition:transform 0.3s ease;height:100%}
.unit-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.unit-slide img{width:100%;height:100%;object-fit:contain;border-radius:8px}
.slider-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.5);color:white;border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;z-index:2}
.slider-nav:hover{background:rgba(0,0,0,0.7)}
.slider-prev{left:8px}
.slider-next{right:8px}
.zoom-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;background:rgba(0,0,0,0.5);color:white;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;font-size:14px;font-weight:bold}
.zoom-btn:hover{background:rgba(0,0,0,0.7)}
.zoom-btn::before{content:'+';color:white;font-style:normal}

/* Responsive para viviendas */
@media (max-width: 768px) {
  .units{grid-template-columns:1fr;gap:12px}
  .unit-media{height:100px}
  .slider-nav{width:25px;height:25px;font-size:12px}
  .zoom-btn{width:25px;height:25px;font-size:12px}
}

@media (min-width: 769px) and (max-width: 1024px) {
  .units{grid-template-columns:repeat(2,1fr)}
}

@media (max-width: 768px) {
  .lightbox{padding:10px}
  .lightbox-content{max-width:95vw;max-height:85vh}
  .lightbox-slider{max-width:90vw;max-height:70vh}
  .lightbox-nav{width:36px;height:36px;font-size:18px;margin:0 10px}
  .lightbox .close{width:35px;height:35px;font-size:18px;top:15px;right:15px}
  .lightbox-caption{font-size:12px;padding:8px 12px}
}

/* Calidades */
.calidades{background:#262626;color:#fff;padding:0}
.calidades .section{padding:64px 24px;max-width:1200px;margin:0 auto}
.calidades h2{color:#fff}
.calidades .section-description{color:#ccc}

.calidades-list{display:flex;flex-direction:column;gap:32px}
.calidad-item{display:block;background:#333;border-radius:12px;border:1px solid #444;box-sizing:border-box;overflow:hidden}
.calidad-image{width:280px;height:220px;margin:24px;margin-right:0;float:left;border-radius:12px;overflow:hidden;box-sizing:border-box}
.calidad-image img{width:100%;height:100%;object-fit:contain;border-radius:12px;display:block}
.calidad-content{margin:24px;margin-left:328px;box-sizing:border-box;padding:0}
.calidad-content h3{color:#fff;margin-bottom:16px;font-size:24px}
.calidad-content p{color:#ccc;margin-bottom:12px;line-height:1.6;font-size:14px}
.calidad-content p:last-child{margin-bottom:12px}

/* Ajustes específicos para la sección Calidades */
.calidades .calidad-image{height:180px}
.calidades .calidad-content h3{margin-top:0;margin-bottom:8px}

/* Ubicación */
.ubicacion{background:#ffffff;padding:0}
.ubicacion .section{padding:64px 24px;max-width:1200px;margin:0 auto}
.map-wrap{border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-top:32px}
.map-wrap iframe{width:100%;height:380px;border:0}

/* Contacto */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px}
.mensaje-full{margin-bottom:12px}
input,textarea{background:#ffffff;border:1px solid var(--border);color:var(--text);border-radius:10px;padding:10px;font:inherit}
input:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(174,127,86,.15)}
label{color:var(--text);font-weight:500;display:block;margin-bottom:4px}
label[for]:has(+ input[required])::after,
label[for]:has(+ textarea[required])::after,
.form-field:has(input[required]) label::after,
.form-field:has(textarea[required]) label::after{content:" *";color:#e74c3c;font-weight:bold;font-size:16px}
.form-field{display:flex;flex-direction:column}
.captcha-row{display:flex;justify-content:space-between;align-items:center;margin:8px 0}
.captcha{display:flex;gap:10px;align-items:center}
.form-note-inline{font-size:14px;color:var(--muted);margin:0;text-align:center;display:block;width:100%}
/* Asegura centrado en la sección de contacto */
.contact .form-note-inline{text-align:center}
.honeypot{position:absolute;left:-9999px}
.consent{display:flex;gap:8px;align-items:center;margin:8px 0}
#form-msg{margin-top:10px}
.contact .btn{width:100%;margin-top:8px;font-size:16px;font-weight:400}

/* Ajustes de espaciado específicos de Contacto */
.contact .section-description{margin-bottom:0}
.contact .form-note-inline{margin-top:0;margin-bottom:16px;font-style:italic}

/* Botones de las tarjetas de viviendas */
.unit .btn{font-size:16px;font-weight:400}

/* Estilos para el mensaje informativo del formulario */
/* (eliminado: .form-info no utilizado) */

/* Estilos para las secciones legales */
/* (eliminado: .legal-section no utilizado) */

/* Estilos para los enlaces del footer */
footer a {
  color: var(--primary);
  text-decoration: none;
  transition: color 0.3s ease;
}

footer a:hover {
  color: var(--accent);
  text-decoration: underline;
}

/* Estilos para enlaces inline (Política de Privacidad y Aviso Legal) */
a.inline {
  color: var(--primary);
  text-decoration: none;
  transition: color 0.3s ease;
}

a.inline:hover {
  color: var(--accent);
  text-decoration: underline;
}

/* Estilos para las ventanas modales */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.modal.show {
  display: flex;
  opacity: 1;
}

.modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(3px);
}

.modal-content {
  position: relative;
  background: white;
  border-radius: 12px;
  border-top: 4px solid var(--primary);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  max-width: 800px;
  max-height: 90vh;
  width: 90%;
  margin: 20px;
  overflow: hidden;
  transform: scale(0.9);
  transition: transform 0.3s ease;
}

.modal.show .modal-content {
  transform: scale(1);
}

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 30px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: white;
  border-bottom: 1px solid #eee;
}

.modal-header h2 {
  margin: 0;
  font-size: 24px;
  font-weight: 600;
}

.modal-close {
  background: none;
  border: none;
  font-size: 28px;
  color: white;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background-color 0.2s ease;
}

.modal-close:hover {
  background-color: rgba(255, 255, 255, 0.2);
}

.modal-body {
  padding: 30px;
  max-height: calc(90vh - 120px);
  overflow-y: auto;
  line-height: 1.6;
}

.modal-body p {
  margin-bottom: 16px;
  color: #333;
}

.modal-body ul {
  margin: 16px 0;
  padding-left: 20px;
}

.modal-body li {
  margin-bottom: 8px;
  color: #333;
}

.modal-body strong {
  color: var(--primary);
  font-weight: 600;
}

/* Responsive para modales */
@media (max-width: 768px) {
  .modal-content {
    width: 95%;
    margin: 10px;
    max-height: 95vh;
  }
  
  .modal-header {
    padding: 15px 20px;
  }
  
  .modal-header h2 {
    font-size: 20px;
  }
  
  .modal-body {
    padding: 20px;
    max-height: calc(95vh - 100px);
  }
}

/* Footer */
.site-footer{border-top:1px solid #444;margin-top:40px;padding:24px;background:#262626;color:#fff;font-size:12px}
.site-footer .footer-content{max-width:1200px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:center;gap:16px}
.footer-nav{display:flex;gap:12px;font-size:11px}
.footer-nav a{font-size:11px}
.logo-footer{height:60px;vertical-align:middle;display:inline;margin-left:8px;opacity:0.8}

/* Responsive */
@media (max-width:1024px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .features-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:720px){
  .hero{height:55vh;min-height:360px}
  .hero-copy{left:4%;right:4%;max-width:none}
  .form-grid{grid-template-columns:1fr}
  .units{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .main-nav{display:none}
  .features-grid{grid-template-columns:1fr}
  
  /* Calidades responsive */
  .calidad-item{display:block;text-align:center;overflow:hidden}
  .calidad-image{width:100%;max-width:350px;height:260px;margin:24px auto;float:none;border-radius:12px;overflow:hidden;box-sizing:border-box}
  .calidad-image img{width:100%;height:100%;object-fit:contain;border-radius:inherit;display:block}
  .calidad-content{margin:0 24px 24px 24px;float:none;box-sizing:border-box}
}

/* Mostrar más imagen y reducir recorte en pantallas pequeñas */
@media (max-width: 900px) {
  .slides img{object-fit:contain}
}

/* Reduced motion accessibility */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .slides img { transition: none; }
  .slides img.is-active { animation: none; }
  .tour-card:hover { transform: none; box-shadow: none; }
  .btn:not(:disabled):hover { transform: none; box-shadow: none; }
}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.9);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.lightbox .close{position:absolute;top:20px;right:24px;background:rgba(255,255,255,0.9);color:#333;border:0;border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:all 0.2s}
.lightbox .close:hover{background:white;transform:scale(1.1)}

.lightbox-content{position:relative;display:flex;align-items:center;max-width:90vw;max-height:80vh}
.lightbox-slider{overflow:hidden;border-radius:12px;position:relative;max-width:min(85vw,900px);max-height:75vh}

/* (Eliminado) Aviso de cookies y placeholder de mapa: no se requiere */
.lightbox-slide{display:none;flex-direction:column;align-items:center}
.lightbox-slide.active{display:flex}
.lightbox-slide img{width:100%;height:70vh;object-fit:contain;border-radius:8px}
.lightbox-caption{background:rgba(0,0,0,0.8);color:white;padding:12px 20px;margin-top:12px;border-radius:6px;font-size:14px;text-align:center}

.lightbox-nav{background:rgba(255,255,255,0.9);border:none;border-radius:50%;width:50px;height:50px;cursor:pointer;font-size:24px;color:#333;display:flex;align-items:center;justify-content:center;transition:all 0.2s;margin:0 20px;flex:0 0 auto;aspect-ratio:1/1;line-height:1}
.lightbox-nav:hover{background:white;transform:scale(1.1)}
.lightbox-prev{margin-right:20px}
.lightbox-next{margin-left:20px}

.lightbox-indicators{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.indicator{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,0.5);background:transparent;cursor:pointer;transition:all 0.2s}
.indicator.active{background:white;border-color:white}
.indicator:hover{border-color:white}

/* Estilos para viviendas reservadas */
/* Estilos para viviendas reservadas */
.unit.reserved{
  position:relative;
  opacity:0.75;
  transform:scale(0.98);
  transition:all 0.3s ease;
}

.unit.reserved::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:rgba(220, 38, 38, 0.08);
  border-radius:12px;
  z-index:1;
  pointer-events:none;
}

.unit.reserved .unit-info,
.unit.reserved .unit-media,
.unit.reserved .btn{
  position:relative;
  z-index:2;
}

.unit.reserved .btn.interest{
  background:linear-gradient(135deg, #7f1d1d, #991b1b);
  border-color:#7f1d1d;
  color:white;
  cursor:not-allowed;
  opacity:0.9;
  font-weight:400;
}

.unit.reserved .btn.interest:hover{
  background:linear-gradient(135deg, #7f1d1d, #991b1b);
  border-color:#7f1d1d;
  transform:none;
  box-shadow:none;
}

.unit.reserved:hover{
  transform:scale(0.98);
  opacity:0.75;
}