﻿/* ========================================================
   === ESTILOS LOGIN (motion elegante, robusto) ===
   ======================================================== */

/* ===== Tokens ===== */
:root {
    --navy: #0b2545;
    --azul: #00a7e1;
    --azul-400: #2fb7ef;
    --borde: rgba(11,46,91,.12);
    --e-out: cubic-bezier(.22,.61,.36,1);
    --e-soft: cubic-bezier(.16,.84,.44,1);
    --dur-fast: .28s;
    --dur-med: .50s;
    --dur-slow: .80s;
    --stagger: 80ms;
}

/* ===== Resets maestro ===== */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html, body {
    height: 100%;
    overflow-x: hidden; /* evita scroll lateral fantasma */
}

body {
    margin: 0 !important;
    padding: 0 !important;
    overflow-y: hidden;
    font-family: "Inter",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.mBody {
    padding: 0 !important;
    margin: 0 !important;
}

.container-fluid {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.row.login-container {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* ===== Layout ===== */
.login-container {
    min-height: 100svh;
    width: 100%;
    max-width: 100vw; /* asegura no exceder el viewport */
    overflow-x: hidden; /* evita scroll horizontal */
    display: flex;
    align-items: stretch;
    padding: 0;
    opacity: .001; /* evita FOUC pero permite calcular layout */
    transition: opacity var(--dur-slow) var(--e-soft);
}

html.fx .login-container {
    opacity: 1;
}

/* ===== Imagen con reveal moderno ===== */
.login-image {
    position: relative; /* ancla del ::after */
    flex: 0 0 50%;
    min-width: 0; /* evita desborde por min-content en flex */
    min-height: 100svh;
    height: 100svh;
    align-self: stretch;
    background: url('https://zeus.mxamro.com/images/plane.jpg') center center/cover no-repeat;
    margin: 0 !important;
    border: 0 !important;
    will-change: transform,opacity,clip-path;
    backface-visibility: hidden;
    overflow: hidden; /* el brillo no se sale y no genera scroll */
    opacity: 0;
    transform: translateX(-14px) scale(1.04) translateZ(0);
    clip-path: inset(0 12% 0 0 round 0);
    transition: opacity var(--dur-slow) var(--e-soft) .06s, transform var(--dur-slow) var(--e-soft) .06s, clip-path var(--dur-slow) var(--e-soft) .06s;
}

    /* velo de brillo que barre al entrar */
    .login-image::after {
        content: "";
        position: absolute;
        inset: 0;
        /* ancho extra para el barrido sin desbordar gracias a overflow:hidden */
        left: -40%;
        width: 140%;
        height: 100%;
        background: linear-gradient(115deg, rgba(255,255,255,0) 35%, rgba(255,255,255,.35) 50%, rgba(255,255,255,0) 65%);
        transform: translateX(-40%);
        opacity: 0;
        pointer-events: none;
        transition: transform .9s var(--e-soft) .08s, opacity .9s var(--e-soft) .08s;
    }

html.fx .login-image {
    opacity: 1;
    transform: translateX(0) scale(1) translateZ(0);
    clip-path: inset(0 0 0 0 round 0);
}

    html.fx .login-image::after {
        transform: translateX(120%);
        opacity: 1;
    }

/* ===== Columna del form ===== */
.login-form-col {
    flex: 0 0 50%;
    min-width: 0; /* previene desbordes de contenido dentro del flex */
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

/* ===== Card ===== */
.login-card {
    width: 100%;
    max-width: 520px;
    background: #fff;
    border-radius: 20px;
    border: 1px solid var(--borde);
    box-shadow: 0 18px 34px rgba(11,46,91,.14);
    padding: 28px 24px;
    min-height: 420px;
    opacity: 0;
    transform: translateY(14px) scale(.985) translateZ(0);
    transition: opacity var(--dur-med) var(--e-out) .14s, transform var(--dur-med) var(--e-out) .14s, box-shadow .3s var(--e-out);
}

html.fx .login-card {
    opacity: 1;
    transform: translateY(0) scale(1) translateZ(0);
}

.login-card:hover {
    box-shadow: 0 22px 40px rgba(11,46,91,.18);
}

.login-card .login-logo {
    width: 160px;
    max-width: 45%;
    display: block;
    margin: 0 auto 10px;
    filter: drop-shadow(0 4px 10px rgba(0,0,0,.08));
    opacity: 0;
    transform: translateY(8px);
    transition: opacity var(--dur-fast) var(--e-out) .22s, transform var(--dur-fast) var(--e-out) .22s;
}

html.fx .login-card .login-logo {
    opacity: 1;
    transform: none;
}

.login-card h2 {
    color: var(--navy);
    font-weight: 800;
    text-align: center;
    margin-bottom: 18px;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity var(--dur-fast) var(--e-out) .28s, transform var(--dur-fast) var(--e-out) .28s;
}

html.fx .login-card h2 {
    opacity: 1;
    transform: none;
}

/* ===== Campos con stagger ===== */
.login-card .form-group {
    margin-bottom: 14px;
    opacity: 0;
    transform: translateY(10px);
    will-change: transform,opacity;
}

    .login-card .form-group:nth-of-type(1) {
        transition: opacity var(--dur-fast) var(--e-out) calc(.34s + 0*var(--stagger)), transform var(--dur-fast) var(--e-out) calc(.34s + 0*var(--stagger));
    }

    .login-card .form-group:nth-of-type(2) {
        transition: opacity var(--dur-fast) var(--e-out) calc(.34s + 1*var(--stagger)), transform var(--dur-fast) var(--e-out) calc(.34s + 1*var(--stagger));
    }

html.fx .login-card .form-group {
    opacity: 1;
    transform: none;
}

.login-card label {
    color: var(--navy);
    font-weight: 600;
    margin-bottom: .35rem;
    display: block;
}

.input-wrapper {
    position: relative;
    width: 100%;
}

/* Inputs 32px + microinteracciones */
.form-control {
    height: 32px;
    line-height: 1.05;
    border-radius: 8px;
    border: 1px solid rgba(11,46,91,.18);
    background: #f6f9ff;
    padding: .4rem .6rem;
    width: 100%;
    transition: border-color .2s var(--e-out), box-shadow .2s var(--e-out), transform .1s var(--e-out), background-color .2s var(--e-out);
}

    .form-control:hover {
        background: #f2f7ff;
    }

    .form-control:focus {
        border-color: var(--azul);
        box-shadow: 0 0 0 .18rem rgba(0,166,233,.16);
        outline: 0;
        transform: translateY(-1px);
    }

    .form-control.has-eye {
        padding-right: 40px;
    }

/* Botón ojo */
.btn-eye {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    border: none;
    border-radius: 10px;
    background: transparent;
    cursor: pointer;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 18px 18px;
    transition: transform .12s var(--e-out), background-image .12s linear, opacity .12s linear;
    opacity: .9;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%230b2e5b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8Z'/><circle cx='12' cy='12' r='3'/></svg>");
}

    .btn-eye:hover {
        transform: translateY(-50%) scale(1.05);
        opacity: 1;
    }

    .btn-eye.on {
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%230b2e5b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M17.94 17.94A10.94 10.94 0 0 1 12 20C5 20 1 12 1 12a21.8 21.8 0 0 1 5.06-6.94M9.9 4.24A10.94 10.94 0 0 1 12 4c7 0 11 8 11 8a21.82 21.82 0 0 1-3.87 5.15M9 9l6 6M3 3l18 18'/></svg>");
    }

/* Botón principal */
.button {
    display: block;
    width: 100%;
    border: none;
    border-radius: 10px;
    padding: .7rem 1rem;
    font-weight: 800;
    letter-spacing: .3px;
    color: #fff;
    background: linear-gradient(135deg,var(--azul),var(--azul-400));
    box-shadow: 0 16px 28px rgba(0,166,233,.28);
    text-decoration: none;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity var(--dur-fast) var(--e-out) calc(.34s + 2*var(--stagger)), transform var(--dur-fast) var(--e-out) calc(.34s + 2*var(--stagger)), box-shadow .2s var(--e-out), filter .2s var(--e-out);
}

html.fx .button {
    opacity: 1;
    transform: none;
}

.button:hover {
    filter: saturate(1.06) brightness(1.02);
    box-shadow: 0 20px 34px rgba(0,166,233,.34);
    transform: translateY(-1px);
}

.button:active {
    transform: translateY(1px);
}

/* Helpers / link */
.helper {
    text-align: center;
    margin-top: 10px;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity var(--dur-fast) var(--e-out) calc(.34s + 3*var(--stagger)), transform var(--dur-fast) var(--e-out) calc(.34s + 3*var(--stagger));
}

html.fx .helper {
    opacity: 1;
    transform: none;
}

.link-forgot {
    background: none;
    border: 0;
    cursor: pointer;
    color: #0b2545;
    text-decoration: underline;
    transition: opacity .2s var(--e-out);
}

    .link-forgot:hover {
        opacity: .85;
    }

/* ===== Responsive ===== */
@media (max-width:991.98px) {
    .login-image {
        display: none;
    }

    .login-form-col {
        flex: 1 1 auto;
        padding: 20px;
    }

    .login-card {
        min-height: auto;
    }
}

/* Si no hay navbar, quita espacios del contenido bajo el nav */
.main-navbar + .mBody {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* ===== Accesibilidad ===== */
@media (prefers-reduced-motion: reduce) {
    * {
        animation: none !important;
        transition: none !important;
    }

    .login-container, .login-image, .login-card, .login-card .login-logo,
    .login-card h2, .login-card .form-group, .button, .helper {
        opacity: 1 !important;
        transform: none !important;
        clip-path: none !important;
    }
}


/* Help text discreto para metadatos como versión */
.helptext {
    display: block;
    margin-top: 6px;
    font-size: .82rem; /* pequeño */
    line-height: 1.2;
    color: #64748b; /* gris azulado legible */
    text-align: right; /* alineado a la derecha dentro del panel */
    letter-spacing: .2px;
    user-select: text;
    word-break: break-word;
}

/* ========================================================
   === FIN ESTILOS LOGIN ===
   ======================================================== */
