/**
 * Login SAP — folha isolada (apenas auth/login).
 * Sem style.css / login-custom.css: evita conflitos de .page e .formLogin.
 */

:root {
    --login-bg-blue: #0d4f8c;
    /* +25% face a min(78dvh, 720px) → min(97.5dvh, 900px) */
    --login-card-max-h: min(97.5dvh, 900px);
    /* Espaço livre acima da taskbar fixa (altura típica + folga; evita sobrepor a barra) */
    --login-taskbar-pad: max(56px, calc(52px + env(safe-area-inset-bottom, 0px)));
    /* Folga visual entre o bloco login e a taskbar — proporcional à altura do ecrã */
    --login-above-taskbar-gap: clamp(6px, 1.2vh, 18px);
}

/* ---------- Base ---------- */
.login-app {
    margin: 0;
    min-height: 100vh;
    min-height: 100dvh;
    overflow-x: hidden;
    overflow-y: auto;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
    background-color: var(--login-bg-blue);
    background-image: url("../img/tela_azul.jpg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #1a1a1a;
    -webkit-font-smoothing: antialiased;
    box-sizing: border-box;
}

.login-app *,
.login-app *::before,
.login-app *::after {
    box-sizing: border-box;
}

/* Área principal: bloco ancorado em baixo; conteúdo alinhado à direita (não centrado) */
.login-app__shell {
    min-height: 100vh;
    min-height: 100dvh;
    min-height: 100svh;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-end;
    padding-left: clamp(8px, 2.5vw, 24px);
    padding-right: clamp(16px, 4vw, 56px);
    /* Pouco espaço no topo (evita “flutuar” ao centro em ecrãs altos, ex.: 1080×1920) */
    padding-top: max(env(safe-area-inset-top, 0px), clamp(8px, 2.5vh, 36px));
    padding-bottom: calc(var(--login-taskbar-pad) + var(--login-above-taskbar-gap));
}

.login-app__main {
    width: 100%;
    min-width: 0;
}

/* Linha hero + cartão: à direita, com folga à borda (padding no .login-app__shell) */
.login-app__row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-end;
    gap: clamp(8px, 2vw, 32px);
    width: 100%;
    min-width: 0;
}

