/* --- NUEVO TEMA BASADO EN EL LOGO --- */

:root {
  --color-azul-oscuro: #1a2630;
  --color-azul-medio: #253347;
  --color-azul-claro: #31425a;
  --color-blanco: #fff;
  --color-gris-claro: #fafafa;
  --color-acento: #31425a;
}

body {
  font-family: Arial, Helvetica, sans-serif;
  margin: 0; padding: 0;
  background: var(--color-gris-claro);
  color: var(--color-azul-oscuro);
}

header {
  background: var(--color-blanco); /* Cambia el fondo a blanco */
  color: var(--color-azul-oscuro); /* Cambia el texto a azul oscuro */
  box-shadow: 0 2px 8px rgba(26,38,48,0.08);
}

.header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: auto;
  padding: 16px 32px;
}

.logo {
  height: 80px;
}

nav {
  display: flex;
  align-items: center;
  gap: 32px;
}

nav ul {
  display: flex;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
}

nav a {
  color: var(--color-azul-oscuro);
  font-weight: 500;
  font-size: 1.25rem; /* Más grande */
  text-decoration: none; /* Quita el subrayado */
  padding: 4px 8px;
}

.contact-btn {
  background: var(--color-acento);
  color: var(--color-blanco);
  padding: 10px 24px;
  border-radius: 24px;
  margin-left: 24px;
  font-weight: bold;
  transition: background 0.2s;
}

.contact-btn:hover {
  background: var(--color-azul-medio);
}

main {
  margin-top: 10px; /* Reduce el margen superior */
  scroll-snap-type: y mandatory;
}

.hero {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 1200px;
  margin: 0 auto;
  gap: 48px;
  padding: 16px 24px 0 24px; /* Reduce el padding superior */
}

