:root{
  --azul:#0a8fdc;
  --azul-oscuro:#064f88;
  --celeste:#27b4ff;
  --gris:#f7f9fb;
  --gris-borde:#e6eef5;
  --texto:#253241;
  --muted:#627182;
  --font-title:'Outfit',sans-serif;
  --font-body:'Nunito',sans-serif;
  --shadow:0 10px 24px rgba(10,143,220,.12);
}

/* ======================================================
   RESET / BASE
====================================================== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--texto);background:#fff}
img{max-width:100%;display:block}
.container{width:92%;max-width:1200px;margin:0 auto}
.section-title{font-family:var(--font-title);font-weight:800;color:var(--azul);text-align:center;margin-bottom:10px}
.section-sub{text-align:center;color:var(--muted);max-width:840px;margin:0 auto 28px}

/* ======================================================
   NAVBAR
====================================================== */
.navbar{position:fixed;inset:0 0 auto 0;background:#fff;border-bottom:1px solid var(--gris-borde);z-index:1000}
.nav-container{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.logo img{width:50px;height:50px;object-fit:contain}
.nav-links{display:flex;gap:10px}
.nav-links a{text-decoration:none;color:#324b64;font-weight:800;padding:10px 12px;border-radius:10px}
.nav-links a:hover{background:#eaf6ff;color:var(--azul)}
.nav-toggle{display:none;background:none;border:0;font-size:1.4rem;color:var(--azul)}
/* móvil navbar */
@media(max-width:900px){
  .nav-toggle{display:block}
  .nav-links{
    display:none;position:absolute;right:0;top:70px;width:100%;
    background:#fff;border-top:1px solid var(--gris-borde);flex-direction:column;gap:6px;padding:12px 14px;
  }
  .nav-links.show{display:flex}
}

/* ======================================================
   BOTÓN WHATSAPP EN LA NAVBAR (versión final limpia)
====================================================== */
.btn-whatsapp-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #0a8fdc; /* azul sólido base */
  color: #fff !important;
  font-weight: 700;
  padding: 8px 18px;
  border-radius: 10px;
  box-shadow: 0 4px 10px rgba(10, 143, 220, 0.35);
  transition: background 0.25s, box-shadow 0.25s;
  text-decoration: none;
  z-index: 2;
}

.btn-whatsapp-nav i {
  font-size: 1rem;
  color: #fff !important;
}

/* Hover: agrega el degradado */
.btn-whatsapp-nav:hover {
  background: linear-gradient(90deg, #097ec1, #1da6f0) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(10, 143, 220, 0.4);
  transform: none !important;
}

/* ======================================================
   HERO: texto decorativo superior (nombre del negocio)
====================================================== */
.hero-tag {
  display: inline-block;
  font-family: var(--font-title);
  font-weight: 700;
  font-size: clamp(18px, 2vw, 26px);
  letter-spacing: 3px;
  color: #cde9ff;
  text-transform: uppercase;
  margin-bottom: 10px;
  position: relative;
  z-index: 2;
  animation: fadeDown 1s ease-out forwards;
}

/* Línea decorativa debajo del texto */
.hero-tag::after {
  content: "";
  display: block;
  width: 80px;
  height: 3px;
  background: linear-gradient(90deg, #27b4ff, #0a8fdc);
  margin: 6px auto 0;
  border-radius: 3px;
}

/* Animación de aparición suave */
@keyframes fadeDown {
  0% {opacity: 0; transform: translateY(-20px);}
  100% {opacity: 1; transform: translateY(0);}
}


/* ======================================================
   HERO (con overlay oscuro y botones mejorados)
====================================================== */
.hero {
  position: relative;
  min-height: 88vh;
  display: grid;
  place-items: center;
  padding-top: 90px;
  overflow: hidden;
}

/* Imagen de fondo */
.hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.8) saturate(1.05);
  z-index: 0; /* capa más baja */
}

/* Overlay azul oscuro sobre la imagen */
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10, 50, 100, 0.10) 20%,   /* tono azul profundo en la base */
    rgba(10, 60, 120, 0.10) 60%,   /* degradado intermedio */
    rgba(10, 70, 150, 0.1) 90%    /* tono celeste muy tenue arriba */
  );
  z-index: 1; /* encima de la imagen, debajo del texto */
}




/* Contenido (texto y botones) */
.hero-content {
  position: relative;
  z-index: 2; /* por encima del overlay */
  text-align: center;
  color: #fff;
  padding: 0 18px;
  max-width: 920px;
}

