* {
    box-sizing: border-box;
}

body {
    display: grid;
    width: 100vw;
    height: 100vh;
    place-items: center;
    margin: 0px;
    padding: 10px;
    background-image: url('bg.jpg');
}

.memorial {
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
    border: solid 1px black;
    overflow: hidden;
}

.content {
    padding: 10px;
    font-size: 1.1em;
    overflow-y: auto;
}

.content.eulogy {
    margin-top: 3em;
}

.content.eulogy h1 {
    margin: .3em 0px;
    font-size: 1.5em;
}

@media screen and (min-width: 550px) {
    body {
        background-image: linear-gradient(rgba(0, 0, 0, 0) 70%, rgba(0, 0, 0, 0.3)), url('bg.jpg');
        padding: 5vh 10px;
    }

    .memorial {
        max-width: 650px;
        box-shadow: rgba(0, 0, 0, 0.3) 5px 5px 5px;
        background-image: url('bg.jpg');
    }
}

@media screen and (min-width: 825px) {
    .content.eulogy {
        margin-top: unset;
    }
}