body {
    min-height: 100vh;
    min-height: -webkit-fill-available;
}

html {
    height: -webkit-fill-available;
}

body {
    margin: 0;
    padding: 0;
    opacity: 1;
    font-family: 'TWK Lausanne' !important;
    font-style: normal;
    font-size: 20px;
    line-height: 1.3;
    letter-spacing: -0.2px;
    transition: all 1s ease;
    overflow-x: hidden;
    outline: none !important;
    transition: opacity 1s ease;
    overflow-y: scroll;
    overflow-x: hidden;
    color:rgb(113,57,171);
    background-color: #fff;
}

header{
    padding: 20px 0px;
    position: fixed;
    top: 0;
    left: 0;
    background-color: white;
    width: 100%;
    z-index: 10;
}

main{
    overflow-x: hidden !important;
    margin-top: 70px;
}

p{
    font-size: 20px;
    color: rgb(113,57,171);
    margin-bottom: 15px;
}

.red{
    color: rgb(206,0,33);
}

.lila{
    color: rgb(113,57,171);
}

h3{
    font-size: 25px;
}

header h3{
    font-weight: 600;
    text-align: center;
    margin: 0;
    font-size: 25px;
    padding-top: 5px;
}

.top-header {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.top-header a{
    color: rgb(113,57,171);
    text-decoration: underline;
    transition: color 0.15s linear;
}

.top-header a:hover,
.top-header a:active,
.top-header a:focus {
    color: #000;
}

.top-header .btn{
    font-family: 'TWK Lausanne';
    font-weight: 450;
    font-size: inherit;
    line-height: 35px;
    height: 35px;
    padding: 0 12px;
    border-radius: 50px;
    border-width: 0;
    background-color: rgb(206,0,33);
    border: 1px solid rgb(206,0,33);
    color: #fff;
    width: fit-content;
    margin-top: 15px;
    margin-bottom: 3px;

    cursor: pointer;
    transition: background-color 0.15s linear, color 0.15s linear;
}

.top-header .btn:hover,
.top-header .btn:active {
    background-color: #fff;
    color: rgb(206,0,33);
}

#logo-mobile {
    display: none;
}

main .top{
    padding: 90px;
}

@media(max-width: 800px){

    main .top{
        padding: 120px 50px;
    }

}

main .top svg{
    text-align: center;
    width: 90%;
    margin: 0 auto;
    padding-bottom: 50px;
    display: block;
}

main .top p{
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    color: #000;
    margin: 0;
    padding-bottom: 15px;
}

main .top #activista {
    display: none;
    text-align: center;
    padding-bottom: 80px;
}
main .top #activista h2 {
    font-size: 45px;
    margin-top: 0;
}
main .top #activista h3 {
    text-decoration: underline;
    font-size: 22px;
    font-weight: 450;
}
main .top #activista .wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 700px;
    padding: 0 10vw;
    margin: 0 auto;
}
main .top #activista .wrapper .btn {
    border: 2px solid rgb(113,57,171);
    border-radius: 60px;
    color: rgb(113,57,171);

    height: 48px;
    line-height: 48px;
    font-weight: 800;
    text-decoration: none;

    min-width: 140px;
    margin: 20px 10px;
    text-align: center;
    display: grid;
    align-content: center;
    cursor: pointer;
    transition: background-color 0.15s linear, color 0.15s linear, border-color 0.15s linear;
}
main .top #activista .wrapper .btn:hover,
main .top #activista .wrapper .btn:active,
main .top #activista .wrapper .btn:focus {
    border-color: rgb(206,0,33);
    background-color: #fff;
    color: rgb(206,0,33);
}

main .video video{
    width: 100%;
    height: auto;
    box-sizing: border-box;
    object-fit: cover;

}

main .antes-video {
    pointer-events: none;
}

/* .swiper-wrapper{
    transition-timing-function: linear !important;
} */

main .antes-video .image{
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    height: 80vh;
}
main .antes-video .image--0 { background-image: url('images/first-image.jpg'); }
main .antes-video .image--1 { background-image: url('images/carousel1.jpg'); }
main .antes-video .image--2 { background-image: url('images/carousel2.jpg'); }
main .antes-video .image--3 { background-image: url('images/carousel3.jpg'); }
main .antes-video .image--4 { background-image: url('images/carousel4.jpg'); }

main .preguntas{
    background-color: rgb(113,57,171);
    padding-top: 100px;
    padding-bottom: 100px; 
}

