*{
    box-sizing:border-box;
    margin:0;
    padding:0;
    font-family:Arial,sans-serif;
}

body{
    min-height:100vh;
    background:#eef3f6;
    color:#1f2933;
}

.login-page{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:28px;
    background: #447c9b;
}

.login-shell{
    width:100%;
    max-width:980px;
    display:grid;
    grid-template-columns:1fr 420px;
    align-items:center;
    gap:40px;
}

.login-brand{
    display:flex;
    align-items:center;
    justify-content:center;
    color:#447c9b;
    padding:30px;
    min-height:300px;
}

/* LOGO COPIADA DA PÁGINA INICIAL */
.logo-texto{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:15px;
}

.titulo-principal{
    font-family:'Comfortaa', sans-serif;
    font-weight:bold;
    font-size:70px;
    margin:0;
}

.subtitulo{
    text-align:left;
    font-family:'Comfortaa', sans-serif;
    font-weight:normal;
    font-size:25px;
    margin:0;
}

.logo-texto{
    opacity:0;
    animation:aparecerSuave 1s ease forwards;
}

.titulo-principal{
    opacity:0;
    animation:aparecerSuave 1s ease forwards;
}

.subtitulo{
    opacity:0;
    animation:aparecerSuave 1s ease forwards;
    animation-delay:.3s;
}

@keyframes aparecerSuave{
    from{
        opacity:0;
        transform:translateY(-40px);
    }
    to{
        opacity:1;
        transform:translateY(0);
    }
}

.login-logo-texto,
.login-logo-texto .titulo-principal,
.login-logo-texto .subtitulo{
    color:#447c9b;
}

.login-card{
    background:rgba(255,255,255,.94);
    border:1px solid rgba(255,255,255,.8);
    border-radius:28px;
    padding:34px;
    box-shadow:0 24px 70px rgba(27,55,75,.14);
    backdrop-filter:blur(10px);
}

.login-card h1{
    font-size:28px;
    color:#21313c;
    margin-bottom:8px;
}

.login-card p{
    color:#667987;
    margin-bottom:26px;
    line-height:1.4;
}

.login-error{
    background:#fff1f1;
    color:#b42318;
    border:1px solid #ffd0d0;
    padding:12px 14px;
    border-radius:14px;
    margin-bottom:18px;
    font-size:14px;
}

.form-group{
    margin-bottom:18px;
}

.form-group label{
    display:block;
    font-size:13px;
    font-weight:700;
    color:#425466;
    margin-bottom:8px;
}

.input-wrap{
    display:flex;
    align-items:center;
    gap:10px;
    background:#f6f9fb;
    border:1px solid #dce6ec;
    border-radius:16px;
    padding:0 14px;
}

.input-icon{
    color:#447c9b;
    font-size:16px;
}

.input-wrap input{
    width:100%;
    height:52px;
    border:none;
    background:transparent;
    outline:none;
    font-size:15px;
    color:#1f2933;
}

.eye-btn{
    border:none;
    background:transparent;
    color:#447c9b;
    cursor:pointer;
    font-size:16px;
}

.login-row{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin:6px 0 22px;
    font-size:13px;
    color:#60707b;
}

.login-row a,
.login-help a{
    color:#447c9b;
    text-decoration:none;
    font-weight:700;
}

.login-btn{
    width:100%;
    height:54px;
    border:none;
    border-radius:16px;
    background:#447c9b;
    color:#fff;
    font-size:16px;
    font-weight:800;
    cursor:pointer;
    box-shadow:0 14px 30px rgba(68,124,155,.28);
    transition:.2s;
}

.login-btn:hover{
    transform:translateY(-1px);
    opacity:.96;
}

.login-help{
    text-align:center;
    font-size:13px;
    margin:20px 0!important;
}

.login-footer{
    display:flex;
    justify-content:space-between;
    gap:12px;
    border-top:1px solid #e6eef2;
    padding-top:18px;
    font-size:14px;
    color:#7b8b96;
}

@media(max-width:820px){
    .login-shell{
        grid-template-columns:1fr;
        gap:20px;
    }

    .login-brand{
        padding:12px;
        min-height:auto;
    }

    .logo-texto{
        flex-direction:column;
        gap:10px;
    }

    .titulo-principal{
        font-size:54px;
    }

    .subtitulo{
        text-align:center;
        font-size:20px;
    }

    .login-card{
        padding:26px;
        border-radius:24px;
    }

    .login-footer{
        flex-direction:column;
        text-align:center;
    }
}


.login-logo-marca{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:18px;

    opacity:0;

    animation:
    aparecerSuave 2.2s ease forwards;
}



/* JONAT */
.login-logo-marca h1{
    color:#fff;

    font-family:'Comfortaa', sans-serif;
    font-weight:bold;

    font-size:70px;

    margin:0;

    opacity:0;

    animation:
    aparecerSuave 2s ease forwards;
}



/* CLIMATIZAÇÃO */
.login-logo-marca h2{
    color:#fff;

    text-align:left;

    font-family:'Comfortaa', sans-serif;
    font-weight:normal;

    font-size:25px;

    line-height:1.3;

    margin:0;

    opacity:0;

    animation:
    aparecerSuave 2.6s ease forwards;

    animation-delay:.3s;
}



/* ANIMAÇÃO */
@keyframes aparecerSuave{

    from{
        opacity:0;

        transform:
        translateY(-90px);
    }

    to{
        opacity:1;

        transform:
        translateY(0);
    }

}



/* MOBILE */
@media(max-width:768px){

    .login-logo-marca{
        gap:12px;
    }

    .login-logo-marca h1{
        font-size:52px;
    }

    .login-logo-marca h2{
        font-size:18px;
    }

}



@media(max-width:768px){

    .login-logo-marca{
        flex-direction:column;

        align-items:center;

        gap:8px;
    }

    .login-logo-marca h1{
        font-size:52px;

        text-align:center;
    }

    .login-logo-marca h2{
        font-size:18px;

        text-align:center;
    }

}