body { text-align: center; max-width: 960px; font-family: "Helvetica Neue", Arial, "Noto Sans", sans-serif; padding: 0; margin: 0 auto; height: 100vh; --margin-y: 1em; --margin-x: 0; } #wrapper { height: 100%; display: flex; flex-flow: column; margin: 0 var(--margin-x); } #desc { margin: var(--margin-y) 0; } #desc > p:first-child { margin-top: 0; } #desc > p:last-child { margin-bottom: 0; } #map { border: 1px solid black; width: 500px; max-height: 600px; margin: 0 auto var(--margin-y) auto; flex: 1; } @media screen and (max-width: 500px) { body { --margin-x: .25em; } #map { width: 100%; } } @media screen and (max-height: 1280px) { body { --margin-y: .5em; } } @media screen and (max-height: 600px) { body { --margin-y: .25em; } }