main .preguntas .pregunta{   
    border-bottom: 1px solid #fff;
}

main .preguntas .pregunta .texto-pregunta {
    padding: 15px 100px;
    color: #fff;
    cursor: pointer;

    transition: background-color 0.15s linear, color 0.15s linear;

}

main .preguntas .pregunta .texto-pregunta:hover, 
main .preguntas .pregunta .texto-pregunta.active {
    background-color: #fff;
    color: rgb(113,57,171);
}

main .preguntas .pregunta .texto-pregunta h3{
    font-weight: 450;
    font-size: 30px;
    margin: 0;
}

main .preguntas .pregunta .texto-respuesta{
    padding: 15px 100px;
}

main .preguntas .pregunta .texto-respuesta p,
main .preguntas .pregunta .texto-respuesta h3,
main .preguntas .pregunta .texto-respuesta li{
    color: #fff;
}

main .preguntas .pregunta .texto-respuesta h5{
    font-size: 28px;
    font-weight: 700;
    margin: 40px 0;
    color: #000;
}

main .preguntas .pregunta .btn-group > h3{
    font-size: 28px;
    font-weight: 500;
    color: rgb(206,0,33);
    text-decoration: underline;
    text-align: center;
}

main .preguntas .pregunta .btn-group.group-2 > h3{
    color: rgb(113,57,171);
    margin-top: 100px;
}

main .preguntas .pregunta .btn-group .pregunta{
    padding: 0;
}

main .preguntas .pregunta .btn-group .pregunta h3{
    border: 2px solid rgb(206,0,33);
    border-radius: 60px;
    color: #fff;
    background-color: rgb(206,0,33);

    padding: 0px 20px;
    width: min-content;
    min-width: 400px;
    height: 90px;

    line-height: 28px;
    font-weight: 800;
    font-size: 25px;
    letter-spacing: 0.01em;
    text-decoration: none;

    margin: 10px;
    text-align: center;
    display: grid;
    align-content: center;
    cursor: pointer;    
    transition: background-color 0.15s linear, color 0.15s linear;
}

main .preguntas .pregunta .btn-group .pregunta h3:hover{
    background-color: transparent;
    color: rgb(206,0,33);
}

main .preguntas .pregunta .btn-group.group-2 .pregunta h3:hover{
    background-color: transparent;
    color: rgb(113,57,171);
}

@media(max-width: 430px){
    main .preguntas .pregunta .btn-group .pregunta h3{
        min-width: calc(100vw - 80px);
    }
}

main .preguntas .pregunta .btn-group.group-2 .pregunta h3{
    border: 2px solid rgb(113,57,171);
    background-color: rgb(113,57,171);
}

#respuesta_2 {
    background-color: #fff;
    color: rgb(113,57,171)!important;
}
main .preguntas .pregunta .btn-group .group-wrap {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    justify-content: center;
}

main .preguntas .pregunta {
    position: relative;
}

main .preguntas .pregunta .texto-respuesta{
    display: none;
}

main .abrir-texto .image{
    background-image: url('images/second-image.jpeg');
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    width: 100%;
    min-height: 80vh;
    display: grid;
}

main .abrir-texto .image h3{
    align-self: center;
    text-align: center;
    margin: 0;
    font-size: 40px;
    font-weight: 550;
    color: white;
}

main .abrir-texto h2{
    padding: 40px 100px;
    /* font-size: 62px;
    line-height: 72px;*/
    font-weight: 300; 
    font-size: 40px;
    line-height: 1.15;
    color: rgb(113,57,171);
    margin: 0;
}

main .categorias-texto{
    margin-top: 50px;
}

main .categorias-texto h3, main .avancemos h3{
    font-weight: 700;
    font-size: 25px;
    text-align: center;
    margin-bottom: 0px;
}

main .categorias-texto p, main .avancemos p{
    font-weight: 400;
    text-align: center;
    margin: 5px 0px;
}

main .elements {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px 15px;
}

main .elements .btn{
    padding: 30px 20px;
    min-width: 250px;
    text-align: center;
    color: rgb(113,57,171);
    line-height: 1.3;
    font-weight: 850;
    border: 2px solid rgb(206,0,33);
    border-radius: 60px;
    display: grid;
    align-content: center;
    margin: 3px 1.5px;

    cursor: pointer;
    transition: color 0.15s linear, border-color 0.15s linear;

}

main .elements .btn:hover{
    color: #000;
    border-color: #000;
}

