/* Esna Tours Cuernavaca - styles */
:root{
  --brand:#0a5fd3; /* ajuste con el logo si cambia */
  --brand-2:#0ac38a;
  --dark:#0f172a;
  --text:#1f2937;
  --muted:#6b7280;
  --bg:#f8fafc;
  --card:#ffffff;
  --radius:16px;
  --shadow:0 10px 30px rgba(2,6,23,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--text);background:var(--bg)}

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

.navbar{position:sticky;top:0;background:#fff;border-bottom:1px solid #e5e7eb;z-index:50}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:.7rem 0}
.brand{display:flex;gap:.6rem;align-items:center;text-decoration:none;color:var(--dark);font-weight:700}
.brand img{width:34px;height:34px;object-fit:cover;border-radius:50%}
.navbar nav a{margin-left:1rem;text-decoration:none;color:var(--dark);font-weight:600}
.navbar nav a:hover{color:var(--brand)}

.hero{position:relative;height:68vh;min-height:420px;display:grid;place-items:center;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(1.1)}
.hero-overlay{position:relative;z-index:1;text-align:center;color:#fff;padding:1rem}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.35))}

.hero h1{font-size:clamp(28px,4.2vw,56px);line-height:1.1;margin:0 0 .6rem}
.hero h1 span{color:var(--brand-2)}
.hero p{font-size:clamp(16px,2vw,20px);opacity:.95;margin:.2rem 0 1rem}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:.85rem 1.2rem;border-radius:999px;text-decoration:none;border:2px solid transparent;font-weight:700;transition:.2s}
.btn.primary{background:var(--brand);color:#fff}
.btn.primary:hover{filter:brightness(.95)}
.btn.ghost{background:transparent;border-color:#fff;color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.12)}

.section{padding:3.5rem 0}
.section h2{font-size:clamp(24px,3.4vw,36px);margin:0 0 1rem;color:var(--dark)}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem}
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card img{width:100%;height:210px;object-fit:cover}
.card-body{padding:1rem 1.1rem}
.card h3{margin:.2rem 0 .4rem}
.card p{margin:0;color:var(--muted)}

.video .video-wrap{position:relative;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.video iframe{position:absolute;inset:0;width:100%;height:100%}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.8rem}
.grid img{width:100%;height:210px;object-fit:cover;border-radius:14px;box-shadow:var(--shadow)}

.embeds{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}
.embed{background:var(--card);border-radius:var(--radius);padding:.5rem;box-shadow:var(--shadow)}

.contact{background:#fff}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:1.2rem}
.contact-grid .map-wrap{margin-top:.6rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.contact-grid .map-wrap iframe{width:100%;height:260px;border:0}
.form-card{padding:1rem}
.form-card label{display:grid;gap:.35rem;margin:.55rem 0;font-weight:600}
.form-card input,.form-card textarea{padding:.8rem .9rem;border:1px solid #e5e7eb;border-radius:12px;font:inherit}
.form-card button{margin-top:.6rem}
.small{font-size:.85rem}.muted{color:var(--muted)}

.footer{background:var(--dark);color:#e5e7eb}
.foot-wrap{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:1rem 0}
.footer a{color:#fff;text-decoration:underline}

.wa-float{position:fixed;right:16px;bottom:16px;background:#25D366;color:#fff;width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 20px rgba(0,0,0,.25);z-index:60}
.wa-float:hover{transform:translateY(-2px)}

@media (max-width:800px){
  .contact-grid{grid-template-columns:1fr}
  .hero{height:64vh}
}
