.principal-desktop {
  display: block;
}
.principal-movil {
  display: none;
}

@media (max-width: 767px) {
    .quienes-somos-text h1 {
      font-size: 3rem !important;
    }
  
    .quienes-somos-text h4 {
      font-size: 1.2rem !important;
    }
  
    .quienes-somos-text p {
      font-size: 1rem !important;
      padding: 0 10px;
    }
  
    .quienes-somos-img img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
    .quienes-somos-img::after {
        content: '';
        position: absolute;
        top: 0; left: 0;
        width: 100%;
        height: 100%;
        background-color: rgba(0, 0, 0, 0.45); /* Nivel de oscuridad */
        z-index: 1;
      }

    .principal-movil {
      display: block;
    }
    .principal-desktop {
      display: none;
    }
  }

  



.custom-accordion .accordion-body {
  color: #000;
  padding-top: 20px;
}


/* Ítems individuales */
.custom-accordion .accordion-item {
    border: none;
}

/* Contenido del acordeón */
.custom-accordion .accordion-body {
    padding: 25px 0;
    color: #000000;
}





/* Asegurar que la imagen no se solape en móviles */
            @media (max-width: 992px) {
                .position-absolute {
                    width: 100% !important;
                }
                .justify-content-end {
                    justify-content: flex-start !important;
                }
            }
            
            /* Animaciones fadeIn */
            .fadeInLeft {
                animation: fadeInLeft 1s ease-in-out;
            }
            .fadeInRight {
                animation: fadeInRight 1s ease-in-out;
            }
            
            @keyframes fadeInLeft {
                from {
                    opacity: 0;
                    transform: translateX(-50px);
                }
                to {
                    opacity: 1;
                    transform: translateX(0);
                }
            }
            
            @keyframes fadeInRight {
                from {
                    opacity: 0;
                    transform: translateX(50px);
                }
                to {
                    opacity: 1;
                    transform: translateX(0);
                }
            }
        
  
/* Acordeón personalizado amarillo */
.custom-accordion .accordion-item {
  margin-bottom: 25px;
  border: none;
}

