@font-face {
        font-family:'PP\ Right\ Grotesk\ Medium';
        src: url('../fonts/PP\ Right\ Grotesk\ Medium.eot');
        src: url('../fonts/PP\ Right\ Grotesk\ Medium.eot#iefix') format('embedded-opentype'),
            url('../fonts/PP\ Right\ Grotesk\ Medium.woff2') format('woff2'),
            url('../fonts/PP\ Right\ Grotesk\ Medium.woff') format('woff'),
            url('../fonts/PP\ Right\ Grotesk\ Medium.svg#PP\ Right\ Grotesk\ Medium') format('svg');
        font-weight: 500;
        font-style: normal;
        font-stretch: normal;
        unicode-range: U+0020-2044;
    }
    @font-face {
        font-family: 'Tiempos Text Regular';
        src: url('../fonts/TiemposText-RegularItalic.eot');
        src: url('../fonts/TiemposText-RegularItalic.eot?#iefix') format('embedded-opentype'),
            url('../fonts/TiemposText-RegularItalic.woff2') format('woff2'),
            url('../fonts/TiemposText-RegularItalic.woff') format('woff'),
            url('../fonts/TiemposText-RegularItalic.svg#TiemposText-RegularItalic') format('svg');
        font-weight: normal;
        font-style: italic;
        font-display: swap;
    }
    @font-face {
        font-family: 'Good Sans';
        src: url('../fonts/GoodSans-Regular.eot');
        src: url('../fonts/GoodSans-Regular.eot?#iefix') format('embedded-opentype'),
            url('../fonts/GoodSans-Regular.woff2') format('woff2'),
            url('../fonts/GoodSans-Regular.woff') format('woff');
        font-weight: normal;
        font-style: normal;
        font-display: swap;
    }
    html{
        height: 100%;
        -ms-overflow-style: none; /* for Internet Explorer, Edge */
        scrollbar-width: none; /* for Firefox */
        overflow-y: scroll; 
    }
    body {
        background: black;
        font-size: 16px;
        color: white;
        font-family:'PP\ Right\ Grotesk\ Medium';
    }
    /* Telón */
    .container-hero{
        width: 100%;
        height: auto;
        background: black;
        margin-top: 7.5rem;
        margin-bottom: 10px;
    }
    .container-menu{
        width: 100%;
        height: auto;
        background: black;
    }
    .curtain {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 9999;
      display: flex;
    }

    .curtain .left, .curtain .right {
      background: black;
      width: 50%;
      height: 100%;
    }

    .curtain.open .left {
      animation: openLeft 2s forwards;
    }

    .curtain.open .right {
      animation: openRight 2s forwards;
    }

    @keyframes openLeft {
      to { transform: translateX(-100%); }
    }

    @keyframes openRight {
      to { transform: translateX(100%); }
    }

    /* Hero */
    .hero {
      position: relative;
      height: 65vh;
      overflow: hidden;
      width: 100%;
      margin: 0 auto;
      border-radius: 30px;
      z-index: 2;
    }

    .hero video {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      z-index: -1;
    }

    .hero h1 {
      position: absolute;
      bottom: 30px;
      left: 25px;
      color: white;
      z-index: 1;
      font-size: 4rem;
      font-family:'PP\ Right\ Grotesk\ Medium';
      width: 60%;
      line-height: 4rem;
    }
    .hero-noticias h1{
        bottom: 6rem;
    }
    .hero h1 span{
         font-family: 'Tiempos Text Regular';
         font-style: italic;
         font-size: 2rem;
         line-height: 2rem;
         margin-top: 2rem;
         display: block;
    }
    @media (max-width: 768px) {
      .hero h1 {
        font-size: 2rem;
        bottom: 20px;
        left: 20px;
        line-height: 32px;
      }
    }

    /* Menú */
    .menu-top {
      top: -135px;
      left: 50%;
        transform: translate(-50%, -50%);
        width: max-content !important;
       padding-left: 3.4rem;
        padding-right: 3.4rem;
      height: 90px;
      z-index: 99999;
      background: #FEFFAA;
      margin: 0 auto;
      border-radius: 30px;
      margin-bottom: 0px;
    }

    .menu-top.visible {
      top: 60px;
    }
    .nav-link {
      font-size: 1rem;
      font-family: 'PP\ Right\ Grotesk\ Medium';
      text-transform: uppercase;
      color: black;
      padding: 0px !important;
      padding-right: 1.5rem !important;
    }
    .nav-link:hover {
        color: black;
        text-decoration: underline;
    }
    .navbar-brand img{
        padding-right: 3rem;
    }
    /* Overlay de búsqueda */
    .search-overlay {
        background-color: #FF0;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 1rem;
        z-index: 1050;
        border-radius: 30px;
  }

  .fa-times {
    color: black;
    padding-top: 15px;
    font-size: 2rem;
    padding-right: 40px;
  }
  .search-overlay input {
    width: 100%;
    max-width: 75%;
    padding: 0.75rem 1rem;
    font-size: 1.2rem;
    border: none;
    border-radius: 0.5rem;
    position: relative;
    top: -20px;
  }

  .search-overlay .close-btn {
    position: absolute;
    right: 1rem;
    top: 1rem;
    font-size: 1.5rem;
    color: white;
    background: none;
    border: none;
  }
    #searchBtn {
        margin: 0;
        padding: 0;
        border: 0;
    }
    #searchBtn:hover{
        background-color: transparent;
        border-color: transparent;
    }
    #searchBtn i{
        color: black;
        font-size: 1.8rem;
        padding-left: 5rem;
    }
    .custom-container-global {
        max-width: 1400px;
        margin-left: auto;
        margin-right: auto;
        padding-left: 30px;  /* Para que no pegue en los bordes */
        padding-right: 30px; /* Igual */
    }
    .custom-container {
        max-width: 1290px;
        margin-left: auto;
        margin-right: auto;
        padding-left: 15px;  /* Para que no pegue en los bordes */
        padding-right: 15px; /* Igual */
    }
    .fixed-top-menu {
        position: fixed;
    }
    .subtitle {
        padding-top: 20px;
        padding-bottom: 0px;
        font-size: 2rem;
        line-height: 2.4rem;
        width: 80%;
        padding-left: 0px;
    }
    .subtitle span{
        font-family: 'Tiempos Text Regular' !important;
        font-style: italic;
    }
     .parallax-section {
        background-image: url(../images/parallax-home.webp); 
        background-attachment: fixed;
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        height: 800px;
        position: relative;
        z-index: 1;
        width: 1340px;
        max-width: 1340px;;
        margin: 0 auto;
        border-radius: 30px;
    }

    @media (max-width: 991px) {
      /* Fallback para móviles y tablets: se comporta como imagen normal */
      .parallax-section {
        background-attachment: scroll;
      }
    }
    .title-seccion {
        font-size: 3.75rem;
        line-height: 3.75rem;
        text-align: center;
        margin-bottom: 2rem;
    }
    .subtitle-seccion {
        font-family: 'Tiempos Text Regular';
        font-style: italic;
        text-align: center;
        font-size: 2rem;
        margin-bottom: 2rem;
    }
    .card {
        min-height: 400px;
        background: #FEFFAA;
    }
    .card-title {
        font-size: 1.125rem;
    }
    .card-text {
        position: absolute;
        bottom: 30px;
        font-size: 3rem;
        line-height: 50px;
    }
    .mt-7 {
        margin-top: 7rem;
    }
    .mb-7 {
        margin-bottom: 7rem;
    }
    .px-7 {
        padding-bottom: 6rem;
        padding-top: 6rem;
        margin-top: 5rem !important;
        margin-bottom: 5rem !important;
    }
    .btn-capital {
        display: block;
        margin: 0 auto;
            margin-top: 0px;
        text-align: center;
        margin-top: 30px;
        background: black;
        width: fit-content;
        padding: 11px;
        border-radius: 10px;
        color: white;
        text-decoration: none;
    }
    .btn-noticias{
        background: #FEFFAA !important;
        color: black !important;
        float: left;
        bottom: 2rem;
        position: absolute;
        left: 2rem;
    }
    .btn-capital:hover{
        text-decoration: underline;
    }
    .hover-card .card-title{
        font-size: 2rem;
    }
    .hover-card .card-text {
        font-size: 1.125rem;
        line-height: 22px;
    }
    .hovered {
        background: #FFFF00;
        
    }
    .hovered .inicial-block {
        opacity: 0;
        display: none !important;
        transform: translateY(0%);
        transition: transform 0.4s ease-out, opacity 0.4s ease-out;
    }
    .hovered .d-none {
        opacity: 1;
        display: block !important;
        
       transform: translateY(0);
        
    }
    .scroll-wrapper {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        gap: 1rem;
        padding: 1rem 0;
    }

    .scroll-wrapper > .col {
        flex-shrink: 0;
        min-width: 25%; /* 4 en desktop */
        scroll-snap-align: start;
    }

    /* Responsivo para tablets */
    @media (max-width: 992px) {
        .scroll-wrapper > .col {
        min-width: 50%; /* 2 en tablet */
        }
    }

    /* Responsivo para móviles */
    @media (max-width: 576px) {
        .scroll-wrapper > .col {
        min-width: 100%; /* 1 en móvil */
        }
    }

    
    .font-size-2 {
        font-size: 2.5rem !important;
    }
    .container-overflow {
      overflow: visible;
      position: relative;
    }

    .slider-container {
      position: relative;
      margin: auto;
      height: 500px;
    }

    .slider-viewport {
      height: 100%;
      overflow-y: scroll;
      scroll-snap-type: y mandatory;
      -webkit-overflow-scrolling: touch;
    }

    .slider-vertical {
      display: flex;
      flex-direction: column;
    }

    .slide {
      height: 500px;
      width: 100%;
      position: relative;
      scroll-snap-align: start;
    }

    .slide-image {
      width: 90%;
      height: 80%;
      background-size: cover;
      background-position: center;
      position: relative;
      border-radius: 30px;
      margin: auto;
    }

    .slide-description {
      height: auto;
        width: 100%;
        padding: 2rem 1rem 1rem 6rem; /* más espacio a la izquierda */
        font-family: 'Good Sans';
        overflow-y: auto;
        font-size: 1rem;
        text-align: left;         /* texto alineado a la izquierda */
        display: flex;
        align-items: center;
        font-size: 1.125rem;
        line-height: 1.5rem;
        justify-content: flex-end; /* mueve la caja hacia la derecha */
    }
    .slide-description p{
        width: 80%;
        margin: 0 auto;
        padding-left: 14rem;   
    }
     .slide-description p::-webkit-scrollbar {
        display: none !important;    
    }

    .slide-title {
      position: absolute;
        bottom: 2rem;
        left: -5rem;
        color: white;
        padding: 0.75rem 1.5rem;
        font-weight: bold;
        z-index: 999;
        font-size: 5rem;
        font-family: 'PP\ Right\ Grotesk\ Medium';
        line-height: 4.5rem;
    }

    .btn-fixed {
      position: absolute;
      bottom: 22px;
        left: 57px;
      z-index: 1001;
      background-color: #FEFFAA;
      color: black;
      font-family:'PP\ Right\ Grotesk\ Medium';
      border: 0;
      padding-top: 11px;
        padding-bottom: 11px;
        padding-left: 15px;
        padding-right: 15px;
    }
    .btn-fixed:focus-visible,
    .btn-fixed:focus,
    .btn-fixed:active,
    .btn-fixed:hover {
        border: 0;
        background-color: #FEFFAA !important;
        color: black !important;
        border-color: none !important;
        text-decoration: underline;
        box-shadow:none !important;
    }

    .slider-indicators {
      position: absolute;
      top: 1rem;
      right: 1rem;
      z-index: 1000;
      display: flex;
      flex-direction: column;
    }

    .slider-indicators button {
      background-color: #ccc;
      border: none;
      margin: 0.25rem 0;
      width: 15px;
      height: 15px;
      border-radius: 50%;
      cursor: pointer;
    }

    .slider-indicators button.active {
      background-color: #FEFFAA;
    }
    .slider-viewport {
        /* ya existentes */
        height: 100%;
        overflow-y: scroll;
        scroll-snap-type: y mandatory;
        -webkit-overflow-scrolling: touch;

        /* nueva configuración de scroll bar */
        scrollbar-width: thin; /* Firefox */
        scrollbar-color: #FEFFAA transparent !important; /* Firefox */ 
    }

    .slider-viewport::-webkit-scrollbar {
        width: 6px;
         background: #FEFFAA !important;
    }

    .slider-viewport::-webkit-scrollbar-track {
     background: transparent;
    }

    .slider-viewport::-webkit-scrollbar-thumb {
        background-color: #FEFFAA;
        border-radius: 6px;
    }
    .background-yellow{
        background: #FEFFAA;
        width: 90%;
        margin: 0 auto;
        font-family:'PP\ Right\ Grotesk\ Medium';
        border-radius: 30px;
    }
    .background-yellow p{
        text-align: center;
        font-size: 3.75rem;
        color: black;
        line-height: 3.75rem;
        width: 100%;
        margin: 0 auto;
        padding-left: 3rem;
        padding-right: 3rem;
    }
    .footer-capital{
        background: white;
        border-radius: 30px 30px 0px 0px;
        z-index: 9999 !important;
      position: absolute;
    }
    .footer-capital a{
        display: block;
        margin-bottom: .5rem;
    }
    .title-impacto{
        padding-top: 11rem;
        padding-bottom: 11rem;
        text-align: center;
        margin: 0 auto;
        color: black;
        font-size: 4.375rem;
        line-height: 4.375rem;
        font-weight: bold;
    }
    .title-impacto span{
        font-family: 'Tiempos Text Regular';
        font-style: italic;
    }
    .bk-capital{
        background-image: url(../images/footer-bk.webp);
  
        background-position: right bottom;
        background-size: 800px;
        background-repeat: no-repeat;
    }
    ul{
        padding-left: 0;
    }
    .text-align-right{
        text-align: right;
        color: black;
        font-size: 1.8rem;
        line-height: 1.8rem;
        margin-bottom: 1rem !important;
    }
    .text-align-left{
        text-align: left;
        color: black;
        font-size: 1.8rem;
        line-height: 1.8rem;
        margin-bottom: 1rem !important;
    }
    .direccion a,
    ul li a{
        color: black;
        text-decoration: none;
        font-size: 1rem;
         font-family: 'Good Sans';
    }
     .direccion a:hover,
     ul li a:hover{
        text-decoration: underline;
     }
     .divisor{
        background: #A4B3A4;
        height: 1px;
        width: 90%;
        margin: 0 auto;
     }
     .p-footer{
        text-align: center;
        color: black;
        font-family: 'Good Sans';
        padding: 30px;
     }
     .bk-gray {
        background: #C1C1C1;
        border-radius: 30px;
     }
     .pp-bb{
        padding-bottom: 1rem;
        margin-bottom: 4rem;
     }
     .container-cuadros {
        width: 100%;
        border-radius: 30px;
        margin-top: 2rem !important;
     }
     .container-cuadros p {
        width: 45%;
        font-size: 3rem;
        color: black;
        line-height: 50px;
        padding-top: 30px;
        padding-left: 30px;
     }
     .container-cuadros p span {
        font-family: 'Tiempos Text Regular';
        font-style: italic;
     }
     .container-cuadros a {
        margin-bottom: 5rem;
        background: #FEFFAA;
        color: black;
        padding-left: 30px;
        padding-right: 30px;
     }
     #searchOverlay .fa-search{
        font-size: 2rem;
        position: absolute;
        left: 3rem;
        top: 2rem;
        color: black;
     }
     
      #searchOverlay .form-control {
        background: transparent;
        border-bottom: 1px solid black !important;
        border-radius: 0px;
        padding-bottom: 0px;
     }
     #searchOverlay .form-control:focus-visible,
     #searchOverlay .form-control:focus{
        box-shadow: 0 0 0 .25rem rgba(13,110,253,0);
     }
     .btn-buscador {
        background: transparent !important;
        border: 0;
        padding-top: 45px;
        padding-left: 20px;
        font-size: 1rem;
        text-transform: uppercase;
        position: relative;
      top: -18px;
     }
     .max-width-title{
        width: 60%;
        margin-top: 4rem;
        font-size: 5.25rem;
        font-family:'PP\ Right\ Grotesk\ Medium';
        line-height: 80px;
     }
     .maxi-width-title{
        width: 100%;
        margin-top: 4rem;
        font-size: 5.25rem;
        font-family:'PP\ Right\ Grotesk\ Medium';
        line-height: 80px;
        text-align: center;
        margin-bottom: 4rem;
     }
     .direccion{
        width: 100%;
        background: #FEFFAA;
        padding-top: 3rem;
        border-radius: 30px;
        position: relative;
        right: 2rem;
        z-index: 8888;
        color: black;
        padding-bottom: 3rem;
        padding-left: 2rem;
        padding-right: 10rem;
       
    }
    .direccion p{
        font-size: 1rem;
        font-family: 'Good Sans';
    }
    .pp-footer{
        display: block;
        width: 100%;
        padding: 7rem;
    }
    .pp-footer-en-construccion{
        padding: 3rem;
    }
    .contacto-footer{
        width: 50%;
        margin: 0 auto;
        display: block;
        color: black;
        padding-top: 5rem;
        padding-bottom: 5rem;
    }
    .contacto-footer h4{
        font-size: 3.75rem;
    }
    .contacto-footer p{
        font-size: 2rem;
        line-height: 2rem;
        margin-bottom: 2rem;
    }
    .contacto-footer input,
    .contacto-footer select{
        display: block;
        width: 100%;
        border: 0;
            border-bottom-width: 0px;
            border-bottom-style: none;
            border-bottom-color: currentcolor;
        border-bottom: .01rem solid black;
        color: black;
        margin-bottom: 2rem;
        background: transparent;
        padding-bottom: .5rem;
    }
    .sib-form .input::placeholder,
    .contacto-footer input::placeholder{
        color: black;
        font-family:'PP\ Right\ Grotesk\ Medium' !important;
    }
    .submit-footer {
        background: black !important;
        color: white !important;
        width: fit-content !important;
        float: right !important;
        padding-top: 10px !important;
        border-radius: 10px !important;
        padding-bottom: 10px !important;
        padding-left: 20px !important;
        padding-right: 20px !important;
        text-decoration: none !important;
    }
    .submit-footer:hover {
        text-decoration: underline !important;
    }
    .accordion-item {
        background-color: transparent !important;
        border: 1px solid #FEFFAA !important;
        border-radius: 10px !important;
        margin-bottom: 20px !important;
    }
    .accordion-button{
        background-color: transparent;
        color: white;
        padding-bottom: 1.5rem;
        padding-top: 1.5rem;
        font-size: 1.3rem !important;
    }
    .accordion-button::after {
        background-image: url(../images/plus.svg);
    }
    .accordion-button:not(.collapsed){
        background-color: #FEFFAA !important;
        box-shadow: none !important;
        color: black !important;
        border-radius: 6px 6px 0px 0px !important;
    }
    .accordion-button:not(.collapsed)::after {
        background-image: none !important;
        content: "-";
        font-size: 3rem;
        top: 1rem;
        position: relative;
    }
    .accordion-body{
        border-top: 1px solid #FEFFAA;
        color: black;
        font-family: 'Good Sans';
        font-size: .9rem;
        background: #FEFFAA;
        border-radius: 0px 0px 6px 6px;
    }
    .accordion-body ul{
        padding-left: 3rem !important;
    }
    .active-acordion{
        display: block;
        width: fit-content;
        color: white;
        text-decoration: none;
        font-size: 1.2rem;
        border: 1px solid #FEFFAA;
        border-radius: 30px;
        padding-left: 20px;
        padding-right: 20px;
        padding-top: 10px;
        padding-bottom: 10px;
        margin-bottom: 1rem;
    }
    .actived-acordion,
    .active-acordion:hover{
        background: #FEFFAA;
        color: black;
    }
    .actived-accordionFlush {
        display: block;
    }
    .desactived-accordionFlush {
        display: none;
    }
    .accordion-body a{
        color: white;
        text-decoration: none;
    }
    .accordion-body a:hover{
        color: white;
        text-decoration: underline;
    }
    .sin-sol .bk-capital {
        display: none;
    }
    .sin-formulario .formulario-footer{
        display: none;
    }
    .bk-yellow {
       background: #FEFFAA;
       color: black;
       border-radius: 0px 0px 30px 30px;
    }
    .bk-gray-trans{
        background: #EAEAEA;
       
       border-radius: 0px 0px 0px 0px !important;
    }
    .bk-gray .subtitle{ 
        color: black !important;
    }
    .menu-sin-wrapper .menu-top{
        width: 100%;
        margin-bottom: 0px;
        border-radius: 0px;
    }
    .menu-sin-wrapper .fixed-top-menu{
        border-radius: 30px;
    }
    #registra-proyecto{
        width: 1000px;
        max-width: 1000px;
    }
    .pegado-al-top {
       position: fixed;
        top: 20%;
        left: 50%;
        transform: translateX(-50%);
        z-index: 9998;
         margin-top: 10rem !important;
        margin-bottom: 9rem !important;
        width: 1187px;
    }
    #separador-parallax-contact{
        width: 100%;
        height: 200px;
        margin-top: 15rem;
        margin-bottom: 15rem;
    }
    #separador-parallax{
        width: 100%;
        height: 200px;
        margin-top: 12rem;
        margin-bottom: 12rem;
    }
    .fixeds-al-top,
    .fixed-al-top-map{
        position: fixed !important;
        top: 0px !important;
        z-index: 89;
        margin: 0 auto;
        display: block;
        text-align: center;
        left: 50%;
        transform: translateX(-50%);
    }
    .fixed-al-top-map{
        margin-top: 6rem;
    }
    .fixed-al-top{
       position: fixed !important;
       
    }
    #direccion-float{
        position: absolute;
        right: 5rem;
        top: 150%;
        
        z-index: 90;
    }
    .pt-7{
        padding-top: 7rem;
    }
    .pt-9 {
        padding-top: 9rem;
    }
    .color-black{
        color: black !important;
    }
    .text-legal {
        font-family: 'Good Sans';
        font-size: 1.125rem;
        color: black;
    }
    .bk-color-white{
        background: white;
    }
    .bk-color-gray {
       background: #EAEAEA;
    }
    #descripcion .regresar-glorario:hover{
        text-decoration: none !important;
        background: #FEFFAA;
        border-color: #FEFFAA;
    }
    .download-file{
       font-family:'PP\ Right\ Grotesk\ Medium' !important;
        font-size: 1.125rem !important;
        width: 149px !important;
    }
    .navbar-expand-lg .navbar-nav .nav-link{
        padding-right: 1.5rem;
    }
    #descripcion .form-select{
        width: 90%;
        margin-bottom: 2rem;
        border-radius: 30px;
        color: #FEFFAA;
        max-width: 400px;
        height: 60px;
        max-height: 60px;
        padding-left: 25px;
        font-size: 1.125rem;
        font-family: 'PP\ Right\ Grotesk\ Medium' !important;
        background: url(../images/select.svg) no-repeat right black;
        background-position-x: 95%;
    }
    .hero-presenta{
        background: url(../images/presenta-proyecto.webp) no-repeat center black;  
        width: 100%;
        background-size: 100%;
    }
    .hero-proximos-eventos,
    .hero-noticias{
        background-size: 100% !important;
        background-position: top !important; 
        width: 100%;
    }
    .hero-noticias p{
        font-size: 1rem;
        font-family: 'Good Sans';
        line-height: 1rem;
        float: right;
        bottom: 2rem;
        position: absolute;
        right: 3rem;
    }
    .hero-proximos-eventos h1{
        bottom: 6rem;
    }
    .hero-proximos-eventos p{
        position: absolute;
        bottom: 3rem;
        left: 2rem;
    }
    .btn-proximos-eventos{
        position: absolute;
        right: 2rem;
        bottom: 4rem;
        width: fit-content;
        padding: 11px;
            padding-right: 11px;
            padding-left: 11px;
        padding-right: 11px;
        padding-left: 11px;
        border-radius: 10px;
        background: #FEFFAA;
        color: black;
        text-decoration: none;
    }
    .btn-proximos-eventos:hover{
        text-decoration: underline;
    }
    .tag-noticias{
        font-size: 1rem;
         line-height: 1rem;
         position: absolute;
         left: 2rem;
         top: 2rem;
         background: #FFFF00;
         color: black;
         padding-top: 5px;
         padding-bottom: 5px;
         padding-left: 15px;
         padding-right: 15px;
         border-radius: 10px;
    }
    .noticias-historias {
        font-size: 4rem;
        line-height: 4rem;
        margin-top: 3rem;
        width: fit-content;
        display: flex;
    }
    .glosarios .tile a{
        width: 100%;
        display: block;
        height: 46px;
        align-content: center;
        border-radius: 30px;
        padding-left: 1rem;
        font-size: 1.1rem !important;
        position: relative;
        left: -1rem;
    }
    .glosarios .tile a:hover{
         background: url(../images/tile.svg) no-repeat right #FEFFAA !important;
         background-position-x: 95% !important;
         color: black !important;
         text-decoration: none !important;
    }
    .navbar-toggler{
        border: 0px !important;
    }
    ::-webkit-scrollbar {
        display: none !important;
    }
     #recuadros p{
        font-size: 1.8rem;
        border: 2px solid black;
        border-radius: 30px;
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        padding-bottom: 1rem;
        padding-top: 1rem;
        color: black;
        width: 480px;
        max-width: 480px;
        text-align: center;
        margin: 0 auto;
        margin-bottom: 4.3rem;
        height: 110px;
        max-height: 110px;
        align-content: center;
        line-height: 2rem;
        background: #c1c1c1;
     }
        .direccion{
            bottom: 30rem;
        }
        .fixed-al-top{
            top: 65% !important;
        }
        .privacidad h3{
            color: black;
            font-size: 2rem;
        }
        .privacidad p a{
            color: black;
            font-size: 1.125rem;
            line-height: 1.5rem;
             font-family: 'Good Sans';
        }
        .privacidad p{
            color: black;
            font-size: 1.125rem;
             font-family: 'Good Sans';
             padding-left: 40px;
             padding-bottom: 0px;
            margin-bottom: 2rem;
        }
        .privacidad ul li{
             color: black;
            font-size: 1.125rem;
             font-family: 'Good Sans';
             margin-left: 90px;
             padding-left: 10px;
        }
        .privacidad .table{
            margin-left: 40px;
            border: 1px solid black;
        }
        .privacidad tr{
            color: black;
            font-size: 1.125rem;
             font-family: 'Good Sans';
        }
        .privacidad th,
        .privacidad td{
            border-right: 1px solid black;
        }
        .roman{
            list-style-type: upper-roman;
        }
        .text-right{
            text-align: right;
        }
        .style-numbers{
            list-style-type: decimal;
        }
        ol li{
            padding-left: 0px !important;
            list-style-type: circle !important;
            margin-left: 0px !important;
        }
        .subtitle-presenta{
            width: 40%;
            font-size: 4rem;
            line-height: 4rem;
            margin-top: 3rem;
            margin-bottom: 4rem;
        }
        .subtitle-presenta-p{
            width: 70%;
            font-size: 1.8rem;
            line-height: 1.8rem;
            
        }
        .circle-presenta{
            font-size: 3rem;
            border: 1px solid white;
            width: 60px;
            height: 60px;
            border-radius: 30px;
            text-align: center;
            align-content: center;
            align-items: center;
            display: block;
        }
        .circle-presenta span{
            position: relative;
            top: -5px;
        }
        .permanente{
            margin-bottom: 2rem;
        }
        .permanente h5{
            font-size: 3rem;
            line-height: 3rem;
            margin-bottom: 2rem;
        }
        .permanente p a,
        .permanente p{
            font-size: 1.125rem;
            line-height: 1.5rem;
             font-family: 'Good Sans';
             color: white;
        }
        .permanente p a{
            color: #FEFFAA;
        }
       
       

        .scrollable-col {
            min-height: 90vh;
            max-height: 90vh; /* altura máxima relativa al viewport */
            overflow-y: scroll;
            position: sticky;
            top: 1rem; /* distancia desde arriba */
            padding-right: 1rem;
            scrollbar-gutter: stable; 
            scroll-snap-type: y mandatory;
            -webkit-overflow-scrolling: touch;

            /* nueva configuración de scroll bar */
            scrollbar-width: thin; /* Firefox */
            scrollbar-color: #FEFFAA transparent !important; /* Firefox */ 
            scrollbar-gutter: stable both-edges;
        }
        .scrollable-col:after {
            content: '';
            display: block;
            height: 1px; /* o 2px, según necesites */
            }

        .scrollable-col::-webkit-scrollbar {
            width: 6px;
            background: #FEFFAA !important;
        }

        .scrollable-col::-webkit-scrollbar-track {
            background: transparent;
        }

        .scrollable-col::-webkit-scrollbar-thumb {
            background-color: #FEFFAA !important;
            background: #FEFFAA !important;
            border-radius: 6px;
        }
       
        #convocatorias-abiertas {
            background: #FEFFAA;
            border-radius: 30px;
            padding: 40px;
            margin-top: 6rem;
        }
        #convocatorias-abiertas {
            color: black;
        }
        #convocatorias-abiertas a{
            font-size: 1.8rem;
            display: block;
            width: 100%;
            color: black;
            text-decoration: none;
            margin-bottom: 1rem;
        }
        #convocatorias-abiertas a:hover{
            text-decoration: underline;
        }
        #convocatorias-abiertas a img{
            float: right;
            position: relative;
            top: 10px;
        }
        #convocatorias-abiertas h4{
            font-size: 1.8rem;
        }
        #convocatorias-abiertas h5{
            font-size: 2.8rem;
        }
        button {
            font-size: 0.875rem !important;
        }
        .px-5{
            padding-bottom: 5rem !important;
            padding-top: 5rem !important;
            margin-top: 5rem !important;
            margin-bottom: 5rem !important;
        }
        .font-tiempos{
             font-family: 'Tiempos Text Regular' !important;
             font-style: italic;
        }
        .w-break{
            width: 95%;
            margin: 2rem auto;
        }
        .container-proximos-eventos .container-hero{
            background: #FEFFAA !important;
            border-radius: 30px;
            margin-top: 3.5rem !important;
        }
       .suscribete-noticias {
            text-align: center;
            color: black;
            margin: 0 auto;
            display: block;
            padding: 5rem;
       }
       .suscribete-noticias h3{
        font-size: 2.8rem;
       }
       .suscribete-noticias p{
         font-family: 'Good Sans';
         font-size: 1rem;
         line-height: 1.2rem;
         width: 55%;
         margin: 0 auto;
         margin-bottom: 3rem;
       }
       .suscribete-form{
            width: 50% !important;
            margin: 0 auto !important;
            margin-top: 3rem !important;
            border: 1px solid white;
            border-radius: 10px;
       }
       .suscribete-form .input{
        border: 0px !important;
        height: 40px;
       }
       .suscribete-form .sib-form-block{
        text-align: right !important;
        margin-right: 1.5rem !important;
       }
       .suscribete-form .sib-form-block button{
        color: #000 !important;
       }
       .suscribete-form .input:-ms-input-placeholder {
            color: #000 !important;
       }

        .suscribete-form .input::placeholder {
            color: #000 !important;
       }
       .container-prensa h3{
            font-size: 4rem;
         line-height: 4rem;
       }
       .container-prensa .card{
            background: transparent !important;
            min-height: auto !important;
       }
       .single-etiquetas-destacada{
        background: #FF0;
        padding-left: 10px;
        padding-right: 10px;
        padding-top: 10px;
        padding-bottom: 10px;
        border-radius: 20px;
        margin-right: 1rem;
       }
       .single-etiquetas-interna{
        background: #9FCEE2;
        padding-left: 10px;
        padding-right: 10px;
        padding-top: 10px;
        padding-bottom: 10px;
        border-radius: 20px;
        margin-right: 1rem;
       }
       .single-titulo{
        display: flex;
       }
       .single-titulo h2{
        font-size: 5.25rem;
        line-height:  5.25rem;
        width: 60%;
       }
       .single-titulo p{
        align-content: flex-end;
        text-align: right;
        width: 40%;
       }
       .img-full{
            width: 100%;
          border-radius: 30px;
       }
       .single-contenido{
        margin: 0 auto;
       }
       .single-contenido h1,
       .single-contenido h2,
       .single-contenido h3,
       .single-contenido h4,
       .single-contenido h5,
       .single-contenido h6{
        font-size: 2rem;
        margin-top: 1rem;
        margin-bottom: 1rem;
       }
       .dropdown-item{
        text-align: center;
       }
        @media (min-width:1400px){
            .container, .container-lg, .container-md, .container-sm, .container-xl, .container-xxl {
                max-width: 1140px !important;
            }
        }
     /* Forzar que el dropdown esté pegado al item padre */
    .custom-dropdown .dropdown-menu {
        top: 100%;   /* justo debajo del link */
        left: 0;
        margin-top: 0; /* sin espacio */
        border-radius: 0.5rem;
        animation: fadeIn 0.2s ease-in-out;
        
        background: #FEFFAA;
        border:0;
    }

    /* Permitir hover sin cortes */
    
    .custom-dropdown:hover > .dropdown-menu {
    display: block;
    
    }

     .custom-dropdown:hover > .dropdown-menu a{
 background: #FEFFAA;
 font-size: 1rem;
   font-family: 'Good Sans' !important;
     }

    /* Opcional: ampliar el área activa del padre para que no se cierre fácil */
    .custom-dropdown {
    position: relative;
    }
    .custom-dropdown .dropdown-menu {
    padding-top: 5px; /* zona extra de hover invisible */
    }    
    #sib-container input:-ms-input-placeholder {
    text-align: left;
    font-family: Helvetica, sans-serif;
    color: #c0ccda;
  }

  #sib-container input::placeholder {
    text-align: left;
    font-family: Helvetica, sans-serif;
    color: #c0ccda;
  }

  #sib-container a {
    text-decoration: underline;
    color: #2BB2FC;
  }
  .sib-form{
    margin: 0px !important;
    padding: 0px !important;
     font-family:'PP Right Grotesk Medium' !important;
     font-size: 1.125rem !important;
     color: #A4B3A4 !important;
     
  }
  .border-bottom-sus{
    border-bottom: 1px solid #A4B3A4;
  }
  .sib-form-block,
  #sib-container{
    margin: 0px !important;
    padding: 0px !important;
  }
  .sib-form .input{
    color: black !important;
  }
  .izq-suscrip{
    display: flex;
    float: left;
    width: 70%;
    
  }
  .der-suscrip{
    display: flex;
    float: left;
    width: 30%;
    
  }
  .sib-form-block{
    width: 100%;
  }
  .der-suscrip button {
    margin: 0px !important;
    padding: 0px !important;
    font-family: 'PP Right Grotesk Medium' !important;
    font-size: 1.125rem !important;
    color: #A4B3A4 !important;
    background: transparent !important;
  }
  .sib-form .entry__field{
    border-top: 0px !important;
    border-left: 0px !important;
    border-right: 0px !important;
    border-bottom: 0px !important;
    border-radius: 0px !important;
  }
  .izq-suscrip input::placeholder {
    font-size: 1.125rem !important;
    color: #A4B3A4 !important;
  }
  .cards-scroller {
            position: relative;
        }
        
        .cards-container {
            display: flex;
            overflow-x: auto;
            gap: 20px;
            padding: 20px 0;
            scroll-snap-type: x mandatory;
            -webkit-overflow-scrolling: touch;
            scroll-behavior: smooth;
            -ms-overflow-style: none;
            scrollbar-width: none;
            overflow-x: scroll;
        }
        
        /* Ocultar scrollbar pero mantener funcionalidad */
        .cards-container::-webkit-scrollbar {
            display: none;
        }
        
        /* Estilos individuales de cada card */
        .card {
            position: relative;
            overflow: hidden;
            flex: 0 0 300px;
            min-height: 492px;
            border-radius: 10px;
            background: #FEFFAA;
            cursor: pointer;
        }

        .card-front, .card-curtain {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }

        /* Contenido de la cara frontal */
        .card-front-content {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            height: 100%;
            transition: transform 0.6s ease;
            padding: 2rem;
            text-align: left;
        }

        .card-subtitle {
            font-size: 1.125rem;
            color: black;
            text-transform: uppercase;
            top: 20px;
            left: 20px;
            position: absolute;
        }

        .card-title {
            font-size: 3rem;
            font-weight: 800;
            color: black;
            margin: 0;
            position: absolute;
            bottom: 1rem;
            text-align: left;
            line-height: 3rem;
            width: 90%;
        }

        /* Contenido de la cortina */
        .curtain-content {
            position: absolute;
            bottom: -100%;
            width: 100%;
            height: 100%;
            color: black;
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            transition: bottom 0.6s ease;
            padding: 2rem;
            text-align: left;
        }

        .curtain-content h2 {
            font-size: 2rem;
            position: absolute;
            top: 1rem;
            left: 1rem;
        }

        .curtain-content p {
            font-family: 'Good Sans';
            font-size: 1.125rem;
            position: absolute;
            bottom: 1rem;
            left: 1rem;
            width: 90%;
            line-height: 1.5rem;
        }

        /* Hover animations */
        .card:hover .card-front-content {
            transform: translateY(-100%);
        }

        .card:hover .curtain-content {
             bottom: 0;
        }
        .card:hover{
            background: #FFFF00 !important;
        }
        
        /* Botones de navegación */
        .scroll-btn {
            width: 30px;
            height: 30px;
            border: none;
            cursor: pointer;
            display: inline-block;
            background: url(../images/arrow_right_white.svg) no-repeat right black;
        }
        
        .scroll-btn:hover{
           background: url(../images/arrow_right_yellow.svg) no-repeat right black;
        }
        
        .scroll-btn.left {
            left: 0;
            transform: rotate(180deg);
            margin-right: 10px;
        }
        
        .scroll-btn.right {
            right: 0;
        }
        
        .scroll-btn:disabled {
            opacity: 0.3;
            cursor: not-allowed;
        }
        
        /* Indicador de posición */
        .dots-indicator {
            display: flex;
            justify-content: center;
            gap: 8px;
            margin-top: 20px;
        }
        
        .dot {
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background-color: #ccc;
            cursor: pointer;
            transition: all 0.3s ease;
        }
        
        .dot.active {
            background-color: #3498db;
            transform: scale(1.2);
        }
      .fixed-top-menu {
       
        transition: all 0.8s ease-in; /* transición suave */
      }
       .menu-top {
      transition: top 0.7s ease-out;
    }
    .container-btns{
        float: right;
    }
    .container-svg {
      position: relative;
      width: 99%;
      height: auto;
      overflow: hidden;
      margin: 10px;
    }

    .background-svg {
      position: absolute;
      top: 90px;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 0;
      pointer-events: none;
    }

    .content {
      position: relative;
      z-index: 10;
      color: black;
      padding: 2rem;
      padding-bottom: 0px;
    }

    .noticia-relevante{
        background: #FF0;
        text-align: center;
        color: black;
        font-family: 'Good Sans';
        font-size: 1rem;
        padding: 10px;
    }
    .noticia-relevante a{
        color: black;
    }
   
    @media screen and (min-width: 2782px){
        .direccion{
            bottom: 50rem;
        }
        .fixed-al-top{
            top: 70% !important;
        }
    }
    @media screen and (max-width: 1764px){
        .fixed-al-top{
            top: 75% !important;
        }
    }
    @media screen and (max-width: 1530px) {
        .direccion{
            bottom: 20rem;
        }
        .fixed-al-top{
            top: 70% !important;
        }
    } 
    @media screen and (max-width: 1390px) {
        .menu-top{
            width: 96% !important;
        }
    } 
    @media screen and (max-width: 1339px) {
        .parallax-section{
            width: 99% !important;
        }
        .direccion {
            bottom: -13rem;
        }
    } 

    @media screen and (max-width: 1200px) {
.navbar-collapse {
            background-color: #FEFFAA; /* Cambia el fondo según tu diseño */
            padding: 1rem;
            top: 4rem;
            right: 10px;
            margin-top: 0.5rem;
            position: fixed;
            width: 50%;
            
        }

        .navbar-nav {
            flex-direction: column;
            gap: 0.75rem;
        }

        .navbar-nav .nav-link {
            padding: 0.75rem 1rem;
            border-radius: 0.375rem;
            font-size: 1rem;
            font-weight: 500;
            color: black;
            text-align: center;
            transition: background-color 0.2s, color 0.2s;
        }

        .navbar-nav .nav-link:hover,
        .navbar-nav .nav-link:focus {
            background-color: transparent;
            color: #000;
        }

        .navbar-toggler {
            border: none;
            padding: 0.5rem 0.75rem;
        }

        .navbar-toggler:focus {
            outline: none;
            box-shadow: none;
        }
        #searchBtn{
        display: none;
       }
    }
   
    @media screen and (max-width: 1186px) {
        #registra-proyecto, 
        .pegado-al-top{
            width: 91% !important;
        }
    }
    @media screen and (max-width: 1025px) {
        
        .hero h1{
            font-size: 4rem;
            width: 80%;
            line-height: 60px;
        }
        .subtitle{
            padding-left: 3rem;
        }
        .container-cuadros p{
            width: 70%;
        }
        .slide-description p{
            width: 80%;
        }
        .background-yellow p{
            width: 95%;
        }
        #recuadros p{
            width: 350px;
            max-width: 350px;
            margin-bottom: 2rem;
            padding-bottom: 0rem;
            padding-top: 0rem;
            font-size: 1.4rem;
            line-height:  1.4rem;
        }
        .slide-title{
            left: -3rem;
        }
        .izq-suscrip{
            width: 60% !important;
        }
       .der-suscrip{
            width: 40% !important;
        }
        #convocatorias-abiertas h5{
            margin-bottom: 3rem;
        }
        .subtitle-presenta{
            width: 75%;
        }
    }
     @media screen and (max-width: 769px) {
        .navbar-collapse {
            width: 70%;
        }
        .hero-proximos-eventos,
        .hero-noticias,
        .hero-presenta{
            height: 35vh;
        }
        .container-cuadros p {
            width: 100%;
        }
        .subtitle{
             width: 95%;
        }
        .title-seccion{
            line-height: 3.5rem;
        }
        .slide-title{
            left: -2rem;
            font-size: 3rem;
            line-height: 3rem;
        }
         .slide-description p {
            width: 100%;
            padding-left: 0px;
        }
        .slide-image{
            background-position: center !important;
        }
        .btn-fixed{
            bottom: 6rem;
            left: 50%;
            transform: translate(-50%, -50%);
            bottom: -40px;
        }
        .background-yellow p {
            width: 100%;
        }
        .background-yellow p{
            font-size: 3rem;
            line-height: 3rem;
        }
        .text-align-left,
        .text-align-right{
            line-height: 1.7rem;
        }
        .text-align-left,
        .text-align-right,
        .footer-capital .col,
        .footer-capital .col-2{
            width: 100%;
            margin: 0 auto;
            text-align: center;
        }
        .search{
            margin-top: 3rem;
        }
        #descripcion h3{
            font-size: 2.5rem !important;
                line-height: 2.5rem !important;
        }
        .columna,
        .text-legal{
            font-size: 1rem !important;
        }
        .contacto-footer{
            width: 80%;
        }
        .fixed-al-top {
            top: 30% !important;
        }
        .maxi-width-title{
            font-size: 4.25rem;
        }
        .accordion-button{
            padding-bottom: 1rem;
            padding-top: 1rem;
            font-size: 1rem;
        }
        .active-acordion{
            font-size: 1rem;
        }
        #recuadros p{
            width: 250px;
            height: 75px;
            padding-top: 1rem;
            padding-bottom: 1rem;
            font-size: 1.2rem;
            line-height: 1.2rem;
        }
        #registra-proyecto, .pegado-al-top {
            
            padding-left: 0px !important;
            padding-right: 0px !important;
        }
        .contiene-logo-footer{
            margin: 0 auto;
            text-align: center;
            margin-bottom: 2rem;
        }
    }
    @media screen and (max-width: 500px) {
         .fixed-al-top {
            top: 5% !important;
        }
        #convocatorias-abiertas h5 {
        font-size: 2.3rem;
        line-height: 2.3rem;
        text-align: center;
        }
        #convocatorias-abiertas h4 {
            font-size: 1.5rem;
            }
        .permanente h5,
        .subtitle-presenta{
            font-size: 2.5rem;
            line-height: 2.5rem;
        }
            .background-svg{
                display: none;
            }
            .hero h1{
                font-size: 2.5rem;
                  line-height: 2.5rem;
            }
            .subtitle {
                width: 100%;
                font-size: 2rem;
                line-height: 2.4rem;
                padding-left: 2rem;
                padding-bottom: 2rem;
            }
            .container-cuadros p{
                font-size: 2rem;
                padding-right: 30px;
                line-height: 2rem;
            }
            .title-seccion,
            .title-seccion{
                font-size: 2.5rem;
                line-height: 2.5rem;
            }
            .subtitle-seccion{
                font-size: 1.5rem;
            }
            .slide-title {
                left: -1rem;
                font-size: 3rem;
              line-height: 45px;
            }
            .slide-description{
                display: none;
            }
            #registra-proyecto,
            .no-mt-7{
                margin-top: 0px !important;
            }
            
            .contacto-footer{
             width: 95%;
            }
            .contacto-footer h4 {
            font-size: 2.5rem;
            }
            .contacto-footer p {
            font-size: 1.5rem;
            line-height: 1.5rem;
            margin-bottom: 1.5rem;
            }
            #descripcion .form-select{
                font-size: 1rem !important;
                height: 50px !important;
            }
            .download-file{
                font-size: .9rem !important;
            }
            .download-file img{
                display: none;
            }
            .table > :not(caption) > * > *{
                font-size: .9rem !important;
            }
            #direccion-float {
                right: -1rem !important;
                width: 90% !important;
                margin: 0 auto !important;
            }
            .direccion{
                padding-right: 5rem !important;
                bottom: -10rem;
            }
             #recuadros p{
                width: 100%;
                max-width: 100%;
                font-size: 1.5rem;
                line-height: 1.5rem;
                height: fit-content;
             }
             .menu-top{
                padding-left: 1.4rem;
                padding-right: 1.4rem;
             }
             .navbar-brand img {
                padding-right: 0rem;
                }
            .btn-fixed{
                padding-top: 7px;
                padding-bottom: 7px;
                padding-left: 6px;
                padding-right: 6px;
            }
            .background-yellow p {
                font-size: 2.5rem;
                line-height: 2.5rem;
            }
            .title-impacto{
                font-size: 4rem;
                line-height: 4rem;
            }
            .footer-capital a{
                text-align: center;
            }
            .footer-capital .divisor{
                display: none;
            }
            .hero-construccion{
                height: 90vh;
            }
            .hero h1 span{
                font-size: 1.8rem;
                line-height: 1.8rem;
            }
            .maxi-width-title{
                margin-top: 2rem;
                margin-bottom: 2rem;
            }
            .tile a{
                font-size: 1.4rem !important;
            }
            .privacidad h3{
                font-size: 1.5rem;
                line-height: 1.5rem;
            }
            .privacidad ul li,
            .privacidad p{
                font-size: 1rem;
            }
            .privacidad .table{
                margin-left: 0px;
            }
         }

       