.wrapper {
    margin: auto;
    padding: 0 1rem;
    max-width: 1024px;
    flex: 0 1 1024px;
}

.flex-v {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;

    margin-bottom: 64px;
    margin-bottom: 4rem;
}

a {
    color: #DB4272;
}
a:visited {
    color: #B0233C;
}

body {
    color: #444;
    font-family: Arial;
    font-size: 20px;
    line-height: 135%;

    height: 120vh;
}

header.main {
    margin: 0 0 64px 0;
    margin: 0 0 4rem 0;
    padding: 25VH 0 15vh 0;
    background-image:url("images/001.jpg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: auto 100%;
    background-size: cover;
    background-attachment: fixed;
    background-blend-mode: overlay;
    background-color: #555;
}

header h1 {
    margin: 0;
    color: #fff;
}

main dd {
    margin-bottom: 16px;
    margin-bottom: 1rem;
}

main section {
    -webkit-box-flex: 1;
        -ms-flex: 1 0 auto;
            flex: 1 0 auto;
    max-width: 1024px;
    margin: 0 64px 0 0;
    margin: 0 4rem 0 0;
}

main h2 {
    margin-top: 0;
}

main div + section {
    margin: 0 0 0 64px;
    margin: 0 0 0 4rem;
}

main div {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 60%;
            flex: 0 1 60%;
    -o-object-fit: cover;
       object-fit: cover;
}

main div img {
    max-width: 100%;
}

footer {
    height: 70vh;
    background-image: url("images/004.jpg");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: auto 100%;
    background-size: cover;
    background-attachment: fixed;
    background-blend-mode: overlay;
    background-color: #555;
}

footer h2 {
    padding: 15vh 0 0;
}
