/* Estilos Generales */
:root {
  --primary-color: #0d1b2a; /* Azul oscuro */
  --secondary-color: #415a77; /* Azul grisáceo */
  --accent-color: #778da9; /* Azul claro */
  --light-color: #e0e1dd; /* Casi blanco */
  --text-color: #333;
}

body {
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  margin: 0;
  background-color: #f4f4f9;
  color: var(--text-color);
  line-height: 1.6;

  /* --- CAMBIOS PARA EL FOOTER FIJO --- */
  display: flex;
  flex-direction: column;
  min-height: 100vh; /* El cuerpo de la página ocupará como mínimo el 100% de la altura de la ventana */
}

/* --- NUEVA REGLA PARA EL CONTENIDO PRINCIPAL --- */
main {
  flex-grow: 1; /* Esta es la magia: hace que el contenido principal crezca y empuje el footer hacia abajo */
}

.container {
  background: var(--light-color);
  width: 90%;
  max-width: 1200px;
  margin: 20px auto;
  padding: 20px;
}

/* Header y Navegación */
header {
  background-color: white;
  padding: 1rem 0;
  border-bottom: 1px solid #ddd;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  position: sticky;
  top: 0;
  z-index: 1000;
}

nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}

nav .logo img {
  height: 50px;
}
.logo-container {
    padding: 12px;
    text-align: center; /* Centra la imagen que está adentro */
}
.logo-taxi{
      padding: 12px;
      /*max-width: 180px;*/
      height: auto;
      margin-bottom: 10px;
      text-align: center;
    }

    @media (max-width: 768px) {
      .logo-taxi {
        /* Hacemos el logo más grande para pantallas más anchas */
        max-width: 150px;
      }
    }

    @media (max-width: 1028px){
        .logo-taxi{
        max-width: 250px;
    }

    }

nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
}

nav ul li {
  margin-left: 25px;
}

nav ul li a {
  text-decoration: none;
  color: var(--secondary-color);
  font-weight: bold;
  padding-bottom: 5px;
  transition: color 0.3s, border-bottom 0.3s;
}

nav ul li a:hover,
nav ul li a.active {
  color: var(--primary-color);
  border-bottom: 2px solid var(--primary-color);
}

/* Hero Section (Página de Inicio) */
.hero {
  background: var(--light-color); /*var(--primary-color)*/
  color: black;
  text-align: center;
  padding: 40px 20px;
}

/* Sección de Preguntas Frecuentes (Accordion) */
.faq-section {
    max-width: 800px;
    margin: 40px auto;
}
.accordion-item button {
    background-color: white;
    color: var(--text-color);
    cursor: pointer;
    padding: 18px;
    width: 100%;
    text-align: left;
    border: none;
    border-bottom: 1px solid #ddd;
    outline: none;
    font-size: 1.1rem;
    font-weight: bold;
    transition: background-color 0.4s ease;
    position: relative;
}
.accordion-item button:hover {
    font-size: 1.5rem;
    color: var(--accent-color);
    /*position: absolute;*/
    right: 10px;
    transition: transform 0.3s ease;
    background-color: #f9f9f9;
}
.accordion-content {
    background-color: white;
    padding: 0 18px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}
.accordion-content p {
    margin-top: 15px;
    margin-bottom: 15px;
}
.accordion-item button.active {
    color: white;
    background-color: black; /* Cambia el color de fondo cuando está activo */
}
.accordion-item button::after {
    content: '\002B'; /* Código para el signo '+' */
    font-size: 1.5rem;
    color: var(--accent-color);
    position: absolute;
    right: 20px;
    transition: transform 0.3s ease;
}

.accordion-item button.active::after {
    /* Rota el '+' para que parezca un 'x' o usa el signo de resta */
    content: '\2212'; /* Código para el signo '−' */
    transform: rotate(180deg);
}
/* Footer */
footer {
  background: var(--secondary-color);
  color: var(--light-color);
  text-align: center;
  padding: 2rem 0;
  margin-top: auto; /* Asegura que no haya margen extra si el contenido principal ya llena la página */
}
/* Contenedor principal de los íconos */
.social-icons {
    display: flex; /* ✅ Esto asegura que los íconos se alineen horizontalmente */
    justify-content: center; /* Centra el grupo de íconos */
    align-items: center;
    margin-bottom: 1rem;
}

.social-icons a {
  color: white;
  margin: 0 15px;
  font-size: 1.8rem;
  transition: color 0.3s;
}

.social-icons a:hover {
  color: var(--accent-color);
  transform: scale(1.2);
}

.social-icons .youtube-icon:hover{
   color: red;
   transition: color 0.3s;
}
.social-icons .linkedin-icon:hover{
   color: blue;
   background: white;
   transform: scale(1);
   transition: color 0.3s;
}
.social-icons .facebook-icon:hover{
   color: blue;
}

/* --- NUEVO: ESTILOS PARA LA SECCIÓN DE BENEFICIOS --- */
.benefits-section {
    padding: 40px 20px;
}

.benefits-grid {
    display: grid;
    /* En pantallas grandes, muestra 2 columnas. Puedes cambiarlo a 4 con 'repeat(4, 1fr)' */
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px; /* Espacio entre los elementos */
}
.benefit-item {
    background: white;
    padding: 25px;
    text-align: center;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    transition: transform 0.3s, box-shadow 0.3s;
}

.benefit-item:hover {
    transform: translateY(-5px); /* Efecto de "levantarse" al pasar el mouse */
    box-shadow: 0 8px 20px rgba(0,0,0,0.1);
}

.benefit-icon {
    font-size: 3rem; /* Tamaño del ícono */
    color: var(--primary-color);
    margin-bottom: 15px;
}

.benefit-item h3 {
    margin-bottom: 10px;
    color: var(--secondary-color);
}
.passenger-benefits {
    background-color: var(--light-color); /* Un fondo blanco para esta sección */
    border-radius: 12px;
}