/* Estilos generales */
body {
    font-family: 'Poppins', sans-serif;
    margin: 0;
    padding: 0;
    background-color: white;
}

/*Para cuando algo tarde en cargar*/
#preloader {
    position: fixed;
    width: 100%;
    height: 100%;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.spinner {
    width: 50px;
    height: 50px;
    border: 5px solid #0078d7;
    border-top: 5px solid transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}


/* Imagen con texto sobrepuesta */
.hero-container {
    margin-top: 130px;
    position: relative;
    width: 100%;
    height: 600px;
}

.hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.6);
}

.hero-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 36px;
    font-weight: bold;
    text-align: center;
    width: 90%;
}

 /* Estilos básicos para la sección */
 .navigation-section {
    width: 80%;
    padding: 20px;
    text-align: left;
    
}

.navigation-section ul {
    list-style-type: none;
    padding: 0;
}

.navigation-section ul li {
    display: inline;
    margin: 0 15px;
}

.navigation-section ul li a {
    text-decoration: none;
    color: #333;
    font-weight: bold;
}

.navigation-section ul li a:hover {
    color: #007BFF;
}

/* Estilos para las secciones a las que se enlaza */
.section {
    padding: 50px 20px;
    margin-top: 20px;
    border-top: 1px solid #ccc;
}

#equipamiento {
    background-color: #e9f5ff;
}

#galeria {
    background-color: #fff3e6;
}

#servicios {
    background-color: #e6ffe6;
}

#localizacion {
    background-color: #ffe6e6;
}



/* Detalles del proyecto */
.project-details {
    background-color: white;
    padding: 30px;
    margin: 20px auto;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    width: 80%;
    margin-top: 40px;
}

.project-details h2{
    color: #405D72;
    font-size: 30px;
}

.details-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 20px;
}

.detail-box {
    background-color: #f9f9f9;
    padding: 20px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
    text-align: center;
    font-size: 20px;
}

.promocion-caracteristicas {
    width: 80%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    padding: 20px;
    margin: 20px auto;
}

.titulo-container {
    width: 100%;
    padding-right: 20px;
    text-align: left;
}

.titulo-container h2 {
    font-size: 32px;
    font-weight: 600;
    color: #405D72;
    margin: 0;
}

.texto-container {
    flex: 1;
    text-align: left;
}

.texto-container p {
    font-size: 24px;
    line-height: 1.6;
    color: #333;
    margin: 0 0 15px 0;
}

.promocion-equipamiento {
    padding: 40px 20px;
    background-color: #ffffff;
    text-align: center;
    width: 80%;
    margin: 0 auto;
    display: flex;
    gap: 20px;
}

.equipamiento-titulo {
    width: 30%; /* Ocupa el 30% del ancho */
    text-align: left;
}

.promocion-equipamiento h2{
    font-size: 28px;
    color: #405D72;
    margin-bottom: 40px;
    text-align: left;
}

.equipamiento-container {
    display: grid; /* Usamos CSS Grid */
    grid-template-columns: repeat(4, 1fr); /* 4 columnas de igual tamaño */
    gap: 20px; /* Espacio entre las cajas */
    scroll-snap-type: x mandatory;
    white-space: nowrap;
}

.equipamiento-box {
    border: 1px solid #e0e0e0;
    padding: 20px;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    aspect-ratio: 1 / 1; /* Hace que el alto sea igual al ancho */
    display: flex;
    flex-direction: column;
    justify-content: center; /* Centra el contenido verticalmente */
    align-items: center; /* Centra el contenido horizontalmente */
}

.equipamiento-box:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

.equipamiento-box i {
    font-size: 40px;
    color: #405D72;
    margin-bottom: 10px;
}

.equipamiento-box p {
    font-size: 20px;
    color: #333;
    margin: 0;
}


.btn-dosier, .btn-memoria {
    background-color: #405D72; /* Color de fondo */
    color: white; /* Color del texto */
    padding: 10px 20px; /* Espaciado interno */
    font-size: 16px; /* Tamaño de la fuente */
    font-weight: bold; /* Grosor de la fuente */
    text-decoration: none; /* Quita el subrayado del enlace */
    border-radius: 5px; /* Bordes redondeados */
    transition: background-color 0.3s ease; /* Transición suave */
    margin-right: 10px; /* Espacio entre botones */
}

