@media screen and (max-width: 70em) {
    .container {
        display: flex;
        flex-direction: column-reverse;
    }

    .login-image {
        width: 60vw;
    }

    div.bg-square {
        width: 300vw;
        height: 300vw;
        left: 70vw;
        top: -160vw;
    }

    form {
        margin: 5vw 5vw 0 0;
        align-items: end;
    }

    label {
        font-size: 1.6em;
        margin: 0.25em;
        padding: 0.25em;
    }

    .forgot-password a {
        margin-top: 2vw;
        font-size: 1.8em;
    }

    .links p {
        font-size: 1em;
    }

    .submit-wrapper button {
        /* background: var(--accent); */
        border-radius: 10px;
        padding: 0.5em 1em;
        margin-right: 1vw;
    }

    .submit-wrapper p {
        font-size: 1.2em;
    }

}


@media screen and (max-width: 60em) {

    .container {
        display: flex;
        flex-direction: column-reverse;
    }

    .login-image {
        width: 60vw;
    }

    div.bg-square {
        width: 300vw;
        height: 300vw;
        left: 70vw;
        top: -156vw;
    }

    .tagline h1 {
        text-align: center;
        font-size: 2.5em;
    }

    .tagline h3 {
        font-size: 1.5em;
        margin-bottom: 6vw;
    }

    form {
        align-items: end;
    }

    label {
        font-size: 1.3em;
        margin: 0.25em;
        padding: 0.25em;
    }

    .forgot-password a {
        font-size: 1.3em;
    }

    .submit-wrapper button {
        /* background: var(--accent); */
        border-radius: 10px;
        padding: 0.5em 1em;
        margin-right: 1vw;
    }

    .submit-wrapper p {
        font-size: 1.2em;
    }

    .links {
        text-align: center;
        width: 100%;
        font-size: 1.3em;
    }
}

@media screen and (max-width: 40em) {
    .container {
        display: block;
    }

    .bg-square {
        width: 144vw !important;
        height: 122vw !important;
        left: -9vw !important;
        top: 0vw !important;
    }

    .bg-shape {
        display: none;
    }

    .page-logo {
        margin: 0.8em;
        width: 45px;
    }

    label {
        margin: 0.25em;
        padding: 0.25em;
        font-size: 0.8em;
    }

    .forgot-password a {
        padding: 0em;
    }

    .login-image img {
        position: relative;
        text-align: end;
        top: 33em;
        left: 0em;
        width: 50vw !important;
    }

    .form-tag {
        position: relative;
        top: -30vw;
    }

    .tagline h1 {
        text-align: center;
        margin-right: 0.5em;
        font-size: 1.8em;
        margin-top: 0.5em;
    }

    .tagline h3 {
        text-align: center;
        font-size: 1em;
        margin-right: 0.9em;
        margin-bottom: 3vw;
    }

    form {
        align-items: center;
    }

    .forgot-password a {
        margin-top: 1.2em;
        font-size: 1em;
    }

    .links {
        text-align: center;
        font-size: 0.80em;
    }

    .submit-wrapper button {
        border-radius: 10px;
        padding: 0.5em 1em;
    }

    .submit-wrapper p {
        font-size: 0.8em;
    }
}