.hero h1 {
  font-family: var(--font-title);
  font-weight: 800;
  font-size: clamp(32px, 5.2vw, 54px);
  letter-spacing: 0.3px;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.45);
}

.hero p {
  margin: 10px auto 22px;
  max-width: 1000px; /* antes 760px */
  font-size: clamp(16px, 2.4vw, 20px);
  line-height: 1.6;
  text-shadow: 0 3px 10px rgba(0, 0, 0, 0.35);
  padding: 0 20px; /* margen interno lateral */
}


/* Botones */
.hero-cta {
  display: flex;
  gap: 14px;
  justify-content: center;
}

.btn-primary {
  display: inline-block;
  background: var(--azul);
  color: #fff;
  padding: 12px 22px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 800;
  box-shadow: var(--shadow);
  transition: 0.25s;
}
.btn-primary:hover {
  background: #0770b9;
  transform: translateY(-2px);
}

/* Botón secundario (borde completo) */
.btn-link {
  display: inline-block;
  color: #fff;
  text-decoration: none;
  font-weight: 800;
  border: 2px solid rgba(255, 255, 255, 0.9);
  border-radius: 14px;
  padding: 10px 22px;
  transition: 0.25s;
}
.btn-link:hover {
  background: rgba(255, 255, 255, 0.15);
  transform: translateY(-2px);
}

/* móvil hero */
@media (max-width: 620px) {
  .hero-cta {
    flex-direction: column;
  }
}


/* ======================================================
   NOSOTROS
====================================================== */
.nosotros {
  background: #f8fafc;
  padding: 100px 0;
}

.nosotros-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  flex-wrap: wrap;
}

.nosotros-img {
  flex: 1 1 420px;
  text-align: center;
}

.nosotros-img img {
  width: 100%;
  max-width: 480px;
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.15);
  object-fit: cover;
}

.nosotros-text {
  flex: 1 1 480px;
}

.nosotros h2 {
  font-family: var(--font-title);
  font-weight: 800;
  color: var(--azul);
  font-size: clamp(28px, 4vw, 42px);
  margin-bottom: 14px;
}

.nosotros p {
  color: #333;
  font-size: 1.05rem;
  line-height: 1.6;
  margin-bottom: 22px;
}

.nosotros-lista {
  list-style: none;
  margin-bottom: 32px;
}

.nosotros-lista li {
  margin-bottom: 10px;
  font-weight: 600;
  color: #444;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nosotros-lista i {
  color: var(--azul);
  font-size: 1.2rem;
}

/* Mini franja de cifras */
.nosotros-datos {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  text-align: center;
  gap: 20px;
  margin-top: 20px;
}

.nosotros-datos h3 {
  color: var(--azul);
  font-size: 2rem;
  font-weight: 800;
  margin-bottom: 6px;
}

.nosotros-datos p {
  font-size: 0.95rem;
  color: #555;
}

/* ======================================================
   ANIMACIONES EN SCROLL
====================================================== */
[data-animate="fade-left"],
[data-animate="fade-right"] {
  opacity: 0;
  transform: translateX(40px);
  transition: all 0.8s ease;
}
[data-animate="fade-right"] {
  transform: translateX(-40px);
}
[data-animate].visible {
  opacity: 1;
  transform: none;
}