main .avancemos{
    margin-top: 50px;
    padding-top: 50px;
    background-color: rgb(206,0,33);
    color: #fff;
}

main .avancemos p{
    color: #fff;
}

main .avancemos .flex-elements{
    padding: 30px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 50px;
}

main .avancemos .flex-elements .element img{
    width: 100%;
    height: auto;
    display: block;
}

main .avancemos .flex-elements .element h4{
    margin-top: 10px;
    color: #fff;
}



main .avancemos .flex-elements .element a{
    text-decoration: none;
}

main .socialistas{
    text-align: center;
    font-size: 52px;
    line-height: 72px;
    padding: 60px 30px 40px 30px;
    background-color: rgb(206,0,33);
    color: #fff;
}

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

footer{
    padding: 30px;
    background-color: rgb(206,0,33);
    color: white;
}

footer a{
    color: white;
    text-decoration: none;

    transition: color 0.15s linear;
}

footer a:hover,
footer a:active,
footer a:focus{
    color: rgb(113,57,171);
}

footer .flex-footer{
    display: flex;
    justify-content: space-between;
    font-size: 16px;
}

.modal-texto, .modal-respuesta{
    position: fixed;
    top: 0;
    left: 0;
    background-color: rgba(255, 255, 255, 0.8);
    width: 100%;
    height: 100vh;
    z-index: 20;
    display: none;
}

.modal-texto .content,
.modal-respuesta .content{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80%;
    max-width: 1024px;
    border: 2px solid rgb(206,0,33);
    border-radius: 40px;
    background-color: white;
    padding: 30px;
    max-height: 80vh;

    font-size: 20px;
    color: rgb(113,57,171);
    font-weight: 400;

    display: flex;
    flex-direction: column;
}

.close{
    font-size: 20px;
    text-align: right;
    color:rgb(113,57,171);
    cursor: pointer;
    font-weight: 600;

    width: 15px;
    height: 20px;
    opacity: 0.3;
    padding: 5px;

    transition: opacity 0.15s linear;
}
.close:hover {
    opacity: 1;
}
.close:before, 
.close:after {
    position: absolute;
    content: ' ';
    height: 25px;
    right: 45px;
    width: 2px;
    background-color: rgb(206,0,33);
}
.close:before {
    transform: rotate(45deg);
}
.close:after {
    transform: rotate(-45deg);
}

.modal-respuesta .close {
    position: absolute;
    top: 30px;
    right: 35px;
    padding: 7px;
    width: 20px;
}

.modal-respuesta .close::before,
.modal-respuesta .close::after{
    right: 15px;
}

.modal-texto .content .modal-header{
    display: flex;
    justify-content: space-between;
}

.modal-texto .content h3{
    font-size: 25px;
    color: rgb(206,0,33);
    font-weight: 500;
    margin-top: 0;
    margin-bottom: 5px;
}
.modal-texto .content ol{
    display: block;
    counter-reset:item; 
    column-count: 2;
    overflow-y: scroll;
    margin-bottom: 0;
}

.modal-texto .content li{
    display: block;
    margin-bottom: 20px;
    margin-right: max(50px, 6vw);
    position: relative;
}
.modal-texto .content li:before { 
    content:counter(item) '. '; 
    counter-increment:item; 
    display: block;
    position: absolute;
    left: -30px;
    top: 0;
}

@media(max-width: 767px){
    .modal-texto .content ol{
        column-count: 1;
    }
    .modal-texto .content li{
        margin-right: 0;
    }
}

ol.active{
    display: block;
}
ol{
    display: none;
}

.modal-respuesta .content > h3 {
    display: block;
    width: fit-content;
    margin: 6px auto 25px auto;
    position: relative;
    color: rgb(206,0,33);
    text-decoration: underline;
    text-align: center;
    max-width: calc(100% - 40px);
}

.modal-respuesta.group-2 .content > h3 {
    color: rgb(113,57,171);
}

.modal-respuesta.group-2 .close:before,
.modal-respuesta.group-2 .close:after {
    background-color: rgb(113,57,171);

}
.modal-respuesta.group-2 .content{
    border-color: rgb(113,57,171);
}


.modal-respuesta .content .flex-content{
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 10px;
    overflow-y: scroll;
}

.modal-respuesta .content .flex-content .element{
    margin-bottom: 20px;
    padding: 0 10px;
}

.modal-respuesta .content .flex-content .element h4{
    display: flex;
    align-items: center;
    font-size: 30px;
    line-height: 33px;
    letter-spacing: 0.01em;
    font-weight: 750;
    margin: 30px 0;
}


