/* ====== Variables de marca (ajustables según el logo) ====== */
:root{
  --brand:#1f7a67;        /* verde del logotipo */
  --brand-2:#e67817;      /* acento cálido */
  --ink:#1d1d1f;
  --muted:#6b7280;
  --bg:#f7f7f5;
  --white:#fff;
  --radius:1.25rem;
  --shadow:0 10px 30px rgba(0,0,0,.07);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Montserrat,system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg)}
img{max-width:100%;height:auto;display:block}
.container{width:min(1100px, 92%);margin-inline:auto}
.muted{color:var(--muted)}
.rounded{border-radius:var(--radius)}

.btn{display:inline-block;padding:.85rem 1.2rem;border-radius:999px;border:1px solid var(--ink);text-decoration:none;font-weight:700}
.btn-primary{background:var(--brand);color:var(--white);border-color:var(--brand)}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}

/* Header */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(140%) blur(8px);z-index:10;border-bottom:1px solid #eee}
.header-wrap{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0}
.brand{display:flex;gap:.8rem;align-items:center}
.brand .logo{width:54px;height:54px;border-radius:14px;object-fit:cover;box-shadow:var(--shadow)}
.brand-text h1{font:700 1.25rem/1 Playfair Display,serif;margin:0}
.brand-text p{margin:0;color:var(--muted);font-size:.9rem}
.nav{display:flex;gap:1rem;align-items:center}
.nav a{color:var(--ink);text-decoration:none;font-weight:600}
.nav a.btn{margin-left:.5rem}

/* Hero */
.hero{padding:3.5rem 0 2rem}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center}
.hero-text h2{font:800 2.2rem/1.1 Montserrat,system-ui}
.hero-text p{color:var(--muted);font-size:1.05rem;margin:.6rem 0 1.2rem}
.img-cover{width:100%;height:100%;object-fit:cover}

/* Sections */
section{padding:3rem 0}
h3{font:800 1.6rem/1.1 Montserrat;margin:0 0 1.2rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.card-body{padding:1rem}
.card h4{margin:.2rem 0 .4rem;font-size:1.1rem}
.card p{margin:0;color:var(--muted)}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem}
.gallery img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:.8rem;box-shadow:var(--shadow)}

/* Video */
.video-embed{position:relative;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;background:#000}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%}

/* Facebook */
.redes .fb-page{width:100%}
.redes .container{max-width:700px}

/* Mapa */
.map-embed{position:relative;padding-top:56%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* Contacto */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.form{display:grid;gap:.9rem;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}
.form label{display:grid;gap:.35rem;font-weight:600}
.form input,.form select,.form textarea{padding:.8rem;border:1px solid #e5e7eb;border-radius:.7rem;font-family:inherit}
.form button{justify-self:start}

/* Footer */
.site-footer{padding:1.2rem 0;border-top:1px solid #eee;background:#fff}
.footer-grid{display:flex;justify-content:space-between;align-items:center}
.made-by{color:var(--brand-2);text-decoration:none;font-weight:700}

/* WhatsApp Float */
.wa-float{position:fixed;right:18px;bottom:18px;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);z-index:20}
.wa-float:hover{transform:scale(1.03)}

/* Responsive */
@media (max-width: 900px){
  .hero-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width: 560px){
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
}