.btn-dosier:hover, .btn-memoria:hover {
    background-color: #0056b3; /* Cambia el color al pasar el mouse */
}

/* Contenedor principal */
.servicios {
    display: flex; /* Usamos flexbox para dividir el espacio */
    width: 100%; /* Ocupa todo el ancho disponible */
    margin-bottom: 20px;
    margin: 0 auto;
}

/* Estilos para el div .arboles */
.arboles {
    width: 35%; /* Ocupa el 20% del ancho */
    position: relative; /* Necesario para posicionar elementos hijos */
    padding: 0; /* Eliminamos el padding para que no afecte el ancho */
    color: white; /* Color del texto */
    overflow: hidden; /* Evita que la imagen se desborde */
    align-items: end;
    margin-left: 2%;
}

/* Estilos para la imagen de fondo */
.login-image {
    position: absolute; /* Posiciona la imagen de forma absoluta */
    bottom: 0;
    width: 100%; /* Ocupa todo el ancho del div */
    height: 100%; /* Ocupa todo el alto del div */
    object-fit: cover; /* Cubre todo el espacio disponible */
    z-index: 1; /* Coloca la imagen en una capa inferior */
    opacity: 0.75;
}

/* Estilos para el texto */
.arboles h2 {
    position: relative; /* Posiciona el texto de forma relativa */
    z-index: 2; /* Coloca el texto en una capa superior */
    margin: 0; /* Elimina el margen por defecto */
}

/* Estilos para .promocion-servicios */
.promocion-servicios {
    width: 70%; /* Ocupa el 70% del ancho (80% - 10% de margen) */
    background-color: #ffffff;
    text-align: center;
    margin-right: 10%; /* Margen izquierdo del 10% */
    margin-left: 5%;
}

.promocion-servicios h2 {
    font-size: 28px;
    color: #405D72;
    margin-bottom: 40px;
    text-align: left;
}

.servicios-container {
    display: grid; /* Usamos CSS Grid */
    grid-template-columns: repeat(4, 1fr); /* 4 columnas de igual tamaño */
    gap: 20px; /* Espacio entre las cajas */
    align-items: stretch;
}

/* Estilos para .servicios-box en el carrusel */
.servicios-box {
    flex: 0 0 calc(50% - 5px); /* Muestra 2 boxes a la vez en móviles */
    box-sizing: border-box;
    padding: 10px;
    text-align: center;
    border: 1px solid #ccc; /* Borde para mejor visualización */
    aspect-ratio: 1 / 1; /* Hace que el alto sea igual al ancho */
    display: flex;
    flex-direction: column;
    justify-content: center; /* Centra el contenido verticalmente */
    align-items: center; /* Centra el contenido horizontalmente */
}

.servicios-box:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

/* Ajustar el tamaño de las imágenes dentro de .servicios-box */
.servicios-box img {
    width: 45%; /* Ajusta el tamaño de la imagen */
    height: auto; /* Mantiene la proporción de la imagen */
    margin-bottom: 10px; /* Espacio entre la imagen y el texto */
}

/* Ajustar el texto dentro de .servicios-box */
.servicios-box p {
    font-size: 16px; /* Tamaño de fuente adecuado para móviles */
    color: #333;
    margin: 0;
    text-align: center;
}


