/**
 * CSS Customizado para Login - Sistema de Customização por Assessoria
 * Permite personalização de cores, logo e background via variáveis CSS
 */

/* Variáveis CSS para customização dinâmica */
:root {
    --cor-primaria-login: #007bff;
    --cor-secundaria-login: #6c757d;
}

/* Estilos para background personalizado */
body.login-page.custom-background {
    background-attachment: fixed;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

body.login-page.custom-background::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    z-index: -1;
}

/* Card com transparência para backgrounds personalizados */
.login-page.custom-background .login-box .card {
    background: rgba(255, 255, 255, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);
}

/* Logo personalizado */
.login-box .card-header .logo-assessoria {
    max-height: 120px;
    max-width: 300px;
    width: auto;
    height: auto;
    display: block;
    margin: 0 auto;
}

/* Customização de cores primárias */
.login-custom .card-primary.card-outline {
    border-top: 3px solid var(--cor-primaria-login);
}

.login-custom .btn-primary {
    background-color: var(--cor-primaria-login);
    border-color: var(--cor-primaria-login);
}

.login-custom .btn-primary:hover,
.login-custom .btn-primary:focus,
.login-custom .btn-primary:active {
    background-color: var(--cor-primaria-login);
    border-color: var(--cor-primaria-login);
    filter: brightness(0.9);
}

.login-custom .icheck-primary > input:checked + label::before {
    background-color: var(--cor-primaria-login);
    border-color: var(--cor-primaria-login);
}

.login-custom .icheck-primary > input:checked + label::after {
    color: #fff;
}

/* Links com cor secundária */
.login-custom a {
    color: var(--cor-secundaria-login);
}

.login-custom a:hover {
    color: var(--cor-primaria-login);
    text-decoration: none;
}

/* Responsividade para mobile */
@media (max-width: 768px) {
    .login-box .card-header .logo-assessoria {
        max-height: 80px !important;
        max-width: 200px !important;
    }

    body.login-page.custom-background {
        background-attachment: scroll !important;
    }

    .login-page.custom-background .login-box .card {
        background: rgba(255, 255, 255, 0.98);
    }
}

/* Ajustes para telas muito pequenas */
@media (max-width: 480px) {
    .login-box .card-header .logo-assessoria {
        max-height: 60px !important;
        max-width: 150px !important;
    }

    .login-box {
        width: 95%;
    }
}

/* Estados de loading e transições */
.login-box .card-header .logo-assessoria {
    transition: opacity 0.3s ease-in-out;
}

.login-box .card-header .logo-assessoria:not([src]) {
    opacity: 0;
}

/* Fallback para navegadores que não suportam backdrop-filter */
@supports not (backdrop-filter: blur(10px)) {
    .login-page.custom-background .login-box .card {
        background: rgba(255, 255, 255, 0.9);
    }
}

/* Melhorias de acessibilidade */
.login-box .card-header .logo-assessoria[alt] {
    background-color: transparent;
}

/* Animações suaves */
.login-custom .btn-primary {
    transition: all 0.2s ease-in-out;
}

.login-custom .form-control:focus {
    border-color: var(--cor-primaria-login);
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* Customização para input groups */
.login-custom .input-group-text {
    border-color: var(--cor-secundaria-login);
    color: var(--cor-secundaria-login);
}

.login-custom .form-control:focus + .input-group-append .input-group-text {
    border-color: var(--cor-primaria-login);
    color: var(--cor-primaria-login);
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .login-page.custom-background .login-box .card {
        background: rgba(255, 255, 255, 1);
        backdrop-filter: none;
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .login-box .card-header .logo-assessoria,
    .login-custom .btn-primary {
        transition: none;
    }
}