/* login_register.css (unificado a partir de login.css) */

.login-page .login-box {
    width: 100%;
    max-width: none;
    margin: 0;
    height: 100%;
}

.login-page {
    background: #fff;
}

.auth-layout {
    display: flex;
    align-items: stretch;
}

.auth-hero {
    width: 50%;
    background: #0a6b75 url('../images/login-bg.png') no-repeat center/cover;
    color: #fff;
    padding: 24px 24px 48px 24px;
    position: sticky;
    top: 0;
    height: 100vh;
    box-sizing: border-box;
    overflow: hidden;
}

/* Registration variant: hero on right with specific background */
.auth-hero.register{
    background: #0a6b75 url('../images/register-bg.png') no-repeat center/cover;
}

.auth-hero-top {
    position: absolute;
    top: 24px;
    left: 24px;
    right: 24px;
}

.auth-logo {
    height: 24px;
}

.return-site {
    background: rgba(255, 255, 255, .18);
    border: 1px solid rgba(255, 255, 255, .25);
    color: #fff;
}

.return-site:hover {
    background: rgba(255, 255, 255, .28);
    color: #fff;
}

.return-site, .return-site * {
    transition: none;
}

.auth-hero-content {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 32px;
}

.hero-icon {
    height: 60px;
    opacity: .85;
}

.hero-title {
    font-size: 42px;
    font-weight: 700;
    margin: 0 0 10px 0;
    line-height: 1.1;
}

.hero-subtitle {
    margin: 0;
    opacity: .95;
    font-size: 22px;
    line-height: 1.4;
}

.auth-form-panel {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 48px 24px 24px 48px;
    position: relative;
    box-sizing: border-box;
    overflow: visible;
}

.auth-form-header {
    margin-bottom: 16px;
    color: #6c757d;
}

.auth-form-header {
    position: absolute;
    top: 24px;
    right: 24px;
}

.new-here {
    margin-right: .5rem;
}

.create-account {
    color: #0a6b75;
    text-decoration: none;
    margin-right: .5rem;
}

.create-account:hover {
    text-decoration: underline;
}

.auth-form {
    border-radius: 12px;
    box-shadow: none;
    padding: 24px 24px 16px;
    background: #fff;
    max-width: 480px;
    margin: 0 auto;
}

.welcome-title {
    font-weight: 700;
    color: #333;
    margin: 0;
}

.welcome-subtitle {
    color: #6c757d;
    margin: 6px 0 24px 0;
}

.form-control {
    border-radius: 8px;
    height: 50px;
    background: #f3f5f7;
    border: 1px solid #e2e5e9;
}

/* Logo selector (register) */
.logo-circle{
    width: 88px;
    height: 88px;
    border-radius: 50%;
    border: 1px dashed rgba(0,0,0,.2);
    background: #f3f5f7;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #9aa4ae;
    cursor: pointer;
}
.logo-circle img{
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}

.form-control.is-invalid {
    border-color: var(--danger);
    background: #f3f5f7;
}

.invalid-feedback { 
    display: none; 
    color: var(--danger-dark); 
    font-size: 12px; 
    margin-top: 6px; 
}

.email-field.was-blurred.is-invalid .invalid-feedback { display: block; }
/* Mostrar mensagens de erro para outros wrappers também */
.input-wrapper.was-blurred.is-invalid .invalid-feedback { display: block; }

.login-alert{ 
    background:#f9eded;
    border:none;
    border-radius:12px;
    padding:12px 16px;
    color:var(--danger-dark);
    font-size:14px;
    font-weight:500 
}

.login-alert i{ color:var(--danger-dark) }

/* Floating label style inside input when invalid */
.input-wrapper{ position: relative }
.floating-label{
    position: absolute;
    left: 12px;
    top: 6px;
    font-size: 12px;
    color: var(--danger-dark);
    display: none;
}

/* Mostrar label no inválido apenas quando focado ou com valor */
.input-wrapper.is-focused .form-control.is-invalid ~ .floating-label,
.input-wrapper.has-value .form-control.is-invalid ~ .floating-label{ display:block }

