html,
body {
    min-height: 100vh;
    height: 100%;
}

body {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin: 0;
    font-family: "Noto Serif", serif;
    font-weight: 400;
    font-style: normal;
}

header {
    padding: 15px 15px 12px;
    border-bottom: 1px solid #3b8a8a;
}

header div,
footer div,
main {
    max-width: 660px;
    margin: auto;
}

main {
    flex: 1;
    padding: 0 15px 60px;
}

img.logo {
    margin-left: -5px;
}

footer {
    color: #FFF;
    padding: 20px 15px;
    background: #003d3d;
    background: linear-gradient(90deg, rgba(0, 61, 61, 1) 0%, rgba(59, 138, 138, 1) 50%, rgba(83, 19, 87, 1) 100%);
    border-top: 1px solid #333;
    font-size: 11px;
    font-family: "Open Sans", sans-serif;
}

figure {
    text-align: center;
}

figure.tm {
    margin-top: 60px;
    margin-bottom: 50px;
}

figure img {
    width: 100%;
    max-height: 280px;
    border-radius: 5px;
    object-fit: cover;
    box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
}

figure figcaption {
    font-size: 13px;
    font-style: italic;
    margin-top: 10px;
    color: #999;
}

h1 {
    font-size: 38px;
    font-weight: 700;
    margin: 40px 0;
    max-width: 680px;
    padding: 0 20px;
    text-align: center;
}

h2 {
    margin-top: 40px;
    padding-bottom: 0;
    margin-bottom: 0;
    font-size: 14px;
    font-weight: 600;
    text-transform: uppercase;
    font-family: "Open Sans", sans-serif;
    color: #3b8a8a;
}

p {
    font-size: 17px;
    line-height: 28px;
    font-weight: 300;
    color: #343e3e;
    margin-bottom: 20px;
}

p a {
    text-decoration: none;
    color: #3b8a8a;
    font-weight: 500;
}