h1 {
    margin: 0;
    padding: 0;
    line-height: 50px;
    color: rgb(32, 129, 201);
    font-size: 2em;
    text-align: center;
}

main div.contact {
    width: 100%;
    height: auto;
    margin: 50px 0;
}
div.contact div.form {
    width: 100%;
    max-width: 800px;
    background: #fff;
    height: auto;
    margin: 0 auto;
    padding: 60px;
    border-radius: 16px;
    box-shadow: 10px 10px 30px rgba(30,42,61,.15);
}
div.contact div.form div.intro {
    width: 100%;
    background: rgba(203, 224, 241, 0.3);
    padding: 25px;
    margin: 10px 0;
}
div.contact div.form form div.field {
    width: 100%;
    float: none; 
    padding-right: 20px;
    margin: 20px 0;
}
div.contact div.form form div.half {
    width: 50%;
    float: left; 
}
div.contact div.form form div.field label {
    width: 100%;
    height: 25px;
    line-height: 25px;
    margin: 0 20px;
    color: #777;
}
div.contact div.form form div.field select,
div.contact div.form form div.field textarea,
div.contact div.form form div.field input[type="text"] {
    width: 100%;
    display: inline-block;
    vertical-align: top;
    margin: 0;
    border: 1px solid rgba(46,52,62,.1);
    padding: 13px 20px;
    font: 16px/26px "lato",sans-serif;
    color: #2e343e;
    background: 0 0;
    outline: 0;
    -webkit-appearance: none;
    border-radius: 8px;
    font-size: 1em;
    font-family: 'Lato', sans-serif;
}
div.contact div.form form div.field textarea {
    height: 100px;
}
div.contact div.form span {
    display: inline;
    color: rgb(32,129,201);
}

div.contact div.form form button {
    width: auto;
    margin-top: 30px;
    display: inline-block;
    padding: 16px 44px;
    border: none;
    background: rgb(32,129,201);
    border: solid 1px rgb(32,129,201);
    background: rgb(32,129,201);
    font-size: 15px;
    font-weight: 700;
    border-radius: 8px;
    color: #fff;
    font-family: 'Lato', sans-serif;
    transition: all 0.5s ease;
}
div.contact div.form form button:hover {
    color: rgb(32,129,201);
    background: #fff;
    transition: all 0.5s ease;
}

div.contact div.coordonnees {
    width: 100%;
    max-width: 800px;
    background: #fff;
    height: auto;
    margin: 50px auto;
    padding: 60px;
    border-radius: 16px;
    box-shadow: 10px 10px 30px rgba(30,42,61,.15);
}
div.contact div.coordonnees ul {
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
}
div.contact div.coordonnees ul li {
    width: 100%;
    margin: 25px 0;
    padding: 30px;
    background: rgba(203, 224, 241, 0.5);
    border: solid 2px rgb(32,129,201);
    border-radius: 8px;
    font-size: 1.3em;
}
div.contact div.coordonnees ul li span {
    display: block;
}
div.contact div.coordonnees ul li a {
    display: block;
    text-decoration: none;
    color: rgb(32,129,201);
    font-size: 1.3em;
}

iframe.map {
    width: calc(100% - 40px);
    max-width: 800px;
    display: block;
    height: 500px;
    border: 0;
    position: relative;
    z-index: 900;
    margin: 10px auto 50px;
    padding: 0;
    border-radius: 16px;
    box-shadow: 10px 10px 30px rgba(30,42,61,.15);
}

footer {
    margin: 0;
}

@media screen and (max-width: 800px) {
    div.contact div.form,
    div.contact div.coordonnees {
        width: calc(100% - 40px);
        padding: 40px;
    }
    iframe {
        width: 100%;
        box-shadow: none;
        border-radius: 0;
        margin: 0;
    }
}
@media screen and (max-width: 500px) {
    div.contact div.form form div.half {
        width: 100%;
        float: none;
        clear: both; 
    }    
}