.custom-accordion .accordion-button {
  font-size: 16px;
  
  color: #000;
  background-color: transparent;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.custom-accordion .accordion-body {
  color: #000;
  padding-top: 10px;
}


/* Ítems individuales */
.custom-accordion .accordion-item {
    border: none;
}

/* Botones del acordeón */
.custom-accordion .accordion-button {
    padding: 20px 60px 20px 10px;
    font-size: 24px;
    color: #000000;
    background-color: transparent !important;
    border-bottom: 1px solid rgba(39, 34, 34, 0.1);
}


.accordion-button:not(.collapsed) {
  background-color: transparent;
  color: rgb(0, 0, 0);
  box-shadow: none;
}

/* Ícono + / - */
.accordion-button::after {
  content: "+";
  position: absolute;
  right: 15px;
  margin-bottom: 20px;
   -webkit-text-stroke: 1.5px #000; /* Grosor y color del borde */
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  color: #000000;
  font-weight: bold;
  transition: transform 0.3s ease;
  background-image: none;
}

.accordion-button:not(.collapsed)::after {
  content: "-";
  color: #000000;
}
/* Botón cuando está expandido */
.custom-accordion .accordion-button:not(.collapsed) {
    color:rgb(0, 0, 0);
    box-shadow: none;
    border-bottom-color: rgba(0, 0, 0, 0.1);
}

/* Contenido del acordeón */
.custom-accordion .accordion-body {
    padding: 25px 0;
    color: #000000;
}

/* Ícono de flecha */
.custom-accordion .accordion-button::after {
    color:rgb(0, 0, 0);
   
    transition: transform 0.3s ease;
}

.custom-accordion .accordion-button:not(.collapsed)::after {
    transform: rotate(0deg);
}




/* Asegurar que la imagen no se solape en móviles */
            @media (max-width: 992px) {
                .position-absolute {
                    width: 100% !important;
                }
                .justify-content-end {
                    justify-content: flex-start !important;
                }
            }
            
            /* Animaciones fadeIn */
            .fadeInLeft {
                animation: fadeInLeft 1s ease-in-out;
            }
            .fadeInRight {
                animation: fadeInRight 1s ease-in-out;
            }
            
            @keyframes fadeInLeft {
                from {
                    opacity: 0;
                    transform: translateX(-50px);
                }
                to {
                    opacity: 1;
                    transform: translateX(0);
                }
            }
            
            @keyframes fadeInRight {
                from {
                    opacity: 0;
                    transform: translateX(50px);
                }
                to {
                    opacity: 1;
                    transform: translateX(0);
                }
            }
        
  

        






.custom-accordion .accordion-button-negro {
  font-size: 16px;
  
  color: #ffea00;
  background-color: transparent;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

/* Botones del acordeón */
.custom-accordion .accordion-button-negro {
    padding: 20px 0;
    font-size: 24px;
    color: #ffea00;
    background-color: transparent !important;
    border-bottom: 1px solid rgba(39, 34, 34, 0.1);
}


.accordion-button-negro:not(.collapsed) {
  background-color: transparent;
  color: #ffea00;
  box-shadow: none;
}

/* Ícono + / - */
.accordion-button-negro::after {
  content: "+";
  position: absolute;
  right: 15px;
  margin-bottom: 20px;
   -webkit-text-stroke: 1.5px #ffea00; /* Grosor y color del borde */
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  color: #ffea00;
  font-weight: bold;
  transition: transform 0.3s ease;
  background-image: none;
}

.accordion-button-negro:not(.collapsed)::after {
  content: "-";
  color: #ffea00;
}
/* Botón cuando está expandido */
.custom-accordion .accordion-button-negro:not(.collapsed) {
    color:#ffea00;
    box-shadow: none;
    border-bottom-color: #000;
}


            .custom-accordion .accordion-button-negro {
              display: flex;
              justify-content: space-between;
              padding: 20px 60px 20px 10px;
              font-size: 24px;
              color: rgb(255, 230, 0);
              background-color: transparent !important;
              border-bottom: 1px solid rgba(0, 0, 0, 0.1);
              position: relative; /* Añadimos esto para posicionar los íconos */
          }
          /* Botón cuando está expandido */
          .custom-accordion .accordion-button-negro:not(.collapsed) {
              color:rgb(255, 230, 0);
              box-shadow: none;
              border-bottom-color: rgba(0, 0, 0, 0.1);
          }
          
          .custom-accordion .accordion-button-negro::after {
            color: #ffea00;
            transition: transform 0.3s ease;
        }


        .principal-desktop {
          position: relative;
          background-color: #000;
          min-height: 500px; /* o la altura que necesites para que se vea bien */
          overflow: hidden;
        }
        
        .principal-desktop > .position-absolute.h-100 {
          position: absolute;
          right: 0;
          top: 0;
          width: 60%;
          height: 100%; /* ahora 100% toma el min-height del padre */
          z-index: 0;
          overflow: hidden;
        }
        
        .principal-desktop > .position-absolute.h-100 > div {
          height: 100%;
          width: 100%;
          mask-image: linear-gradient(to right, transparent 0%, black 15%, black 100%);
          mask-size: 100% 100%;
          mask-repeat: no-repeat;
        }
        
        .principal-desktop > .position-absolute.h-100 > div > img {
          height: 100%;
          width: 100%;
          object-fit: contain;  /* Cambiado aquí */
          object-position: right center;
          display: block;
        }
        
                


/* Sección contenedora */
.contacto-section {
  position: relative;
  margin-bottom: 1%;
  background-color: #000;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

/* Contenedor de imagen */
.contacto-img-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
}

/* Imagen responsive sin recortes */
.contacto-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Texto encima */
.contacto-text {
  position: relative;
  z-index: 1;
  padding: 5% 0;
}

/* Ajuste de títulos */
.contacto-text h1 {
  font-size: 5rem;
  color: #fff;
}

.contacto-text p {
  font-size: 1.3rem;
}

/* Móvil: adapta layout */
@media (max-width: 767.98px) {
  .contacto-section {
    aspect-ratio: auto;
    height: auto;
  }

  .contacto-img-wrapper {
    position: relative;
    height: auto;
  }

  .contacto-img {
    object-fit: contain;
    height: auto;
  }

  .contacto-text h1 {
    font-size: 2.8rem;
  }

  .contacto-text p {
    font-size: 1.1rem;
  }
}
.contacto-text {
  position: absolute;
  bottom: 5%;
  left: 0;
  right: 0;
  z-index: 1;
  padding: 0 15px;
  padding-bottom: 15% !important;
}
@media (max-width: 767.98px) {
  .contacto-text {
    position: relative;
    bottom: auto;
    padding: 2rem 1rem;
    text-align: center;
  }
}        