.login-page {
    min-height: 100vh;
    margin: 0;
    position: relative;
    overflow-x: hidden;
    font-family: "Plus Jakarta Sans", "Poppins", sans-serif;
    background: linear-gradient(135deg, var(--cor-primaria-background-tela-login) 0%, var(--cor-azul-escuro) 56%, var(--cor-primaria-background-tela-login) 100%);
}

.login-page::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 15% 18%, rgba(255, 255, 255, .06), transparent 34%),
        radial-gradient(circle at 88% 80%, rgba(255, 255, 255, .05), transparent 32%);
}

.login-background-pattern {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image:
        linear-gradient(90deg, rgba(255, 255, 255, .035) 1px, transparent 1px),
        linear-gradient(rgba(255, 255, 255, .035) 1px, transparent 1px);
    background-size: 56px 40px;
    animation: loginGridMove 26s linear infinite;
}


.legal-icons-container,
.geometric-shapes {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.planet-layer {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
}

.planet {
    position: absolute;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .16);
    box-shadow: 0 0 0 8px rgba(255, 255, 255, .03);
}

.planet-earth {
    width: 86px;
    height: 86px;
    right: 12%;
    top: 16%;
    background: radial-gradient(circle at 30% 35%, rgba(163, 199, 225, .5), rgba(5, 59, 140, .16) 58%, transparent 100%);
    animation: orbitFloat 18s ease-in-out infinite;
}

.planet-land {
    width: 58px;
    height: 58px;
    left: 10%;
    bottom: 14%;
    background: radial-gradient(circle at 35% 30%, rgba(163, 199, 225, .44), rgba(5, 59, 140, .15) 62%, transparent 100%);
    animation: orbitFloat 14s ease-in-out infinite reverse;
}

.legal-icon {
    position: absolute;
    font-size: 1.05rem;
    color: rgba(255, 255, 255, .09);
    animation: legalFloat 11s ease-in-out infinite;
    filter: drop-shadow(0 1px 2px rgba(1, 18, 36, .35));
}

.shape {
    position: absolute;
    border: 1px solid rgba(255, 255, 255, .12);
}

.shape-circle {
    width: 116px;
    height: 116px;
    border-radius: 999px;
    top: 17%;
    right: 10%;
    animation: spinSlow 28s linear infinite;
}

.shape-square {
    width: 68px;
    height: 68px;
    border-radius: 10px;
    left: 10%;
    bottom: 12%;
    animation: spinSlowReverse 22s linear infinite;
}

.login-growl {
    position: relative;
    z-index: 4;
}

.login-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    position: relative;
    z-index: 2;
}

.login-single-card {
    width: min(100%, 480px);
    border-radius: 24px;
    border: 1px solid rgba(255, 255, 255, .15);
    background: linear-gradient(180deg, rgba(12, 35, 66, .8), rgba(5, 27, 57, .72));
    backdrop-filter: blur(10px);
    box-shadow: 0 26px 52px rgba(1, 18, 36, .52);
    padding: 2rem 1.8rem 1.45rem;
}

.login-logo-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 1.35rem;
}

.login-logo-main {
    width: min(100%, 360px);
    height: auto;
}

.login-header {
    margin-bottom: 1.15rem;
}

.login-form-title {
    margin: 0;
    color: var(--cerurb-white);
    font-size: 1.28rem;
    font-weight: 700;
    line-height: 1.2;
}

.login-form-description {
    margin: .45rem 0 0;
    color: rgba(255, 255, 255, .84);
    font-size: .9rem;
    line-height: 1.45;
}

.login-floating {
    margin-bottom: .95rem;
    position: relative;
}

.login-floating > .form-control {
    min-height: 59px;
    padding: 1.2rem 2.8rem 0.36rem 0.96rem;
    border-radius: 12px;
    border: 1px solid rgba(163, 199, 225, .42);
    background: rgba(255, 255, 255, .97);
    color: var(--cor-azul-escuro);
    box-shadow: 0 3px 10px rgba(5, 59, 140, .12);
    transition: border-color .22s ease, box-shadow .22s ease, transform .2s ease;
}

.login-floating > .form-control:focus {
    border-color: var(--cor-azul-primaria);
    box-shadow: 0 0 0 .2rem rgba(5, 59, 140, .18);
    transform: translateY(-1px);
}

.login-floating > label {
    padding: .88rem .95rem;
    color: rgba(12, 35, 66, .8);
    font-size: .87rem;
    font-weight: 600;
    pointer-events: none;
}

/* Corrige contraste e leitura do label (Login/Senha) */
.login-floating > .form-control:focus ~ label,
.login-floating > .form-control:not(:placeholder-shown) ~ label {
    color: var(--cor-azul-primaria) !important;
    opacity: 1 !important;
    font-weight: 700;
}

