/* General */ 
* {
  font-family: "Questrial", sans-serif; /* Aplica la fuente 'Questrial' a todos los elementos */
}

body {
  margin: 0; /* Elimina márgenes por defecto del navegador */
  font-family: sans-serif; /* Fuente por defecto si no se carga Questrial */
  background-color: #203145; /* Fondo negro (puedes usar #000 también) */
  color: #fff; /* Texto blanco por defecto */
}

/* Header */
.header {
  justify-content: space-between; /* Espacia elementos al máximo dentro del header */
  background-color: #203145; /* Fondo negro (puedes usar #000 también) */
  top: 10; /* Este valor no tiene efecto sin posición relativa/absoluta */
  z-index: 100; /* Prioridad de apilamiento (útil si se usa posición absoluta) */
  display: flex; /* Usa Flexbox para alinear elementos del header */
  align-items: center; /* Centra verticalmente los elementos */
  padding: 20px 50px; /* Espacio interno alrededor del contenido */
}

.back-arrow, .contact-link {
  color: #fff; /* Texto blanco */
  text-decoration: none; /* Sin subrayado */
  font-size: 1rem; /* Tamaño de fuente */
}

.logo {
  height: 1.5rem; /* Altura del logo (autoajusta el ancho) */
}

/* Gallery layout */
.gallery {
  display: flex; /* Layout vertical */
  flex-direction: column; /* Apila los elementos en columna */
  gap: 2rem; /* Espacio entre filas de galería */
  padding: 1rem; /* Espacio interior alrededor de la galería */
  max-width: 92%; /* Limita el ancho máximo */
  margin: auto; /* Centra horizontalmente */
}

.gallery-row {
  display: grid; /* Usa grid para colocar imagen y texto */
  grid-template-columns: 1fr 2fr; /* Primer columna (texto): 1 parte, segunda (imagen): 2 partes */
  gap: 1rem; /* Espacio entre columnas */
}

.gallery-row.reverse {
  grid-template-columns: 2fr 1fr; /* Inversa: imagen 2/3, texto 1/3 */
}

.texto-container {
  position: relative; /* Para posicionar overlay de texto */
}

.texto-container img {
  width: 100%; /* Imagen ocupa todo el ancho disponible */
  border-radius: 8px; /* Bordes redondeados */
}

.image-container {
  position: relative; /* Para overlays o efectos */
  width: 100%; /* Ocupa todo el ancho del contenedor padre */
  overflow: hidden; /* Oculta contenido que se salga (zoom, etc.) */
  cursor: grab; /* Cursor de "agarrar" cuando se pasa por encima */
}

.image-container img {
  width: 100%;
  height: auto;
  border-radius: 8px;
  display: block; /* Quita espacio extra debajo de la imagen */
  transition: transform 0.2s ease; /* Suaviza zoom/movimiento */
  transform-origin: center center; /* Punto de origen para transformaciones */
  user-select: none; /* Evita seleccionar la imagen al hacer drag */
  pointer-events: none; /* Hace que los eventos pasen al contenedor (no a la imagen) */
}

.image-container.zoom img {
  transform: scale(var(--zoom, 1)); /* Permite usar una variable CSS para hacer zoom */
}

/* Text Overlay */
.text-overlay {
  position: relative;
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 0.1rem;
  color: white;
  box-sizing: border-box;
  height: 100%; /* Asegura que se alinee con la imagen vecina */
}


.text-content {
  display: flex;
  flex-direction: column; /* Apila título y párrafos */
  max-width: 80%; /* Limita el ancho del bloque de texto */
}

.text-content h1 {
  margin-top: 7%;
  font-weight: 600; /* Semi-negrita */
  font-size: clamp(1.4rem, 2.8vw, 2rem); /* se adapta entre 1rem y 1.8rem según el ancho */
  text-align: left; /* Alineación izquierda */
  margin-bottom: 1.5rem; /* Espacio inferior con el párrafo */
}

.text-content p {
  font-size: clamp(1.1rem, 2.2vw, 1.1rem); /* escala con el ancho de la pantalla */
  line-height: 1.4; /* Espaciado entre líneas */
  text-align: justify; /* Justifica el texto */
}


/* Redes sociales */
.social-links {
    width: 80%;
    gap: 10px; /* Espacio entre enlaces */
    margin: auto auto; /* Centra horizontalmente */
}

.social-links a {
    padding: 3px;
    color: #E8EEF1;
    text-decoration: none;
    font-size: 30px;
    transition: color 0.3s ease, transform 0.3s ease;
}
.social-links a:hover i {
    color: #E8EEF1; /* o cualquier color que quieras al pasar el mouse */
    transform: scale(1.2); /* efecto de zoom suave */
  }

/* Footer */
footer {
    text-align: center; /* Centra texto en el footer */
    padding: 1rem 4rem; /* Espaciado arriba/abajo e izquierda/derecha */
    font-size: 0.9rem;
    background-color: #203145; /* Gris oscuro */
  }

/* Responsive */
@media (max-width: 600px) {
    
  .social-links {
        width: 100%;
        justify-content: center;
    }
      .social-links a {
        font-size: 24px;
    }
  .contenedor-scroll {
    max-height: 180px; /* Altura máxima del contenedor */
    overflow-y: auto;  /* Agrega scroll vertical si es necesario */
    padding: 0 2%;
    scrollbar-width: thin;           /* Firefox */
    scrollbar-color: rgba(252, 75, 75, 0.568) transparent;
  }
  
  .contenedor-scroll::-webkit-scrollbar {
    width: 6px;                      /* Ancho fino */
  }
  
  .contenedor-scroll::-webkit-scrollbar-thumb {
    background-color: #999;          /* Color del "pulgarcito" */
    border-radius: 4px;
  }
  
  .contenedor-scroll::-webkit-scrollbar-track {
    background: transparent;         /* Sin fondo */
  }
  .gallery-row,
  .gallery-row.reverse {
    grid-template-columns: 1fr; /* Una sola columna en móviles */
  }

  .info-btn {
    padding: 0.3rem 0.5rem;
    font-size: 0.9rem;
  }

  .text-overlay {
    font-size: 0.9rem; /* Tamaño de texto más pequeño */
  }
  .text-overlay {
    padding: 0.5rem;
  }

  .text-content {
    padding: 0.5rem;
  }

  .text-content h1 {
    font-size: clamp(1rem, 4vw, 1.4rem);
  }

  .text-content p {
    font-size: clamp(0.8rem, 3vw, 1.1rem);
  }
}