.hero-content {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.logo-full-container {
  flex: 0 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 8px;
  margin-bottom: 0;
}

.logo-full {
  max-width: 360px; /* ajusta al tamaño deseado */
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
  margin: 0;
}

.hero-text {
  flex: 1 1 420px;
}

.hero-text h1 {
  color: var(--color-azul-oscuro);
  font-size: 2.4rem;           /* título principal más grande */
  font-weight: 800;
  line-height: 1.05;
  margin: 0;
  letter-spacing: 0.3px;
}

.hero-text p {
  font-size: 1.125rem;         /* texto de introducción más legible */
  color: #26333a;
  line-height: 1.6;
  margin-top: 12px;
  opacity: 0.95;
}

.hero-buttons {
  display: flex;
  gap: 16px;
}

.btn {
  display: inline-block;
  padding: 10px 18px;
  border-radius: 8px;
  font-weight: 700;
  text-decoration: none;
  font-size: 1.05rem;
  transition: background 0.2s;
  background: var(--color-acento);
  color: var(--color-blanco);
}

.btn-orange {
  background: var(--color-azul-oscuro);
  color: var(--color-blanco);
}

.btn-orange:hover {
  background: var(--color-azul-medio);
}

.hero-image img {
  width: 340px;
  height: 420px;
  object-fit: cover;
  border-radius: 18px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}

/* Servicios */
.servicios {
  max-width: 1200px;
  margin: 48px auto 0 auto;
  padding: 0 24px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Evitar que la tarjeta empalme con la línea: espaciado y control de z-index */
.servicios { 
  /* separa visualmente la sección del separador siguiente */
  padding-bottom: 48px; 
  position: relative;
}

/* Si las tarjetas usan posicionamiento, asegurarlas debajo de la línea */
.servicio-card {
  position: relative;
  z-index: 1; /* baja prioridad de apilamiento */
}

.servicios h2,
.section-title {
  color: var(--color-azul-oscuro);
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 32px;
  text-align: center;
  letter-spacing: 0.4px;
  margin: 0 0 12px 0;
}

.servicios-lista {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  justify-content: center;   /* Centra horizontalmente las tarjetas */
  align-items: center;       /* Centra verticalmente si hay espacio */
  width: 100%;
  margin: 0 auto;
  min-height: 400px;
}

.servicio-card {
  background-color: var(--color-azul-oscuro);
  color: var(--color-blanco) !important;
  background-size: cover;
  background-position: center;
  border-radius: 20px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  padding: 48px 64px;
  font-size: 2.2rem;
  font-weight: 900;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
  text-align: center;
  min-width: 320px;
  min-height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  z-index: 2;
}

.servicio-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(26,38,48,0.65);
  border-radius: 20px;
  z-index: 1;
  pointer-events: none;
}

.servicio-card:hover,
.servicio-card.active {
  transform: scale(1.07);
  box-shadow: 0 12px 32px rgba(0,0,0,0.22);
}

.servicio-card span {
  display: block;
  transition: opacity 0.3s;
  position: relative;
  z-index: 2;
  font-size: 2rem;            /* aumentado: título dentro de la tarjeta */
  font-weight: 800;
  color: var(--color-blanco);
  text-transform: none;
  text-shadow: 0 1px 2px rgba(0,0,0,0.35);
}

/* descripción que aparece al hover */
.servicio-info {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: transparent;
  color: var(--color-blanco);
  padding: 0;
  border-radius: 0;
  font-size: 1.125rem;        /* aumentado: descripción en la tarjeta */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  z-index: 3;
  width: 100%;
  text-align: center;
  font-weight: 700;
  line-height: 1.3;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.servicio-card:hover,
.servicio-card.active {
  transform: scale(1.07);
  box-shadow: 0 12px 32px rgba(0,0,0,0.22);
}

.servicio-card:hover span,
.servicio-card.active span {
  opacity: 0;
  pointer-events: none;
}

.servicio-info {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: transparent;
  color: var(--color-blanco);
  padding: 0;
  border-radius: 0;
  font-size: 1rem;             /* descripción en la tarjeta */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
  z-index: 3;
  width: 100%;
  text-align: center;
  font-weight: 900;
  line-height: 1.2;
  box-shadow: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.servicio-card:hover .servicio-info,
.servicio-card.active .servicio-info {
  opacity: 1;
  pointer-events: auto;
}

.btn-agendar {
  background: var(--color-acento);
  color: var(--color-blanco);
  padding: 12px 32px;
  border-radius: 24px;
  font-weight: bold;
  font-size: 1.1rem;
  text-decoration: none;
  border: none;
  cursor: pointer;
  margin-top: 16px;
  transition: background 0.2s;
}

.btn-agendar:hover {
  background: var(--color-azul-medio);
}

section {
  min-height: calc(100vh - 96px);
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding: 48px 0 0 0;
  margin-bottom: 48px;
  box-sizing: border-box;
  background: var(--color-gris-claro);
  border-bottom: 8px solid var(--color-acento);
}

.hero-content {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

section:not(:last-child) {
  border-bottom: 8px solid var(--color-acento);
}

.footer-bg {
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-azul-oscuro);
  color: var(--color-blanco);
  text-align: center;
  padding: 32px 0;
  margin-top: 48px;
}

/* Sección Preguntas frecuentes */
.preguntas {
  padding: 56px 20px;
  background: linear-gradient(180deg, rgba(250,250,251,0.98), rgba(246,247,249,0.98));
  color: var(--color-azul-oscuro);
}
.preguntas .container { max-width:1200px; margin:auto; position: relative; }

/* Carrusel horizontal: tarjetas grandes que ocupan todo el ancho */
.preguntas .container { max-width: 1200px; margin: auto; position: relative; }

/* convertimos la grid en un slider horizontal */
.preguntas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 18px;
  padding: 18px 8px;
  align-items: stretch;
  overflow: visible;           /* permitir ver todas sin scroll interno */
  scroll-snap-type: none;      /* desactivar snap si existía */
}

/* Tarjeta más compacta */
.pregunta-card {
  flex: none;
  scroll-snap-align: none;
  min-height: 220px;           /* menos altura */
  padding: 20px;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--color-acento), var(--color-azul-medio));
  color: #fff;
  box-shadow: 0 10px 28px rgba(49,66,90,0.12);
  transition: transform .16s ease, box-shadow .16s ease;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

/* Tipografía adaptada: título y texto más pequeños para caber más tarjetas */
.pregunta-num { font-size: 0.95rem; margin-bottom: 8px; color: rgba(255,255,255,0.9); }
.pregunta-titulo { font-size: 1.1rem; line-height:1.15; margin: 0 0 8px 0; font-weight:800; color:#fff; text-shadow: 0 4px 10px rgba(0,0,0,0.28); }
.pregunta-respuesta { font-size: 0.95rem; line-height:1.4; color: rgba(255,255,255,0.92); max-height: none; opacity:1; transform:none; }

/* Estado hover/open con ligero lift */
.pregunta-card:hover,
.pregunta-card.open { transform: translateY(-6px); box-shadow: 0 18px 46px rgba(49,66,90,0.16); }

/* Ocultar controles del carrusel si siguen cargándose (evita solapamientos visuales) */
.preguntas .carousel-btn { display: none !important; }
.preguntas .carousel-dots { display: none !important; }

/* Responsive: reducir padding y tamaño en móviles */
@media (max-width:1100px) {
  .preguntas-grid { gap: 14px; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
  .pregunta-card { min-height: 200px; padding: 16px; }
  .pregunta-titulo { font-size: 1rem; }
  .pregunta-respuesta { font-size: 0.95rem; }
}
@media (max-width:600px) {
  .preguntas-grid { gap: 12px; grid-template-columns: 1fr; }
  .pregunta-card { min-height: auto; padding: 14px; }
  .pregunta-titulo { font-size: 0.98rem; }
  .pregunta-respuesta { font-size: 0.92rem; }
}

@media (max-width: 768px) {
  .header-container,
  .hero-content,
  .servicios-lista {
    flex-direction: column !important;
    padding: 16px !important;
    gap: 16px !important;
    max-width: 100% !important;
  }

  .logo {
    height: 56px !important;
  }

  .servicio-card {
    min-width: 90vw !important;
    min-height: 180px !important;
    padding: 24px 12px !important;
    font-size: 1.2rem !important;
  }

  .servicio-card span {
    font-size: 1.25rem !important; /* título en móvil */
  }

  .servicio-info {
    font-size: 1rem !important;    /* descripción en móvil */
  }

  .section-title {
    font-size: 1.5rem !important;
  }

  .hero-text h1 {
    font-size: 1.6rem !important;
  }

  .hero-image img {
    width: 90vw !important;
    height: auto !important;
    max-width: 320px !important;
    border-radius: 12px !important;
  }

  .footer-bg {
    padding: 16px 0 !important;
    min-height: 80px !important;
    font-size: 1rem !important;
  }
}

/* Si quieres aún más pequeño en pantallas grandes */
@media (min-width: 1200px) {
  .logo-full { max-width: 500px; }
}

/* Fix: evitar overflow horizontal por tarjetas de servicios en móviles */
html, body { box-sizing: border-box; }
*, *::before, *::after { box-sizing: inherit; }

/* Asegurar que el contenedor respete su padding sin desbordar */
.servicios {
  padding-left: 16px;
  padding-right: 16px;
}

/* limitar el ancho efectivo de la lista y evitar scroll inesperado */
.servicios-lista {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
  overflow-x: hidden; /* evita pequeños desbordes visibles */
}

/* tarjetas: permitir que encajen y reducir min-width en pantallas pequeñas */
.servicio-card {
  min-width: 260px;               /* menos estricto para móviles */
  max-width: calc(100% - 32px);   /* evita que una tarjeta supere el ancho disponible */
  padding: 28px 36px;             /* reducir si es necesario */
}

/* en pantallas muy estrechas, hacer que las tarjetas ocupen casi todo el ancho */
@media (max-width: 820px) {
  .servicios-lista {
    gap: 18px;
    justify-content: center;
  }
  .servicio-card {
    min-width: calc(90vw - 32px) !important;
    max-width: calc(90vw - 32px) !important;
    padding: 20px 18px !important;
  }
}

/* como última medida, ocultar overflow horizontal en html si algo sigue provocándolo */
html, body { overflow-x: hidden; }
