body {
    margin: 0 8px;
    background-color: #003443;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: start;
    font-family: "Lora", sans-serif;
    line-height: 1.4;
    position: absolute;
    inset: 0;
}

#app {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

main {
    max-width: 65ch;
}

main p {
    text-indent: 2ch;
}

main a {
    color: unset;
}

main #hero {
    width: 100%;
    margin: 24px auto;
}

.links {
    display: flex;
    gap: 2px;
}

.links img {
    max-width: 24px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 6px;
}

.column {
    display: flex;
    flex-direction: column;
    flex-basis: 100%;
    flex: 1;
  }

hr {
    border: none;
    height: 1px;
    background-color: #fff;
    opacity: 0.25;
}

h1, h2, h3, header, footer {
    font-family: "Playfair Display", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    letter-spacing: -0.07em;
}

footer {
    margin: 8px 0;
    display: flex;
    justify-content: center;
}