/* Importar la fuente */
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,200..900;1,8..60,200..900&display=swap');

/* General Reset */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body, .image-grid, .grid-item, header, section, footer {
  background-color: #ffffff; /* Fondo blanco */
}

/* Estilo general de la página */
body {
  font-family: 'source serif 4', serif; /* Fuente principal */
  color: #333; /* Color de texto general */
  background-color: #fff; /* Fondo blanco */
}

a {
  pointer-events: auto; /* Asegúrate de que los clics están habilitados */
  text-decoration: none; /* Opcional: quitar el subrayado */
}

a.name {
  cursor: pointer; /* Asegura que el cursor cambie al pasar por el enlace */
}

/* Encabezado */
header {
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0 20px;
  font-size: 1.5em; /* Tamaño reducido del encabezado */
  font-weight: 700; /* Negrita */
  color: #000;
  position: fixed;
  z-index: 9999;
  background-color: transparent
}

header .bold {
  font-weight: 600; /* Negrita */
  text-decoration: none; /* Eliminar subrayado */
  color: #000; /* Color negro */
}

header .regular {
  font-weight: 400; /* Regular */
  text-decoration: none; /* Eliminar subrayado */
  color: #000; /* Color negro */
}

header a:hover {
  text-decoration: none; /* Asegura que no se subraye en hover */
  color: #000; /* Mantiene el color negro en hover */
}

/* Estilo para el segundo header */
.secondary-header {
  top: 0;
  right: 0; /* Alinea el header a la derecha */
  height: 80px; /* Igual altura para alinear con el primer header */
  display: flex;
  align-items: center; /* Centra el contenido verticalmente */
  justify-content: flex-end; /* Alinea el contenido al final (derecha) */
  padding: 0 20px;
  background-color: transparent; /* Fondo transparente o lo que necesites */
  color: #333;
  position: fixed;
  z-index: 1;
  font-weight: 300; /* Regular */
  text-decoration: none; /* Eliminar subrayado */
  font-size: 1.5em;
}

/* Sidebar */
.sidebar {
  position: fixed;
  top: 80px;
  left: 0;
  width: 25%;
  height: calc(100% - 80px);
  background-color: transparent; /* Fondo blanco para el sidebar */
  color: #000; /* Texto negro */
  padding: 20px;
  overflow-y: auto;
  z-index: 900;
}

.menu-links {
  list-style: none;
  padding: 0;
}

.menu-links .nav-link a {
  text-decoration: none; /* Sin subrayado */
  color: #000; /* Color negro */
  font-size: 0.8em; /* Tamaño de la tipografía reducido */
  font-weight: 400; /* Peso normal */
  display: block;
  margin-bottom: 10px;
  transition: color 0.3s ease;
  font-family: 'source serif 4', serif;
  font-weight: 300; /* Light */
}


.gray-text {
  color: #333; /* Texto gris */
  font-weight: normal; /* Peso normal */
}

.menu-links .nav-link a:hover {
  color: #333; /* Cambio de color al pasar el ratón */
}

/* Contenido principal */
.content {
  margin-left: 25%;
  width: 75%;
  padding: 100px 20px 20px 20px;
  background-color: #ffffff;
}


/* Estilo para las imágenes en la galería */
.clickable-image {
  cursor: pointer;
  transition: transform 0.3s ease;
}

.clickable-image:hover {
  transform: none;
}

/* Imagen de la galería */
/* Estilo general para la galería de imágenes */
.image-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* Máximo de 3 columnas */
  gap: 15px; /* Espacio entre imágenes */
  margin-right: 150px;
}

.grid-item {
  position: relative;
}

.horizontal img {
  width: 100%; /* Ocupa todo el ancho del contenedor */
  height: 150%;
  display: block;
}

.vertical img {
  width: 100%; /* Ocupa todo el ancho del contenedor */
  height: 100%;
  display: block;
  object-fit: cover;
}

.horizontal {
  display: flex;
  flex-direction: column;
}

.vertical {
  grid-row: span 2; /* Ocupa el espacio de dos filas */
}

/* Efecto de overlay al pasar el cursor */
.grid-item .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.5); /* Filtro blanco translúcido */
  display: flex;
  justify-content: center;
  align-items: center;
  opacity: 0; /* Oculto por defecto */
  transition: opacity 0.3s ease; /* Transición suave */
  pointer-events: none; /* Esto permite que los clics pasen a través del overlay */
}

.grid-item:hover .overlay {
  opacity: 1; /* Muestra el overlay al pasar el cursor */
}

.overlay .text {
  color: black; /* Ajusta el color del texto */
  font-size: 0.9rem; /* Tamaño del texto */
  text-align: center;
  font-family: 'source serif 4', serif;
  font-weight: 300; /* Regular */
  font-size: 0.8em;
}

/* Patrones */
.pattern1 .grid-item:nth-child(1) {
  grid-column: 1;
}

.pattern1 .grid-item:nth-child(2) {
  grid-column: 2;
}

.pattern1 .grid-item:nth-child(3) {
  grid-column: 2;
  grid-row: span 2;
}

.pattern1 .grid-item:nth-child(4) {
  grid-column: 3;
}

