/* Login Module */
.login-container {
    display: flex;
    flex-direction: column;
    background-color: var(--blanco);
    padding: 2rem;
    border-radius: var(--border-radius-md);
    box-shadow: var(--containerboxshadow);
    max-width: 400px;
}

.login-container img {
    max-width: 100%;
    display: block;
    margin: 0 auto;
}

.form-login{
    display: flex;
    flex-direction: column;
    width: 100%;

    .input-textbox{
        width: 100%;
        margin-top: 15px;
    }

    .login-button{
        margin-top: 30px;
    }

    .login-button-noseparate{
        margin-top: 10px;
    }

    .link-label{
        font-size: var(--fontsizesmallnotes);
        margin-top: 5px;
        text-align: right;

        a{
            color: var(--negro);
            text-decoration: none;

            &:hover{
                cursor: hand;
                color: var(--verde-principal);
            }
        }
    }
}

/* 2FA Verify */
.verify2fa-info {
    font-size: var(--fontsizesmallnotes);
    color: var(--negro);
    text-align: center;
    margin-top: 12px;
    line-height: 1.5;
}

.verify2fa-email {
    font-weight: 600;
    color: var(--verde-principal);
}

.verify2fa-trust {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
    font-size: var(--fontsizesmallnotes);
    color: var(--negro);
}

.verify2fa-resend {
    font-size: var(--fontsizesmallnotes);
    margin-top: 6px;
    text-align: center;

    a {
        color: var(--negro);
        text-decoration: none;

        &:hover {
            color: var(--verde-principal);
        }
    }
}

.pass-instructions{
    font-family: var(--fontfamilyroboto);
    font-size: var(--fontsizepassinstructions);
    color: var(--backcolornotiferror);
    text-align: center;
}

/* =========================================
   Login - Responsivo
   ========================================= */

/* Móvil vertical */
@media (max-width: 480px) {
    .login-container {
        width: 100%;
        max-width: 100%;
        min-height: 100vh;
        border-radius: 0;
        box-shadow: none;
        padding: 2rem 1.5rem;
        justify-content: center;
    }

    .login-container img {
        max-width: 200px;
        margin: 0 auto 1rem;
    }

    .form-login .login-button {
        margin-top: 20px;
    }

    .form-login .login-button .btn img {
        display: none;
    }
}

/* Móvil horizontal - layout logo+form en fila */
@media (max-height: 500px) and (orientation: landscape) {
    body {
        overflow-y: auto;
    }

    .login-container {
        flex-direction: row;
        align-items: center;
        gap: 2rem;
        width: auto;
        max-width: 94vw;
        min-height: unset;
        padding: 1.2rem 2rem;
        border-radius: var(--border-radius-md);
        box-shadow: var(--containerboxshadow);
    }

    /* Logo a la izquierda */
    .login-container img {
        width: 110px;
        max-width: 110px;
        flex-shrink: 0;
        margin: 0;
    }

    /* Formulario a la derecha */
    .login-container main {
        flex: 1;
        min-width: 0;
    }

    .form-login .input-textbox {
        margin-top: 6px;
    }

    .form-login .login-button {
        margin-top: 10px;
    }

    .form-login .login-button .btn {
        width: 100% !important;
    }

    .form-login .login-button .btn img {
        display: none;
    }

    .form-login .link-label {
        margin-top: 2px;
    }
}

/* iPad Air vertical (~820px) */
@media (min-width: 481px) and (max-width: 900px) and (orientation: portrait) {
    .login-container {
        width: 420px;
        max-width: 90vw;
        padding: 2.5rem 2rem;
    }

    .login-container img {
        max-width: 260px;
        margin: 0 auto 1rem;
    }

    .form-login .login-button .btn img {
        display: none;
    }
}

/* iPad Air horizontal (~1180×820px) */
@media (min-width: 901px) and (max-width: 1366px) and (orientation: landscape) {
    .login-container {
        width: 420px;
        padding: 2rem;
    }

    .login-container img {
        max-width: 240px;
        margin: 0 auto 1rem;
    }

    .form-login .login-button .btn img {
        display: none;
    }
}