.login-floating > .form-control::placeholder {
    color: transparent;
}

.login-password-toggle {
    position: absolute;
    top: 50%;
    right: .75rem;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 8px;
    background: rgba(5, 59, 140, .1);
    color: var(--cor-azul-primaria);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all .2s ease;
    z-index: 3;
    pointer-events: auto;
}

.login-password-toggle:hover,
.login-password-toggle:focus {
    background: rgba(5, 59, 140, .2);
    color: var(--cor-azul-escuro);
    outline: none;
}

.login-links-row {
    margin: .4rem 0 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: .6rem;
}

.login-link {
    color: var(--cerurb-light-blue);
    font-size: .82rem;
    font-weight: 600;
    text-decoration: none;
    transition: opacity .2s ease, color .2s ease;
}

.login-link:hover {
    color: var(--cerurb-white);
    opacity: .95;
}

.login-submit {
    width: 100%;
    height: 47px;
    border-radius: 12px;
    border: 1px solid var(--cor-azul-primaria);
    background: var(--cor-azul-primaria);
    color: var(--cerurb-white);
    font-size: .95rem;
    font-weight: 700;
    letter-spacing: .01em;
    transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
}

.login-submit:hover,
.login-submit:focus {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(5, 59, 140, .34);
    filter: brightness(1.03);
}

.login-support {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 4;
}

.login-support-link {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border-radius: 999px;
    border: 1px solid var(--cor-azul-primaria);
    background: var(--cor-azul-primaria);
    color: var(--cerurb-white);
    text-decoration: none;
    font-weight: 700;
    font-size: .84rem;
    padding: .55rem .92rem;
    box-shadow: 0 8px 18px rgba(5, 59, 140, .32);
}

.login-support-link:hover {
    color: var(--cerurb-white);
    filter: brightness(1.04);
}

/* ============================
   AUTH PAGES (cadastro/redefinir)
   ============================ */
.auth-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.6rem 1rem 5rem;
    position: relative;
    z-index: 2;
}

.auth-card {
    width: min(980px, 94vw);
    border-radius: 22px;
    border: 1px solid rgba(163, 199, 225, .28);
    background: linear-gradient(180deg, rgba(12, 35, 66, .8), rgba(5, 27, 57, .72));
    backdrop-filter: blur(8px);
    box-shadow: 0 26px 52px rgba(1, 18, 36, .45);
    padding: 1.4rem 1.4rem 1.1rem;
}

.auth-card-narrow {
    width: min(760px, 96vw);
}

.auth-logo-wrap {
    display: flex;
    justify-content: center;
    margin: .2rem 0 .85rem;
}

.auth-logo-main {
    width: min(100%, 360px);
    height: auto;
}

.auth-title {
    margin: 0;
    text-align: center;
    color: var(--cerurb-white);
    font-size: 1.45rem;
    font-weight: 700;
}

.auth-subtitle {
    margin: .4rem 0 1.15rem;
    text-align: center;
    color: rgba(244, 247, 254, .86);
    font-size: .92rem;
}

.auth-form-wrap .form-group,
.auth-form-wrap .mp-form-group {
    margin-bottom: .9rem;
    position: relative;
}

.auth-form-wrap .ui-outputlabel,
.auth-form-wrap label {
    color: rgba(244, 247, 254, .9) !important;
    font-size: .86rem !important;
    font-weight: 700 !important;
    margin-bottom: .28rem !important;
}

.auth-form-wrap .form-control,
.auth-form-wrap .ui-inputtext,
.auth-form-wrap .ui-inputfield,
.auth-form-wrap .ui-inputmask {
    min-height: 46px !important;
    border-radius: 10px !important;
    border: 1px solid rgba(5, 59, 140, .25) !important;
    background: rgba(255, 255, 255, .98) !important;
    color: var(--cor-azul-escuro) !important;
    font-size: .93rem !important;
    font-weight: 600 !important;
    box-shadow: 0 3px 10px rgba(5, 59, 140, .08) !important;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease !important;
}

.auth-form-wrap .form-control:focus,
.auth-form-wrap .ui-inputtext:focus,
.auth-form-wrap .ui-inputfield:focus,
.auth-form-wrap .ui-inputmask:focus,
.auth-form-wrap .ui-inputtext.ui-state-focus,
.auth-form-wrap .ui-inputfield.ui-state-focus {
    border-color: var(--cor-azul-primaria) !important;
    box-shadow: 0 0 0 .2rem rgba(5, 59, 140, .16) !important;
    transform: translateY(-1px);
}

.auth-form-wrap .ui-tabs {
    border: 1px solid rgba(163, 199, 225, .22) !important;
    border-radius: 12px !important;
    overflow: hidden;
    background: rgba(255, 255, 255, .06) !important;
}

