:root {
  --azul-profundo: #1A4C7D;
  --verde-salvia: #A8CBB7;
  --blanco: #FFFFFF;
  --gris-claro: #F5F5F5;
  --negro: #222;
  --sombra: 0 2px 8px rgba(26, 76, 125, 0.07);
  --transicion: .3s cubic-bezier(.4,0,.2,1);
  --equipo-gradiente: linear-gradient(90deg, #A8CBB7 0%, #1A4C7D 100%);
}

* { box-sizing: border-box; }

body {
  font-family: 'Lato', 'Roboto', Arial, sans-serif;
  background: var(--gris-claro);
  color: var(--negro);
  margin: 0;
  padding: 0;
}

.header {
  position: fixed;
  top: 0; left: 0; width: 100%; z-index: 30;
  background: var(--azul-profundo);
  color: var(--blanco);
  box-shadow: var(--sombra);
  padding: 0;
}
.header-flex {
  display: flex; align-items: center; justify-content: space-between;
  max-width: 1200px; margin: 0 auto; padding: 0.5em 1em;
}
.logo {
  display: flex; align-items: center; gap: .5em;
  font-family: 'Playfair Display', serif;
  font-weight: 900; font-size: 1.2em;
}
.logo img {
  border-radius: 50%; background: var(--blanco); padding: 2px;
}
.nav ul {
  display: flex; gap: 1.2em; list-style: none; margin: 0; padding: 0;
  align-items: center;
}
.nav a {
  color: var(--blanco); text-decoration: none; font-weight: 700;
  letter-spacing: 0.02em; transition: color var(--transicion);
  padding: 0.3em 0.7em;
  border-radius: 2em;
}
.nav a:hover, .nav a:focus { color: var(--verde-salvia); background: rgba(255,255,255,0.08);}
.nav-toggle {
  display: none; background: none; border: none; color: var(--blanco); font-size: 1.7em;
}
.btn-equipo {
  background: var(--verde-salvia);
  color: var(--azul-profundo);
  font-weight: 900;
  border-radius: 2em;
  padding: 0.3em 1em;
  margin-left: 0.3em;
  box-shadow: 0 2px 8px rgba(26, 76, 125, 0.09);
  transition: background var(--transicion), color var(--transicion), box-shadow var(--transicion);
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  border: none;
  font-size: 1em;
}
.btn-equipo:hover, .btn-equipo:focus {
  background: var(--azul-profundo);
  color: var(--verde-salvia);
  box-shadow: 0 4px 16px rgba(26,76,125,0.13);
  text-decoration: none;
}

@media (max-width: 900px) {
  .header-flex { flex-wrap: wrap; }
  .nav ul { flex-direction: column; gap: 0.5em; background: var(--azul-profundo); }
  .nav { display: none; position: absolute; top: 60px; right: 1em; min-width: 170px; border-radius: 6px; box-shadow: var(--sombra); }
  .nav.open { display: block; }
  .nav-toggle { display: block; }
}

.hero {
  margin-top: 80px;
  background: var(--azul-profundo);
  color: var(--blanco);
  padding: 2.5em 0 2em 0;
  display: flex; align-items: center; justify-content: center;
}
.hero-content {
  display: flex; align-items: center; max-width: 1100px; margin: 0 auto;
  gap: 3em;
  flex-wrap: wrap;
}
.hero-img img {
  width: 340px; max-width: 100%; border-radius: 1em; box-shadow: var(--sombra);
  background: var(--blanco);
}
.hero-text {
  max-width: 460px;
}
.hero-text h1 {
  font-family: 'Playfair Display', serif; font-size: 2.3em; font-weight: 900;
  margin-bottom: 0.3em;
}
.hero-text p { font-size: 1.15em; margin-bottom: 1em; }
.btn {
  display: inline-block; padding: 0.65em 1.5em; border: none; border-radius: 2em;
  font-weight: 700; font-size: 1.05em; cursor: pointer; text-decoration: none; transition: background var(--transicion), color var(--transicion);
}
.btn-primary {
  background: var(--verde-salvia); color: var(--azul-profundo);
}
.btn-primary:hover, .btn-primary:focus {
  background: var(--blanco); color: var(--azul-profundo); border: 1px solid var(--verde-salvia);
}
.btn-secondary {
  background: var(--azul-profundo); color: var(--blanco); border: 1.5px solid var(--verde-salvia);
}
.btn-secondary:hover, .btn-secondary:focus {
  background: var(--verde-salvia); color: var(--azul-profundo);
}

.section {
  padding: 3em 0;
  background: var(--blanco);
}
.bg-light { background: var(--gris-claro); }
.container {
  max-width: 1100px; margin: 0 auto; padding: 0 1em;
}
.section-flex {
  display: flex; align-items: center; gap: 2.5em; flex-wrap: wrap;
}
.section-text { flex: 1 1 340px; }
.section-img { flex: 1 1 320px; text-align: center; }
.section-img img, .servicios-img img {
  max-width: 340px; width: 100%; border-radius: 1em; box-shadow: var(--sombra);
}
h2 {
  font-family: 'Playfair Display', serif; font-size: 2em; font-weight: 900;
  color: var(--azul-profundo); margin-bottom: 0.5em;
}
h3 { color: var(--azul-profundo); margin-top: 1.1em; }
h4 { margin: 0.8em 0 0.3em 0; }

.servicios-cards {
  display: flex; flex-wrap: wrap; gap: 1.5em; margin-bottom: 1em; margin-top: 1em;
  justify-content: space-between;
}
.servicio-card {
  background: var(--blanco); box-shadow: var(--sombra);
  border-radius: 1em; padding: 1em 1.3em; text-align: center; flex: 1 1 150px; min-width: 140px;
  transition: transform .2s, box-shadow .2s;
}
.servicio-card:hover, .servicio-card:focus {
  transform: translateY(-5px) scale(1.04);
  box-shadow: 0 6px 20px rgba(26,76,125,0.12);
}
.servicio-card i { font-size: 2em; color: var(--azul-profundo); margin-bottom: .2em; }
.servicios-list { margin-top: 1.5em; }
.servicios-list ul { margin: 0.3em 0 0.5em 1.2em; padding: 0; }
.servicios-list li { margin-bottom: .2em; }
.servicios-img { margin-top: 2em; text-align: center; }

.calendly-inline-widget {
  margin: 2em auto 0 auto;
  border-radius: 1em;
  box-shadow: var(--sombra);
  background: var(--gris-claro);
  min-width: 320px;
  max-width: 600px;
}

.agenda-form {
  margin-top: 1.2em; background: var(--gris-claro); padding: 1.2em 1em; border-radius: 1em; box-shadow: var(--sombra);
  display: flex; flex-direction: column; gap: 0.8em; max-width: 350px;
}
.agenda-form label { font-weight: 700; font-size: 1em; color: var(--azul-profundo);}
.agenda-form input, .agenda-form select {
  display: block; width: 100%; margin-top: .25em; margin-bottom: .7em; padding: 0.5em 0.7em;
  border: 1px solid #bbb; border-radius: 0.5em; font-size: 1em;
}
.agenda-form button { align-self: flex-start; }

.contact-cta {
  display: flex; gap: 1em; margin-top: 1em; justify-content: center;
}
.footer {
  background: var(--azul-profundo); color: var(--blanco); padding: 1em 0;
  margin-top: 2em;
}
.footer-flex {
  max-width: 1100px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center;
  padding: 0 1em;
}
.footer a { color: var(--blanco); margin-left: 0.5em; }
.footer a:hover, .footer a:focus { color: var(--verde-salvia); }

.whatsapp-float {
  position: fixed; bottom: 22px; right: 22px; z-index: 100;
  background: #25D366; color: #fff; font-size: 2.2em; border-radius: 50%;
  padding: 0.2em 0.28em; box-shadow: var(--sombra); transition: background var(--transicion);
  display: flex; align-items: center; justify-content: center;
}
.whatsapp-float:hover, .whatsapp-float:focus { background: #128C7E; color: #fff; }

/* Sección invitación equipo */
.equipo-invita {
  background: var(--equipo-gradiente);
  color: #fff;
  padding: 2.5em 0 2em 0;
}
.equipo-invita h2 {
  color: #fff;
  font-size: 2em;
}
.equipo-invita p {
  font-size: 1.15em;
  margin-bottom: 1em;
}
.equipo-mensaje .btn-equipo {
  font-size: 1.08em;
  margin-top: 1em;
  box-shadow: 0 2px 8px rgba(26,76,125,0.18);
  background: #fff;
  color: var(--azul-profundo);
  border: 2px solid var(--verde-salvia);
}
.equipo-mensaje .btn-equipo:hover, .equipo-mensaje .btn-equipo:focus {
  background: var(--azul-profundo);
  color: #fff;
  border: 2px solid #fff;
}
.equipo-mensaje img {
  max-width: 280px;
  background: #fff;
  border-radius: 1em;
  box-shadow: 0 2px 8px rgba(26,76,125,0.10);
  margin-top: 1em;
}

@media (max-width: 700px) {
  .hero-content, .section-flex, .footer-flex, .equipo-mensaje { flex-direction: column; gap: 1.2em; align-items: stretch;}
  .hero-img img, .section-img img, .servicios-img img, .equipo-mensaje img { max-width: 98vw; }
  .footer-flex { flex-direction: column; }
}
