body{
    margin:0;
    display:flex;
    flex-direction: column;
    height: 100vh;
}

/*****************************
 *    Barre de navigation    *
 *****************************/

nav{
    background-color: #76a2e8;
}
div.menu-container{
    display: flex;
    width: fit-content;
}
div.menu{
    white-space: nowrap;
    display: inline-flex;
    align-items: center;
    position: relative;
    flex: 1;
    margin: 10px;
}
div.menu.right{
    float: right;
}
div.menu a{
    padding:5px;
    font-size:30px;
    display: block;
    color:black;
    text-decoration:none;
}
div.menu div.hamburger{
    display: none;
    background-color: #76a2e8;
}
div.menu div.hamburger div.menu{
    width: calc(100% - 20px);
    height: unset;
    display: block;
}
div.menu:hover{
    background-color: #fff4;
}
div.menu:hover div.hamburger{
    display: block;
    position: absolute;
    top: 100%;
    left: 0%;
}
div.menu.right:hover div.hamburger{
    left: unset;
    right:0%;
}

/*****************************
 *      Page principale      *
 *****************************/
 
main{
    overflow-y: scroll;
    flex-grow: 1;
    padding:20px;
    
}
 
/*****************************
 *       Pied de page        *
 *****************************/
 
footer{
    background-color: #76a2e8;
}

/*****************************
 *        Formulaires        *
 *****************************/

form{
    display:grid;
    width: fit-content;
    grid-template-columns: auto 500px;
}
form h3{
    grid-column: span 2;
}
form button{
    margin: 40px auto 0;
    grid-column: span 2;
}
form label{
    margin: 20px 10px;
}
form label span{
    color: red;
}
form input{
    margin: 10px 0;
}
form textarea{
    height: 200px;
    margin: 10px 0;
}
