html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: "Poppins", sans-serif;
    color: #000;
    overflow-x: hidden;
    overflow-y: scroll;
}

body a {
    outline: none;
}

p, h1, h2, h3, h4, h5, h6 {
    margin: 0;
}

/* Desktop */
@media only screen and (min-device-width: 800px) and (max-device-width: 1920px) and (min-device-height: 600px), (max-device-height: 599px) and (orientation: landscape) {
    .site-5d {
        display: flex;
        width: 100vw;
        flex-direction: column;
        align-items: center;
    }
    
    .header {
        height: 10vh;
        position: fixed;
        width: 100vw;
        display: flex;
        justify-content: center;
        background-color: #ffffff01;
        transition: all 0.2s ease-in-out;
    }
    
    .header-content {
        width: 80vw;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
    }

    .logo-menu a {
        display: flex;
    }
    
    .logo {
        height: 5.4vh;
        margin-right: auto;
    }
    
    .menu {
        visibility: hidden;
        position: absolute;
    }
    
    .head-menu {
        display: flex;
        flex-direction: row;
        align-items: center;
    }
    
    .navbar {
        display: flex;
        flex-direction: row;
        gap: 4vw;
        align-items: center;
        color: #585858
    }
    
    .menu-text {
        text-align: center;
        font-size: 1.8vh;
        cursor: pointer;
        border-bottom: dashed 0.15vw transparent;
    }
    
    .menu-text .selected {
        font-weight: 700;
        color: #000;
        text-decoration: underline;
    }

    .menu-text a {
        text-decoration: none;
        color: #585858;
    }
    
    .page {
        font-weight: 700;
        border-bottom: dashed 0.15vw #FF8200;
        padding: 0 0.5vw 0 0.5vw;
    }

    #pt,
    #en {
        cursor: pointer;
    }
    
    .line {
        background-color: #D7D7D7;
        height: 5.4vh;
        width: 0.1vw;
        margin: 0 2vw 0 2vw;
    }
    
    .links {
        display: flex;
        flex-direction: row;
        gap: 1.5vw;
        height: 3vh; 
        align-items: center;
    }
    
    .links a {
        padding: 0;
        margin: 0;
        display: flex;
    }
    
    .icon {
        height: 1.9vh;
        transition: transform 0.3s ease-in-out;
    }
    
    .links .icon:hover {
        transform: scale(1.2);
        cursor: pointer;
    }
    
    .contato {
        width: 80vw;
        margin-top: 22vh;
        display: flex;
        flex-direction: row;
        justify-content: space-evenly;
    }
    
    .texts {
        display: flex;
        flex-direction: column;
    }
    
    .titles {
        display: flex;
        flex-direction: column;
        width: 23.85vw;
    }
    
    .title {
        font-size: 6vh;
        font-weight: 600;
    }

    .sub-title {
        font-size: 5vh;
        font-weight: 600;
        line-height: 5vh;
        margin-left: 6vw;
    }
    
    .sub {
        color: #8800BD;
        font-size: 4vh;
        font-weight: 600;
    }

    .title span {
        font-size: 6vh;
    }
    
    .desc-contato {
        font-size: 1.8vh;
        width: 31vw;
        margin-top: 2.5vh;
    }
    
    .contato .image {
        height: 37vh;
        margin-top: 2vh;
        display: flex;
        justify-content: center;
    }
    
    .cloud1,
    .cloud2,
    .cloud3 {
        position: absolute;
        background: linear-gradient(180deg, rgba(72, 191, 227, 0.4) 0%, rgba(116, 0, 184, 0.4) 100%);
        z-index: -1;
        filter: blur(7vh);
    }

    .cloud1 {
        width: 17vw;
        height: 75vh;
        align-self: flex-start;
        border-radius: 0 70vh 70vh 0;
    }

    .cloud2 {
        width: 20vw;
        height: 48vh;
        border-radius: 0 0 0 80vh;
        align-self: flex-end;
    } 

    .content-contato {
        width: 80vw;
        display: flex;
        flex-direction: column;
        margin-top: -5vh;
        align-items: center;
    }
    
    .content-contato .sub {
        font-size: 1.5vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .content-contato .title {
        font-size: 2.6vh;
        font-weight: 600;
    }

    .content-contato .texts {
        width: 80%;
    }
    
    .text {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    }
    
    .desc-jornada { 
        display: flex;
        flex-direction: row;
        margin-top: 8vh;
        width: 80%;
    }

    .desc-jornada .text {
        width: 34vw;
    }

    .msg-jornada {
        visibility: hidden;
        position: absolute;
    }
    
    .jornada {
        align-self: flex-end;
        display: flex;
        cursor: pointer;
        z-index: 1;
        margin-left: auto;
    }
    
    .jornada-info {
        height: 5.8vh;
        width: 24vh;
        border-radius: 10vh;
        position: absolute;
        background-color: #00C0E5;
        margin-left: -18vh;
        align-self: flex-end;
        z-index: -1;
        display: flex;
        align-items: center;
    }
    
    .jornada-text {
        width: 18vh;
        display: flex;
        flex-direction: column;
        font-size: 1.4vh;
        color: #fff;
        position: absolute;
        margin-left: 1vw;
        transition: all 0.2s ease-out;
    }
    
    .mid-line {
        width: 80vw;
        margin-top: 13vh;
        border-top: 0.25vh dashed #FF8200;
    }
    
    .content-equipe {
        width: 80vw;
        margin-top: 13vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .equipe {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: 2vh;
    }
    
    .content-equipe .sub {
        font-size: 1.5vh;
        font-weight: 400;
    }
    
    .content-equipe .title {
        font-size: 2.6vh;
        font-weight: 600;
        text-align: center;
    }

    .content-equipe .text {
        width: 30vw;
    }
    
    .row {
        display: flex;
        flex-direction: row;
        margin-top: 4vh;
    }
    
    .image-equipe {
        height: 36vh;
        align-self: flex-start;
    }
    
    .info {
        display: flex;
        flex-direction: column;
        gap: 1.3vh;
        margin-left: 4.2vw;
    }
    
    .cloud3 {
        width: 16vw;
        height: 74vh;
        filter: blur(10vh);
        background: linear-gradient(180deg, rgba(72, 191, 227, 0.4) 1.42%, rgba(255, 130, 0, 0.4) 86.99%);
        margin-top: 100vh;
        border-radius: 100vh 0 0 100vh;
        align-self: flex-end;
    }
    
    .footer {
        width: 100vw;
        display: flex;
        justify-content: center;
    }
    
    .footer-content {
        width: 70vw;
        height: 10vh;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: flex-end;
        border-top: 0.3vh dashed #4C186A;
    }
    
    .footer-text {
        font-size: 1.8vh;
        font-weight: 400;
        margin-right: auto;
        margin-left: auto;
    }
    
    .images {
        color: #59007E;
        font-size: 1.2vh;
        font-weight: 400;
        position: absolute;
    }
}

/* Ultrawide */
@media only screen and (min-device-width: 1921px) {
    .site-5d {
        display: flex;
        width: 100vw;
        flex-direction: column;
        align-items: center;

        .texts {
            display: flex;
            flex-direction: column;
        }

        .text {
            font-size: 1.8vh;
            font-weight: 400;
            color: #000;
            line-height: normal;
        }
    
        .header {
            height: 10vh;
            position: fixed;
            width: 100vw;
            display: flex;
            justify-content: center;
            background-color: #ffffff01;
            transition: all 0.2s ease-in-out;
       
            .header-content {
                width: 70vw; /*63vw */
                display: flex;
                flex-direction: row;
                justify-content: space-between;
                align-items: center;

                .logo-menu {
                    .logo {
                        height: 5.4vh;
                        margin-right: auto;
                    }
                
                    .menu {
                        visibility: hidden;
                        position: absolute;
                    }
                }

                .logo-menu a {
                    display: flex;
                }

                .head-menu {
                    display: flex;
                    flex-direction: row;
                    align-items: center;

                    .navbar {
                        display: flex;
                        flex-direction: row;
                        gap: 4vw;
                        align-items: center;
                        color: #585858;
                
                        .menu-text {
                            text-align: center;
                            font-size: 1.8vh;
                            cursor: pointer;
                            border-bottom: dashed 0.15vw transparent;

                            .selected {
                                font-weight: 700;
                                color: #000;
                                text-decoration: underline;
                            }

                            #en {
                                cursor: pointer;
                            }
                        }

                        .menu-text a {
                            text-decoration: none;
                            color: #585858;
                        }
                    
                        .page {
                            font-weight: 700;
                            border-bottom: dashed 0.15vw #FF8200;
                            padding: 0 0.5vw 0 0.5vw;
                        }
                    }

                    .line {
                        background-color: #D7D7D7;
                        height: 5.4vh;
                        width: 0.1vw;
                        margin: 0 2vw 0 2vw;
                    }
                
                    .links {
                        display: flex;
                        flex-direction: row;
                        gap: 1.5vw;
                        height: 3vh;
                        align-items: center;

                        .icon {
                            height: 1.9vh;
                            transition: transform 0.3s ease-in-out;
                        }
                    
                        .icon:hover {
                            transform: scale(1.2);
                            cursor: pointer;
                        }
                    }
                
                    .links a {
                        padding: 0;
                        margin: 0;
                        display: flex;
                    }
                }
            }
        }
        
        .contato {
            width: 70vw;
            margin-top: 22vh;
            display: flex;
            flex-direction: row;
            justify-content: space-evenly;

            .texts {
                .titles {
                    display: flex;
                    flex-direction: column;
                    width: 23.85vw;

                    .title {
                        font-size: 6vh;
                        font-weight: 600;

                        .sub {
                            color: #8800BD;
                            font-size: 4vh;
                            font-weight: 600;
                        }
                    }

                    .title span {
                        font-size: 6vh;
                    }
            
                    .sub-title {
                        font-size: 5vh;
                        font-weight: 600;
                        line-height: 5vh;
                        margin-left: 4vw;
                    }
                }

                .desc-contato {
                    font-size: 1.8vh;
                    width: 21vw;
                    margin-top: 2.5vh;
                }
            }

            .image {
                height: 37vh;
                margin-top: 2vh;
                display: flex;
                justify-content: center;
            }
        }
        
        .cloud1,
        .cloud2,
        .cloud3 {
            position: absolute;
            background: linear-gradient(180deg, rgba(72, 191, 227, 0.4) 0%, rgba(116, 0, 184, 0.4) 100%);
            z-index: -1;
            filter: blur(7vh);
        }

        .cloud1 {
            width: 17vw;
            height: 75vh;
            align-self: flex-start;
            border-radius: 0 70vh 70vh 0;
        }

        .cloud2 {
            width: 20vw;
            height: 48vh;
            border-radius: 0 0 0 80vh;
            align-self: flex-end;
        } 

        .content-contato {
            width: 70vw;
            display: flex;
            flex-direction: column;
            margin-top: -5vh;
            align-items: center;

            .texts {
                width: 68%;

                .sub {
                    font-size: 1.5vh;
                    font-weight: 400;
                    color: #FF8200;
                }

                .title {
                    font-size: 2.6vh;
                    font-weight: 600;
                }
            }

            .desc-jornada { 
                display: flex;
                flex-direction: row;
                margin-top: 8vh;
                width: 68%;

                .texts {
                    width: 80%;
    
                    .sub {
                        font-size: 1.5vh;
                        font-weight: 400;
                        color: #FF8200;
                    }
    
                    .title {
                        font-size: 2.6vh;
                        font-weight: 600;
                    }

                    .text {
                        width: 28vw;
                    }

                    .msg-jornada {
                        visibility: hidden;
                        position: absolute;
                    }
                }

                .jornada {
                    align-self: flex-end;
                    display: flex;
                    cursor: pointer;
                    z-index: 1;
                    margin-left: auto;
        
                    .jornada-info {
                        height: 5.8vh;
                        width: 24vh;
                        border-radius: 10vh;
                        position: absolute;
                        background-color: #00C0E5;
                        margin-left: -18vh;
                        align-self: flex-end;
                        z-index: -1;
                        display: flex;
                        align-items: center;
        
                        .jornada-text {
                            width: 18vh;
                            display: flex;
                            flex-direction: column;
                            font-size: 1.4vh;
                            color: #fff;
                            position: absolute;
                            margin-left: 1vw;
                            transition: all 0.2s ease-out;
                        }
                    }
                }
            }
        }

        .mid-line {
            width: 60vw;
            margin-top: 13vh;
            border-top: 0.25vh dashed #FF8200;
        }
        
        .content-equipe {
            width: 70vw;
            margin-top: 13vh;
            display: flex;
            flex-direction: column;
            align-items: center;

            .equipe {
                display: flex;
                flex-direction: column;
                align-items: center;
                margin-top: 2vh;

                .sub {
                    font-size: 1.5vh;
                    font-weight: 400;
                }
                
                .title {
                    font-size: 2.6vh;
                    font-weight: 600;
                    text-align: center;
                }
            }

            .row {
                display: flex;
                flex-direction: row;
                margin-top: 4vh;

                .image-equipe {
                    height: 40vh;
                    align-self: flex-start;
                }
                
                .info {
                    display: flex;
                    flex-direction: column;
                    gap: 1.3vh;
                    margin-left: 3.7vw;

                    .text {
                        width: 24vw;
                    }
                }
            }
        }

        .cloud3 {
            width: 16vw;
            height: 74vh;
            filter: blur(10vh);
            background: linear-gradient(180deg, rgba(72, 191, 227, 0.4) 1.42%, rgba(255, 130, 0, 0.4) 86.99%);
            margin-top: 100vh;
            border-radius: 100vh 0 0 100vh;
            align-self: flex-end;
        }

        .footer {
            width: 100vw;
            display: flex;
            justify-content: center;

            .footer-content {
                width: 60vw;
                height: 10vh;
                display: flex;
                flex-direction: row;
                align-items: center;
                justify-content: flex-end;
                border-top: 0.3vh dashed #4C186A;

                .footer-text {
                    font-size: 1.8vh;
                    font-weight: 400;
                    margin-right: auto;
                    margin-left: auto;
                }
        
                .images {
                    color: #59007E;
                    font-size: 1.3vh;
                    font-weight: 400;
                    position: absolute;
                }
            }
        }
    }
}

