:root {
  --brand:#0b1761;
  --brand-700:#081150;
  --text:#1f2937;
  --muted:#6b7280;
  --bg:#ffffff;
  --white:#fff;
}

/* ---------- TIPOGRAFÍA GLOBAL ---------- */
body {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  color: #333333;
  line-height: 1.5;
}

html, body {
  overflow-x: hidden;
}

/* Reset mínimo */
*,*::before,*::after{ box-sizing:border-box }
body{ margin:0;}
a{ color:inherit; text-decoration:none }
img{ max-width:100%; height:auto; display:block }

.container{ max-width:1200px; margin:0 auto; padding:0 16px }

/* ===== Header blanco (desktop) ===== */
.header{ display:none; background:var(--white); }
.header__wrap{ display:flex; align-items:center; justify-content:space-between; height:72px }
.brand{ display:flex; align-items:center; gap:12px; font-weight:700; font-size:20px }
.brand__logo{ height:42px }
.header__right{ display:flex; align-items:center; gap:16px }
.social{ display:flex; gap:17px; color:var(--muted) }
.social a{ display:inline-flex; align-items:center; justify-content:center; width:19px; height:19px; transition:background .2s }
.social a:hover{ background:#eef2ff }
.lang-group{ display:flex; gap:8px; }

/* BOTONES */
.lang-btn {
  --size: 36px;
  display: grid;
  place-items: center;
  width: var(--size);
  height: var(--size);
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px;
  border-radius: 6px;
  transition: background 0.2s ease, transform 0.1s ease;
}

/* HOVER / ACTIVO */
.lang-btn:hover {
  background: rgba(0, 0, 0, 0.06);
  transform: translateY(-1px);
}

.lang-btn.active {
  background: rgba(0, 74, 145, 0.1);
  box-shadow: 0 0 0 2px rgba(0, 74, 145, 0.15) inset;
}

/* BANDERAS */
.flag {
  display: block;
  width: 24px;
  height: auto;
}

/* ===== Navbar azul (mobile + desktop) ===== */
.navbar{ position:sticky; top:0; z-index:50; padding:0; background:transparent }
.nav-surface{ background:var(--brand); color:#fff; border-radius:0; box-shadow:none }
.nav__mobile{ display:flex; align-items:center; justify-content:space-between; height:56px; padding:0 12px }
.nav__logo img{ height:28px }
.menu-btn{ border:0; background:transparent; color:#fff; padding:10px; border-radius:8px; cursor:pointer }
.menu-btn:hover{ background:var(--brand-700) }

.nav__mobile-menu{ display:none; padding:8px 12px 14px }
.nav__mobile-menu.open{ display:block }
.mm__links{ display:grid; gap:6px; padding:6px 0 }
.mm__links a{ display:block; padding:12px 12px; border-radius:8px; font-weight:600 }
.mm__links a:hover{ background:var(--brand-700) }

.mm__divider{ height:1px; border:0; background:rgba(255,255,255,.25); margin:8px 0 10px }
.mm__bottom{ display:flex; align-items:center; justify-content:space-between; gap:12px }
.mm__social{ display:flex; gap:12px }
.mm__social a{ display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:10px; background:rgba(255,255,255,.1) }
.mm__social a:hover{ background:rgba(255,255,255,.2) }

/* Idiomas en panel mobile */
.mm__langs{ display:flex; gap:8px }
.lang-ico{ border:1px solid rgba(255, 255, 255, 0.298); background:transparent; color:#fff; border-radius:6px; padding:4px 8px; cursor:pointer; display:inline-flex; align-items:center; gap:6px }
.lang-ico.active{ background:#fff; color:var(--brand); border-color:#fff }

/* Desktop links centrados, hover sólo texto */
.nav__desktop{ display:none; height:56px; align-items:center; justify-content:center; padding:0 12px }
.nav__links{ display:flex; gap:16px }
.nav__links a{ padding:0; border-radius:0; font-weight:600; line-height:1; transition:color .15s }
.nav__links a:hover{ background:transparent; color:#78B9EB } /* solo cambia el color de la palabra */

/* Estado activo (link de la sección actual) */
.nav__links a.activo,
.mm__links a.activo {
  color: #78B9EB; /* 🔹 el celestito de la marca */
}

/* Breakpoint */
@media (min-width:768px){
  .header{ display:block }
  .nav__mobile{ display:none }
  .nav__mobile-menu{ display:none !important }
  .nav__desktop{ display:flex }
}

/* ======= NAVBAR RESPONSIVE ======= */

/* ----- MOBILE ----- */
@media (max-width: 767px) {
  .navbar {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    background-color: #0B1761;
    box-sizing: border-box;
  }

  /* solo se muestra el header mobile */
  .nav__mobile {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
    padding: 10px 20px;
  }

  /* ocultar menú desktop */
  .nav__desktop {
    display: none !important;
  }

  /* menú desplegable mobile (el que aparece al hacer click en la hamburguesa) */
  .nav__mobile-menu {
    display: none;
    flex-direction: column;
    background-color: #0B1761;
    width: 100%;
    padding: 20px;
  }

  .nav__mobile-menu.active {
    display: flex;
  }
}

/* ===== HEADER MOBILE FIX ===== */
@media (max-width: 768px) {
  /* 🔹 Solo aplicamos esto en mobile */
  .navbar {
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;              /* fondo azul a todo el ancho */
    background-color: #0B1761;
    box-sizing: border-box;
  }

  .nav__mobile {
    max-width: 1200px;         /* coincide con el contenido */
    margin: 0 auto;
    padding: 10px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

    .nav__mobile img {
    margin-left: 0px; /* leve compensación del logo */
  }

  .menu-btn {
    margin-right: 0px; /* leve compensación de la hamburguesa */
  }

  /* Menú desplegable */
  .nav__mobile-menu {
    display: none;
    flex-direction: column;
    background-color: #0B1761;
    width: 100%;
    padding: 20px 0;
    text-align: center;
  }

  .nav__mobile-menu.active {
    display: flex;
  }

  .nav__mobile-menu a {
    color: white;
    text-decoration: none;
    padding: 10px 0;
    font-size: 18px;
  }

  .nav__mobile-menu a:hover {
    color: #78B9EB;
  }
}




/* ---------- DESTACADO CELESTE ---------- */

.highlight {
  background-color: #73B2DE; /* color de fondo */
  padding: 40px 0;
  margin-top: 8px;
}

.highlight .container {
  background-color: transparent;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.highlight p {
  color: #ffffff;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.3;
  flex: 1 1 60%;
  margin: 0;
}

.highlight strong {
  font-weight: 700;
}

.highlight .btn-wrapper {
  flex: 1 1 25%;
  display: flex;
  justify-content: flex-end; /* 👈 alinea el botón al borde derecho */
  align-items: center;
}

.highlight .btn {
  background-color: transparent;
  color: #fff;
  border: 2px solid #fff;
  padding: 12px 60px;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 0.9rem;
  cursor: pointer;
  transition: all 0.3s ease;
}

.highlight .btn:hover {
  background-color: #fff;
  color: #004A91;
}


/* ---------- Versión mobile ---------- */
@media (max-width: 768px) {
  .highlight .container {
    flex-direction: column;
    text-align: center;
  }

  .highlight p {
    flex: 1 1 100%;
    margin-bottom: 20px;
  }

  .highlight .btn-wrapper {
    flex: 1 1 100%;
    justify-content: center; /* botón centrado en mobile */
  }
}


/* ---------- MEMBRESÍAS ---------- */
.membresias {
  padding: 48px 0;
  background: #ffffff;
  border-bottom: 2px solid #73AADD;  /* Línea azul abajo */
}

.membresias .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0px;

}

.membresias h2 {
  font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  font-weight: 700;
  color: #0b1761;
  font-size: 33px;
  margin: 0 0 15px 0;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  position: relative;
}


/* Grid de logos */
.membresias-logos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  align-items: stretch;
}

/* Cada tarjeta de logo */
.membresias-logos .logo-item {
  background: #f5f5f6;
  padding: 30px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100px;
  box-shadow: none;
  border-radius: 4px;
}

.membresias-logos .logo-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.membresias-logos .logo-item img {
  max-width: 100%; /* Asegurarse de que la imagen no se expanda más allá de su contenedor */
  max-height: 100px; /* Limitar altura en caso de logos muy grandes */
  display: block;
  object-fit: contain;
}

/* Hover ligero */
.membresias-logos .logo-item:hover {
  transform: translateY(-4px);
  transition: transform .18s ease;
}


/* ================= RESPONSIVE ================= */

/* Tablets y pantallas más pequeñas */
@media (max-width: 992px) {
  .membresias h2 {
    font-size: 42px;
  }
  .membresias-logos {
    grid-template-columns: repeat(3, 1fr); /* 3 columnas en tablet */
  }
  .membresias-logos .logo-item {
    padding: 30px 18px;
    min-height: 110px;
  }
  .membresias .container {
    padding: 0 16px;
  }
}

/* Small tablets y phones */
@media (max-width: 768px) {
  .membresias h2 {
    font-size: 36px;
    text-align: left;
  }
  .membresias-logos {
    grid-template-columns: repeat(2, 1fr); /* 2 columnas */
  }
  .membresias-logos .logo-item {
    padding: 24px 16px;
  }
}

/* Mobile phones */
@media (max-width: 480px) {
  .membresias {
    padding: 28px 0;
  }

  .membresias h2 {
    font-size: 28px;
    text-align: center;
  }

  .membresias h2::after {
    margin: 8px auto 0;
  }

  /* 🔹 CAMBIO PRINCIPAL: FLEX EN VEZ DE GRID + SCROLL HORIZONTAL */
  .membresias-logos {
    display: flex !important;             /* forzamos flex */
    flex-wrap: nowrap !important;         /* no hacer salto de línea */
    overflow-x: auto !important;          /* habilita scroll horizontal */
    overflow-y: hidden;
    gap: 16px;
    scroll-snap-type: x mandatory;        /* que encaje cada logo al deslizar */
    -webkit-overflow-scrolling: touch;    /* suaviza el scroll en iOS */
    scrollbar-width: none;                /* oculta scrollbar en Firefox */
  }

  /* ocultar la barra de scroll en Chrome/Safari */
  .membresias-logos::-webkit-scrollbar {
    display: none;
  }

  .membresias-logos .logo-item {
    flex: 0 0 85%;                        /* cada logo ocupa 85% del ancho visible */
    scroll-snap-align: start;             /* se alinea al inicio al soltar */
    background: #f5f5f6;
    padding: 28px 16px;
    min-height: 120px;
    border-radius: 6px;
  }

  .membresias-logos .logo-item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
  }

  .membresias-logos .logo-item img {
    max-width: 95%;
    height: auto;
    object-fit: contain;
  }
}


/* ----------------------------- SERVICIOS ----------------------------- */

/* Contenedor principal */
.servicios {
  padding: 50px 0;
  background-color: #ffffff;  /* Fondo blanco */
  
  border-bottom: 2px solid #73AADD;  /* Línea azul abajo */
}

/* Contenedor centrado de 1200px */
.servicios .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0px;
}

/* Título */
.servicios h2 {
  font-weight: 700;
  font-size: 34px;
  color: #0B1761;
  margin: 0 0 10px; /* Ajustamos la separación entre el título y el contenido */
  text-align: left; /* Alineado a la izquierda */
}

/* Estructura del contenido: 4 columnas en desktop */
.servicios-content {
  display: grid;
  grid-template-columns: 1fr 3fr; /* Una columna para el título y tres para el contenido */
  gap: 10px;
  align-items: flex-start; /* Alineamos los elementos en la parte superior */
}

/* La columna de texto "LEER MÁS" */
.servicios-title {
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* Alineado a la izquierda */
  justify-content: flex-start; /* Aseguramos que se alinee arriba */
}

/* Estilo del botón */
.servicios-title a {
  background-color: #0B1761;
  color: white;
  padding: 10px 20px;
  text-decoration: none;
  border-radius: 5px;
  font-size: 16px;
  text-align: center;
  width: 95%;
  margin-top: 0px;  /* Separación entre el título y el botón */
}

.servicios-title a:hover,
.mobile-readmore-wrap a:hover {
  background-color: #006DC1;
  transition: color 0.25s ease-in-out;
}

/* Contenedor de los 3 items */
.servicios-items {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 columnas para los items */
  gap: 20px;
  justify-items: center; /* Centra los items en desktop */
}

/* Estilo de cada item */
.servicio-item {
  background-color: white;
  padding: 10px;
  text-align: center;
  border: 2px solid #0b1761; /* Borde sólido */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center; /* Centra imagen y texto */
  width: 100%;
  max-width: 320px; /* 🔹 controla el ancho máximo del item */
  min-width: 280px; /* 🔹 evita que sea más chico que esto */
  box-sizing: border-box;    
}

/* Imagen de cada item */
.servicio-item img {
  width: 114px;
  height: 114px;
  margin-bottom: 5px;
  margin-top: 15px;
    object-fit: contain;
}

/* Estilo del texto */
.servicio-item p {
  font-size: 16px;
  color: #004A91;
  font-weight: 500;
  line-height: 17px;
line-height: 1.2;
  margin: 0;
  max-width: 220px; /* 🔹 ancho máximo del texto */
  text-align: center;
}


/* ================= RESPONSIVE ================= */

/* Para dispositivos móviles */
@media (max-width: 768px) {
  /* Cambiar la estructura de las columnas */
  .servicios-content {
    grid-template-columns: 1fr; /* Una sola columna en móvil */
  }

  /* El título va arriba en móvil */
  .servicios-title {
    order: -1; /* Coloca el título encima de los items */
    text-align: center;
    margin-bottom: 20px;
  }

  .servicios-title h2,
  .membresias .servicios-title h2 {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    font-size: 2.25rem; /* 🔹 este define el tamaño igual para todos */
    font-weight: 700;
    line-height: 1.2;
  }

  /* El botón "LEER MÁS" va debajo del carrusel */
  .servicios-title a {
    margin-top: 20px; /* Separación entre el carrusel y el botón */
  }

  /* Contenedor de los items en forma de carrusel en móvil */
  .servicios-items {
    display: flex;
    overflow-x: auto;
    gap: 15px;
    scroll-snap-type: x mandatory;
    padding-bottom: 20px;
    scroll-behavior: smooth;
    justify-content: flex-start;
  }

  /* Estilo de cada item */
  .servicio-item {
    flex: 0 0 auto; /* Asegura que cada item tenga un ancho fijo */
    scroll-snap-align: start;
    min-width: 250px; /* Asegura que cada item tenga un tamaño adecuado */
      max-width: 100%; 
    border: 2px solid #003366; /* Borde sólido */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; /* Centrado de contenido */
  }
}


.servicio-item p {
    font-size: 15px;
    max-width: 200px;  /* 🔹 mantiene márgenes */
  }


/* ======== BOTÓN "LEER MÁS" MOBILE ======== */

/* Ocultar el botón original dentro de .servicios-title cuando se vea en mobile */
@media (max-width: 768px) {
  .servicios-title a {
    display: none;
  }

  /* Mostrar el nuevo botón debajo del carrusel */
  .mobile-readmore-wrap {
    display: block;
    text-align: center;
    margin-top: 20px;
  }

  .mobile-readmore-wrap a {
    background-color: #0B1761;
    color: white;
    padding: 10px 20px;
    text-decoration: none;
    border-radius: 5px;
    font-size: 16px;
    display: inline-block;
    width: 90%;
    max-width: 400px;
  }
}

/* Ocultar el contenedor del botón mobile en escritorio */
@media (min-width: 769px) {
  .mobile-readmore-wrap {
    display: none;
  }
}





/* ---------- CONTACTO ---------- */

.contacto {
  max-width: var(--ancho-contenido);
  margin: 0 auto;
  padding: 0;
  background-color: white;
}

.contacto-titulo {
  background-color: #70abdf;
  color: white;
  padding: 10px 20px;
  text-align: center;
  font-size: 38px;
  margin: 40px 0 10px 0;;
}

.contacto-container {
  display: flex;
  gap: 20px;
  padding: 20px 0;
  align-items: stretch; /* ✅ asegura mismo alto entre info y form */
}

.contacto-info,
.contacto-form {
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* Ítems de contacto */
.contacto-info { gap: 16px; }

.contacto-item {
  display: flex;
  height: 100%;
  align-items: stretch; 
}

/* Columna del ícono */
.icono-columna {
  background-color: #D5E6F5;
  padding: 15px;
  width: 80px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 5px;
}

.icono-columna img {
  width: 30px;
  height: 30px;
}

/* Columna del texto */
.texto-columna {
  flex: 1;
  padding: 15px;
  background-color: rgba(213, 229, 245, 0.5);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

/* Bullets */
.texto-columna ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.texto-columna li {
  position: relative;
  padding-left: 1em;
  margin-bottom: 5px;
  color: #004A91;
  font-size: 16px;
}

.texto-columna li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: -0.15em;
  color: #73A9DD;
  font-size: 1.7em;
  line-height: 1;
}

/* Bullets diferenciales */
.texto-columna li.wp::before   { color: #25D366; } /* WhatsApp */
.texto-columna li.mail::before { color: #0a66c2; } /* Mail */
.texto-columna li.dir::before  { color: #6b7280; } /* Dirección */

/* Texto y links */
.texto-columna p {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: #004A91;
}

.texto-columna a {
  text-decoration: none;
  color: inherit;
  font-weight: bold;
}

/* Formulario */
.contacto-form {
  background-color: #f2f2f2;
  padding: 15px;
  gap: 15px;
  min-width: 0;
}

.contacto-form input,
.contacto-form textarea {
  width: 100%;
  padding: 12px;
  font-size: 14px;
  border: none;
}

.contacto-form textarea {
  resize: vertical;
  height: 150px;
}

.contacto-form button {
  background-color: #071466;
  color: white;
  padding: 15px;
  border: none;
  font-weight: bold;
  cursor: pointer;
  border-radius: 5px;
  transition: background 0.3s;
}

.contacto-form button:hover {
  background-color: #006DC1;
}

/* Línea separadora */
.separador {
  border: none;
  border-top: 1px solid #0b1761;
  margin: 10px 0;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 768px) {
  .contacto-container {
    flex-direction: column;
    padding: 20px 0;
  }

.contacto-titulo {

  margin: 40px 0 5px 0;;
}

  .contacto-item {
    flex-direction: column;
  }

  .icono-columna {
    width: 100%;
    justify-content: center;
  }

  .texto-columna {
    align-items: center;
    text-align: center;
    margin-top: 5px;
  }
}


/* ---------- legal ---------- */

.legal {
  text-align: left;
  font-size: 14px;
  color: #0B1761;
margin: 0 auto 20px auto;
  font-weight: 500;
  max-width: var(--ancho-contenido);
}

.legal a {
  text-decoration: none;
  color: inherit;
}

/* ---------- footer ---------- */

.footer {
  max-width: var(--ancho-contenido);
  margin: 0 auto;
  background-color: #0B1761;
  color: white;
  font-size: 14px;
  padding: 20px;
}

.footer-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

.footer-content p {
  margin: 0;
}

.footer-content img {
  height: 30px;
  max-width: 250px;
  object-fit: contain;
}

/* ===== Footer - versión limpia ===== */
@media (max-width: 768px) {
  /* Fondo azul a todo ancho */
  .footer {
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    background: #0B1761;
    color: white;
    padding: 20px 0;
    box-sizing: border-box;
  }

  /* Contenido centrado y con aire */
  .footer-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
  }

  .footer-content img {
    display: block;
    margin: 0 auto;
  }
}


html {
  scroll-behavior: smooth;
}




/* -------------------- SECCIÓN SOLO TEXTO - Nosotros -------------------- */
.texto-seccion {
  padding: 40px 0;              /* Espacio arriba y abajo */
  background-color: #fff;       /* Fondo blanco */
}

.texto-seccion .container {
  max-width: 1200px;            /* Ancho máximo en desktop */
  margin: 0 auto;
  padding: 0 0px;              /* Padding lateral para mobile */
  box-sizing: border-box;
}

.texto-seccion p {
  font-size: 20px;              /* Tamaño desktop */
  color: #6A6A6A;               /* Color gris pedido */
  line-height: 1.6;             /* Buena legibilidad */
  margin: 0;
}

/* ================== RESPONSIVE ================== */
@media (max-width: 768px) {
  .texto-seccion p {
    font-size: 18px;            /* Ajuste para mobile */
    line-height: 1.4;
  }

  .legal{
    text-align: center;
    display: flex;
    justify-content: center;
  }
  

}