.auth-form-wrap .ui-tabs .ui-tabs-nav {
    background: rgba(163, 199, 225, .14) !important;
    border: none !important;
}

.auth-form-wrap .ui-tabs .ui-tabs-nav li a {
    color: rgba(244, 247, 254, .9) !important;
    font-weight: 700 !important;
}

.auth-form-wrap .ui-tabs .ui-tabs-nav li.ui-state-active a {
    color: var(--cerurb-white) !important;
}

.auth-form-wrap .ui-tabs .ui-tabs-nav li.ui-state-active {
    background: rgba(5, 59, 140, .5) !important;
    border-radius: 8px !important;
}

.auth-form-wrap .ui-tabs .ui-tabs-panel {
    background: transparent !important;
}

.auth-form-wrap .form-control::placeholder,
.auth-form-wrap .ui-inputtext::placeholder,
.auth-form-wrap .ui-inputfield::placeholder {
    color: transparent !important;
    opacity: 0 !important;
    font-weight: 500 !important;
}

/* Floating label para telas de cadastro/redefinir */
.auth-form-wrap .auth-float-group .auth-float-label {
    position: absolute;
    top: 14px;
    left: 12px;
    margin: 0 !important;
    color: rgba(12, 35, 66, .6) !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    pointer-events: none;
    transition: all .18s ease;
    z-index: 2;
}

.auth-form-wrap .auth-float-group .form-control,
.auth-form-wrap .auth-float-group .ui-inputtext,
.auth-form-wrap .auth-float-group .ui-inputfield,
.auth-form-wrap .auth-float-group .ui-inputmask {
    padding-top: 1.2rem !important;
    padding-bottom: .32rem !important;
}

.auth-form-wrap .auth-float-group.is-active .auth-float-label {
    top: 4px;
    font-size: .68rem !important;
    color: var(--cor-azul-primaria) !important;
    font-weight: 700 !important;
}

.auth-actions {
    text-align: center;
    margin-top: .55rem;
}

.auth-actions .ui-button {
    min-width: 180px;
}

.auth-bottom-link {
    margin-top: .75rem;
    text-align: right;
}

.auth-bottom-link a {
    color: var(--cerurb-light-blue);
    font-weight: 700;
    font-size: .84rem;
    text-decoration: none;
}

.auth-bottom-link a:hover {
    opacity: .9;
}

/* Cadastro usa apenas uma aba; esconde a barra para evitar faixa visual feia */
.auth-cadastro-form .ui-tabs .ui-tabs-nav {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
    background: transparent !important;
}

.auth-cadastro-form .ui-tabs .ui-tabs-panels,
.auth-cadastro-form .ui-tabs .ui-tabs-panel {
    border-top: none !important;
    padding-top: 0 !important;
}

.auth-cadastro-form .ui-tabs.ui-tabs-top > .ui-tabs-nav {
    display: none !important;
}

.auth-cadastro-form .ui-tabs.ui-tabs-top > .ui-tabs-panels {
    border-top: none !important;
}

.login-error-banner {
    display: flex;
    align-items: center;
    gap: .5rem;
    border: 1px solid rgba(163, 28, 28, .35);
    background: rgba(161, 34, 34, .16);
    color: #fee2e2;
    border-radius: 10px;
    padding: .6rem .75rem;
    margin-bottom: .9rem;
    font-size: .84rem;
    font-weight: 600;
}

@media (max-width: 576px) {
    .login-shell {
        padding: 1rem .7rem 5rem;
    }

    .login-single-card {
        padding: 1.5rem .95rem 1rem;
        border-radius: 18px;
    }

    .login-logo-main {
        width: min(100%, 290px);
    }

    .login-links-row {
        flex-direction: column;
        align-items: flex-start;
    }
}

@keyframes loginGridMove {
    from {
        background-position: 0 0, 0 0;
    }
    to {
        background-position: 56px 40px, 56px 40px;
    }
}

@keyframes legalFloat {
    0%, 100% {
        transform: translateY(0) rotate(0deg);
        opacity: .09;
    }
    50% {
        transform: translateY(-14px) rotate(3deg);
        opacity: .18;
    }
}

/* Pulso suave para icones tematicos de fundo */
.legal-icon.icon-land {
    animation: legalFloat 11s ease-in-out infinite, iconPulse 6s ease-in-out infinite;
}

@keyframes iconPulse {
    0%, 100% {
        opacity: .1;
    }
    50% {
        opacity: .2;
    }
}

@keyframes spinSlow {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

@keyframes spinSlowReverse {
    from {
        transform: rotate(360deg);
    }
    to {
        transform: rotate(0deg);
    }
}

@keyframes orbitFloat {
    0%, 100% {
        transform: translateY(0) scale(1);
        opacity: .92;
    }
    50% {
        transform: translateY(-8px) scale(1.04);
        opacity: 1;
    }
}