/* Estilos generales para el carrusel */
.carousel-container {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.equipamiento-container {
    display: flex;
    transition: transform 0.5s ease-in-out;
    gap: 10px; /* Espacio entre los boxes */
}

.equipamiento-box {
    flex: 0 0 calc(50% - 5px); /* Muestra 2 boxes a la vez (ajusta según necesidad) */
    box-sizing: border-box;
    padding: 10px;
    text-align: center;
    border: 1px solid #ccc; /* Borde para mejor visualización */
}

.equipamiento-box img {
    width: 45%; /* Ocupa todo el ancho del contenedor */
    height: 45%; /* Altura fija para las imágenes */
}

/* Flechas de navegación */
.carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 10;
    display: none; /* Ocultar flechas por defecto */
    border-radius: 50%; /* Hace que las flechas sean circulares */
    width: 40px; /* Tamaño fijo para las flechas */
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-arrow-prev {
    left: 10px; /* Pegada al lateral izquierdo con un pequeño margen */
}

.carousel-arrow-next {
    right: 10px; /* Pegada al lateral derecho con un pequeño margen */
}

/* Media Queries para pantallas pequeñas (móviles) */
@media (max-width: 768px) {

    .project-details {
        width: 90%;
    }

    .carousel-arrow {
        display: flex; /* Mostrar flechas solo en móviles */
    }

    .equipamiento-box {
        flex: 0 0 calc(50% - 5px); /* Muestra 2 boxes a la vez */
    }

    .promocion-equipamiento{
        width: 95%;
        flex-direction: column;
    }
    .navigation-section{
        width: 100%;
    }

    .detail-box .detail-row {
        display: grid;
        grid-template-columns: 1fr 1fr; /* Dos columnas: título y valor */
        gap: 10px;
    }

    .detail-box h3 {
        text-align: left;
        font-size: 20px;
    }

    .detail-box p {
        text-align: right;
        font-size: 20px;
    }

    .details-container br {
        display: none;
    }
}

/* Estilos para pantallas grandes (sin carrusel) */
@media (min-width: 769px) {
    .equipamiento-container {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); /* Diseño original */
        gap: 10px;
    }

    .equipamiento-box {
        flex: 1 1 auto; /* Restablece el comportamiento original */
    }

    .carousel-arrow {
        display: none; /* Ocultar flechas en pantallas grandes */
    }
}




/* Estilos generales para el carrusel */
.carousel-container {
    position: relative;
    width: 100%; /* Ocupa el 100% del ancho */
    overflow: hidden;
}

.servicios-container {
    display: flex;
    transition: transform 0.5s ease-in-out;
    gap: 10px; /* Espacio entre los boxes */
}

.servicios-box {
    flex: 0 0 calc(50% - 5px); /* Muestra 2 boxes a la vez (ajusta según necesidad) */
    box-sizing: border-box;
    padding: 10px;
    text-align: center;
    border: 1px solid #ccc; /* Borde para mejor visualización */
}

/* Flechas de navegación */
.carousel-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.5); /* Fondo semitransparente */
    color: white;
    border: none;
    padding: 10px;
    cursor: pointer;
    z-index: 10;
    display: none; /* Ocultar flechas por defecto */
    border-radius: 50%; /* Hace que las flechas sean circulares */
    width: 40px; /* Tamaño fijo para las flechas */
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.carousel-arrow-prev {
    left: 10px; /* Pegada al lateral izquierdo con un pequeño margen */
}

.carousel-arrow-next {
    right: 10px; /* Pegada al lateral derecho con un pequeño margen */
}

/* Media Queries para pantallas pequeñas (móviles) */
@media (max-width: 768px) {
    .carousel-arrow {
        display: flex; /* Mostrar flechas solo en móviles */
    }

    .servicios-box {
        flex: 0 0 calc(50% - 5px); /* Muestra 2 boxes a la vez */
        aspect-ratio: 1 / 1; /* Mantiene la relación de aspecto cuadrada */
    }

    .servicios-box img {
        width: 40%; /* Ajusta el tamaño de la imagen para móviles */
    }

    .servicios-box p {
        font-size: 14px; /* Tamaño de fuente más pequeño para móviles */
    }

    .promocion-servicios{
        width: 93%;
        margin-left: 3.5%;
        text-align: left;
    }

    .texto-container p {
        font-size: 18px;
        text-align: justify;
    }

    .promocion-caracteristicas {
        width: 95%;
    }

    .servicios{
        width: 95%;
    }
}

/* Estilos para pantallas grandes (sin carrusel) */
@media (min-width: 769px) {
    .servicios-container {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); /* Diseño original */
        gap: 10px;
    }

    .servicios-box {
        flex: 1 1 auto; /* Restablece el comportamiento original */
    }

    .carousel-arrow {
        display: none; /* Ocultar flechas en pantallas grandes */
    }
}












/* Media Queries para responsividad */

@media (max-width: 1200px) {
    
    .arboles h2 {
        padding: 10px; 
        text-align: center;
    }

    .equipamiento-titulo a{
        font-size: 14px;
    }

    .equipamiento-titulo {
        width: 35%;
    }
}

