body {
    font-family: sans-serif;

    margin: 40px auto;
    max-width: 700px;
    line-height: 1.6;
    font-size: 18px;
    color: #444;
    padding: 0 10px;
}

h1,
h2,
h3 {
    overflow-wrap: break-word;
    hyphens: auto;
    line-height: 1.2;
}

section label {
    display: inline-block;
    min-width: 120px;
    padding-left: 10px;
}

section label.small {
    min-width: 50px;
}

input[type='text'],
input[type='number'],
input[type='datetime-local'] {
    width: 50%;
}

#map {
    height: 240px;
}

#autoComplete {
    width: 50%;
    height: inherit;
    border: 1px solid #888;
    border-radius: 2px;
    color: #000;
    font-size: 10pt;
    padding: 2px;
}

#button-container {
    margin-top: 40px;
}

button {
    width: 100%;
    height: 40px;
    min-width: 100px;

    font-weight: bold;
}

address p {
    margin: 0;
}

#container {
    display: flex;
    flex-direction: column;
}

footer {
    margin-top: 20px;
    text-align: right;
}
