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;
    }
    
    .servicos {
        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 {
        color: #8800BD;
        font-size: 4vh;
        font-weight: 600;
    }

    .sub-title {
        font-size: 6vh;
        font-weight: 600;
        line-height: 5vh;
        margin-left: 6vw;
    }
    
    .desc-servicos {
        font-size: 1.8vh;
        width: 28.5vw;
        margin-top: 2.5vh;
    }
    
    .servicos .image {
        height: 29vh;
        margin-top: 3.5vh;
    }
    
    .cloud1,
    .cloud2,
    .cloud3,
    .cloud4 {
        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-servicos {
        width: 80vw;
        margin-top: 8.5vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .historia {
        width: 73%;
        display: flex;
        flex-direction: row;
    }
    
    .historia .sub {
        font-size: 1.5vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .historia .title {
        font-size: 2.6vh;
        font-weight: 600;
    }
    
    .text {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    }

    .text-mobile {
        position: absolute;
        visibility: hidden;
    }
    
    .design {
        width: 100%;
        margin-top: 6vh;
        display: flex;
        flex-direction: row;
        align-self: center;
        justify-content: space-evenly;
    }

    .design .text {
        width: 23.5vw;
    }

    .design ul {
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .arrow-show {
        visibility: hidden;
        position: absolute;
    }
    
    .small-title {
        font-size: 1.8vh;
        font-weight: 700;
        margin-bottom: 1.5vh;
    }
    
    .cloud3 {
        width: 19vw;
        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: 120vh;
        border-radius: 100vh 0 0 100vh;
        align-self: flex-end;
    }
    
    .content-entregas {
        margin-top: 9vh;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    
    .content-entregas .small-title {
        color: #8800BD;
        margin-bottom: 0;
    }
    
    .blocks {
        display: flex;
        flex-direction: row;
        margin-top: 4.6vh;
        width: 80%;
        justify-content: space-evenly;
    }
    
    .block {
        width: 13vw;
        text-align: center;
        align-items: center;
        display: flex;
        flex-direction: column;
    }
    
    .material-icons, .material-icons-outlined {
        font-size: 5vh !important;
        margin-bottom: 0.5vh;
    }
    
    .content-atuacao {
        width: 80vw;
        margin-top: 17vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .arrow-atuacao {
        height: 10vh;
        position: absolute;
        margin: 8.5vh 0 0 -1.5vw;
    }
    
    .atuacao {
        width: 80%;
        display: flex;
        flex-direction: row;
    }
    
    .atuacao .sub {
        font-size: 1.5vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .atuacao .title {
        font-size: 2.6vh;
        font-weight: 600;
    }

    .content-atuacao .texts {
        width: 100%;
    }
    
    .situacao {
        margin-top: 4vh;
        display: flex;
        flex-direction: row;
        align-self: center;
        align-items: center;
        width: 70%;
        justify-content: center;
    }
    
    .card-icon {
        height: 5vh;
        margin-right: 3.2vw;
    }

    #icon-3 {
        margin-right: 3vw;
    }
    
    .content-etapas {
        width: 80vw;
        margin-top: 15vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .content-etapas .title {
        font-size: 2.6vh;
        color: #FF8200;
    }
    
    .content-etapas .text {
        width: 80%;
        margin-top: 3.8vh;
        text-align: center;
    }
    
    .etapas {
        margin-top: 5.7vh;
        display: flex;
        flex-direction: row-reverse;
        width: 90%;
        justify-content: center;
    }
    
    .etapas ul {
        list-style-type: disc;
        list-style-position: outside;
        margin-block-start: 0;
        margin-block-end: 0;
        padding: 0;
    }
    
    .etapas ul li::marker {
        font-size: 120%;
        color: #00C0E5;
    }
    
    ul.points li {
        position:relative; /* so that pseudoelements are positioned relatively to their "li"s*/
    }
    
    ul.points li:before {
        /* lines */
        content:"";
        position: absolute;
        left: -1vw; /* adjust manually */
        border-left: 0.4vh dashed #00C0E51A;
        height: 110%;
    }
    
    ul.points li:first-child:before {
       /* first li's line */
       top: 1vh; /* moves the line down so that it disappears under the bullet. Adjust manually */
    }
    
    ul.points li:last-child:before {
        /* last li's line */
       height: 0.6vh; /* shorten the line so it goes only up to the bullet. Is equal to first-child:before's top */
    }
    
    .points {
        display: flex;
        flex-direction: column;
    }
    
    .etapa {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    
        height: 5vh;
        width: 27vw;
        border-bottom: 0.1vh solid #D7D9D9;
        margin-top: 0.8vh;
    }

    .etapa .textos {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
    }
    
    .etapa-text {
        margin-top: 1vh;
        position: absolute;
        opacity: 0;
        margin-bottom: 2vh;
    }
    
    .drop {
        margin-top: 2vh;
        margin-right: 1.5vh;
        cursor: pointer;
        display: flex;
        justify-content: center;
        z-index: 10;
    }

    .fa-minus {
        margin-bottom: 1vh;
    }

    .etapa .icon-show {
        font-size: 2vh;
        cursor: pointer;
        user-select: none;
        color: #cacaca;
    }

    .image-etapas {
        height: 40vh;
        margin-right: 15vh;
    }
    
    .etapas .arrow-etapas {
        height: 18vh;
        margin-top: 9.5vh;
        margin-left: 2vh;
    }
    
    .content-contato {
        width: 80vw;
        margin-top: 20vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .contato {
        display: flex;
        flex-direction: column;
        align-items: center;
        margin-top: 2vh;
    }
    
    .content-contato .sub {
        font-size: 1.5vh;
        font-weight: 400;
    }
    
    .content-contato .title {
        font-size: 2.6vh;
        font-weight: 600;
        text-align: center;
    }
    
    .row {
        display: flex;
        flex-direction: row;
        margin-top: 4vh;
        margin-left: -31vh;
    }
    
    .image-contato {
        height: 36vh;
        align-self: flex-start;
    }
    
    .info {
        display: flex;
        flex-direction: column;
        gap: 1.3vh;
        margin-left: 4.2vw;
        font-size: 1.8vh;
        width: 19vw;
    }

    .info .contatos {
        display: flex;
        flex-direction: row;
        gap: 1vw;
    }

    .info .texts {
        gap: 1.3vh;
    }

    .info .icons {
        position: absolute;
        visibility: hidden;
    }

    .icons .icon {
        height: 2.5vh;
    }

    .whats {
        visibility: visible;
        position: inherit;
    }

    .num {
        visibility: hidden;
        position: absolute;
    }

    .info .links {
        visibility: hidden;
        position: absolute;
    }
    
    .cloud4 {
        width: 20vw;
        height: 93vh;
        background: linear-gradient(0deg, rgba(136, 0, 189, 0.3) 0%, rgba(255, 130, 0, 0.3) 100%);
        margin-top: 240vh;
        border-radius: 0 70vh 70vh 0;
        align-self: flex-start;
    }
    
    .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;
    }
    
    .jornada {
        align-self: flex-end;
        display: flex;
        cursor: pointer;
        z-index: 99;
    }
    
    .align {
        position: fixed;
        bottom: 5.4vh;
    }

    .fixed {
        position: absolute;
        margin-bottom: 15.4vh;
        margin-left: auto;
    }

    .show {
        visibility: visible !important;
        width: 18vh
    }

    .expand {
        width: 24vh !important;
        margin-left: -18vh !important;
    }
    
    .jornada-info {
        height: 5.8vh;
        width: 5.8vh;
        border-radius: 10vh;
        position: absolute;
        background-color: #00C0E5;
        margin-left: 0.4vw;
        align-self: flex-end;
        z-index: -1;
        display: flex;
        align-items: center;
        transition: margin 0.5s, width 0.5s;
        transition-timing-function: ease-in-out;
    }
    
    .jornada-text {
        display: flex;
        flex-direction: column;
        font-size: 1.4vh;
        color: #fff;
        position: absolute;
        visibility: hidden;
        margin-left: 1vw;
        transition: all 0.2s ease-out;
    }
    
    .jornada:hover .jornada-info {
        width: 24vh;
        margin-left: -18vh;
    }
    
    .jornada:hover .jornada-text {
        visibility: visible;
        width: 18vh
    }
    
    .cloud5 {
        width: 100vw;
        height: 10vh;
        background: linear-gradient(243.24deg, rgba(89, 0, 126, 0.4) 8.98%, rgba(0, 192, 229, 0.4) 88.41%);
    }
}

/* 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;
                    }
                }
            }
        }

        .servicos {
            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;
                    }
                
                    .sub-title {
                        font-size: 6vh;
                        font-weight: 600;
                        line-height: 5vh;
                        margin-left: 5vw;
                    }
                }
        
                .desc-servicos {
                    font-size: 1.8vh;
                    width: 23vw;
                    margin-top: 2.5vh;
                }
            }
            
            .image {
                height: 33vh;
                margin-top: 3.5vh;
            }
        }
    
        .cloud1,
        .cloud2,
        .cloud3,
        .cloud4 {
            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-servicos {
            width: 70vw;
            margin-top: 8.5vh;
            display: flex;
            flex-direction: column;
            align-items: center;

            .historia {
                width: 68%;
                display: flex;
                flex-direction: row;

                .texts {
                    .sub {
                        font-size: 1.5vh;
                        font-weight: 400;
                        color: #FF8200;
                    }
                    
                    .title {
                        font-size: 2.6vh;
                        font-weight: 600;
                    }
            
                    .text-mobile {
                        position: absolute;
                        visibility: hidden;
                    }
                }
            }

            .design {
                width: 68%;
                margin-top: 6vh;
                display: flex;
                flex-direction: row;
                align-self: center;
                justify-content: space-between;
    
                .texts {
                    .text {
                        width: 19vw;
                    }
                }
    
                .arrow-show {
                    visibility: hidden;
                    position: absolute;
                }
            }
    
            .design ul {
                margin: 0;
                padding: 0;
                list-style: none;

                font-size: 1.8vh;
                font-weight: 700;
                margin-bottom: 1.5vh;
            } 

            .content-entregas {
                margin-top: 9vh;
                width: 68%;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
    
                .small-title {
                    color: #8800BD;
                    margin-bottom: 0;
                    font-size: 1.8vh;
                    font-weight: 700;
                    margin-bottom: 1.5vh;
                }
    
                .blocks {
                    display: flex;
                    flex-direction: row;
                    margin-top: 4.6vh;
                    width: 100%;
                    justify-content: space-between;
    
                    .block {
                        width: 10vw;
                        text-align: center;
                        align-items: center;
                        display: flex;
                        flex-direction: column;
    
                        .material-icons, .material-icons-outlined {
                            font-size: 5vh !important;
                            margin-bottom: 0.5vh;
                        }
                    }

                    .block:nth-child(4) {
                        width: 9vw;
                    }
                }
            }
        }
        
        .cloud3 {
            width: 19vw;
            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: 120vh;
            border-radius: 100vh 0 0 100vh;
            align-self: flex-end;
        }
        
        .content-atuacao {
            width: 70vw;
            margin-top: 17vh;
            display: flex;
            flex-direction: column;
            align-items: center;

            .atuacao {
                width: 68%;
                display: flex;
                flex-direction: row;

                .arrow-atuacao {
                    height: 10vh;
                    position: absolute;
                    margin: 8.5vh 0 0 -1.5vw;
                }

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

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

            .texts {
                width: 78%;

                .situacao {
                    margin-top: 4vh;
                    display: flex;
                    flex-direction: row;
                    align-self: center;
                    align-items: center;
                    width: 70%;
                    justify-content: center;

                    .card-icon {
                        height: 5vh;
                        margin-right: 3.2vw;
                    }

                    #icon-3 {
                        margin-right: 3vw;
                    }
                }
            }
        }
        
        .content-etapas {
            width: 70vw;
            margin-top: 15vh;
            display: flex;
            flex-direction: column;
            align-items: center;

            .title {
                font-size: 2.6vh;
                color: #FF8200;
            }

            .text {
                width: 68%;
                margin-top: 3.8vh;
                text-align: center;
            }

            .etapas {
                margin-top: 5.7vh;
                display: flex;
                flex-direction: row-reverse;
                width: 68%;
                justify-content: center;

                .arrow-etapas {
                    height: 18vh;
                    margin-top: 9.5vh;
                    margin-left: 2vh;
                }

                .points {
                    display: flex;
                    flex-direction: column;

                    list-style-type: disc;
                    list-style-position: outside;
                    margin-block-start: 0;
                    margin-block-end: 0;
                    padding: 0;

                    .etapa {
                        font-size: 1.8vh;
                        font-weight: 400;
                        color: #000;
                        line-height: normal;
                    
                        height: 5vh;
                        width: 20vw;
                        border-bottom: 0.1vh solid #D7D9D9;
                        margin-top: 0.8vh;

                        .textos {
                            display: flex;
                            flex-direction: row;
                            justify-content: space-between;

                            .etapa-text {
                                margin-top: 1vh;
                                position: absolute;
                                opacity: 0;
                                margin-bottom: 2vh;
                            }
                            
                            .drop {
                                margin-top: 2vh;
                                margin-right: 1.5vh;
                                cursor: pointer;
                                display: flex;
                                justify-content: center;
                                z-index: 10;
                            }
                    
                            .fa-minus {
                                margin-bottom: 1vh;
                            }
                    
                            .etapa .icon-show {
                                font-size: 2vh;
                                cursor: pointer;
                                user-select: none;
                                color: #cacaca;
                            }
                        }
                    }

                    .etapa::marker {
                        font-size: 120%;
                        color: #00C0E5;
                    }

                    .etapa {
                        position:relative; /* so that pseudoelements are positioned relatively to their "li"s*/
                    }
                    
                    .etapa:before {
                        /* lines */
                        content:"";
                        position: absolute;
                        left: -0.75vw; /* adjust manually */
                        border-left: 0.4vh dashed #00C0E51A;
                        height: 110%;
                    }
                    
                    .etapa:first-child:before {
                        /* first li's line */
                        top: 1vh; /* moves the line down so that it disappears under the bullet. Adjust manually */
                    }
                    
                    .etapa:last-child:before {
                        /* last li's line */
                        height: 0.6vh; /* shorten the line so it goes only up to the bullet. Is equal to first-child:before's top */
                    }
                }

                .image-etapas {
                    height: 40vh;
                    margin-right: 5vw;
                }
            }
        }

        .content-contato {
            width: 80vw; /*60vw*/
            margin-top: 20vh;
            display: flex;
            flex-direction: column;
            align-items: center;

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

                .sub {
                    color: #FF8200;
                    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;
                margin-left: -31vh;

                .image-contato {
                    height: 36vh;
                    align-self: flex-start;
                }

                .info {
                    display: flex;
                    flex-direction: column;
                    gap: 1.3vh;
                    margin-left: 4.2vw;
                    font-size: 1.8vh;
                    width: 19vw;

                    .contatos {
                        display: flex;
                        flex-direction: row;
                        gap: 1vw;

                        .icons {
                            position: absolute;
                            visibility: hidden;

                            .icon {
                                height: 2.5vh;
                            }
                        }

                        .texts {
                            gap: 1.3vh;

                            .whats {
                                visibility: visible;
                                position: inherit;
                            }
                    
                            .num {
                                visibility: hidden;
                                position: absolute;
                            }
                        }
                    }

                    .links {
                        visibility: hidden;
                        position: absolute;
                    }
                }
            }
        }
        
        .cloud4 {
            width: 20vw;
            height: 93vh;
            background: linear-gradient(0deg, rgba(136, 0, 189, 0.3) 0%, rgba(255, 130, 0, 0.3) 100%);
            margin-top: 240vh;
            border-radius: 0 70vh 70vh 0;
            align-self: flex-start;
        }
        
        .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;
                }
        
                .jornada {
                    align-self: flex-end;
                    display: flex;
                    cursor: pointer;
                    z-index: 99;

                    .jornada-info {
                        height: 5.8vh;
                        width: 5.8vh;
                        border-radius: 10vh;
                        position: absolute;
                        background-color: #00C0E5;
                        margin-left: 0.3vw;
                        align-self: flex-end;
                        z-index: -1;
                        display: flex;
                        align-items: center;
                        transition: margin 0.5s, width 0.5s;
                        transition-timing-function: ease-in-out;
            
                        .jornada-text {
                            display: flex;
                            flex-direction: column;
                            font-size: 1.4vh;
                            color: #fff;
                            position: absolute;
                            visibility: hidden;
                            margin-left: 1vw;
                            transition: all 0.2s ease-out;
                        }
            
                        .show {
                            visibility: visible !important;
                            width: 18vh;
                        }
                    }

                    .expand {
                        width: 26vh !important;
                        margin-left: -7.4vw !important;
                    }
                }

                .align {
                    position: fixed;
                    bottom: 5.4vh;
                }
        
                .fixed {
                    position: absolute;
                    margin-bottom: 15.4vh;
                    margin-left: auto;
                }
        
                .jornada:hover .jornada-info {
                    width: 26vh;
                    margin-left: -7.4vw;
                }
                
                .jornada:hover .jornada-text {
                    visibility: visible;
                    width: 18vh;
                }
            }
        }
    }
}