@media (max-width: 768px) {
    .equipamiento-container,
    .servicios-container {
        grid-template-columns: repeat(2, 1fr); /* Crea una tabla de 2 columnas */
        gap: 0; /* Espacio entre las cajas */
        width: 100%;
    }

    .equipamiento-titulo{
        width: 95%;
    }

    .equipamiento-box,
    .servicios-box {
        width: 80%; /* Ocupa todo el ancho de la celda */
    }

    .equipamiento-titulo h2,
    .promocion-servicios h2 {
        font-size: 32px; /* Reduce el tamaño de la fuente */
        margin-bottom: 20px; /* Reduce el margen inferior */
    }

    /*button {
        width: 100%;
        margin: 5px 0; 
    }*/

    .servicios {
        flex-direction: column; /* Cambia a columna en pantallas pequeñas */
        
    }

    .arboles {
        width: 100%; /* Ocupa el 100% del ancho en pantallas pequeñas */
        margin-left: 0; /* Elimina el margen izquierdo */
        margin-bottom: 20px; /* Espacio entre elementos */
        text-align: center;
    }

    .login-image {
        position: relative; /* La imagen se coloca arriba */
        height: 180px; /* Altura fija para la imagen en móviles */
    }

    .arboles h2 {
        padding: 10px; /* Ajusta el padding para móviles */
        text-align: center; /* Centra el texto en móviles */
    }
}

@media (max-width: 480px) {
    .equipamiento-container,
    .servicios-container {
        grid-template-columns: 1fr; /* Una sola columna en móviles pequeños */
        width: 100%;
    }

    .equipamiento-box,
    .servicios-box {
        width: 100%; /* Ocupa todo el ancho en móviles pequeños */
    }

    .promocion-equipamiento h2,
    .promocion-servicios h2 {
        font-size: 32px; /* Reduce aún más el tamaño de la fuente */
    }

    button {
        font-size: 14px; /* Reduce el tamaño de la fuente de los botones */
    }
}

/* Contenedor del carrusel */
.carrusel {
    position: relative;
    width: 80%;
    margin: 40px auto;
    overflow: hidden;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

/* Contenedor de imágenes */
.carrusel-imagenes {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

/* Estilos para cada imagen */
.carrusel-img {
    width: 100%; /* Por defecto, cada imagen ocupa el 100% del contenedor */
    flex-shrink: 0;
    display: none; /* Oculta todas las imágenes por defecto */
    transition: opacity 0.5s ease-in-out;
}

.carrusel-img.activa {
    display: block; /* Muestra solo las imágenes activas */
}

/* Flecha de navegación */
.carrusel-flecha {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(255, 255, 255, 0.8);
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    font-size: 24px;
    color: #405D72;
    cursor: pointer;
    z-index: 10;
    transition: background-color 0.3s ease;
}

.carrusel-flecha:hover {
    background-color: rgba(255, 255, 255, 1);
}

#flecha-derecha {
    right: 10px;
}

#flecha-izquierda {
    left: 10px;
}

/* Media query para pantallas más grandes (modo escritorio) */
@media (min-width: 768px) {
    .carrusel-img {
        width: calc(50% - 10px); /* Cada imagen ocupa la mitad del contenedor, menos el margen */
        margin-right: 20px; /* Margen entre imágenes */
    }

    .carrusel-img:last-child {
        margin-right: 0; /* Elimina el margen de la última imagen */
    }
}

/* Barra de progreso */
.barra-progreso {
    width: 80%;
    height: 5px;
    background-color: #e0e0e0;
    border-radius: 5px;
    margin: 20px auto;
    overflow: hidden;
}

/* Progreso */
.progreso {
    height: 100%;
    width: 0;
    background-color: #405D72;
    border-radius: 5px;
    transition: width 0.5s ease-in-out;
}

/* Visor de PDF */
.visor-pdf {
    width: 80%;
    margin: 40px auto;
    text-align: center;
    background-color: #f9f9f9;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 20px;
}

.visor-pdf {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.flecha-navegacion {
    background-color: #405D72;
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 16px;
    transition: background-color 0.3s ease;
    margin: 0 10px; /* Espacio entre las flechas y el canvas */
}

.flecha-navegacion:hover {
    background-color: #2c3e50;
}

#pdf-canvas {
    border: 1px solid #ccc;
    max-width: 100%;
    height: auto;
}