.modal-respuesta .content .flex-content .element.x1980 p,
.modal-respuesta .content .flex-content .element.x1980 h4{
    color: rgb(206,0,33);
}
.modal-respuesta .content .flex-content .element.apruebo p,
.modal-respuesta .content .flex-content .element.apruebo h4{
    color: rgb(113,57,171);
}

.modal-respuesta .content .flex-content .element h4::before{
    display: inline-block;
    height: auto;
    width: 55px;
    margin-right: 24px;
}
.modal-respuesta .content .flex-content .element.x1980 h4::before{
    content: url('images/icon-no.svg');
}
.modal-respuesta .content .flex-content .element.apruebo h4::before{
    content: url('images/icon-apruebo.svg');
    width: 70px;
    margin-right: 21px;
}

.modal-respuesta .content .flex-content .element p{
    font-size: 20px;
    font-weight: 500;
    color:#000;
    margin: 0 0 15px;
}

@media(max-width: 990px){

    main .avancemos .flex-elements {
        padding: 30px;
        display: grid;
        grid-template-columns: 1fr;
        grid-gap: 20px;
    }

    main .preguntas .pregunta .texto-pregunta {
        padding: 15px 50px;
    }

    main .abrir-texto h2 {
        padding: 30px 50px;
    }

}

@media(max-width: 767px){

    .top-header .btn{
        margin-bottom: 0;
    }

    main .avancemos .flex-elements {
        padding: 30px 20px;
        display: grid;
        grid-template-columns: 1fr;
        grid-gap: 0px;
    }

    main .top {
        padding: 110px 20px;
    }

    main .top #activista .wrapper {
        padding: 0;
    }

    main .top #activista .wrapper .btn {
        margin: 7px 7px;
    }

    header h3 {
        font-weight: 600;
        text-align: center;
        margin: 0;
        font-size: 20px;
    }

    footer .flex-footer {
        display: block;
        justify-content: space-evenly;
        font-size: 16px;
        text-align: center;
        flex-flow: wrap;
    }

    footer .flex-footer li{
        margin-bottom: 20px;
    }

    main .socialistas {
        padding-bottom: 10px;
        padding-top: 50px;
        margin-top: 50px;
    }

    main .socialistas h2{
        text-align: center;
        font-size: 30px;
        line-height: 42px;
        padding: 20px;
        margin: 10px;
    }

    main .preguntas .pregunta .texto-respuesta h5 {
        font-size: 25px;
        font-weight: 700;
        margin: 40px 0;
    }

    main .preguntas .pregunta .btn-group {
        width: 100%;
        margin: 0 auto;
    }    

    main .preguntas .pregunta .btn-group > h3 {
        font-size: 25px;
    }

    main .preguntas .pregunta .texto-respuesta {
        padding: 20px;
    }

    main .preguntas .pregunta .texto-pregunta h3 {
        font-weight: 450;
        font-size: 25px;
        margin: 0;
    }

    main .preguntas {
        padding-top: 40px;
        padding-bottom: 40px;
    }

    main .abrir-texto h2 {
        padding: 20px 20px;
    }

    main .preguntas .pregunta .texto-pregunta {
        padding: 15px;
    }

    .modal-texto .content, .modal-respuesta .content {
        padding: 20px;
    }

    .modal-respuesta .close {
        right: 20px;
    }

    .modal-respuesta .content .flex-content {
        display: grid;
        grid-template-columns: 1fr;
        grid-gap: 20px;
        max-width: 100%;
    }

    .modal-respuesta .content .flex-content .element {
        margin-bottom: -20px;
        padding: 0;
    }

    .arrow {
        margin-top: 8px;
    }

    header a{
        display: block;
    }

    main .categorias-texto h3,
    main .categorias-texto p, 
    main .avancemos h3, 
    main .avancemos p,
    header h3 {
        padding-left: 20px;
        padding-right: 20px;
    }

    main .abrir-texto .image h3 {
        padding-left: 30px;
        padding-right: 30px;
    }

}

@media(max-width: 500px){
    #logo-desktop {
        display: none;
    }
    #logo-mobile {
        display: block;
        margin: 0 auto;
        width: 70%;
        min-width: 340px;
        padding: 30px 0;
        box-sizing: border-box;
        margin-bottom: 30px;
    }
}

@media(max-width: 377px){
    #logo-mobile {
        min-width: 280px;
    }
}