/* ============================================================
   AUTH.CSS — DISC Dashboard
   Modal de login, modal de usuário, modal de confirmação saída
   ============================================================ */

/* ── MODAL LOGIN ──────────────────────────────────────────── */
#modalLogin {
    display: flex;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 999999;
    justify-content: center;
    align-items: center;
}
#modalLogin.fechando {
    animation: loginFadeOut .3s ease forwards;
}
@keyframes loginFadeOut {
    to { opacity: 0; transform: scale(0.97); }
}
@keyframes loginShake {
    0%,100% { transform: translateX(0); }
    20%     { transform: translateX(-8px); }
    40%     { transform: translateX(8px); }
    60%     { transform: translateX(-5px); }
    80%     { transform: translateX(5px); }
}
@keyframes cardPop {
    from { opacity: 0; transform: scale(0.95) translateY(10px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

.login-content {
    background: var(--cor-sidebar, #1c1b1b);
    border: 2px solid var(--cor-primaria, #F98948);
    border-radius: 20px;
    padding: 36px 38px 32px;
    max-width: 440px;
    width: 92%;
    box-shadow: 0 0 40px rgba(249,137,72,0.35), 0 12px 40px rgba(0,0,0,0.6);
    animation: cardPop .35s ease both;
    position: relative;
}
[data-theme="light"] .login-content {
    background: #ffffff;
    box-shadow: 0 0 30px rgba(36,30,78,0.18), 0 12px 40px rgba(0,0,0,0.12);
}
.login-logo-topo {
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
}
.login-logo-topo img {
    height: 52px;
    object-fit: contain;
    cursor: pointer;
    transition: opacity .2s ease;
}
.login-logo-topo img:hover { opacity: .8; }
.login-header {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--cor-primaria, #F98948);
    font-family: 'Orbitron', sans-serif;
    font-size: 17px;
    font-weight: 700;
    margin-bottom: 6px;
}
.login-header i { font-size: 20px; }
.login-subtitulo {
    font-family: 'Manrope', sans-serif;
    font-size: 13px;
    color: var(--cor-texto, #ddd);
    opacity: .75;
    margin-bottom: 24px;
}
.login-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}
.login-group label {
    font-family: 'Manrope', sans-serif;
    font-size: 13px;
    font-weight: 600;
    color: var(--cor-texto, #ddd);
    opacity: .85;
}
.login-group input {
    background: var(--cor-header, #141414);
    border: 2px solid rgba(249,137,72,0.25);
    border-radius: 10px;
    padding: 11px 14px;
    font-family: 'Manrope', sans-serif;
    font-size: 14px;
    color: var(--cor-texto, #eee);
    transition: border-color .25s, box-shadow .25s;
    outline: none;
    width: 100%;
    box-sizing: border-box;
}
[data-theme="light"] .login-group input {
    background: #f5f5f5;
    color: #241E4E;
}
.login-group input:focus {
    border-color: var(--cor-primaria, #F98948);
    box-shadow: 0 0 10px rgba(249,137,72,0.3);
}
.login-erro {
    font-family: 'Manrope', sans-serif;
    font-size: 13px;
    color: #ff6b6b;
    margin-bottom: 12px;
    display: none;
    padding: 8px 12px;
    background: rgba(255,70,70,0.1);
    border-radius: 8px;
    border-left: 3px solid #ff4646;
}
.login-erro.visivel { display: block; }
.login-footer {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 8px;
}
.btn-login-entrar {
    padding: 12px 20px;
    border-radius: 30px;
    border: none;
    background: var(--cor-primaria, #F98948);
    color: #0a0a0a;
    font-family: 'Rajdhani', sans-serif;
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: .25s ease;
    width: 100%;
}
.btn-login-entrar:hover {
    transform: translateY(-2px) scale(1.02);
    box-shadow: 0 0 18px rgba(249,137,72,0.6);
}
.btn-login-visitante {
    padding: 11px 20px;
    border-radius: 30px;
    border: 2px solid rgba(249,137,72,0.25);
    background: transparent;
    color: var(--cor-texto, #ddd);
    font-family: 'Rajdhani', sans-serif;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: .25s ease;
    width: 100%;
}
.btn-login-visitante:hover {
    border-color: rgba(249,137,72,0.6);
    box-shadow: 0 0 10px rgba(249,137,72,0.25);
}
.login-divisor {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--cor-texto, #ddd);
    opacity: .35;
    font-size: 12px;
    font-family: 'Manrope', sans-serif;
}
.login-divisor::before,
.login-divisor::after {
    content: '';
    flex: 1;
    height: 1px;
    background: currentColor;
}
.login-rodape {
    margin-top: 20px;
    text-align: center;
    font-family: 'Manrope', sans-serif;
    font-size: 12px;
    color: var(--cor-texto, #ddd);
    opacity: .4;
}

/* ── AVATAR HEADER ────────────────────────────────────────── */
.user-avatar-clicavel {
    cursor: pointer;
    border-radius: 50%;
    transition: box-shadow .2s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.user-avatar-clicavel:hover {
    box-shadow: 0 0 0 3px rgba(249,137,72,0.5);
}

.user-avatar-visitante {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    line-height: 0;
}

.user-avatar-visitante svg {
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
    display: block;
}

/* ── MODAL USUÁRIO (clique no avatar) ─────────────────────── */
.user-modal-bg {
    position: fixed;
    inset: 0;
    z-index: 99998;
    background: transparent;
}
.user-modal-box {
    position: fixed;
    background: var(--cor-sidebar, #1c1b1b);
    border: 1px solid rgba(249,137,72,0.3);
    border-radius: 16px;
    padding: 0;
    min-width: 220px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
    overflow: hidden;
    opacity: 0;
    transform: translateY(-8px) scale(0.97);
    transition: opacity .2s ease, transform .2s ease;
}
[data-theme="light"] .user-modal-box {
    background: #ffffff;
    box-shadow: 0 8px 32px rgba(36,30,78,0.15);
}
.user-modal-box.visivel {
    opacity: 1;
    transform: translateY(0) scale(1);
}
.user-modal-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
}
.user-modal-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    overflow: hidden;
    background: rgba(249,137,72,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 26px;
    color: var(--cor-primaria, #F98948);
}
.user-modal-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.user-modal-nome {
    font-family: 'Manrope', sans-serif;
    font-size: 13px;
    font-weight: 700;
    color: var(--cor-texto, #eee);
}
.user-modal-cargo {
    font-family: 'Manrope', sans-serif;
    font-size: 11px;
    color: var(--cor-texto, #ddd);
    opacity: .6;
}
.user-modal-divisor {
    height: 1px;
    background: rgba(249,137,72,0.15);
    margin: 0;
}
.user-modal-acoes {
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.user-modal-btn {
    width: 100%;
    justify-content: flex-start;
    padding: 10px 14px !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    font-family: 'Manrope', sans-serif !important;
    font-weight: 600 !important;
    gap: 10px;
    background: transparent !important;
    border: none !important;
    color: var(--cor-texto, #ddd) !important;
    transition: background .2s;
    display: flex;
    align-items: center;
    cursor: pointer;
    transform: none !important;
    box-shadow: none !important;
}

.user-modal-btn:hover {
    background: rgba(249,137,72,0.1) !important;
    transform: none !important;
    box-shadow: none !important;
}

.user-modal-btn-sair {
    color: #ff6b6b !important;
}

.user-modal-btn-sair:hover {
    background: rgba(255,70,70,0.08) !important;
}

/* ── MODAL CONFIRMAÇÃO SAÍDA ──────────────────────────────── */
.auth-modal-bg {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 999999;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    transition: opacity .3s ease;
}
.auth-modal-bg.visivel { opacity: 1; }
.auth-modal-box {
    background: var(--cor-sidebar, #1c1b1b);
    border: 2px solid rgba(249,137,72,0.35);
    border-radius: 20px;
    padding: 36px 32px 28px;
    max-width: 380px;
    width: 92%;
    text-align: center;
    box-shadow: 0 0 40px rgba(249,137,72,0.2), 0 12px 40px rgba(0,0,0,0.5);
    transform: scale(0.95);
    transition: transform .3s ease;
}
[data-theme="light"] .auth-modal-box {
    background: #ffffff;
    box-shadow: 0 0 30px rgba(36,30,78,0.12), 0 12px 40px rgba(0,0,0,0.1);
}
.auth-modal-bg.visivel .auth-modal-box { transform: scale(1); }
.auth-modal-icone {
    font-size: 36px;
    color: var(--cor-primaria, #F98948);
    margin-bottom: 14px;
}
.auth-modal-titulo {
    font-family: 'Orbitron', sans-serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--cor-texto, #eee);
    margin-bottom: 8px;
}
.auth-modal-subtitulo {
    font-family: 'Manrope', sans-serif;
    font-size: 13px;
    color: var(--cor-texto, #ddd);
    opacity: .65;
    margin-bottom: 24px;
}
.auth-modal-acoes {
    display: flex;
    gap: 12px;
    justify-content: center;
}

.auth-btn-cancelar {
    padding: 10px 20px !important;
    border-radius: 30px !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    background: transparent !important;
    border: 2px solid rgba(249,137,72,0.3) !important;
    color: var(--cor-texto, #ddd) !important;
    transition: .25s ease;
    transform: none !important;
    box-shadow: none !important;
}
.auth-btn-cancelar:hover {
    border-color: rgba(249,137,72,0.6) !important;
    transform: none !important;
    box-shadow: none !important;
}
.auth-btn-confirmar {
    padding: 10px 20px !important;
    border-radius: 30px !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--cor-primaria, #F98948) !important;
    color: #0a0a0a !important;
    border: none !important;
    transition: .25s ease;
}
.auth-btn-confirmar:hover {
    box-shadow: 0 0 16px rgba(249,137,72,0.5) !important;
    transform: translateY(-1px) !important;
}

.user-foto {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    display: block;
    border: 2px solid rgba(249,137,72,0.4);
}
/* DASHBOARD abaixo da logo */
.login-logo-topo {
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.login-dashboard-label {
    font-family: 'Orbitron', sans-serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 6px;
    color: var(--cor-primaria, #F98948);
    text-transform: uppercase;
    opacity: 0.85;
}

/* Header centralizado */
.login-header {
    justify-content: center;
    text-align: center;
}

/* Subtítulo centralizado em Rajdhani */
.login-subtitulo-center {
    text-align: center;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600;
    opacity: 0.8;
}