.controles-pdf {
    text-align: center;
    margin-top: 10px;
}

.controles-pdf span {
    font-size: 18px;
    margin: 0 5px;
}

/* Canvas para mostrar el PDF */
#pdf-canvas {
    width: 100%;
    border: 1px solid #e0e0e0;
    border-radius: 5px;
    background-color: white;
}

/* Botón "Subir arriba" */
#btn-subir {
    display: none; /* Oculto por defecto */
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: #405D72;
    color: white;
    border: none;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    font-size: 24px;
    cursor: pointer;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, opacity 0.3s ease;
    opacity: 0.8;
    z-index: 1000; /* Asegura que esté por encima de otros elementos */
}

#btn-subir:hover {
    background-color: #2c3e50;
    opacity: 1;
}


.promocion-localizacion {
    width: 80%;
    margin-bottom: 20px;
}




.tabla-viviendas {
    padding: 2rem 1rem;
    background-color: #f4f9fc; /* azul muy suave */
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0, 50, 80, 0.1);
  }
  
  .tabla-viviendas h2 {
    text-align: center;
    font-size: 2rem;
    margin-bottom: 1.5rem;
    font-weight: 600;
    color: #005f8a; /* azul mediterráneo */
  }
  
  .tabla-responsive {
    overflow-x: auto;
  }
  
  .tabla-responsive table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 8px; /* espacio entre filas */
  }
  
  .tabla-responsive thead th {
    background-color: #686a4e; /* azul cielo muy pálido */
    color: #004b6e;
    font-weight: 600;
    padding: 0.75rem 1rem;
    text-align: center;
    position: sticky;
    top: 0;
    z-index: 1;
  }
  
  .tabla-responsive tbody tr {
    background-color: #ffffff;
    transition: transform 0.2s;
  }
  
  .tabla-responsive tbody tr:hover {
    transform: translateY(-2px);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }
  
  .tabla-responsive td {
    padding: 0.75rem 1rem;
    text-align: center;
    border-top: 1px solid #d0e4ee; /* línea entre filas */
    color: #333;
  }
  
  .tabla-responsive td:first-child {
    border-left: 1px solid #d0e4ee;
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
  }
  
  .tabla-responsive td:last-child {
    border-right: 1px solid #d0e4ee;
    border-top-right-radius: 8px;
    border-bottom-right-radius: 8px;
  }
  
  .tabla-responsive tbody tr:first-child td {
    border-top: none; /* evita doble línea en primera fila */
  }
  
  .tabla-responsive td a {
    display: inline-flex;
    align-items: center;
    font-weight: 500;
    color: #0077a3;
    text-decoration: none;
  }
  
  .tabla-responsive td a i {
    margin-right: 4px;
  }
  
  .tabla-responsive td a:hover {
    text-decoration: underline;
  }
  
  @media (max-width: 768px) {
    .tabla-viviendas h2 {
      font-size: 1.5rem;
    }
    .tabla-responsive table {
      font-size: 0.9rem;
    }
    .tabla-responsive thead th,
    .tabla-responsive td {
      padding: 0.6rem 0.8rem;
    }
  }
  
  /* Estilos para el banner de cookies */
  .cookie-banner {
      position: fixed; /* Fija el banner en la pantalla */
      bottom: 0; /* Lo coloca en la parte inferior */
      left: 0;
      right: 0;
      background: #333; /* Color de fondo */
      color: #fff; /* Color del texto */
      padding: 15px;
      text-align: center;
      z-index: 1000; /* Asegura que esté por encima de otros elementos */
      display: flex;
      justify-content: space-between;
      align-items: center;
      flex-wrap: wrap;
  }
  
  .cookie-banner p {
      margin: 0;
      flex: 1;
      font-size: 14px;
  }
  
  .cookie-banner button {
      margin: 5px;
      padding: 8px 15px;
      border: none;
      background: #4CAF50; /* Color del botón Aceptar */
      color: white;
      cursor: pointer;
      font-size: 14px;
  }
  
  .cookie-banner button.reject {
      background: #f44336; /* Color del botón Rechazar */
  }