.login-app__hero {
    flex: 0 1 auto;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-app__hero-img {
    display: block;
    width: clamp(56px, 24vw, 360px);
    max-width: 100%;
    height: auto;
    max-height: min(300px, max(120px, min(36vh, 38dvh)));
    object-fit: contain;
}

/* Só desktop: faixa dentro do cartão fica oculta */
.login-app__hero--in-card {
    display: none;
}

.login-app__column {
    flex: 1 1 220px;
    min-width: 0;
    max-width: 420px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(8px, 1.2vw, 14px);
}

/* Mobile: ilustração entra no cartão (entre logos e formulário); ao lado some */
@media (max-width: 768px) {
    .login-app__row {
        flex-direction: column;
        align-items: flex-end;
        gap: clamp(8px, 2.5vw, 18px);
    }

    .login-app__hero--beside {
        display: none !important;
    }

    .login-app__hero--in-card {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        padding: 6px 14px 10px;
        background: #fafafa;
        border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    }

    .login-app__hero--in-card .login-app__hero-img {
        width: auto;
        max-width: min(92%, 280px);
        max-height: min(30vh, 210px);
    }

    .login-app__column {
        flex: 0 1 auto;
        flex-basis: auto;
        width: min(420px, 100%);
        max-width: min(420px, 100%);
        align-self: flex-end;
    }
}

/* Cartão */
.login-app__card {
    width: 100%;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.login-app__card-body {
    flex: 1 1 auto;
    padding: clamp(14px, 3.2vw, 26px);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    max-height: var(--login-card-max-h);
    min-height: 0;
    border-style: solid;
    border-width: 0 0 5px 0;
    border-color: transparent;
    border-image-source: linear-gradient(90deg, #f9b233, #3ec6e0, #4bb543);
    border-image-slice: 1;
}

.login-app__header {
    text-align: center;
    margin-bottom: 12px;
}

.login-app__brand {
    width: clamp(72px, 20vw, 118px);
    height: auto;
    display: inline-block;
}

/* Alertas */
.login-app .alert {
    padding: 12px 14px;
    margin-bottom: 12px;
    border: 1px solid transparent;
    border-radius: 8px;
    font-size: 0.98rem;
    transition: opacity 0.2s ease;
}

.login-app .alert-error {
    color: #721c24;
    background-color: #f8d7da;
    border-color: #f5c6cb;
    animation: login-app-shake 0.45s ease-in-out;
}

.login-app .alert-success {
    color: #155724;
    background-color: #d4edda;
    border-color: #c3e6cb;
}

.login-app .alert-warning {
    color: #856404;
    background-color: #fff3cd;
    border-color: #ffeeba;
}

.login-app .alert p {
    margin: 0;
    padding: 0;
}

.login-app .alert strong {
    display: block;
    margin-bottom: 4px;
    font-weight: 600;
}

.login-app .alert .alert-icon {
    margin-right: 8px;
    font-size: 1.2em;
    vertical-align: middle;
}

@keyframes login-app-shake {
    0%, 100% { transform: translateX(0); }
    20%, 60% { transform: translateX(-4px); }
    40%, 80% { transform: translateX(4px); }
}

.login-app .error-message {
    color: #dc3545;
    font-size: 0.88rem;
    margin-top: 4px;
    display: block;
}

.login-app .form-group.has-error input {
    border-color: #dc3545;
    background-color: #fff8f8;
}

/* Formulário */
.login-app__form {
    width: 100%;
    margin-top: 6px;
}

.login-app .form-group {
    margin-bottom: clamp(8px, 1.5vw, 14px);
    width: 100%;
}

.login-app .form-group label {
    display: block;
    margin-bottom: 4px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #333;
}

.login-app .form-group input[type="text"],
.login-app .form-group input[type="password"],
.login-app .form-group input[type="email"] {
    width: 100%;
    padding: 10px 12px;
    font-size: 1rem;
    border: 1px solid #ccc;
    border-radius: 8px;
    font-family: inherit;
}

.login-app .form-group input[type="text"]:focus,
.login-app .form-group input[type="password"]:focus,
.login-app .form-group input[type="email"]:focus {
    outline: none;
    border-color: #2e5169;
    box-shadow: 0 0 0 3px rgba(46, 81, 105, 0.2);
}

.login-app .form-group small.text-muted {
    display: block;
    font-size: 0.82rem;
    color: #666;
    margin-top: 4px;
    line-height: 1.3;
}

.login-app .login-form-check-row {
    margin-bottom: 8px;
}

.login-app .form-group input[type="checkbox"] {
    margin-right: 8px;
    vertical-align: middle;
}

.login-app .form-group input[type="checkbox"] + label {
    display: inline;
    font-size: 0.88rem;
    font-weight: 500;
    cursor: pointer;
    vertical-align: middle;
}

.login-app .btn-acesso {
    width: 100%;
    background: #0056b3;
    color: #fff;
    font-weight: 700;
    font-size: 1.05rem;
    border-radius: 8px;
    padding: 12px 14px;
    margin: 10px 0 6px;
    border: none;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.2s ease;
}

.login-app .btn-acesso:hover {
    background: #003a75;
}

.login-app__links {
    text-align: center;
    margin-top: 6px;
}

.login-app .link-senha {
    color: #0056b3;
    text-decoration: underline;
    font-size: 0.95rem;
    white-space: nowrap;
}

.login-app .link-senha:hover {
    color: #003a75;
}

/* Logos TEA / Foccus — primeiro bloco dentro do cartão */
.login-app__logos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: clamp(12px, 2vw, 22px);
    padding: 12px clamp(12px, 3vw, 20px);
    flex-shrink: 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    background: #fafafa;
    border-radius: 18px 18px 0 0;
}

.login-app__logos img {
    height: clamp(26px, 5vw, 40px);
    max-width: min(100px, 28vw);
    object-fit: contain;
}

/*
 * Faixa mantida no layout (evita o cartão “descer” se removida do DOM).
 * Conteúdo invisível; o suporte continua na taskbar.
 */
.login-app__support-strip {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 8px;
    padding: 4px 2px;
    visibility: hidden;
    pointer-events: none;
    user-select: none;
}

.login-app__support-text {
    color: rgba(255, 255, 255, 0.95);
    font-family: Roboto, Arial, sans-serif;
    font-size: clamp(11px, 2.8vw, 15px);
    word-break: break-all;
    text-align: right;
    line-height: 1.25;
    min-width: 0;
}

.login-app .btn-copiar-email-suporte {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 0.85rem;
    font-weight: 600;
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
    border: 1px solid rgba(255, 255, 255, 0.45);
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
}

.login-app .btn-copiar-email-suporte:hover {
    background: rgba(255, 255, 255, 0.32);
}

/* Toast (copiar / aviso) */
.notificacao {
    position: fixed;
    top: 16px;
    right: 16px;
    left: auto;
    max-width: min(360px, calc(100vw - 32px));
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 0.95rem;
    color: #fff;
    display: none;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.2);
    transition: opacity 0.35s ease;
    z-index: 10000;
}

.notificacao.sucesso {
    background-color: #28a745;
    display: block;
}

.notificacao.erro {
    background-color: #dc3545;
    display: block;
}

/* ---------- Taskbar (footer fixo) ---------- */
.login-app .taskbar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    min-height: 48px;
    height: auto;
    background: #0056b3;
    border-top: 1px solid rgba(255, 255, 255, 0.22);
    z-index: 1000;
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

.login-app .taskbar--login {
    box-sizing: border-box;
}

.login-app .taskbar--login .taskbar-content {
    justify-content: stretch;
    align-items: center;
    padding: 6px max(10px, env(safe-area-inset-right, 10px)) 6px max(10px, env(safe-area-inset-left, 10px));
}

.login-app .taskbar-content {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 48px;
    max-width: 100%;
    padding: 8px 16px;
}

.login-app .taskbar-support {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    width: 100%;
    font-size: 12px;
    line-height: 1.35;
}

/* Esquerda: Suporte Técnico + WhatsApp | Direita: e-mail + Copiar */
.login-app .taskbar-support--login-split {
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px 12px;
}

.login-app .taskbar-support-wa-block {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 10px;
    min-width: 0;
    flex: 0 1 auto;
}

.login-app .taskbar-support-tech-label {
    color: #fff;
    font-family: Roboto, Arial, sans-serif;
    font-size: clamp(11px, 2.4vw, 15px);
    font-weight: 600;
    line-height: 1.35;
    white-space: nowrap;
}

.login-app .taskbar-support-wa-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #fff;
    font-family: Roboto, Arial, sans-serif;
    font-size: clamp(11px, 2.4vw, 15px);
    font-weight: 500;
    line-height: 1.35;
    text-decoration: none;
    white-space: nowrap;
}