/* Mobile */
@media only screen and (max-device-width: 799px) and (orientation: portrait), (max-device-height: 599px) and (orientation: portrait) {
    .site-5d {
        display: flex;
        width: 100vw;
        flex-direction: column;
        align-items: center;
    }
    
    .header {
        height: 8vh;
        position: fixed;
        width: 100vw;
        display: flex;
        justify-content: center;
        transition: all 0.2s ease-in-out;
        box-shadow: 0 0.4vh 0.4vh #00000020;
        z-index: 99;
        background-color: #fff;
    }
    
    .header-content {
        width: 92%;
        display: flex;
        flex-direction: column;
    }

    .logo-menu {
        width: 100%;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        margin-top: 1.5vh;
    }

    .logo {
        height: 5vh;
    }

    .menu {
        height: 4vh;
    }

    .head-menu {
        display: flex;
        flex-direction: column;
        visibility: hidden;
        position: absolute;
        margin-top: 2vh;
        align-items: center;
    }

    .navbar {
        display: flex;
        flex-direction: column;
        align-self: flex-end;
        align-items: flex-end;
        gap: 2.5vh;
        color: #585858
    }
    
    .menu-text {
        text-align: center;
        font-size: 1.8vh;
        cursor: pointer;
        border-bottom: dashed 0.15vw transparent;
    }
    
    .menu-text a {
        text-decoration: none;
        color: #585858;
    }
    
    .page {
        font-weight: 700;
        border-bottom: dashed 0.15vw #FF8200;
    }
    
    .selected {
        font-weight: 700;
        color: #000;
        text-decoration: underline;
    }
    
    #pt,
    #en {
        cursor: pointer;
    }
    
    .line {
        position: absolute;
        visibility: hidden;
    }
    
    .links {
        display: flex;
        flex-direction: row;
        gap: 5vw;
        height: 3vh;
        margin-top: 6vh;
        align-items: center;
    }

    .links a {
        display: flex;
    }

    .icon {
        height: 3vh;
        transition: transform 0.3s ease-in-out;
    }

    .links .icon:hover {
        transform: scale(1.2);
        cursor: pointer;
    }

    .cloud1,
    .cloud2 {
        position: absolute;
        background: linear-gradient(180deg, rgba(72, 191, 227, 0.4) 0%, rgba(116, 0, 184, 0.4) 100%);
        filter: blur(7vh);
        z-index: -2;
    }

    .cloud1 {
        width: 39vw;
        height: 39vh;
        align-self: flex-end;
        border-radius: 0 0 0 100%;
    } 

    .cloud2 {
        width: 25vw;
        height: 30vh;
        background: linear-gradient(180deg, rgba(72, 191, 227, 0.40) 0%, rgba(116, 0, 184, 0.40) 100%);
        align-self: flex-start;
        margin-top: 170vh;
        border-radius: 0 100% 0 0;
    }
    
    .contato {
        width: 80vw;
        margin-top: 12vh;
        display: flex;
        flex-direction: column;
    }
    
    .texts {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .titles {
        display: flex;
        flex-direction: column;
    }
    
    .title {
        font-size: 5vh;
        font-weight: 600;
    }

    .sub-title {
        font-size: 5vh;
        font-weight: 600;
        line-height: 5vh;
        margin-left: 20vw;
    }
    
    .sub {
        color: #8800BD;
        font-size: 5vh;
        font-weight: 600;
    }
    
    .desc-contato {
        font-size: 1.8vh;
        margin-top: 2.5vh;
        text-align: center;
    }
    
    .contato .image {
        height: 26vh;
        margin-top: 2vh;
        object-fit: contain;
    }
    
    .content-contato {
        width: 80vw;
        display: flex;
        flex-direction: column;
        margin-top: 5vh;
    }

    .content-contato .texts {
        align-items: flex-start;
    }
    
    .content-contato .sub {
        font-size: 1.5vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .content-contato .title {
        font-size: 2.6vh;
        font-weight: 600;
    }
    
    .text {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    }
    
    .desc-jornada { 
        display: flex;
        flex-direction: row;
        margin-top: 5vh;
    }
    
    .jornada {
        position: absolute;
        visibility: hidden;
    }
    
    .mid-line {
        width: 80vw;
        margin-top: 7vh;
        border-top: 0.25vh dashed #FF8200;
    }
    
    .content-equipe {
        width: 80vw;
        margin-top: 4vh;
        display: flex;
        flex-direction: column;
    }
    
    .equipe {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: 2vh;
    }
    
    .content-equipe .sub {
        font-size: 1.5vh;
        font-weight: 400;
    }
    
    .content-equipe .title {
        font-size: 2.6vh;
        font-weight: 600;
        text-align: center;
    }
    
    .row {
        display: flex;
        flex-direction: column-reverse;
        margin-top: 4vh;
        margin-left: 1vw;
    }
    
    .image-equipe {
        height: 24vh;
        margin-top: 8vh;
        object-fit: contain;
    }
    
    .info {
        display: flex;
        flex-direction: column;
        gap: 1.3vh;
        margin-left: 4.2vw;
    }
    
    .footer {
        width: 100vw;
        display: flex;
        justify-content: center;
    }
    
    .footer-content {
        width: 80vw;
        height: 8vh;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-end;
        border-top: 0.3vh dashed #4C186A;
        margin-bottom: 5vh;
    }
    
    .footer-text {
        font-size: 1.8vh;
        font-weight: 400;
        margin-right: auto;
        margin-left: auto;
    }
    
    .images {
        color: #59007E;
        font-size: 1.2vh;
        font-weight: 400;
    }
}