/* 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: 100%;
        display: flex;
        justify-content: center;
        background-color: #ffffff01;
        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,
    .cloud3,
    .cloud3-1,
    .cloud4 {
        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: 20vw;
        height: 54vh;
        align-self: flex-start;
        margin-top: 70vh;
        border-radius: 0 70% 70% 0;
    }

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

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

    .cloud3-1 {
        width: 20vw;
        height: 58vh;
        align-self: flex-start;
        margin-top: 220vh;
        border-radius: 0 70% 70% 0;
    }

    .cloud4 {
        width: 12vw;
        height: 48vh;
        background: linear-gradient(90deg, rgba(72, 191, 227, 0.70) 0%, rgba(116, 0, 184, 0.70) 100%);
        align-self: flex-end;
        margin-top: 355vh;
        border-radius: 70vh 0 0 70vh;
    }
    
    .servicos {
        width: 80vw;
        margin-top: 12vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .texts {
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .titles {
        display: flex;
        flex-direction: column;
    }
    
    .title {
        font-size: 5vh;
        font-weight: 600;
    }
    
    .sub {
        color: #8800BD;
        font-size: 3vh;
        font-weight: 600;
    }

    .sub-title {
        font-size: 5vh;
        font-weight: 600;
        line-height: 5vh;
        margin-left: 14vw;
        color: #FF8200;
    }
    
    .desc-servicos {
        font-size: 1.8vh;
        margin-top: 2.5vh;
        text-align: center;
    }

    .image {
        margin-top: 3.5vh;
        height: 24vh    
    }
    
    .content-servicos {
        width: 80vw;
        margin-top: 8.5vh;
        display: flex;
        flex-direction: column;
    }
    
    .historia {
        display: flex;
        flex-direction: row;
    }
    
    .historia .sub {
        font-size: 1.7vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .historia .title {
        font-size: 2.6vh;
        font-weight: 600;
    }

    .historia .texts {
        display: flex;
        align-items: flex-start;
    }
    
    .text {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    }

    .text-mobile {
        margin-bottom: 2vh;
    }
    
    .design {
        width: 100%;
        margin-top: 6vh;
        display: flex;
        flex-direction: column;
        align-self: center;
        gap: 4vw;
    }

    .design ul {
        margin: 0;
        padding: 0;
    }

    .design li {
        list-style: none;
        display: flex;
        flex-direction: row;
    }
    
    .design .point:before {
        content: "·";
        font-size: 16vh;
        line-height: 2.5vh;
        color: #00C0E5;
        margin-right: 2vw;
    }

    .design-show {
        width: 100%;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        margin-top: 1.5vh;
    }

    .arrow-show {
        font-size: 2.8vh;
        color: #00C0E5;
        margin-right: 3vw;
        align-self: center;
    }

    .design .texts {
        box-shadow: 0 0.5vh 0.5vh 0 #00000040;
        border-radius: 2vh; 
        height: 6vh;   
        background-color: #fff;
        padding-left: 3vw;   
    }

    .design .scaleUp {
        height: auto;
        padding-left: 4vw;
    }

    .design .text {
        visibility: hidden;
        position: absolute;
        margin-top: 1.5vh;
        margin-right: 9vw;
    }

    .design .viewText {
        visibility: visible;
        position: relative;
        margin-bottom: 2vh;
    }
    
    .small-title {
        font-size: 1.8vh;
        font-weight: 700;
        color: #00C0E5;
        align-self: flex-start;
    }
    
    .content-entregas {
        margin-top: 9vh;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    
    .content-entregas .small-title {
        color: #8800BD;
        margin-bottom: 0;
        align-self: center;
        font-size: 2vh;
    }
    
    .blocks {
        display: flex;
        flex-direction: column;
        margin-top: 4.6vh;
        gap: 7vh;
    }
    
    .block {
        text-align: center;
        align-items: center;
        display: flex;
        justify-content: center;
        flex-direction: row;
        gap: 5vw;
    }

    .block .text {
        width: 38vw;
    }

    .linha {
        background-color: #8800BD;
        height: 43vh;
        width: 0.5vw;
        margin-top: 15vh;
        z-index: -1;
        position: absolute;
    }

    .fundo {
        background-color: #8800BD;
        height: 7vh;
        width: 7vh;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .material-icons, .material-icons-outlined {
        font-weight: 400 !important;
        font-size: 4vh !important;
        color: #fff !important;
    }
    
    .block .icon {
        height: 3.4vh;
    }
    
    .content-atuacao {
        width: 80vw;
        margin-top: 17vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .arrow-atuacao {
        visibility: hidden;
        position: absolute;
    }
    
    .atuacao {
        display: flex;
        flex-direction: row;
        align-self: flex-start;
    }

    .atuacao .texts {
        align-items: flex-start;
    }
    
    .atuacao .sub {
        font-size: 1.5vh;
        font-weight: 400;
        color: #FF8200;
    }
    
    .atuacao .title {
        font-size: 2.6vh;
        font-weight: 600;
    }
    
    .situacao {
        margin-top: 4vh;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
    }
    
    .card-icon {
        height: 5vh;
        margin-right: 3.2vw;
    }
    
    .content-etapas {
        width: 80vw;
        margin-top: 8vh;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .content-etapas .title {
        font-size: 2.6vh;
        color: #FF8200;
        text-align: center;
    }
    
    .content-etapas .text {
        margin-top: 3.8vh;
        text-align: center;
    }
    
    .etapas {
        margin-top: 5.7vh;
        display: flex;
        flex-direction: column;
    }
    
    .etapas ul {
        list-style-type: disc;
        list-style-position: outside;
        margin-block-start: 0;
        margin-block-end: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    
    .etapas ul li::marker {
        font-size: 120%;
        color: #00C0E5;
    }
    
    ul.points li {
        position: relative; /* so that pseudoelements are positioned relatively to their "li"s*/
    }
    
    ul.points li:before {
        /* lines */
        content:"";
        position: absolute;
        left: -2.1vh; /* adjust manually */
        border-left: 0.4vh dashed #00c0e51a;
        height: 110%;
    }
    
    ul.points li:first-child:before {
       /* first li's line */
       top: 1vh; /* moves the line down so that it disappears under the bullet. Adjust manually */
    }
    
    ul.points li:last-child:before {
        /* last li's line */
       height: 0.6vh; /* shorten the line so it goes only up to the bullet. Is equal to first-child:before's top */
    }
    
    .points {
        display: flex;
        flex-direction: column;
        margin-left: 3vw; 
    }
    
    .etapa {
        font-size: 1.8vh;
        font-weight: 400;
        color: #000;
        line-height: normal;
    
        height: 7vh;
        width: 70vw;
        border-bottom: 0.1vh solid #D7D9D9;
        margin-top: 0.8vh;
    }

    .etapa .textos {
        width: 70vw;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
    }
    
    .etapa-text {
        margin-top: 1.5vh;
        position: absolute;
        opacity: 0;
        margin-bottom: 2vh;
    }

    .drop {
        cursor: pointer;
        z-index: 10;
    }
    
    .etapa .icon-show {
        font-size: 2.6vh;
        cursor: pointer;
        color: #cacaca;
        user-select: none;
    }

    .image-etapas {
        height: 36vh;
        object-fit: contain;
        margin-top: 8vh;
    }
    
    .etapas .arrow-etapas {
        position: absolute;
        visibility: hidden;
    }
    
    .content-contato {
        width: 80vw;
        margin-top: 10vh;
        display: flex;
        flex-direction: column;
    }

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

    .content-contato .sub {
        font-size: 1.8vh;
        font-weight: 400;
    }

    .content-contato .title {
        font-size: 2.6vh;
        font-weight: 600;
        text-align: center;
    }

    .row {
        display: flex;
        flex-direction: row;
        justify-content: center;
        margin-top: 4vh;
        margin-bottom: 10vh;
    }

    .image-contato {
        position: absolute;
        visibility: hidden;
        transform: scale(0);
    }

    .info {
        display: flex;
        flex-direction: column;
        text-align: center;
        gap: 1.3vh;
        font-size: 1.8vh;
    }

    .info .contatos {
        display: flex;
        flex-direction: row;
        gap: 1.4vw;
        width: 70%;
        margin-top: 2vh;
        align-self: center;
    }

    .info .icons,
    .info .texts {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        text-align: start;
        gap: 1.8vh;
    }

    .info .texts {
        gap: 2.3vh;
    }

    .icons .icon {
        height: 2.7vh;
    }

    .whats {
        visibility: hidden;
        position: absolute;
    }

    .num {
        visibility: visible;
        position: inherit;
    }

    .info .links {
        margin-top: 3vh;
        align-self: center;
    }

    .footer {
        width: 100vw;
        display: flex;
        justify-content: center;
        margin-top: 2vh;
        margin-bottom: 5vh;
    }

    .footer-content {
        width: 70vw;
        height: 8vh;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-end;
        border-top: 0.3vh dashed #4C186A;
    }

    .footer-content a {
        text-decoration: none;
    }

    .footer-text {
        font-size: 1.8vh;
        font-weight: 400;
        margin-right: auto;
        margin-left: auto;
        text-align: center;
    }

    .images {
        color: #59007E;
        font-size: 1.2vh;
        font-weight: 400;
    }

    .jornada {
        align-self: flex-end;
        display: flex;
        cursor: pointer;
        z-index: 99;
        margin-bottom: 5vh;
    }

    .jornada-info {
        height: 5.8vh;
        width: 26vh;
        border-radius: 10vh;
        background-color: #00C0E5;
        align-self: flex-end;
        z-index: -1;
        display: flex;
        align-items: flex-end;
    }

    .jornada img {
        margin-left: -3.5rem;
    }

    .jornada-text {
        display: flex;
        flex-direction: column;
        align-self: center;
        font-size: 1.4vh;
        color: #fff;
        margin-left: 4vw;
    }
}