.login-app .taskbar-support-wa-link i {
    color: #afffc9;
    font-size: 1.1em;
}

.login-app .taskbar-support-wa-link:hover {
    color: #e8f4ff;
    text-decoration: underline;
}

.login-app .taskbar-support-wa-link:hover i {
    color: #fff;
}

.login-app .taskbar--login .taskbar-support-email-row {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 10px;
    min-width: 0;
    flex: 1 1 auto;
    max-width: 100%;
}

.login-app .taskbar--login .taskbar-support-email-text {
    color: #fff;
    font-family: Roboto, Arial, sans-serif;
    font-size: clamp(12px, 2.6vw, 16px);
    font-weight: 400;
    line-height: 1.35;
    word-break: break-all;
    text-align: right;
    min-width: 0;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* Janelas baixas: compactar; mantém ancoragem em baixo */
@media (max-height: 700px) {
    :root {
        --login-card-max-h: min(87.5dvh, 700px);
        --login-above-taskbar-gap: clamp(4px, 1vh, 10px);
    }

    .login-app__hero-img {
        max-height: min(22vh, 160px);
    }

    .login-app__shell {
        padding-top: max(4px, env(safe-area-inset-top, 0px));
    }

    .login-app .form-group small.text-muted {
        font-size: 0.78rem;
    }
}

@media (max-height: 560px) {
    .login-app__hero-img {
        max-height: min(18vh, 110px);
        width: clamp(48px, 18vw, 220px);
    }

    .login-app__header {
        margin-bottom: 6px;
    }

    .login-app .form-group {
        margin-bottom: 6px;
    }

    .login-app .form-group small.text-muted {
        display: none;
    }
}

/* Telas estreitas: mantém linha; reduz faixas */
@media (max-width: 420px) {
    .login-app__row {
        gap: 4px;
    }

    /* Em desktop muito estreito ainda há hero ao lado; em mobile afeta só a cópia no card */
    .login-app__hero--beside .login-app__hero-img {
        width: clamp(48px, 20vw, 120px);
        max-height: min(24vh, 140px);
    }

    .login-app__hero--in-card .login-app__hero-img {
        max-height: min(26vh, 160px);
        max-width: min(92%, 240px);
    }

    .login-app__column {
        flex-basis: auto;
    }

    .login-app .taskbar--login .taskbar-support-email-text {
        font-size: 12px;
    }

    .login-app .taskbar-support-tech-label,
    .login-app .taskbar-support-wa-link {
        white-space: normal;
    }
}

/* Barra: em larguras médias-baixas, e-mail passa para linha completa por baixo (sem alterar layout principal) */
@media (max-width: 520px) {
    .login-app .taskbar--login .taskbar-support-email-row {
        flex-basis: 100%;
        justify-content: flex-end;
    }
}

@media (max-width: 360px) {
    .login-app__shell {
        padding-left: 6px;
        padding-right: 6px;
    }
}
