html, body {
    height: 100%;
    width: 100%;
    margin: 0%;
    background-color: #fff9ec;
    overflow: hidden;
    scroll-behavior: smooth;
}


nav {
    width: 100%;
    text-align: left;
    position: absolute;
}


nav ul li {
    display: inline;
    list-style-type: none;
}

nav ul li a:hover {
    color: rgb(153, 98, 170);
}

nav ul li a {
    color: rgb(58, 58, 58);
    text-decoration: none;
    font-family: 'Nunito';
    padding-right: 9vw;
    font-size: 4.6vh;
}

nav ul li a#titulo {
    color: rgb(58, 58, 58);
    text-decoration: none;
    font-family: 'Nunito';
    font-weight: 800;
    margin-right: 20vw;
    font-size: 15vh;
}

nav ul li a#titulo:hover {
    color: rgb(153, 98, 170);
}


.horizontal{
    height: 80vh;
    width: 100vw;
    margin-top: 100vh;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
}


img{
   height: 40vh;
   margin-top: 25vh;
   margin-left: 3vw;
   flex: 0 0 auto;
}
 

.sobre{
    height: 100vh;
    width: 50vw;
    background-color:  #fff6e1;
    margin-left: 50vw;
}

.contactos{
    height: 100vh;
    width: 100vw;
    text-justify: center;
    background-color:  #fff6e1;
    
}

.ligacao{
    display: block;
    text-align: center;
    padding-top: 95vh;
    font-family: 'Lato', sans-serif;
    color: rgb(43, 43, 43);
}

.ligacao a{
    text-decoration: none;
    color: rgb(58, 58, 58);
    font-size: 2.2vh;
}

.ligacao a:hover{
    color: rgb(153, 98, 170);
}

p{
    font-family: 'Lato', sans-serif;
    padding: 1vw;
    padding-top: 40vh;
    font-size: 2vh;
    text-align: right;
    line-height: 3vh;
    color: rgb(85, 85, 85);
}

@media screen and (min-width: 768px) {

    .sobre{
    width: 60vw;
    margin-left: 0vw;
    }

    p{
    text-align: left;
    padding: 5vw;
    padding-top: 30vh;
    }

    nav ul li a {
        font-size: 3vh;
        padding-right: 5vw;
    }
    
    nav ul li a#titulo {
        font-size: 10vh;
        margin-right: 30vw;
    }

    .horizontal{
        padding-top: 15vh;
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
    }

    .ligacao{
        text-align: left;
        padding-left: 5vw;
    }
}

@media screen and (min-width: 1200px) {
    nav ul li a {
        padding-right: 2vw;
        font-size: 3vh;
        
    }
    
    nav ul li a#titulo {
        margin-right: 65vw;
        font-size: 4vh;
    }

    img{
        height: 50vh;
        margin-top: 10vh;
    }

    .sobre{
        height: 100vh;
        width: 25vw;
        background-color:  #fff6e1;
        margin-left: 75vw;
        padding-top:
    }


    p{
        padding: 4vw;
        padding-top: 15vh;
        font-size: 2vh;
    }

    .ligacao{
        text-align: center;
    }

}