  :root {
    --bs-primary: #2251a3;
    --bs-primary-rgb: 34, 81, 163;
    --bs-primary-bg-subtle: #d6e0f5;
    --bs-primary-border-subtle: #adc2eb;
    --bs-primary-text-emphasis: #6185c4;
  }

  .btn-primary {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    border-radius: 0%;
  }

  .btn-primary:hover {
    background-color: #1a3f82;
    border-color: #1a3f82;
  }

  .text-primary {
    color: var(--bs-primary) !important;
  }

  .bg-primary {
    background-color: var(--bs-primary) !important;
  }

  .btn-light{
    border-radius: 0%;
  }


  html {
    /*font-family: 'Spicy Rice', cursive;*/
    font-size: 1.0rem;
  }

  .text-balance {
    text-wrap: balance;
    max-width: var(--bs-text-balance-width, 80ch);
  }

  .text-justify {
    text-align: justify !important;
    text-justify: inter-word;
  }


  /*  navbar */
  /* Línea animada en links del navbar */
  .navbar-nav .nav-link {
    position: relative;
    display: inline-block;
    padding-bottom: 3px;
    /* espacio para la línea */
    transition: color 0.4s ease-in-out;
  }

  /* Línea oculta inicialmente */
  .navbar-nav .nav-link::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 3px;
    background-color: var(--bs-primary);
    transition: width 0.4s ease-in-out;
  }

  /* Al hacer hover: línea visible */
  .navbar-nav .nav-link:hover::after {
    width: 100%;
  }

  /* cambio de color del texto en hover */
  .navbar-nav .nav-link:hover,
  .navbar.scrolled .nav-link:hover {
    color: var(--bs-primary-text-emphasis) !important;
  }

  .navbar {
    transition: background-color 0.5s ease, padding 0.5s ease, box-shadow 0.5s ease;
  }

  .navbar.scrolled .navbar-brand,
  .navbar.scrolled .nav-link {
    color: #333 !important;
    text-shadow: none;
  }

  .navbar.scrolled .navbar-toggler {
    border-color: #333;
  }

  .offcanvas {
    position: fixed !important;
    top: 0 !important;
    height: 100vh !important;
    z-index: 1050 !important;

    background-color: rgba(33, 37, 41, 0.5) !important;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
  }

  .navbar.scrolled {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #ffffff !important;
    padding: 0px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    z-index: 2000;
    /* Animación de entrada desde arriba */
    animation: slideDown 0.5s ease forwards;
  }

  /* Animación personalizada para deslizar desde arriba */
  @keyframes slideDown {
    from {
      transform: translateY(-100%);
      opacity: 0;
    }

    to {
      transform: translateY(0);
      opacity: 1;
    }
  }





  #carouselHeader .carousel-item img {
    width: 100%;
    height: 75vh;
    min-height: 300px;
    /* Mínimo en móviles */
    max-height: 800px;
    /* Máximo en pantallas grandes */
    object-fit: cover;
    filter: blur(0px);
    /* Filtro blur de 1px - ajusta según necesites */
  }

  #carouselHeader .carousel-item::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
     background-color: rgba(34, 81, 163, 0.25);
    pointer-events: none;
  }



  /* Espacio y tamaño adaptativo para las cards dentro del carrusel */
  #cardsCarousel .carousel-inner {
    padding: 1rem 0;
  }

  .carousel-item .card {
    border: 0;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
    height: 100%;
  }

  /* Imagen de la card ocupa espacio fijo y se recorta si es necesario */
  .card-img-top {
    width: 100%;
    height: 180px;
    /* ajustar altura según necesites */
    object-fit: cover;
    /* mantiene proporción y recorta centrado */
  }

  /* Evita que el carrusel ocupe todo el alto */
  .carousel {
    max-height: none;
  }

  /* Pequeño margen horizontal entre cards */
  .card-column {
    padding-left: 6px;
    padding-right: 6px;
  }

  /* Opcional: centrar contenido del cuerpo de la card */
  .card-body {
    display: flex;
    flex-direction: column;
    gap: .5rem;
  }




  /* Solo aplica al carrusel con id="cardsCarousel" */
  #cardsCarousel {
    position: relative;
    /* para que los indicators se posicionen respecto a este */
    padding-bottom: 3rem;
    /* deja espacio para que no se corten los indicadores */
  }

  .carousel-indicators [data-bs-target="#cardsCarousel"] {
    background-color: #333;
    /* color de los puntos */
    width: 10px;
    height: 10px;
    border-radius: 50%;
  }



  /* Subpage */

  /* Contenedor principal del hero */
  .hero-container {
    position: relative;
    height: 25vh;
  }

  /* Imagen del hero */
  .hero-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Overlay oscuro para mejor legibilidad */
  .hero-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    /* Equivale a bg-dark bg-opacity-50 */
  }

  /* Contenido de texto */
  .hero-content {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    color: white;
    width: 100%;
    padding-bottom: 1.5rem;
    /* Equivale a pb-4 */
  }

  /* Título del hero */
  .hero-title {
    text-transform: uppercase;
    margin-bottom: 0.5rem;
  }

  /* Texto del hero */
  .hero-text {
    text-wrap: balance;
    margin-left: auto;
    margin-right: auto;
    max-width: 600px;
    /* Ajusta según necesites */
  }



  /* Infinite logos carousel */
  .logos-wrapper {
    position: relative;
    /* necesario para los pseudo-elementos */
    overflow: hidden;
  }

  .logos-track {
    display: inline-flex;
    gap: 50px;
    white-space: nowrap;
    animation: scroll 30s linear infinite;
  }

  .logos-track img {
    max-height: 80px;
    width: auto;
    flex-shrink: 0;
  }

  /* Smooth infinite scroll */
  @keyframes scroll {
    0% {
      transform: translateX(0);
    }

    100% {
      transform: translateX(-50%);
    }
  }

  /* Transparencia en los extremos */
  .logos-wrapper::before,
  .logos-wrapper::after {
    content: "";
    position: absolute;
    top: 0;
    width: 80px;
    /* ajusta el ancho del desvanecido */
    height: 100%;
    z-index: 2;
    pointer-events: none;
  }

  .logos-wrapper::before {
    left: 0;
    background: linear-gradient(to right, rgba(248, 249, 250, 1), rgba(248, 249, 250, 0));
  }

  .logos-wrapper::after {
    right: 0;
    background: linear-gradient(to left, rgba(248, 249, 250, 1), rgba(248, 249, 250, 0));
  }

  /* Pause on hover 
 .logos-wrapper:hover .logos-track {
   animation-play-state: paused;
 }*/


  /* iconos areas de trabajo */
  .icon-circle {
    width: 90px;
    height: 90px;
    border: 3px solid #fff;
    border-radius: 50%;
  }

  .capital-number {
    line-height: 1;
    margin-right: 15px;
    font-size: 12rem;
    letter-spacing: -0.10em;
  }


  /* section Soluciones Constructivas */
  .service-item {
    height: 400px;
    position: relative;
    overflow: hidden;
  }

  .service-img {
    object-fit: cover !important;
  }

  /* Texto centrado sobre la imagen */
  .text-overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    /* centra */
    text-align: center;
    color: white;
    font-size: 2rem;
    text-transform: uppercase;
    display: inline-block;
    transition: transform 0.3s ease-in-out;
    /* habilita animación */
  }

  /* Línea debajo del texto */
  .text-overlay::after {
    content: "";
    position: absolute;
    bottom: -6px;
    left: 0;
    width: 0;
    height: 3px;
    background-color: var(--bs-primary);
    transition: width 0.4s ease-in-out;
  }

  /* Hover sobre el contenedor */
  .service-item:hover .text-overlay {
    transform: translate(-50%, -50%) scale(1.05) !important;
    /* centra + agranda */
  }

  .service-item:hover .text-overlay::after {
    width: 100%;
  }




  /* Galería de Proyectos*/
  .project-card {
    height: 45vh;
    /* 45% de la altura visible de la pantalla */
    position: relative;
    overflow: hidden;
  }

  .project-card img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    transition: transform 0.4s ease;
  }

  .project-card:hover img {
    transform: scale(1.1);
  }

  .project-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    opacity: 0;
    transition: opacity 0.4s ease;
    text-align: center;
    padding: 1rem;
  }

  .project-card:hover .project-overlay {
    opacity: 1;
  }


  /* Carrusel de proyectos */
  .project-card .carousel,
  .project-card .carousel-inner,
  .project-card .carousel-item {
    height: 100%;
  }

  /* Asegurar que las imágenes se ajusten al alto */
  .project-card .carousel-item img {
    height: 100%;
    width: 100%;
    object-fit: cover;
  }

  .project-overlay[data-bs-toggle="modal"] {
    cursor: pointer;
  }



