:root {
    --primary: #007236;
    --primary-50: #ecfff5;
    --primary-100: #d3ffe8;
    --primary-200: #aaffd3;
    --primary-300: #69ffb2;
    --primary-400: #21ff8a;
    --primary-500: #00f269;
    --primary-600: #00ca53;
    --primary-700: #009e44;
    --primary-900: #026532;
    --primary-950: #003919;

    --danger: #de3f3f;
    --danger-50: #fdf3f3;
    --danger-400: #ed7c7c;
    --danger-600: #cd3535;
    --danger-700: #ac1919;
    --green: #158114;

    --blue: #0d5cbd;
}

.login-container {
    padding-block: 2rem;
    padding-inline: 1rem;
    width: 100%;
    height: 100dvh;
    display: flex;
    justify-content: center;
    align-items: center;
}

.login-form {
    width: 100%;
    border: 2px solid #ccc;
    border-radius: .8rem;
    padding: 2rem 1.2rem;
}

.login-form-header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 1.5rem;
}

.login-form-header .logo-container {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 7rem;
    height: 7rem;
    aspect-ratio: 1/1;
    object-fit: cover;
    border-radius: 50%;
    background-color: #f0f0f0;
    padding: 1rem;
}

.logo-container img {
    width: 100%;
}

.login-form-header h2 {
    font-size: 2rem;
    font-family: montserratBold;
    opacity: .7;
}

.login-form-header p {
    font-size: .9rem;
    text-align: center;
    opacity: 0.6;
}

.form-group {
    margin-bottom: .5rem;
}

.form-group.input-group {
    position: relative;
}

.form-group.input-group i {
    position: absolute;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    font-size: 1.2rem;
    color: #111;
    padding: .5rem;
    cursor: pointer;
}

.login-input {
    width: 100%;
    font-size: 1rem;
    padding: .8rem .5rem;
    border: 1px solid #ccc;
    border-radius: .3rem;
    font-family: montserrat;
}

.login-input::placeholder {
    opacity: .8;
}

.form-button {
    margin-top: 1.5rem;
    margin-bottom: 1rem;
}

.login-button {
    all: unset;
    width: 100%;
    padding-block: .8rem;
    background-color: var(--primary);
    text-align: center;
    font-family: montserratBold;
    color: white;
    border-radius: .5rem;
    letter-spacing: .1rem;
    cursor: pointer;
}

.form-info {
    margin-bottom: 1rem;
}

.form-info a, .form-forgotten-password {
    text-decoration: none;
    color: var(--blue);
    font-family: montserratBold;
}

.form-forgotten-password-container {
    margin-top: 1.2rem;
}

.alert {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    border-radius: .5rem;
    margin-block: 1rem;
    color: white;
    font-size: .9rem;
}

.alert.alert-danger, .alert.alert-errors {
    border: 1px solid var(--danger-600);
    background-color: var(--danger-700);
}

.alert.alert-success {
    border: 1px solid var(--primary-700);
    background-color: var(--primary);
}

.cursor-pointer {
    cursor: pointer;
    font-size: 1.5rem;
    font-weight: bold;
}

.alert ul{
    padding-left: 1rem;
}


@media only screen and (min-width: 992px) {
    .login-form {
        width: 40%;
    }

    .form-group {
        margin-bottom: .8rem;
    }
}