.pattern1 .grid-item:nth-child(5) {
  grid-column: 3;
  grid-row: span 2;
}

.pattern2 .grid-item:nth-child(1) {
  grid-column: 2;
  grid-row: span 2;
}

.pattern2 .grid-item:nth-child(2) {
  grid-column: 1;
}

.pattern2 .grid-item:nth-child(3) {
  grid-column: 3;
  grid-row: span 2;
}

.pattern2 .grid-item:nth-child(4) {
  grid-column: 3;
  grid-row: span 2;
}


/* Estilos para el lightbox */
.lightbox {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color:  #ffffff;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  overflow: hidden;
}

.lightbox-container {
  position: relative; /* Asegura que el cierre esté relativo a este contenedor */
  width: 100%; /* O cualquier tamaño deseado */
  height: 100%; /* O cualquier tamaño deseado */
}

/* Contenedor del lightbox */
.lightbox-content {
  position: relative;
  width: 1000%;
  max-width: 1000%;
  height: auto;
  background-color: white;
  padding: 20px;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

/* Imagen dentro del lightbox */
#lightbox-image {
  max-width: 100%;
  max-height: 70vh; /* La imagen ocupa un 70% de la altura de la pantalla */
  object-fit: contain;
}

/* Descripción debajo de la imagen */
#lightbox-description {
  color: black;
  font-size: 18px;
  margin-top: 15px;
  text-align: center;
  font-family: 'source serif 4', serif;
  font-weight: 300; /* Regular */
  font-size: 0.9em;
}

/* Botón de cerrar */
.lightbox-close {
  position: absolute;
  top: 0px; /* Sin margen arriba */
  right: 300px; /* Ajustado a la esquina derecha */
  font-size: 48px; /* Aumento de tamaño */
  color: black;
  cursor: pointer;
  z-index: 9999; /* Asegúrate de que la x esté encima de otros elementos */
}

/* Flechas para navegar entre las imágenes */
.lightbox-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-size: 36px;
  color: black;
  cursor: pointer;
  z-index: 10;
  padding: 20px;
}

/* Flecha izquierda */
.lightbox-arrow-left {
  left: 10px;
}

/* Flecha derecha */
.lightbox-arrow-right {
  right: 10px;
}


.copyright {
  position: fixed;
  bottom: 0;
  left: 0;
  padding: 10px;
  font-size: 0.7em; /* Ajusta el tamaño de la fuente si es necesario */
  color: #333; /* Puedes cambiar el color si lo prefieres */
  background-color: #ffff; /* Fondo blanco para asegurar legibilidad */
  width: auto; /* Asegura que ocupe todo el ancho de la página */
  text-align: left; /* Alinea el texto a la izquierda */
  z-index: 1000; /* Asegura que esté por encima de otros elementos */
  font-weight: 300; /* Light */
}

@media (max-width: 768px) {
  /* Sidebar fijo a la izquierda */
  .sidebar {
    position: fixed;
    left: 0;
    margin-top: 10px;
    width: 25%; /* Sidebar ocupa un cuarto de la pantalla */
    height: 100%;
    background-color: transparent;
    padding: 10px;
    overflow-y: auto;
    z-index: 2;
  }

  /* Contenido principal ajustado */
  .content {
    margin-left: 30%; /* Ajuste para mover la columna de imágenes más hacia la derecha */
    width: 70%; /* Reducir el espacio ocupado por el contenido */
    padding: 20px 10px;
  }

  /* Headers fijos y optimizados */
  header {
    position: fixed;
    top: 0;
    width: 50%; /* Ocupa el 50% del espacio restante */
    display: flex;
    justify-content: flex-start; /* Contenido alineado a la izquierda */
    align-items: center;
    height: 50px;
    padding: 0 15px;
    background-color: transparent;
    z-index: 3;
  }

  .secondary-header {
    position: fixed;
    top: 0;
    left: 75%; /* Justo después del header principal */
    width: 25%; /* Ocupa el espacio restante */
    display: flex;
    justify-content: flex-end; /* Contenido alineado a la derecha */
    align-items: center;
    height: 50px;
    padding: 0 15px;
    background-color: transparent;
    z-index: 3;
  }

  /* Galería de imágenes ajustada */
  .image-grid {
    display: block; /* No usar grid, sino solo una columna */
    margin-top: 75px; /* Espacio debajo de los headers */
    margin-left: 60px; /* Mueve las imágenes un poco hacia la derecha */
  }

  .grid-item {
    margin-bottom: 5px; /* Separación entre imágenes más pequeña */
    display: block;
  }

  .grid-item img {
    width: 200%; /* Las imágenes ocupan el ancho completo */
    height: auto; /* Mantiene la proporción */
    max-height: 500px; /* Limita la altura para que no se expandan demasiado */
    object-fit: contain; /* Ajusta sin recortar contenido */
  }

  /* Corrección para eliminar espacio extra */
  body, html {
    margin: 0;
    padding: 0;
    overflow-x: hidden; /* Elimina el scroll horizontal */
  }

  /* Footer optimizado */
  .copyright {
    font-size: 0.9em;
    padding: 10px;
    text-align: center;
  }
}
