/* ===== Cami Real State ===== */
:root{
  --primary:#2f6f63;   /* Ajusta a los colores del logo si deseas */
  --accent:#d6a04d;
  --bg:#0a0a0a;
  --text:#1e1e1e;
  --muted:#6b7280;
  --surface:#ffffff;
}

*{box-sizing:border-box}
html,body{margin:0;font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#f7f7f7}
img{max-width:100%;display:block}

.container{width:min(1100px,92%);margin-inline:auto}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.topbar ul{list-style:none;display:flex;gap:18px;padding:0;margin:0}
.topbar a{color:var(--text);text-decoration:none;font-weight:600}
.topbar a:hover{color:var(--primary)}
.brand{display:flex;gap:12px;align-items:center}
.brand img{width:42px;height:42px;border-radius:8px;object-fit:cover}
.brand strong{display:block;line-height:1}
.brand span{font-size:12px;color:var(--muted)}

.hero{position:relative;background:linear-gradient(180deg,#ffffff, #f0f7f6)}
.hero-content{padding:48px 0 18px 0;text-align:left}
.hero-content h1{font-size:clamp(28px,6vw,52px);line-height:1.05;margin:0 0 8px 0}
.hero-content h1 span{color:var(--primary)}
.hero-content p{max-width:720px;font-size:clamp(14px,2vw,18px);color:#374151}
.cta-row{display:flex;gap:14px;margin-top:12px}
.btn,.btn-outline{display:inline-block;padding:12px 18px;border-radius:12px;font-weight:700;text-decoration:none}
.btn{background:var(--primary);color:white;border:2px solid var(--primary)}
.btn:hover{opacity:.9}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:#eaf3f2}

.hero-media{height:48vh;min-height:320px;overflow:hidden;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}
.hero-media img{width:100%;height:100%;object-fit:cover}

.about{display:grid;grid-template-columns:1.2fr 1fr;gap:26px;align-items:center;padding:48px 0}
.about h2{margin:0 0 8px 0;font-size:clamp(22px,4vw,34px)}
.bullets{margin:10px 0 0 18px;color:#374151}
.ratio{position:relative;width:100%;padding-bottom:56.25%;border-radius:14px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.08)}
.ratio iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}

.gallery{padding:42px 0}
.gallery h2{margin:0 0 6px 0}
.gallery .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.gallery img{border-radius:12px;cursor:zoom-in;height:170px;object-fit:cover;}

.amenities{padding:32px 0}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.card{background:var(--surface);padding:18px;border-radius:16px;box-shadow:0 8px 24px rgba(2,6,23,.05);border:1px solid #eef2f7}
.card h3{margin:4px 0 6px 0;color:var(--primary)}

.social{padding:38px 0}
.social-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.social .link{color:var(--primary);text-decoration:none;font-weight:700}

.contact{padding:42px 0}
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:22px}
form{background:var(--surface);padding:18px;border-radius:16px;box-shadow:0 8px 24px rgba(2,6,23,.05);border:1px solid #eef2f7}
label{display:block;font-weight:600;margin:8px 0 6px}
input,textarea{width:100%;padding:12px;border:1px solid #e5e7eb;border-radius:12px;margin-top:6px;font-family:inherit}
button{cursor:pointer}
.small{color:var(--muted);font-size:13px}

.map .ratio{border-radius:16px}

.footer{background:#0f172a;color:#cbd5e1;padding:18px 0;margin-top:36px}
.footer-grid{display:flex;justify-content:space-between;align-items:center;gap:12px}
.footer a{color:#d6e5df}

.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:99}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:10px}
.lightbox .close{position:absolute;top:16px;right:16px;font-size:38px;background:transparent;border:0;color:white}

.wa-float{position:fixed;right:18px;bottom:18px;background:#25D366;border-radius:50%;width:58px;height:58px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(0,0,0,.2);z-index:100}
.wa-float svg{fill:white;width:30px;height:30px}

@media (max-width: 980px){
  .about,.contact-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
  .gallery .grid{grid-template-columns:repeat(2,1fr)}
  .social-grid{grid-template-columns:1fr}
  .hero-media{height:34vh}
}
