html {
    min-height: 100%;
    height: 100%;
    font-size: 62.5%;
}

body {
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    height: 100%;
    font-size: 1.6rem;
}

header, footer, main {
    text-align: center;
}

main {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    flex-grow: 1;
}

main .badge {
    height: 4rem;
}

footer {
    margin-top: auto;
}

[aria-disabled="true"] {
    cursor: not-allowed;
    opacity: 0.8;
}

.logo {
    margin-top: 1rem;
    height: 10rem;
}

.logo + h1 {
    margin-top: 0;
}

.photo {
    width: 10rem;
    aspect-ratio: 1;
    object-fit: cover;
    border-radius: 999rem;
    margin-bottom: 1rem;
}