/* logos de cliente */
  .logo-small {
    max-height: 80px;
    width: auto;
      object-fit: contain;
  }



  /* Carrusel limitado solo en pantallas medianas y grandes */
  @media (min-width: 768px) {
    .modal-carousel {
      max-height: 82vh; /* máximo 82% del viewport */
      overflow: hidden;
    }

    .modal-carousel img {
      height: 100%;
      width: 100%;
      object-fit: cover; 
    }
  }

  /* En mobile, carrusel se ajusta automáticamente */
  @media (max-width: 767px) {
    .modal-carousel img {
      width: 100%;
      height: auto;
      object-fit: contain;
    }
  }


  .carousel-indicators [data-bs-target*="carousel"] {
    background-color: #fff;
    width: 10px;
    height: 10px;
    border-radius: 50%;
  }

  .btn-close{ 
    opacity: 1; 
    padding: 8px; 
    border: 2px solid white;
  }

  
  /* Evita que el modal oculte el scrollbar */
  .modal {
    overflow-y: auto !important;
    padding-right: 0 !important;
  }

  .modal-open {
    overflow-y: scroll !important;
    padding-right: 0 !important;
  }

  /* Mantiene el scrollbar visible */
  body.modal-open {
    overflow: auto !important;
    padding-right: 0 !important;
  }

  /* Opcional: Asegura que el modal tenga scroll interno si es necesario */
  .modal-dialog {
    margin: 20px auto;
  }