/* ======================================================
   MÓVIL (optimizado y unificado)
====================================================== */
@media (max-width: 768px) {
  .nosotros {
    padding-top: 60px;
    padding-bottom: 40px;
    line-height: 0; /* quita espacio colapsado entre elementos inline */
  }

  .nosotros-wrap {
    display: grid !important;
    grid-template-columns: 1fr;
    row-gap: 0 !important;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .nosotros-img {
    margin: 0 !important;
    padding: 0 !important;
    line-height: 0;
  }

  .nosotros-img img {
    display: block;
    margin: 0 auto;
    max-width: 330px;
    border-radius: 18px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    vertical-align: bottom;
  }

  .nosotros-text {
    line-height: normal;
    margin: 0 !important;
    padding-top: 8px !important;
  }

  .nosotros h2 {
    margin: 6px 0 10px !important;
  }

  .nosotros p {
    margin: 0 0 14px !important;
  }

  .nosotros-lista {
    margin: 10px 0 18px !important;
  }

  .nosotros-datos {
    justify-content: center;
    margin-top: 10px !important;
    gap: 10px !important;
  }

  /* Reduce separación con la siguiente sección */
  .nosotros + .servicios {
    margin-top: 0 !important;
    padding-top: 40px !important;
  }
}




/* ======================================================
   SERVICIOS
====================================================== */
.servicios{padding:90px 0;background:var(--gris)}
.servicios-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.servicio{background:#fff;border:1px solid var(--gris-borde);border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.06);transition:.25s}
.servicio:hover{transform:translateY(-4px)}
.servicio-media img{width:100%;height:180px;object-fit:cover}
.servicio-body{padding:18px;text-align:center}
.servicio-body i{font-size:1.8rem;color:var(--azul);margin-bottom:8px;display:block}
.servicio-body h3{font-family:var(--font-title);margin-bottom:6px}
.servicio-body p{color:var(--muted)}
/* móvil servicios */
@media(max-width:980px){.servicios-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.servicios-grid{grid-template-columns:1fr}.servicio-media img{height:160px}}

/* ======================================================
   MARCAS INLINE (dentro de servicios)
====================================================== */
.marcas-inline {
  margin-top: 60px;
  text-align: center;
}
.marcas-inline .marcas-lead {
  color: #3a4a59;
  font-weight: 700;
  margin-bottom: 16px;
}
.marcas-inline .marcas-track {
  overflow: hidden;
  border-top: 1px dashed var(--gris-borde);
  border-bottom: 1px dashed var(--gris-borde);
  padding: 16px 0;
}
.marcas-inline .marcas-slide {
  display: flex;
  gap: 50px;
  align-items: center;
  animation: marquee 22s linear infinite;
}
.marcas-inline .marcas-slide img {
  height: 42px;
  filter: grayscale(100%);
  opacity: 0.85;
  transition: 0.25s;
}
.marcas-inline .marcas-slide img:hover {
  filter: none;
  opacity: 1;
}

.marcas-inline .marcas-slide {
  display: flex;
  gap: 50px;
  align-items: center;
  animation: marquee 30s linear infinite;
  width: max-content;
}

@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.marcas-inline .marcas-track:hover .marcas-slide {
  animation-play-state: paused;
}



/* ======================================================
   POR QUÉ ELEGIRNOS
====================================================== */
.elegirnos{padding:90px 0;background:linear-gradient(180deg,#1aa6ff,#0a8fdc)}
.white{color:#fff}
.elegirnos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:14px}
.beneficio{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);backdrop-filter:saturate(1.2) blur(1px);border-radius:16px;color:#fff;text-align:center;padding:22px}
.beneficio i{font-size:1.9rem;margin-bottom:8px}
.beneficio h3{font-family:var(--font-title);margin-bottom:6px}
.beneficio p{opacity:.95}
/* móvil elegirnos */
@media(max-width:980px){.elegirnos-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.elegirnos-grid{grid-template-columns:1fr}}

/* ======================================================
   CTA PUBLICITARIA (IMAGEN DE FONDO FIJA)
====================================================== */
.cta-publi {
  position: relative;
  padding: 100px 0;
  color: #fff;
  background: url('media/hero.webp') center/cover no-repeat fixed;
  text-align: center;
  overflow: hidden;
}
.cta-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 0;
}
.cta-wrap {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}
.cta-text h2 {
  font-family: var(--font-title);
  font-size: clamp(28px, 5vw, 46px);
  font-weight: 800;
  margin-bottom: 6px;
}
.cta-text p {
  max-width: 680px;
  opacity: 0.95;
  line-height: 1.5;
}
.btn-white {
  display: inline-block;
  background: #fff;
  color: #0d69ad;
  text-decoration: none;
  font-weight: 800;
  border-radius: 14px;
  padding: 12px 26px;
  transition: 0.25s;
}
.btn-white:hover {
  background: #f0f8ff;
  transform: translateY(-2px);
}

/* ======================================================
   PROCESO (HILADO)
====================================================== */
.proceso{padding:90px 0;background:#fff}
.timeline{display:grid;grid-template-columns:repeat(7,1fr);align-items:start;gap:8px}
.step{grid-column:span 1;text-align:center}
.step .icon{width:56px;height:56px;border-radius:50%;background:#eaf6ff;border:2px solid #bfe6ff;display:grid;place-items:center;margin:0 auto 8px}
.step .icon span{font-weight:900;color:#0a79c6}
.step h3{font-family:var(--font-title);margin-bottom:6px}
.step p{color:#556}
.connector{grid-column:span 1;display:grid;place-items:center}
.connector span{display:block;width:100%;height:3px;background:linear-gradient(90deg,#cfe9fb,#9bd0ff);border-radius:2px}
/* móvil proceso */
@media(max-width:1000px){
  .timeline{grid-template-columns:1fr}
  .connector{display:none}
  .step{margin-bottom:14px}
}

/* ======================================================
   OPINIONES (CARRUSEL)
====================================================== */
.opiniones{padding:90px 0;background:var(--gris)}
.opiniones-wrap{position:relative}
.op-track{display:flex;gap:16px;overflow:hidden;scroll-behavior:smooth}
.op-card{min-width:300px;max-width:360px;background:#fff;border:1px solid var(--gris-borde);border-radius:16px;padding:18px;box-shadow:0 10px 24px rgba(0,0,0,.06)}
.stars{color:#ffb703;margin-bottom:8px;font-weight:800}
.op-card span{display:block;margin-top:8px;font-weight:800;color:#445}
/* controles */
.op-prev,.op-next{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;border:none;background:#ffffff;
  color:#0a8fdc;box-shadow:0 6px 16px rgba(0,0,0,.12);cursor:pointer;
}
.op-prev{left:-10px}
.op-next{right:-10px}
.op-prev:hover,.op-next:hover{background:#f0f8ff}
/* móvil opiniones */
@media(max-width:560px){.op-prev{left:-6px}.op-next{right:-6px}}

/* ======================================================
   FOOTER
====================================================== */
.footer{background:#0f2136;color:#d9e6f5;padding:60px 0 22px}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:22px;align-items:start}
.footer-brand{display:flex;gap:12px;align-items:center}
.footer-brand img{width:54px;height:54px}
.footer-contact h3{color:#9bd0ff;margin-bottom:10px}
.footer-contact p{margin:6px 0}
.social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#163352;color:#9bd0ff;margin-right:8px}
.copy{text-align:center;margin-top:16px;color:#9fb2c6;font-size:.9rem}
.copy a{color:#9bd0ff;text-decoration:none}
.copy a:hover{text-decoration:underline}
/* móvil footer */
@media(max-width:900px){.footer-grid{grid-template-columns:1fr;text-align:center;justify-items:center}}

/* ======================================================
   UTILIDADES (OFFSET ANCLAS)
====================================================== */
section[id]{scroll-margin-top:90px}


/* ======================================================
   FIX ESTRUCTURAL: elimina espacio entre .nosotros-img y .nosotros-text
====================================================== */
@media (max-width: 768px) {
  .nosotros-wrap {
    display: grid !important;
    grid-template-columns: 1fr;
    row-gap: 0 !important;
  }

  .nosotros-img,
  .nosotros-text {
    margin: 0 !important;
    padding: 0 !important;
  }

  .nosotros-img img {
    display: block;
    margin: 0 auto;
    max-width: 330px;
  }

  .nosotros-text {
    margin-top: 0 !important;
    padding-top: 8px !important;
  }
}

/* ======================================================
   BOTÓN FLOTANTE WHATSAPP CON TEXTO
====================================================== */
.whatsapp-float {
  position: fixed;
  bottom: 22px;
  right: 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: #25d366;
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
  text-decoration: none; /* elimina línea debajo */
  border-radius: 50px;
  padding: 12px 18px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  z-index: 999;
}

.whatsapp-float i {
  font-size: 1.6rem;
  color: #fff;
  margin-left: 2px;
}

.whatsapp-float span {
  font-family: var(--font-title);
  color: #fff;
  letter-spacing: 0.2px;
}

.whatsapp-float:hover {
  background: #1ebe5b;
  transform: scale(1.05);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.3);
}

/* Versión móvil: solo el icono (para no tapar contenido) */
@media (max-width: 560px) {
  .whatsapp-float {
    bottom: 18px;
    right: 18px;
    padding: 12px;
    border-radius: 50%;
    width: 54px;
    height: 54px;
    justify-content: center;
  }

  .whatsapp-float span {
    display: none;
  }

  .whatsapp-float i {
    font-size: 1.7rem;
  }
}

/* ======================================================
   FIX: estabiliza ancho de contadores para evitar reflow
====================================================== */
.nosotros-datos h3 {
  display: inline-block;
  min-width: 3.5em; /* reserva espacio para los números */
  text-align: center;
}