/* Floating label on focus/has-value (register fields) */
.input-wrapper.is-focused .floating-label,
.input-wrapper.has-value .floating-label{ display:block; color:#6c757d }
.input-wrapper.is-focused .form-control,
.input-wrapper.has-value .form-control{ padding-top: 26px; height: 50px }

.input-wrapper .form-control.is-invalid{ padding-top: 26px; height: 50px }

/* Neutralize browser autofill yellow */
.form-control:-webkit-autofill,
.form-control:-webkit-autofill:hover,
.form-control:-webkit-autofill:focus{
    -webkit-box-shadow: 0 0 0px 1000px #f3f5f7 inset;
    -webkit-text-fill-color: inherit;
}

.password-field {
    position: relative;
}

.toggle-password {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    background: transparent;
    color: #9aa4ae;
    padding: 4px;
    border-radius: 6px;
}

.toggle-password:hover {
    background: rgba(0,0,0,.04);
}

.toggle-password:focus,
.toggle-password:active,
.toggle-password:focus-visible {
    outline: none;
    box-shadow: none;
    background: transparent;
}

.form-label {
    color: #6c757d;
    font-weight: 500;
}

.submit-btn {
    background: #0a6b75;
    border-color: #0a6b75;
    border-radius: 8px;
    height: 40px;
}

.submit-btn:hover {
    background: #095d66;
    border-color: #095d66;
}

.divider {
    display: flex;
    align-items: center;
    gap: 12px;
    color: #a0a7ae;
    margin: 20px 0;
}

.divider:before, .divider:after {
    content: "";
    flex: 1;
    height: 1px;
    background: #e2e5e9;
}

.divider span {
    white-space: nowrap;
}

.social-buttons {
    display: flex;
    gap: 12px;
}

.social-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid #e2e5e9;
    border-radius: 10px;
    height: 42px;
    background: #fff;
    color: #333;
    padding: 0 16px;
}

.social-btn:hover {
    background: #f7f9fb;
}

.social-btn span {
    font-weight: 500;
}

