body {
    background-color: skyblue;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main {
    background-color: #fff;
    border-radius: 1rem;
    margin: 2rem auto;
    padding: 30px 15px;
    max-width: calc(100vw - 2rem);
}

label.required {
    &:after {
        content: '*';
    }
}

.login-container {
    text-align: center;
    padding: 3rem;
    max-width: 20rem;
    margin: auto !important;
}
