:root {
    --qntax-color-login-body: var(--qntax-color-primary);
}

html {
    overflow-y: hidden !important;

    body {
        background-color: var(--qntax-color-login-body);
        overflow: hidden;
    }
}

.grid-login {
    display: grid;
    grid-template-columns: 1fr 1fr;
    height: 100%;
    width: 100%;
    gap: 10%;
}

.grid-login-container {
    height: 100vh;
    width: 100vw;
    overflow: hidden;
    display: grid;
    align-items: center;

    .container {
        max-width: 96.875rem;
    }
}

.ilustration-login {
    background-image: url('./ilustration-1.png');
    height: 40.625rem;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    margin: 0;
}

.card {
    justify-content: center;
    align-items: center;

    .card-body {
        max-width: 37.5rem;
        width: 100%;
        background-color: var(--qntax-color-card);
        padding: 4.75rem;

        .card-title {
            font-size: 1.25rem;
            color: var(--qntax-color-card-title);

            h5 {
                word-spacing: 0.25rem;
            }
        }

        p.card-subtitle {
            font-size: 1rem;
            font-weight: 400;
            text-align: center;
            color: var(--qntax-color-card-subtitle);
        }
    }

    a {
        font-size: 1rem;
    }
}

.form-control {
    border: 1px solid var(--qntax-color-border-input);
}

.form-group {
    label {
        color: var(--qntax-color-label-input);
        font-size: 1rem;
        font-weight: 500;
    }
}

.form-group+.form-group {
    border-top: none;
}

@media (max-width: 768px) {
    .grid-login {
        grid-template-columns: 1fr;
        gap: 0;
        justify-items: center;
    }

    /* Hide illustration/left side on small screens */
    .left-side,
    .ilustration-login {
        display: none;
    }

    .grid-login-container {
        min-height: 100vh;
        height: auto;
        display: grid;
        place-items: center;
        overflow: auto;
        padding: 1rem;
    }

    .right-side {
        width: 100%;
        max-width: 37.5rem;
        justify-self: center;
    }

    .card .card-body {
        max-width: 100%;
        width: 100%;
        max-height: none;
        padding: 1.5rem;
    }

    html {
        overflow-y: auto !important;
    }

    html body {
        overflow: auto;
    }
}

@media (max-width: 991.98px) {
    .grid-login {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .left-side,
    .ilustration-login {
        display: none;
    }
}

@media (min-width: 992px) {
    .grid-login {
        grid-template-columns: 1fr 1fr;
        gap: 10%;
    }

    .left-side {
        display: block;
    }

    .card .card-body {
        padding: 3rem;
    }
}