.google-btn {
    box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

.linkedin-btn {
    box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

.login-alert {
    background: #fff4f4;
    border: 1px solid #ffd4d4;
    border-radius: 8px;
    padding: 8px 12px;
    color: #b42318;
}

.login-alert img {
    height: 18px;
}

.forgot-link {
    color: #6c757d;
    text-decoration: none;
}

.forgot-link:hover {
    text-decoration: underline;
}

@media (min-width: 768px) {
    .auth-form { width: 100%; max-width: 520px }
}

@media (min-width: 1200px) {
    .auth-form { width: 100%; max-width: 560px }
}

@media (max-width: 767.98px) {
    .auth-layout {
        flex-direction: column;
        align-items: stretch;
        overflow: hidden; /* só o bottom sheet rola */
        padding-top: 80px; /* reserva espaço do header fixo */
        background: #0a6b75 url('../images/login-bg.png') no-repeat center top / cover;
        height: 100vh; /* altura fixa para estabilidade no zoom */
        position: fixed; /* fixa o layout durante zoom */
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
    }

    /* Registration variant background on mobile */
    .auth-layout.is-register {
        background: #0a6b75 url('../images/register-bg.png') no-repeat center top / cover;
    }

    /* Ensure hero comes first on register (form was first in DOM) */
    .auth-layout.is-register .auth-hero { order: 1; }
    .auth-layout.is-register .auth-form-panel { order: 2; }

    /* Make the container behind rounded corners transparent so hero/bg appears */
    .auth-layout.is-register .auth-form-panel { background: transparent; }
    /* Avoid double background: override .auth-hero.register bg on mobile */
    .auth-layout.is-register .auth-hero { background: none; }

    .auth-hero {
        width: 100%;
        height: 80px;
        padding: 12px 16px;
        position: fixed; /* fixo no topo para não depender de scroll container */
        top: 0;
        left: 0;
        right: 0;
        z-index: 3;
        background: transparent;
    }

    .auth-hero-top { top: 12px; left: 12px; right: 12px; }
    .auth-hero-content { display: none; }
    .auth-form-header { display: none; }

    .auth-form-panel {
        width: 100%;
        padding: 0;
        margin-top: auto;
        max-height: none;
        overflow: visible;
        flex-shrink: 0; /* evita encolhimento */
    }

    .auth-form {
        border-radius: 24px 24px 0 0;
        padding: 20px 16px 16px; /* menos padding inferior */
        max-width: none;
        margin: -16px 0 0 0;
        box-shadow: 0 -8px 24px rgba(16, 24, 40, .12);
        max-height: calc(100vh - 80px);
        height: calc(100vh - 80px); /* altura fixa para evitar problemas no zoom */
        overflow-y: auto;            /* só o bottom sheet rola */
        -webkit-overflow-scrolling: touch;
    }

    .welcome-title { font-size: 20px; }

    .mobile-create-account { 
        margin: 14px 0 8px; 
        color: #6c757d; 
        padding-top: 10px; 
    }

    .mobile-create-account a { 
        color: #0a6b75; 
        text-decoration: none; 
    }
    
    .social-buttons { gap: 10px; }
}

/* ---- Invalid credentials banner ---- */
.login-alert{
    background: #f8eded !important; 
    border: none !important;
    border-radius: 12px !important;
    padding: 12px 16px !important;
    color: #d32f2f !important; 
    font-size: 14px !important;
    font-weight: 500 !important;
}
.login-alert i{ color: #d32f2f !important; }

/* Forgot password panels (desktop) */
.forgot-panel,
.forgot-success{
    max-width: 560px;
    margin: 0 auto;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
}
.forgot-panel .welcome-title,
.forgot-success .welcome-title{
    font-weight: 700;
    color: #2a2e34;
    margin: 0 0 12px 0;
}
.forgot-panel .welcome-subtitle,
.forgot-success .welcome-subtitle{
    color: #6c757d;
    margin: 0 0 20px 0;
    line-height: 1.5;
}
.forgot-panel .submit-btn{ margin-top: 8px; }
.forgot-panel .js-back-login,
.forgot-success .js-back-login{ color:#6c757d; text-decoration:none }
.forgot-panel .js-back-login:hover,
.forgot-success .js-back-login:hover{ text-decoration:underline }

/* Success screen specific styles */
.success-icon{
    width: 140px;
    height: auto;
    display: block;
    margin: 0 auto 12px;
}
.auth-form-panel.is-success .register-success{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; /* centraliza elementos dentro do container */
    min-height: calc(100vh - 80px);
    padding: 0 32px;
}
.auth-form-panel.is-success .forgot-success{
    margin-left: auto;
    margin-right: auto;
}
@media (min-width: 768px){
    .auth-form-panel.is-success{
        padding: 48px 48px 24px 48px;
        align-items: center; 
    }
}
.auth-form-panel.is-success .register-success .welcome-title{
    text-align: center; /* centraliza o título */
}
.retry-link{
    color: #0a6b75;
    text-decoration: underline;
}
.retry-link:hover{
    color: #095d66;
    text-decoration: underline;
}
.login-link{
    color: #0a6b75;
    text-decoration: none;
    font-weight: 500;
}
.login-link:hover{
    text-decoration: underline;
    color: #095d66;
}
/* Force primary color on success screen link */
.forgot-success .login-link{ color:#0a6b75 !important; }
.forgot-success .login-link:hover{ color:#095d66 !important; text-decoration: underline; }

/* Hide "Novo por aqui?" only on success screen */
.auth-form-panel.is-success .auth-form-header{ display: none !important; }

/* Mobile bottom sheet for forgot panels */
@media (max-width: 767.98px){
    .forgot-panel,
    .forgot-success{
        border-radius: 24px 24px 0 0;
        padding: 20px 16px;
        max-width: none;
        margin: 0;
        box-shadow: 0 -8px 24px rgba(16,24,40,.12);
        background: #fff;
    }
    .success-icon{
        width: 120px;
    }
    .auth-form-panel.is-success .register-success{
        min-height: auto;
        padding: 12px 16px 24px;
    }
    /* Success bottom sheet: auto height with a max-height limit for better spacing */
    .auth-form-panel.is-success .auth-form{
        height: auto;
        max-height: calc(100vh - 80px);
        overflow-y: visible;
    }
    /* Espaçamento vertical entre campos no mobile */
    .auth-form .input-wrapper{ margin-bottom: 10px; }
}

/* Password strength indicator (reset password) */
.password-strength {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
    color: #6c757d;
    font-size: 12px;
}

.password-strength .bars {
    display: flex;
    gap: 4px;
}

.password-strength .bar {
    width: 24px;
    height: 6px;
    border-radius: 4px;
    background: #e2e5e9;
}

.password-strength.is-weak .bar:nth-child(1) {
    background: #d32f2f;
}

.password-strength.is-medium .bar:nth-child(-n+2) {
    background: #e59f3a;
}

.password-strength.is-strong .bar:nth-child(-n+3) {
    background: #0a6b75;
}

.password-strength .strength-text {
    margin-left: 4px;
}

/* Extras compartilhados */
.form-control select,
select.form-control {
    background: #f3f5f7 !important;
    background-color: #f3f5f7 !important;
}

.form-control option[value=""],
select.form-control option[value=""] {
    color: #9aa4ae !important;
}

select.form-control option[value=""] {
    display: none;
}

select.form-control:invalid,
select.form-control[value=""],
select.form-control.placeholder-active {
    color: #9aa4ae !important;
}

select.form-control:valid:not([value=""]):not(.placeholder-active) {
    color: #333 !important;
}

select.form-control optgroup {
    font-weight: bold;
    font-style: normal;
    padding-left: 0 !important;
    margin-left: 0 !important;
    color: #333;
}

select.form-control optgroup option {
    font-weight: normal;
    padding-left: 20px !important;
    color: #333;
}

select.form-control option.option-heading[disabled] {
    display: block !important;
    padding-left: 0 !important;
    cursor: default;
}

/* Overlay e dropdown do logo (menu de ações) */
.logo-container {
    position: relative;
}

.logo-circle {
    position: relative;
    overflow: hidden;
}

.logo-overlay {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: rgba(0,0,0,.45);
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.logo-circle:hover .logo-overlay {
    display: flex;
}

.logo-overlay i {
    font-size: 18px;
}

.logo-overlay .overlay-text {
    font-weight: 600;
}

.js-logo-menu {
    border-radius: 1rem;
    padding: .25rem;
}

.js-logo-menu .dropdown-item {
    color: var(--secondary);
    border-radius: .75rem;
    padding: .875rem 1.25rem;
}

.js-logo-menu .dropdown-item:hover {
    background: rgba(0,0,0,.06);
    color: var(--secondary);
}

.js-logo-menu .dropdown-item.js-logo-remove:hover {
    background: rgba(220,53,69,.12);
    color: var(--danger);
}

.js-logo-menu .dropdown-divider {
    margin: .5rem 0;
}

/* Ajuste de espaçamento extra entre campos e botão criar conta (assessment) */
.auth-form .submit-btn { margin-top: 12px; }
.auth-form .text-muted.small { margin-top: 8px; }

/* Botões sociais ocupando largura total */
.auth-form .social-buttons{ 
    display:flex; 
    gap:12px; 
    width:100% 
}

.auth-form .social-btn{ 
    flex:1 1 auto; 
    width:100%; 
    max-width: none 
}

.auth-form .social-btn .social-icon{ 
    height:18px; 
    width:auto; 
    margin-right:8px 
}

/* social buttons text color normalization */
.auth-form .social-btn{ color:#333 }
.auth-form .social-btn:hover{ color:#0a6b75 }
.auth-form .social-btn span{ color:inherit }

/* Em estado inválido, não mostrar floating label; manter placeholder visível */
.input-wrapper.is-invalid .floating-label{ display:none }
.input-wrapper.is-invalid .form-control::placeholder{ color: var(--danger-dark) }

/* Placeholder ativo para selects vazios */
select.form-control.placeholder-active { color: #9aa4ae !important; }
.input-wrapper.is-invalid select.form-control.placeholder-active { color: var(--danger-dark) !important; }

/* Esconder label quando inválido para evitar label+placeholder simultâneos */
.input-wrapper.is-invalid .floating-label{ display:none }
.input-wrapper.is-invalid.is-focused .floating-label{ display:block }

/* Corrigir label+placeholder e centragem em inválido */
.input-wrapper:not(.has-value):not(.is-focused) .form-control.is-invalid{ 
    padding-top:0; 
    height:50px 
}

/* Espaçamento consistente entre campos (desktop) */
.auth-form .input-wrapper{ margin-bottom: 14px; }

/* Select wrappers: sem padding por padrão, só quando focado/has-value */
.select-wrapper .form-control{ 
    height:50px; 
    padding-top:0 
}

.select-wrapper.has-value .form-control,
.select-wrapper.is-focused .form-control{ 
    padding-top:26px; 
    height:50px 
}

/* Placeholder activo/cores */
select.form-control.placeholder-active{ color:#9aa4ae !important }
.input-wrapper.is-invalid select.form-control.placeholder-active{ color:var(--danger-dark) !important }

/* Label flutuante dos selects */
.select-wrapper .select-floating-label{ 
    position:absolute; 
    left:12px; 
    top:8px; 
    font-size:12px; 
    color:#6c757d; 
    display:none 
}

.select-wrapper.has-value .select-floating-label,
.select-wrapper.is-focused .select-floating-label{ display:block }

/* Forçar ocultação da label quando solicitado (submit inválido) */
.input-wrapper.hide-label .floating-label{ display:none !important }
.select-wrapper.hide-label .select-floating-label{ display:none !important }