/* ========================================================================= */
/* DESIGN SYSTEM - VARIÁVEIS CSS PADRONIZADAS                               */
/* ========================================================================= */

:root {
    /* ===== CORES PRINCIPAIS (MARCA - Indigo/Violet alinhado com LP) ===== */
    --color-primary-hsl: 221 83% 53%;      /* Indigo LeadCNPJ #2563eb */
    --color-secondary-hsl: 158 64% 42%;    /* Verde ações #22c55e */

    /* ===== PALETA ESCURA (TEMA PADRÃO) - Deep Space (alinhado com LP) ===== */
    --color-bg-900-hsl: 229 84% 5%;        /* #020617 Slate 950 - Fundo principal (= LP) */
    --color-bg-800-hsl: 222 47% 11%;       /* #0f172a Slate 900 - Cards/containers */
    --color-bg-700-hsl: 217 33% 17%;       /* #1e293b Slate 800 - Bordas e separadores */
    --color-bg-600-hsl: 215 25% 27%;       /* #334155 Slate 700 - Hover states */
    --color-text-main-hsl: 210 40% 96%;    /* #f1f5f9 Slate 100 - Texto principal */
    --color-text-subtle-hsl: 217 19% 62%;  /* #8b9bb5 - Texto secundário (melhor contraste 5.2:1 vs bg-800) */
    --color-text-muted-hsl: 215 16% 47%;   /* #64748b Slate 500 - Texto terciário/placeholders */

    /* ===== CORES DE FEEDBACK ===== */
    --color-success-hsl: 142 71% 45%;      /* Verde sucesso */
    --color-warning-hsl: 38 92% 50%;       /* Amarelo aviso */
    --color-error-hsl: 0 84% 60%;          /* Vermelho erro */
    --color-info-hsl: 199 89% 48%;         /* Azul informação */

    /* ===== TIPOGRAFIA ===== */
    --font-size-xs: 0.6875rem;  /* 11px - reduzido de 12px */
    --font-size-sm: 0.8125rem;  /* 13px - reduzido de 14px */
    --font-size-base: 0.875rem; /* 14px - reduzido de 14.4px */
    --font-size-lg: 0.9375rem;  /* 15px - reduzido de 16px */
    --font-size-xl: 1.0625rem;  /* 17px - reduzido de 18px */
    --font-size-2xl: 1.1875rem; /* 19px - reduzido de 20px */
    --font-size-3xl: 1.375rem;  /* 22px - reduzido de 24px */
    --font-size-4xl: 1.75rem;   /* 28px - reduzido de 32px */

    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    --line-height-tight: 1.25;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.75;

    /* ===== ESPAÇAMENTOS ===== */
    --spacing-xs: 0.25rem;      /* 4px */
    --spacing-sm: 0.5rem;       /* 8px */
    --spacing-md: 0.5rem;       /* 8px - reduzido de 12px */
    --spacing-lg: 0.75rem;      /* 12px - reduzido de 16px */
    --spacing-xl: 1.125rem;     /* 18px - reduzido de 24px */
    --spacing-2xl: 1.5rem;      /* 24px - reduzido de 32px */
    --spacing-3xl: 2.25rem;     /* 36px - reduzido de 48px */
    --spacing-4xl: 3rem;        /* 48px - reduzido de 64px */

    /* ===== BORDER RADIUS ===== */
    --radius-sm: 0.25rem;       /* 4px */
    --radius-md: 0.375rem;      /* 6px */
    --radius-lg: 0.5rem;        /* 8px */
    --radius-xl: 0.75rem;       /* 12px */
    --radius-2xl: 1rem;         /* 16px */
    --radius-full: 9999px;      /* Circular */

    /* ===== SOMBRAS (Dark theme - mais intensas para profundidade) ===== */
    --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.2);
    --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.25), 0 1px 2px -1px rgba(0, 0, 0, 0.2);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -2px rgba(0, 0, 0, 0.2);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -4px rgba(0, 0, 0, 0.25);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.35), 0 8px 10px -6px rgba(0, 0, 0, 0.25);
    --shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
    --shadow-card: 0 1px 3px 0 rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(37, 99, 235, 0.04);

    /* ===== TRANSIÇÕES ===== */
    --transition-fast: 0.15s ease-in-out;
    --transition-base: 0.2s ease-in-out;
    --transition-slow: 0.3s ease-in-out;

    /* ===== Z-INDEX SCALE ===== */
    --z-dropdown: 50;
    --z-sticky: 100;
    --z-fixed: 200;
    --z-modal-backdrop: 300;
    --z-modal: 400;
    --z-toast: 1050;

    /* ===== VARIÁVEIS PARA ÍCONES (DASHBOARD/CARDS) - TEMA ESCURO ===== */
    --color-icon-bg: rgba(37, 99, 235, 0.1);        /* Fundo ícone primary (Indigo) */
    --color-icon-text: #818cf8;                     /* Cor ícone primary (Indigo 400) */
    --color-icon-bg-amber: rgba(245, 158, 11, 0.1); /* Fundo ícone amber */
    --color-icon-text-amber: #fbbf24;               /* Cor ícone amber */
    --color-icon-bg-purple: rgba(168, 85, 247, 0.1);/* Fundo ícone purple */
    --color-icon-text-purple: #c084fc;              /* Cor ícone purple */
    --color-icon-bg-orange: rgba(249, 115, 22, 0.1);/* Fundo ícone orange */
    --color-icon-text-orange: #fb923c;              /* Cor ícone orange */
    --color-icon-bg-green: rgba(34, 197, 94, 0.1);  /* Fundo ícone green/secondary */
    --color-icon-text-green: #4ade80;               /* Cor ícone green/secondary */
}


/* ========================================================================= */
/* ESTILOS GLOBAIS                                                           */
/* ========================================================================= */

html, body {
    height: 100%;
    margin: 0;
    padding: 0;
}

body {
    background-color: hsl(var(--color-bg-900-hsl));
    color: hsl(var(--color-text-main-hsl));
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height-normal);
    font-feature-settings: 'cv11', 'cv05';
    transition: background-color var(--transition-slow), color var(--transition-slow);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 1024px) {
    body {
        font-size: var(--font-size-base);
    }
}

/* ===== SCROLLBAR PERSONALIZADA ===== */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: hsl(var(--color-bg-800-hsl));
}

::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-sm);
    transition: background-color var(--transition-base);
}

::-webkit-scrollbar-thumb:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.6);
}


/* ========================================================================= */
/* FORMULÁRIOS - INPUTS E SELECTS                                           */
/* ========================================================================= */

/* Estilos base apenas para o sistema autenticado (não afeta landing pages) */
#main-content input[type="text"]:not([class*="pl-"]),
#main-content input[type="email"]:not([class*="pl-"]),
#main-content input[type="password"]:not([class*="pl-"]),
#main-content input[type="search"]:not([class*="pl-"]),
#main-content input[type="number"]:not([class*="pl-"]),
#main-content input[type="tel"]:not([class*="pl-"]),
#main-content input[type="url"]:not([class*="pl-"]),
#main-content select:not([class*="pl-"]),
#main-content textarea:not([class*="pl-"]),
#main-content .ts-control {
    min-height: 38px !important;
    padding: var(--spacing-sm) var(--spacing-lg) !important;
    background-color: hsl(var(--color-bg-900-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    color: hsl(var(--color-text-main-hsl));
    font-size: var(--font-size-base);
    transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

textarea {
    min-height: 90px;
    resize: vertical;
}

#main-content input:focus:not([class*="pl-"]),
#main-content select:focus:not([class*="pl-"]),
#main-content textarea:focus:not([class*="pl-"]),
#main-content .ts-control.focus {
    border-color: hsl(var(--color-primary-hsl)) !important;
    box-shadow: 0 0 0 3px hsl(var(--color-primary-hsl) / 0.2) !important;
    outline: none !important;
}

/* Inputs com ícone à esquerda */
#main-content input.pl-icon {
    padding-left: 34px !important;
    min-height: 36px !important;
}

input::placeholder,
textarea::placeholder {
    color: hsl(var(--color-text-muted-hsl));
}

/* ===== CHECKBOXES E RADIOS ===== */
#main-content input[type="checkbox"],
#main-content input[type="radio"] {
    width: 1.125rem;
    height: 1.125rem;
    min-height: auto !important;
    background-color: hsl(var(--color-bg-900-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    cursor: pointer;
    transition: all var(--transition-base);
}

#main-content input[type="radio"] {
    border-radius: var(--radius-full);
}

#main-content input[type="checkbox"]:focus,
#main-content input[type="radio"]:focus {
    box-shadow: 0 0 0 3px hsl(var(--color-primary-hsl) / 0.15) !important;
    outline: none !important;
}

#main-content input[type="checkbox"]:checked,
#main-content input[type="radio"]:checked {
    background-color: hsl(var(--color-primary-hsl)) !important;
    border-color: hsl(var(--color-primary-hsl)) !important;
}

/* Checkbox circular para formulário de busca avançada */
#advanced-search-form input[type="checkbox"] {
    border-radius: var(--radius-full) !important;
}

/* ===== INPUTS READONLY ===== */
input[readonly],
textarea[readonly] {
    border-bottom: 2px dashed hsl(var(--color-text-muted-hsl) / 0.4);
    cursor: not-allowed;
    opacity: 0.7;
}

/* ===== AUTOFILL STYLES ===== */
/* Remove fundo branco do autocomplete do navegador */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active,
textarea:-webkit-autofill,
textarea:-webkit-autofill:hover,
textarea:-webkit-autofill:focus,
textarea:-webkit-autofill:active,
select:-webkit-autofill,
select:-webkit-autofill:hover,
select:-webkit-autofill:focus,
select:-webkit-autofill:active {
    -webkit-text-fill-color: hsl(var(--color-text-main-hsl)) !important;
    -webkit-box-shadow: 0 0 0 1000px hsl(var(--color-bg-900-hsl)) inset !important;
    box-shadow: 0 0 0 1000px hsl(var(--color-bg-900-hsl)) inset !important;
    transition: background-color 5000s ease-in-out 0s;
    background-color: hsl(var(--color-bg-900-hsl)) !important;
    border: 1px solid hsl(var(--color-bg-700-hsl)) !important;
}


/* ========================================================================= */
/* BOTÕES - SISTEMA DE DESIGN PADRONIZADO                                   */
/* ========================================================================= */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-sm);
    padding: 10px 20px;
    border-radius: var(--radius-lg);
    border: 1px solid transparent;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
    user-select: none;
    line-height: 1.5;
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* ===== BOTÃO PRIMÁRIO (Sólido Premium com Glow) ===== */
.btn.btn-primary {
    background: #2563eb;
    color: #ffffff;
    border-color: transparent;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.3);
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.btn.btn-primary:hover:not(:disabled) {
    background: #1d4ed8;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.45);
    transform: translateY(-1px);
}

.btn.btn-primary:active:not(:disabled) {
    background: #1e40af;
    box-shadow: 0 2px 8px rgba(37, 99, 235, 0.3);
    transform: translateY(0);
}

/* ===== BOTÃO SECUNDÁRIO (Ação alternativa) ===== */
.btn.btn-secondary {
    background-color: transparent;
    color: hsl(var(--color-text-main-hsl));
    border-color: hsl(var(--color-bg-700-hsl));
}

.btn.btn-secondary:hover:not(:disabled) {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
    border-color: hsl(var(--color-primary-hsl) / 0.3);
}

/* ===== BOTÃO SUCESSO (Ações positivas - Aprovar, Ativar, Confirmar) ===== */
.btn.btn-success {
    background-color: hsl(var(--color-success-hsl));
    color: hsl(var(--color-bg-900-hsl));
    border-color: hsl(var(--color-success-hsl));
}

.btn.btn-success:hover:not(:disabled) {
    background-color: hsl(142 71% 40%);
}

.btn.btn-success:active:not(:disabled) {
    background-color: hsl(142 71% 35%);
}

/* ===== BOTÃO DANGER (Ações destrutivas - Deletar, Remover, Excluir) ===== */
.btn.btn-danger {
    background-color: hsl(var(--color-error-hsl));
    color: #ffffff;
    border-color: hsl(var(--color-error-hsl));
}

.btn.btn-danger:hover:not(:disabled) {
    background-color: hsl(0 84% 55%);
}

.btn.btn-danger:active:not(:disabled) {
    background-color: hsl(0 84% 50%);
}

/* ===== BOTÃO WARNING (Ações que requerem atenção) ===== */
.btn.btn-warning {
    background-color: hsl(var(--color-warning-hsl));
    color: #ffffff;
    border-color: hsl(var(--color-warning-hsl));
}

.btn.btn-warning:hover:not(:disabled) {
    background-color: hsl(38 92% 45%);
}

.btn.btn-warning:active:not(:disabled) {
    background-color: hsl(38 92% 40%);
}

/* ===== BOTÃO INFO (Informações) ===== */
.btn.btn-info {
    background-color: hsl(var(--color-info-hsl));
    color: #ffffff;
    border-color: hsl(var(--color-info-hsl));
}

.btn.btn-info:hover:not(:disabled) {
    background-color: hsl(199 89% 43%);
}

.btn.btn-info:active:not(:disabled) {
    background-color: hsl(199 89% 38%);
}

/* ===== BOTÃO GHOST (Variantes outline) ===== */
.btn.btn-ghost {
    background-color: transparent;
    color: hsl(var(--color-text-main-hsl));
    border-color: transparent;
}

.btn.btn-ghost:hover:not(:disabled) {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
}

/* ===== BOTÃO LINK (Estilo de link - Violet Dark) ===== */
.btn.btn-link {
    background-color: transparent;
    color: #5b21b6;
    border-color: transparent;
    padding-left: var(--spacing-sm);
    padding-right: var(--spacing-sm);
}

.btn.btn-link:hover:not(:disabled) {
    color: #4c1d95;
    text-decoration: underline;
}

/* ===== BOTÕES OUTLINE (Variantes com bordas) ===== */
.btn.btn-outline-primary {
    background-color: transparent;
    color: hsl(var(--color-primary-hsl));
    border-color: hsl(var(--color-primary-hsl) / 0.4);
    border-width: 2px;
}

.btn.btn-outline-primary:hover:not(:disabled) {
    background-color: hsl(var(--color-primary-hsl) / 0.1);
    border-color: hsl(var(--color-primary-hsl));
}

.btn.btn-outline-secondary {
    background-color: transparent;
    color: hsl(var(--color-text-main-hsl));
    border-color: hsl(var(--color-bg-700-hsl));
    border-width: 2px;
}

.btn.btn-outline-secondary:hover:not(:disabled) {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
    border-color: hsl(var(--color-primary-hsl) / 0.3);
}

.btn.btn-outline-success {
    background-color: transparent;
    color: hsl(var(--color-success-hsl));
    border-color: hsl(var(--color-success-hsl) / 0.4);
    border-width: 2px;
}

.btn.btn-outline-success:hover:not(:disabled) {
    background-color: hsl(var(--color-success-hsl) / 0.1);
    border-color: hsl(var(--color-success-hsl));
}

.btn.btn-outline-danger {
    background-color: transparent;
    color: hsl(var(--color-error-hsl));
    border-color: hsl(var(--color-error-hsl) / 0.4);
    border-width: 2px;
}

.btn.btn-outline-danger:hover:not(:disabled) {
    background-color: hsl(var(--color-error-hsl) / 0.1);
    border-color: hsl(var(--color-error-hsl));
}

.btn.btn-outline-warning {
    background-color: transparent;
    color: hsl(var(--color-warning-hsl));
    border-color: hsl(var(--color-warning-hsl) / 0.4);
    border-width: 2px;
}

.btn.btn-outline-warning:hover:not(:disabled) {
    background-color: hsl(var(--color-warning-hsl) / 0.1);
    border-color: hsl(var(--color-warning-hsl));
}

.btn.btn-outline-info {
    background-color: transparent;
    color: hsl(var(--color-info-hsl));
    border-color: hsl(var(--color-info-hsl) / 0.4);
    border-width: 2px;
}

.btn.btn-outline-info:hover:not(:disabled) {
    background-color: hsl(var(--color-info-hsl) / 0.1);
    border-color: hsl(var(--color-info-hsl));
}

/* ===== BOTÕES DE ÍCONE (Ações rápidas compactas) ===== */
.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border-radius: var(--radius-full);
    border: none;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    flex-shrink: 0;
}

.btn-icon.btn-icon-sm {
    width: 32px;
    height: 32px;
}

.btn-icon.btn-icon-lg {
    width: 48px;
    height: 48px;
}

/* Variantes de cores para btn-icon */
.btn-icon-primary {
    background-color: hsl(var(--color-primary-hsl) / 0.1);
    color: hsl(var(--color-primary-hsl));
}

.btn-icon-primary:hover:not(:disabled) {
    background-color: hsl(var(--color-primary-hsl) / 0.2);
    transform: scale(1.1);
}

.btn-icon-success {
    background-color: hsl(var(--color-success-hsl) / 0.1);
    color: hsl(var(--color-success-hsl));
}

.btn-icon-success:hover:not(:disabled) {
    background-color: hsl(var(--color-success-hsl) / 0.2);
    transform: scale(1.1);
}

.btn-icon-danger {
    background-color: hsl(var(--color-error-hsl) / 0.1);
    color: hsl(var(--color-error-hsl));
}

.btn-icon-danger:hover:not(:disabled) {
    background-color: hsl(var(--color-error-hsl) / 0.2);
    transform: scale(1.1);
}

.btn-icon-warning {
    background-color: hsl(var(--color-warning-hsl) / 0.1);
    color: hsl(var(--color-warning-hsl));
}

.btn-icon-warning:hover:not(:disabled) {
    background-color: hsl(var(--color-warning-hsl) / 0.2);
    transform: scale(1.1);
}

.btn-icon-info {
    background-color: hsl(var(--color-info-hsl) / 0.1);
    color: hsl(var(--color-info-hsl));
}

.btn-icon-info:hover:not(:disabled) {
    background-color: hsl(var(--color-info-hsl) / 0.2);
    transform: scale(1.1);
}

.btn-icon-neutral {
    background-color: hsl(var(--color-bg-700-hsl));
    color: hsl(var(--color-text-subtle-hsl));
}

.btn-icon-neutral:hover:not(:disabled) {
    background-color: hsl(var(--color-bg-700-hsl) / 0.8);
    color: hsl(var(--color-text-main-hsl));
    transform: scale(1.1);
}

/* ===== TAMANHOS DE BOTÕES ===== */
.btn.btn-xs {
    padding: 6px 12px;
    font-size: var(--font-size-xs);
    gap: 4px;
}

.btn.btn-sm {
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--font-size-xs);
}

.btn.btn-lg {
    padding: var(--spacing-lg) var(--spacing-2xl);
    font-size: var(--font-size-lg);
}

.btn.btn-xl {
    padding: 18px 32px;
    font-size: var(--font-size-xl);
}

/* ===== BOTÃO FULL WIDTH ===== */
.btn.btn-block {
    width: 100%;
}

/* ===== FOCUS STATE PARA ACESSIBILIDADE ===== */
.btn:focus-visible,
.btn-icon:focus-visible {
    outline: none !important;
    box-shadow: 0 0 0 3px hsl(var(--color-bg-900-hsl)),
                0 0 0 5px hsl(var(--color-primary-hsl)) !important;
}

/* ===== LOADING STATE ===== */
.btn.btn-loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.btn.btn-loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin-left: -8px;
    margin-top: -8px;
    border: 2px solid transparent;
    border-top-color: currentColor;
    border-radius: 50%;
    animation: button-loading-spinner 0.6s linear infinite;
}

@keyframes button-loading-spinner {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

/* ===== GRUPOS DE BOTÕES ===== */
.btn-group {
    display: inline-flex;
    gap: var(--spacing-sm);
}

.btn-group .btn:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.btn-group .btn:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    margin-left: -1px;
}


/* ========================================================================= */
/* CARDS E CONTAINERS                                                        */
/* ========================================================================= */

.card {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-card);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.card:hover {
    border-color: hsl(var(--color-primary-hsl) / 0.25);
    box-shadow: 0 10px 25px -3px rgb(0 0 0 / 0.3), 0 4px 6px -2px rgb(0 0 0 / 0.15), 0 0 0 1px rgba(37, 99, 235, 0.08);
    transform: translateY(-2px);
}

/* ===== CARDS COM EFEITO GLOW ===== */
.card-glow-primary,
.card-glow-secondary,
.card-glow-success,
.card-glow-warning,
.card-glow-yellow,
.card-glow-orange {
    position: relative;
    overflow: hidden;
    transition: all var(--transition-slow);
}

.card-glow-primary::before,
.card-glow-secondary::before,
.card-glow-success::before,
.card-glow-warning::before,
.card-glow-yellow::before,
.card-glow-orange::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 250%;
    height: 250%;
    border-radius: var(--radius-full);
    transform: translate(-50%, -50%);
    opacity: 0.12;
    transition: width 300ms cubic-bezier(0.4, 0, 0.2, 1), height 300ms cubic-bezier(0.4, 0, 0.2, 1), opacity 300ms cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
    z-index: 0;
}

.card-glow-primary::before {
    background: radial-gradient(circle, hsl(var(--color-primary-hsl)) 0%, transparent 70%);
}

.card-glow-secondary::before {
    background: radial-gradient(circle, hsl(var(--color-secondary-hsl)) 0%, transparent 70%);
}

.card-glow-success::before {
    background: radial-gradient(circle, hsl(var(--color-success-hsl)) 0%, transparent 70%);
}

.card-glow-warning::before,
.card-glow-yellow::before {
    background: radial-gradient(circle, hsl(var(--color-warning-hsl)) 0%, transparent 70%);
}

.card-glow-orange::before {
    background: radial-gradient(circle, hsl(22 95% 53%) 0%, transparent 70%);
}

.card-glow-primary:hover::before,
.card-glow-secondary:hover::before,
.card-glow-success:hover::before,
.card-glow-warning:hover::before,
.card-glow-yellow:hover::before,
.card-glow-orange:hover::before {
    width: 300%;
    height: 300%;
    opacity: 0.18;
}


/* ========================================================================= */
/* TIPOGRAFIA APRIMORADA - HEADLINES                                         */
/* ========================================================================= */

/* Headlines com presença visual melhorada - inspirado no Eagles design */
.headline-lg {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    letter-spacing: -0.02em;
}

.headline-xl {
    font-size: var(--font-size-4xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
    letter-spacing: -0.02em;
}

/* Melhorar contraste de títulos em cards */
.card-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    line-height: var(--line-height-normal);
}

.card-title-lg {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-tight);
}

/* Subtítulos com melhor hierarquia */
.subtitle {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-normal);
}

.subtitle-lg {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-normal);
}


/* ========================================================================= */
/* BREADCRUMBS/NAVEGAÇÃO SECUNDÁRIA                                         */
/* ========================================================================= */

.breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    margin-bottom: var(--spacing-lg);
}

.breadcrumb-item {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    color: hsl(var(--color-text-subtle-hsl));
    text-decoration: none;
    transition: color 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.breadcrumb-item:hover:not(.active) {
    color: hsl(var(--color-primary-hsl));
}

.breadcrumb-item.active {
    color: hsl(var(--color-text-main-hsl));
    font-weight: var(--font-weight-medium);
}

.breadcrumb-separator {
    color: hsl(var(--color-text-muted-hsl) / 0.6);
    user-select: none;
}

.breadcrumb-icon {
    width: 16px;
    height: 16px;
}

/* Breadcrumb variant - com background */
.breadcrumb-bg {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}


/* ========================================================================= */
/* PAGE HEADERS - CABEÇALHOS DE PÁGINA PADRONIZADOS                         */
/* ========================================================================= */

.page-header {
    margin-bottom: var(--spacing-xl);
    padding-bottom: var(--spacing-lg);
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl) / 0.5);
}

.page-header-title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: hsl(var(--color-text-main-hsl));
    line-height: var(--line-height-tight);
    letter-spacing: -0.02em;
    margin-bottom: var(--spacing-xs);
}

.page-header-subtitle {
    font-size: var(--font-size-base);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-normal);
    margin-bottom: var(--spacing-md);
}

.page-header-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    margin-top: var(--spacing-md);
}

.page-header-meta-item {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.page-header-meta-item i {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

/* Page header com ações */
.page-header-with-actions {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.page-header-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex-shrink: 0;
}


/* ========================================================================= */
/* SECTION HEADERS - CABEÇALHOS DE SEÇÃO                                    */
/* ========================================================================= */

.section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-md);
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl) / 0.3);
}

.section-title {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-bold);
    color: hsl(var(--color-text-main-hsl));
}

.section-title-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 6px;
    border-radius: var(--radius-lg);
    background-color: hsl(var(--color-primary-hsl) / 0.1);
}

.section-title-icon i {
    width: 20px;
    height: 20px;
    color: hsl(var(--color-primary-hsl));
}

.section-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}


/* ========================================================================= */
/* BADGES E TAGS PADRONIZADOS                                               */
/* ========================================================================= */

.badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    line-height: 1.5;
    white-space: nowrap;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.badge-primary {
    background-color: hsl(var(--color-primary-hsl) / 0.15);
    color: hsl(244 76% 70%);
    border: 1px solid hsl(var(--color-primary-hsl) / 0.3);
}

.badge-secondary {
    background-color: hsl(var(--color-secondary-hsl) / 0.15);
    color: hsl(158 82% 55%);
    border: 1px solid hsl(var(--color-secondary-hsl) / 0.3);
}

.badge-success {
    background-color: hsl(var(--color-success-hsl) / 0.15);
    color: hsl(142 71% 55%);
    border: 1px solid hsl(var(--color-success-hsl) / 0.3);
}

.badge-warning {
    background-color: hsl(var(--color-warning-hsl) / 0.15);
    color: hsl(38 92% 60%);
    border: 1px solid hsl(var(--color-warning-hsl) / 0.3);
}

.badge-error {
    background-color: hsl(var(--color-error-hsl) / 0.15);
    color: hsl(0 84% 70%);
    border: 1px solid hsl(var(--color-error-hsl) / 0.3);
}

.badge-neutral {
    background-color: hsl(var(--color-bg-700-hsl));
    color: hsl(var(--color-text-subtle-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
}

.badge-dot {
    position: relative;
    padding-left: 20px;
}

.badge-dot::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: currentColor;
}


/* ========================================================================= */
/* LISTAS E CARDS DE ITENS                                                  */
/* ========================================================================= */

.list-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.list-item {
    display: block;
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    text-decoration: none;
    color: inherit;
}

.list-item:hover {
    border-color: hsl(var(--color-primary-hsl) / 0.5);
    background-color: hsl(var(--color-bg-800-hsl) / 0.8);
    transform: translateY(-2px);
    box-shadow: 0 10px 25px -3px rgb(0 0 0 / 0.2), 0 4px 6px -2px rgb(0 0 0 / 0.1);
}

.list-item-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-sm);
}

.list-item-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    line-height: var(--line-height-tight);
}

.list-item-subtitle {
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    margin-top: var(--spacing-xs);
}

.list-item-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
    font-size: var(--font-size-xs);
    color: hsl(var(--color-text-subtle-hsl));
    margin-top: var(--spacing-md);
}

.list-item-meta-item {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.list-item-meta-item i {
    width: 14px;
    height: 14px;
    opacity: 0.6;
}

.list-item-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-shrink: 0;
}


/* ========================================================================= */
/* CARDS APRIMORADOS - VARIANTES                                            */
/* ========================================================================= */

/* Card stat - para estatísticas do dashboard */
.card-stat {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-xl);
    padding: var(--spacing-lg);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.card-stat:hover {
    border-color: hsl(var(--color-primary-hsl) / 0.3);
    transform: translateY(-2px);
    box-shadow: 0 10px 25px -3px rgb(0 0 0 / 0.2), 0 4px 6px -2px rgb(0 0 0 / 0.1);
}

.card-stat-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.card-stat-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    padding: 10px;
    border-radius: var(--radius-lg);
    background-color: hsl(var(--color-primary-hsl) / 0.1);
    flex-shrink: 0;
}

.card-stat-icon i {
    width: 24px;
    height: 24px;
    color: hsl(var(--color-primary-hsl));
}

.card-stat-label {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-text-subtle-hsl));
}

.card-stat-value {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: hsl(var(--color-text-main-hsl));
    line-height: var(--line-height-tight);
    margin-bottom: var(--spacing-xs);
}

.card-stat-footer {
    font-size: var(--font-size-xs);
    color: hsl(var(--color-text-subtle-hsl));
    margin-top: var(--spacing-sm);
}

/* Card com borda superior colorida */
.card-bordered-top {
    border-top: 4px solid hsl(var(--color-primary-hsl));
}

.card-bordered-top-success {
    border-top-color: hsl(var(--color-success-hsl));
}

.card-bordered-top-warning {
    border-top-color: hsl(var(--color-warning-hsl));
}

.card-bordered-top-error {
    border-top-color: hsl(var(--color-error-hsl));
}


/* ========================================================================= */
/* UTILITÁRIOS DE LAYOUT E ESPAÇAMENTO                                      */
/* ========================================================================= */

/* Container com largura máxima e centralizado */
.container-narrow {
    max-width: 768px;
    margin-left: auto;
    margin-right: auto;
}

.container-medium {
    max-width: 1024px;
    margin-left: auto;
    margin-right: auto;
}

.container-wide {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
}

/* Grid responsivo de cards */
.grid-cards {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.grid-cards-2 {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(2, 1fr);
}

.grid-cards-3 {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(3, 1fr);
}

.grid-cards-4 {
    display: grid;
    gap: var(--spacing-lg);
    grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 1024px) {
    .grid-cards-4 {
        grid-template-columns: repeat(2, 1fr);
    }
    .grid-cards-3 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .grid-cards-4,
    .grid-cards-3,
    .grid-cards-2 {
        grid-template-columns: 1fr;
    }
}

/* Espaçamentos utilitários */
.section-spacing {
    margin-bottom: var(--spacing-2xl);
}

.content-spacing {
    margin-bottom: var(--spacing-xl);
}

.item-spacing {
    margin-bottom: var(--spacing-lg);
}


/* ========================================================================= */
/* ESTADOS VAZIOS E FEEDBACK                                                */
/* ========================================================================= */

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--spacing-4xl) var(--spacing-xl);
    min-height: 320px;
}

.empty-state-icon {
    width: 64px;
    height: 64px;
    margin-bottom: var(--spacing-lg);
    opacity: 0.3;
}

.empty-state-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    margin-bottom: var(--spacing-sm);
}

.empty-state-description {
    font-size: var(--font-size-base);
    color: hsl(var(--color-text-subtle-hsl));
    max-width: 480px;
    margin-bottom: var(--spacing-lg);
}

.empty-state-action {
    margin-top: var(--spacing-md);
}


/* ========================================================================= */
/* TABS/ABAS DE NAVEGAÇÃO                                                   */
/* ========================================================================= */

nav[aria-label="Tabs"] {
    position: relative;
    border-bottom: 2px solid hsl(var(--color-bg-700-hsl));
}

.tab-btn {
    background-color: transparent !important;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    padding: var(--spacing-md) var(--spacing-lg);
    color: hsl(var(--color-text-subtle-hsl));
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    border-radius: var(--radius-md) var(--radius-md) 0 0;
    transition: all var(--transition-base);
    cursor: pointer;
}

.tab-btn:not(.active):hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08) !important;
    color: hsl(var(--color-primary-hsl)) !important;
}

.tab-btn.active {
    color: hsl(var(--color-text-main-hsl)) !important;
    font-weight: var(--font-weight-semibold);
    border-bottom-color: hsl(var(--color-primary-hsl)) !important;
    background-color: hsl(var(--color-primary-hsl) / 0.15) !important;
}


/* ========================================================================= */
/* SIDEBAR/MENU LATERAL                                                     */
/* ========================================================================= */

aside nav a {
    display: block;
    padding: var(--spacing-md);
    border: 2px solid transparent;
    border-radius: var(--radius-lg);
    transition: all var(--transition-base);
    color: hsl(var(--color-text-subtle-hsl));
}

aside nav a i {
    transition: color var(--transition-base);
}

/* Item ativo */
aside nav a.active {
    background-color: hsl(var(--color-primary-hsl)) !important;
    border-color: hsl(var(--color-primary-hsl)) !important;
}

aside nav a.active i {
    color: #ffffff !important;
}

/* Hover em itens não ativos */
aside nav a:not(.active):hover {
    background-color: hsl(var(--color-primary-hsl) / 0.1) !important;
    border-color: hsl(var(--color-primary-hsl)) !important;
}

aside nav a:not(.active):hover i {
    color: hsl(var(--color-primary-hsl)) !important;
}

/* Hover em item ativo */
aside nav a.active:hover {
    opacity: 0.9;
}


/* ========================================================================= */
/* DROPDOWN MENUS                                                            */
/* ========================================================================= */

#profile-menu-dropdown,
#notifications-dropdown {
    background-color: hsl(var(--color-bg-800-hsl)) !important;
    border: 1px solid hsl(var(--color-bg-700-hsl)) !important;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
}

#profile-menu-dropdown p,
#profile-menu-dropdown a {
    color: hsl(var(--color-text-main-hsl)) !important;
}

#profile-menu-dropdown p.text-dark-subtext,
#profile-menu-dropdown a.text-dark-subtext {
    color: hsl(var(--color-text-subtle-hsl)) !important;
}

#profile-menu-dropdown a.text-red-400 {
    color: hsl(var(--color-error-hsl)) !important;
}

/* Hover azulado no menu de perfil (dark theme) */
#profile-menu-dropdown a:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
}

/* ========================================================================= */
/* ÍCONES DO HEADER                                                         */
/* ========================================================================= */

/* Hover azulado nos botões/ícones do header (dark theme) */
#app-header button:hover,
#app-header .hover\:bg-dark-700:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08) !important;
}

/* ========================================================================= */
/* WIDGET DE AJUDA                                                          */
/* ========================================================================= */

#help-widget-card {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
}

#help-widget-card a:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
}


/* ========================================================================= */
/* SISTEMA DE NOTIFICAÇÕES                                                  */
/* ========================================================================= */

#notifications-dropdown {
    animation: fadeIn var(--transition-base) ease-out;
}

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

.notification-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl));
    cursor: pointer;
    transition: background-color var(--transition-base);
    position: relative;
}

.notification-item:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.05);
}

.notification-item:last-child {
    border-bottom: none;
}

.notification-item.unread {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
}

.notification-item.unread::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background-color: hsl(var(--color-primary-hsl));
}

.notification-icon {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
}

.notification-icon.info {
    background-color: hsl(var(--color-info-hsl) / 0.1);
    color: hsl(var(--color-info-hsl));
}

.notification-icon.sucesso {
    background-color: hsl(var(--color-success-hsl) / 0.1);
    color: hsl(var(--color-success-hsl));
}

.notification-icon.alerta {
    background-color: hsl(var(--color-warning-hsl) / 0.1);
    color: hsl(var(--color-warning-hsl));
}

.notification-icon.erro {
    background-color: hsl(var(--color-error-hsl) / 0.1);
    color: hsl(var(--color-error-hsl));
}

.notification-content {
    flex: 1;
    min-width: 0;
}

.notification-title {
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    font-size: var(--font-size-sm);
    margin-bottom: var(--spacing-xs);
}

.notification-message {
    color: hsl(var(--color-text-subtle-hsl));
    font-size: var(--font-size-xs);
    line-height: var(--line-height-tight);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.notification-time {
    color: hsl(var(--color-text-subtle-hsl) / 0.7);
    font-size: var(--font-size-xs);
    margin-top: var(--spacing-xs);
}

#notifications-badge.pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

@keyframes pulse {
    0%, 100% {
        opacity: 1;
    }
    50% {
        opacity: 0.7;
    }
}

#notifications-list::-webkit-scrollbar {
    width: 6px;
}

#notifications-list::-webkit-scrollbar-track {
    background: hsl(var(--color-bg-900-hsl));
}

#notifications-list::-webkit-scrollbar-thumb {
    background: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-sm);
}

#notifications-list::-webkit-scrollbar-thumb:hover {
    background: hsl(var(--color-primary-hsl) / 0.6);
}


/* ========================================================================= */
/* TOAST/NOTIFICAÇÕES - SONNER-INSPIRED MODERN DESIGN                        */
/* ========================================================================= */

#toast-container {
    z-index: var(--z-toast) !important;
    pointer-events: none;
}

#toast-container > * {
    pointer-events: auto;
}

/* Modern Toast - Sonner-inspired */
.toast-modern {
    --toast-accent: #10b981;
    --toast-icon: #34d399;
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px 14px 20px;
    border-radius: 14px;
    background: hsl(var(--color-bg-700-hsl) / 0.95);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid hsl(var(--color-bg-600-hsl) / 0.6);
    color: hsl(var(--color-text-main-hsl));
    box-shadow:
        0 8px 32px -4px rgba(0, 0, 0, 0.35),
        0 4px 12px -2px rgba(0, 0, 0, 0.2),
        inset 0 1px 0 rgba(255, 255, 255, 0.04);
    overflow: hidden;
    animation: toastSlideIn 0.35s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
    width: 100%;
}

/* Accent bar on the left */
.toast-modern-accent {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--toast-accent);
    border-radius: 14px 0 0 14px;
}

.toast-modern-icon {
    flex-shrink: 0;
    color: var(--toast-icon);
    display: flex;
    align-items: center;
    justify-content: center;
}

.toast-modern-message {
    flex: 1;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.4;
    color: hsl(var(--color-text-main-hsl));
}

.toast-modern-close {
    flex-shrink: 0;
    color: hsl(var(--color-text-muted-hsl));
    padding: 4px;
    border-radius: 6px;
    transition: all 0.15s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
}

.toast-modern:hover .toast-modern-close {
    opacity: 1;
}

.toast-modern-close:hover {
    color: hsl(var(--color-text-main-hsl));
    background: hsl(var(--color-bg-600-hsl) / 0.3);
}

/* Undo button */
.toast-modern-undo {
    flex-shrink: 0;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--toast-accent);
    padding: 4px 8px;
    border-radius: 6px;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.toast-modern-undo:hover {
    background: rgba(255, 255, 255, 0.08);
}

/* Progress bar at bottom */
.toast-modern-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: rgba(255, 255, 255, 0.06);
    overflow: hidden;
}

.toast-modern-progress::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background: var(--toast-accent);
    opacity: 0.5;
    animation: toastProgressShrink var(--progress-duration, 4s) linear forwards;
}

/* Animations */
@keyframes toastSlideIn {
    from {
        opacity: 0;
        transform: translateY(16px) scale(0.96);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.toast-exit {
    animation: toastSlideOut 0.2s ease-in forwards !important;
}

@keyframes toastSlideOut {
    from {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
    to {
        opacity: 0;
        transform: translateY(8px) scale(0.96);
    }
}

@keyframes toastProgressShrink {
    from { width: 100%; }
    to { width: 0%; }
}

/* Legacy animation classes - kept for backward compatibility */
.animate-slide-up {
    animation: toastSlideIn 0.35s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
}

.animate-slide-up-shake {
    animation: toastSlideIn 0.35s cubic-bezier(0.21, 1.02, 0.73, 1) forwards;
}

.animate-slide-down {
    animation: toastSlideOut 0.2s ease-in forwards;
}

/* Animações para modais de confirmação */
.animate-fade-in {
    animation: confirmFadeIn 0.2s ease-out forwards;
}

.animate-fade-out {
    animation: confirmFadeOut 0.2s ease-in forwards;
}

.animate-scale-in {
    animation: confirmScaleIn 0.2s ease-out forwards;
}

.animate-scale-out {
    animation: confirmScaleOut 0.15s ease-in forwards;
}

@keyframes confirmFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes confirmFadeOut {
    from { opacity: 1; }
    to { opacity: 0; }
}

@keyframes confirmScaleIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

@keyframes confirmScaleOut {
    from {
        opacity: 1;
        transform: scale(1);
    }
    to {
        opacity: 0;
        transform: scale(0.95);
    }
}


/* ========================================================================= */
/* MODAIS                                                                    */
/* ========================================================================= */

.modal-backdrop {
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    z-index: var(--z-modal-backdrop);
}

.modal-content {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-2xl);
    z-index: var(--z-modal);
}


/* ========================================================================= */
/* LOADING SPINNER                                                           */
/* ========================================================================= */

#main-content .loader {
    border: 4px solid hsl(var(--color-bg-700-hsl));
    border-top: 4px solid hsl(var(--color-primary-hsl));
    border-radius: var(--radius-full);
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@keyframes spin {
    0% {
        transform: translate(-50%, -50%) rotate(0deg);
    }
    100% {
        transform: translate(-50%, -50%) rotate(360deg);
    }
}


/* ========================================================================= */
/* TOM SELECT (SELETOR DE CNAE)                                             */
/* ========================================================================= */

.ts-control {
    background-color: hsl(var(--color-bg-900-hsl)) !important;
    border-color: hsl(var(--color-bg-700-hsl)) !important;
    color: hsl(var(--color-text-main-hsl)) !important;
    border-radius: var(--radius-md) !important;
}

.ts-control .item-placeholder {
    color: hsl(var(--color-text-subtle-hsl)) !important;
}

.ts-control > .item {
    background-color: hsl(var(--color-bg-700-hsl)) !important;
    color: hsl(var(--color-text-main-hsl)) !important;
    border: 1px solid hsl(var(--color-text-subtle-hsl) / 0.3);
    border-radius: var(--radius-sm);
    padding: 2px 6px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 95%;
}

.ts-dropdown {
    background: hsl(var(--color-bg-800-hsl)) !important;
    border-color: hsl(var(--color-bg-700-hsl)) !important;
    color: hsl(var(--color-text-main-hsl)) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-lg);
}

.ts-dropdown .option.active {
    background-color: hsl(var(--color-primary-hsl) / 0.1) !important;
    color: hsl(var(--color-text-main-hsl)) !important;
}


/* ========================================================================= */
/* FLATPICKR (CALENDÁRIO)                                                   */
/* ========================================================================= */

.flatpickr-calendar {
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    padding: var(--spacing-sm) var(--spacing-md);
}

.flatpickr-months {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: var(--spacing-sm);
    height: 34px;
}

.flatpickr-current-month {
    flex-grow: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-xs);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    font-size: var(--font-size-lg);
    height: 100%;
}

.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
    font-size: 1em;
    font-weight: inherit;
    color: inherit;
    background: transparent;
    border: none;
    padding: 0 var(--spacing-xs);
}

.flatpickr-current-month .numInputWrapper {
    display: inline-block;
}

.flatpickr-current-month input.cur-year {
    width: 4.5ch;
    padding: 0;
}

.flatpickr-current-month input.cur-year:focus {
    outline: none;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 34px;
    width: 34px;
    padding: 0;
    border-radius: var(--radius-md);
    flex-shrink: 0;
    transition: background-color var(--transition-base);
    cursor: pointer;
}

.flatpickr-prev-month:hover,
.flatpickr-next-month:hover {
    background-color: hsl(var(--color-bg-700-hsl));
}

.flatpickr-prev-month svg,
.flatpickr-next-month svg {
    width: 1rem;
    height: 1rem;
    stroke: hsl(var(--color-text-subtle-hsl));
    fill: hsl(var(--color-text-subtle-hsl));
}

.flatpickr-calendar .flatpickr-weekday {
    color: hsl(var(--color-text-subtle-hsl));
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-xs);
}

.flatpickr-day {
    width: 38px;
    height: 38px;
    line-height: 38px;
    border-radius: var(--radius-full);
    border: 1px solid transparent;
    color: hsl(var(--color-text-main-hsl));
    transition: all var(--transition-base);
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
    color: hsl(var(--color-text-main-hsl) / 0.3);
}

.flatpickr-day:not(.selected):hover {
    background-color: hsl(var(--color-primary-hsl) / 0.1);
    border-color: hsl(var(--color-primary-hsl));
    color: hsl(var(--color-primary-hsl));
}

.flatpickr-day.today {
    border-color: hsl(var(--color-primary-hsl));
}

.flatpickr-day.today:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.1);
    border-color: hsl(var(--color-primary-hsl));
    color: hsl(var(--color-primary-hsl));
}

.flatpickr-day.selected {
    background-color: hsl(var(--color-primary-hsl) / 0.15);
    border-color: hsl(var(--color-primary-hsl));
    color: hsl(var(--color-primary-hsl));
    font-weight: var(--font-weight-semibold);
}

.flatpickr-day.selected:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.25);
    border-color: hsl(var(--color-primary-hsl));
}


/* ========================================================================= */
/* ANIMAÇÕES E UTILITÁRIOS                                                  */
/* ========================================================================= */

@keyframes fadeInRight {
    from {
        opacity: 0;
        transform: translateX(100%);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes fadeOutRight {
    from {
        opacity: 1;
        transform: translateX(0);
    }
    to {
        opacity: 0;
        transform: translateX(100%);
    }
}

.animate-fade-in-right {
    animation: fadeInRight 0.5s ease-out forwards;
}

.animate-fade-out-right {
    animation: fadeOutRight 0.5s ease-in forwards;
}

/* ===== CLASSES UTILITÁRIAS ===== */
.truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}


/* ========================================================================= */
/* MELHORIAS ESPECÍFICAS PARA TEMA CLARO                                    */
/* ========================================================================= */


/* Sidebar - PERMANECE ESCURO no tema claro (estilo Pipedrive) */
/* Nota: Regras específicas para #app-sidebar estão no final do arquivo */


/* Cards coloridos - Paleta Pastel Moderna (estilo Linear/Notion) */


/* ===== ÍCONES DO SIDEBAR E HEADER - REFINADOS ===== */


/* ========================================================================= */
/* SISTEMA DE MODAIS PADRONIZADOS                                          */
/* ========================================================================= */

/**
 * BASE DO MODAL
 * Overlay escuro com backdrop blur
 */
.modal-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    z-index: 9500;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    opacity: 0;
    transition: opacity 0.2s ease-in-out;
}

.modal-overlay:not(.hidden) {
    opacity: 1;
}

/**
 * CONTAINER DO MODAL
 * Tamanhos padronizados por tipo
 */
.modal-container {
    background-color: hsl(var(--color-bg-800-hsl));
    border-radius: 12px;
    border: 1px solid hsl(var(--color-bg-700-hsl));
    max-height: 90vh;
    overflow-y: auto;
    width: 100%;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
    transform: scale(0.95);
    transition: transform 0.2s ease-in-out;
}

.modal-overlay:not(.hidden) .modal-container {
    transform: scale(1);
}

/* Tamanhos dos modais */
.modal-sm {
    max-width: 24rem; /* 384px - Confirmações simples */
}

.modal-md {
    max-width: 28rem; /* 448px - Confirmações com mais texto */
}

.modal-lg {
    max-width: 32rem; /* 512px - Formulários simples */
}

.modal-xl {
    max-width: 42rem; /* 672px - Formulários médios */
}

.modal-2xl {
    max-width: 56rem; /* 896px - Formulários complexos */
}

.modal-3xl {
    max-width: 64rem; /* 1024px - Visualizações amplas */
}

.modal-full {
    max-width: 90vw; /* Modais que precisam de muito espaço */
}

/**
 * CABEÇALHO DO MODAL
 * Sticky no topo com separador
 */
.modal-header {
    position: sticky;
    top: 0;
    background-color: hsl(var(--color-bg-800-hsl));
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl));
    padding: 1rem 1.25rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: 10;
}

.modal-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-bold);
    color: hsl(var(--color-text-main-hsl));
    margin: 0;
}

.modal-close-btn {
    color: hsl(var(--color-text-subtle-hsl));
    transition: color 0.2s ease;
    cursor: pointer;
    background: none;
    border: none;
    padding: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

.modal-close-btn:hover {
    color: hsl(var(--color-text-main-hsl));
}

/**
 * CORPO DO MODAL
 * Área de conteúdo com padding padronizado
 */
.modal-body {
    padding: 1.25rem;
}

.modal-body-sm {
    padding: 0.75rem;
}

.modal-body-lg {
    padding: 1.5rem;
}

/**
 * RODAPÉ DO MODAL
 * Para ações e botões
 */
.modal-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid hsl(var(--color-bg-700-hsl));
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
    background-color: hsl(var(--color-bg-800-hsl));
}

.modal-footer-center {
    justify-content: center;
}

.modal-footer-space-between {
    justify-content: space-between;
}

/**
 * VARIAÇÕES POR TIPO DE MODAL
 */

/* Modal de Confirmação */
.modal-confirm .modal-header {
    padding-bottom: 1rem;
}

.modal-confirm .modal-icon {
    width: 3rem;
    height: 3rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1rem;
}

.modal-confirm.modal-warning .modal-icon {
    background-color: rgba(245, 158, 11, 0.1);
    color: rgb(245, 158, 11);
}

.modal-confirm.modal-danger .modal-icon {
    background-color: rgba(239, 68, 68, 0.1);
    color: rgb(239, 68, 68);
}

.modal-confirm.modal-success .modal-icon {
    background-color: rgba(16, 185, 129, 0.1);
    color: rgb(16, 185, 129);
}

.modal-confirm.modal-info .modal-icon {
    background-color: rgba(59, 130, 246, 0.1);
    color: rgb(59, 130, 246);
}

/* Modal de Formulário */
.modal-form .modal-body {
    padding: 2rem 1.5rem;
}

/**
 * DESCRIÇÕES E TEXTOS
 */
.modal-description {
    color: hsl(var(--color-text-subtle-hsl));
    font-size: var(--font-size-sm);
    line-height: var(--line-height-relaxed);
    margin: 0;
}

/**
 * TEMA CLARO
 */

/**
 * RESPONSIVIDADE
 */
@media (max-width: 640px) {
    .modal-container {
        margin: 1rem;
        max-height: calc(100vh - 2rem);
    }

    .modal-xl,
    .modal-2xl,
    .modal-3xl {
        max-width: 100%;
    }
}

/* ========================================================================= */
/* LAYOUT PRINCIPAL - PREVENIR OVERFLOW HORIZONTAL GLOBAL                    */
/* ========================================================================= */

/**
 * Container principal do sistema (flex h-screen)
 * Layout: [Sidebar 72px] [Conteúdo flex-1]
 * Mobile: permite scroll vertical no body
 * Desktop: previne scroll global (scroll é no #main-content)
 */
.flex.h-screen {
    width: 100vw;
    max-width: 100vw;
}

/* Apenas desktop (md+): previne scroll global */
@media (min-width: 768px) {
    .flex.h-screen {
        overflow: hidden;
    }
}

/**
 * Container do conteúdo (main + sidebar direito)
 * Estrutura: [Main Content flex-1] [Sidebar Direito 288px]
 * CRÍTICO: min-width: 0 permite que flex items encolham além do conteúdo
 */
.flex-1.flex.overflow-hidden {
    min-width: 0;
    overflow: hidden;
}

/**
 * Sidebar direito - sempre visível e com largura fixa
 */
#right-sidebar {
    flex-shrink: 0; /* Nunca encolhe */
    width: 18rem; /* 288px - mantém largura fixa */
}

/* ========================================================================= */
/* MÓDULO CRM - KANBAN DE NEGÓCIOS                                          */
/* ========================================================================= */

/**
 * MAIN CONTENT - SCROLL VERTICAL
 * O scroll horizontal é controlado pela .kanban-wrapper interna
 * Layout: [Sidebar 72px] [Main Content dinâmico]
 *
 * CRÍTICO: max-width calculado dinamicamente considerando a sidebar esquerda
 * Largura disponível = 100vw - 72px (sidebar esq)
 */
#main-content {
    overflow-y: auto;
    overflow-x: hidden;
    min-width: 0;
    width: 100%;
    max-width: calc(100vw - 72px); /* Dinâmico: viewport - sidebar esquerda */
    flex: 1 1 auto;
}

/**
 * WRAPPER DO KANBAN - SCROLL HORIZONTAL ISOLADO
 * Largura disponível = 100% do #main-content (que já é calculado)
 * #main-content = calc(100vw - 72px)
 * Kanban Board = 6 colunas × 320px = ~1920px
 *
 * ALTURA: Máxima calculada para respeitar viewport vertical
 * Quando kanban-board > largura disponível, scroll horizontal aparece no RODAPÉ
 * Exemplo: viewport 1920px → disponível 1848px → scroll ativo
 */
.kanban-wrapper {
    width: 100%;
    max-width: 100%;
    max-height: calc(100vh - 220px); /* Altura máxima: viewport - header - padding */
    overflow-x: auto;
    overflow-y: visible;
    padding-bottom: 0.75rem;
}

/* Scrollbar horizontal do wrapper (padrão do sistema) */
.kanban-wrapper::-webkit-scrollbar {
    height: 8px;
}

.kanban-wrapper::-webkit-scrollbar-track {
    background: hsl(var(--color-bg-800-hsl));
}

.kanban-wrapper::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-sm);
    transition: background-color var(--transition-base);
}

.kanban-wrapper::-webkit-scrollbar-thumb:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.6);
}

/**
 * KANBAN BOARD
 * Display flex para as colunas lado a lado
 * width: max-content permite que as colunas expandam naturalmente
 * Se conteúdo > wrapper, aparece scroll horizontal
 */
.kanban-board {
    display: flex;
    gap: 0.75rem;
    width: max-content;
    min-width: 100%;
}

.kanban-column {
    min-width: 280px;
    max-width: 280px;
    flex-shrink: 0;
}

.kanban-cards {
    min-height: 150px;
    max-height: calc(100vh - 320px);
    overflow-y: auto;
    overflow-x: hidden; /* Remove scroll horizontal */
}

/* Remove scroll de qualquer elemento dentro dos cards */
.kanban-card,
.kanban-card *:not(svg):not(svg *) {
    overflow: hidden !important;
}

/* Scrollbar vertical nas colunas do Kanban */
.kanban-cards::-webkit-scrollbar {
    width: 6px;
}

.kanban-cards::-webkit-scrollbar-track {
    background: transparent;
}

.kanban-cards::-webkit-scrollbar-thumb {
    background: hsl(var(--color-bg-700-hsl));
    border-radius: 3px;
}

.kanban-cards::-webkit-scrollbar-thumb:hover {
    background: hsl(var(--color-text-subtle-hsl) / 0.5);
}

/**
 * KANBAN CARD (Cards de oportunidades)
 */
.kanban-card {
    cursor: grab;
    transition: all 0.2s ease;
    overflow: hidden !important; /* Remove qualquer scroll do card */
}

.kanban-card:active {
    cursor: grabbing;
}

.kanban-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.kanban-card.dragging {
    opacity: 0.5;
}

.kanban-column.drag-over {
    background-color: hsla(var(--color-primary-hsl), 0.05);
}

/**
 * INDICADORES DE SCROLL HORIZONTAL (Setas)
 * Posicionados fixos nas bordas laterais inferiores
 * Aparecem quando há conteúdo para scrollar
 */
.scroll-indicator {
    position: fixed;
    bottom: 20px;
    z-index: 50;
    background: hsl(var(--color-primary-hsl));
    color: #ffffff;
    border: none;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    border-radius: 50%;
    box-shadow: 0 2px 10px hsl(var(--color-primary-hsl) / 0.4);
    transition: all 0.2s ease;
    opacity: 0.85;
}

.scroll-indicator:hover {
    opacity: 1;
    transform: scale(1.1);
    box-shadow: 0 4px 16px hsl(var(--color-primary-hsl) / 0.5);
}

.scroll-indicator.left {
    left: 90px;
}

.scroll-indicator.right {
    right: 20px;
}

.scroll-indicator.hidden {
    opacity: 0 !important;
    pointer-events: none;
    transform: scale(0.9);
}

/**
 * ABAS DO MODAL DE DETALHES
 */
.tab-btn {
    color: hsl(var(--color-text-subtle-hsl));
}

.tab-btn.active {
    color: hsl(var(--color-primary-hsl));
    border-bottom-color: hsl(var(--color-primary-hsl));
}

/**
 * PIPELINE FULL WIDTH - Scroll na borda
 * Faz o pipeline ocupar 100% da largura com scroll horizontal na borda da página
 */
.kanban-full-width {
    margin-left: calc(-1.5rem);
    margin-right: calc(-1.5rem);
    width: calc(100% + 3rem);
}

.kanban-wrapper-full {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0;
    /* Altura fixa para que o scrollbar horizontal fique colado no rodapé da viewport */
    height: calc(100vh - 195px);
}

/* Scrollbar horizontal do wrapper full width (padrão do sistema) */
.kanban-wrapper-full::-webkit-scrollbar {
    height: 8px;
}

.kanban-wrapper-full::-webkit-scrollbar-track {
    background: hsl(var(--color-bg-800-hsl));
    border-radius: 0;
}

.kanban-wrapper-full::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: 0;
}

.kanban-wrapper-full::-webkit-scrollbar-thumb:hover {
    background: hsl(var(--color-primary-hsl) / 0.8);
}

/* Remover spinners dos campos numéricos */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

/* Cursor pointer para campos de data (datepicker) */
.datepicker,
.datepicker-oportunidade,
input[type="text"][name="data_fechamento_prevista"],
input[type="text"][name="data_atividade"] {
    cursor: pointer !important;
}


/* ========================================================================= */
/* SPRINT 1 & 2: MELHORIAS UX/UI                                            */
/* ========================================================================= */

/* ===== SKELETON LOADERS (Sprint 1.3) ===== */

.skeleton {
    background: linear-gradient(
        90deg,
        hsl(var(--color-bg-800-hsl)) 0%,
        hsl(var(--color-bg-700-hsl)) 50%,
        hsl(var(--color-bg-800-hsl)) 100%
    );
    background-size: 200% 100%;
    animation: skeleton-loading 1.5s ease-in-out infinite;
    border-radius: var(--radius-md);
}

@keyframes skeleton-loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.skeleton-text {
    height: 16px;
    margin-bottom: var(--spacing-sm);
    width: 100%;
}

.skeleton-text--sm {
    height: 12px;
}

.skeleton-text--lg {
    height: 20px;
}

.skeleton-text:last-child {
    margin-bottom: 0;
    width: 60%;
}

.skeleton-avatar {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-full);
}

.skeleton-avatar--lg {
    width: 64px;
    height: 64px;
}

.skeleton-card {
    height: 120px;
    border-radius: var(--radius-lg);
}

.skeleton-button {
    height: 40px;
    width: 100px;
    border-radius: var(--radius-md);
}

/* ===== SPINNER/LOADER MELHORADO (Sprint 1.3) ===== */

.spinner {
    width: 20px;
    height: 20px;
    border: 2px solid hsl(var(--color-bg-700-hsl));
    border-top-color: hsl(var(--color-primary-hsl));
    border-radius: var(--radius-full);
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.spinner--sm {
    width: 16px;
    height: 16px;
    border-width: 2px;
}

.spinner--lg {
    width: 40px;
    height: 40px;
    border-width: 3px;
}

.spinner--xl {
    width: 64px;
    height: 64px;
    border-width: 4px;
}

/* Container de loading centralizado */
.loading-container {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
}

.loading-container--fullscreen {
    position: fixed;
    inset: 0;
    background: hsl(var(--color-bg-900-hsl) / 0.9);
    backdrop-filter: blur(4px);
    z-index: var(--z-modal);
}

/* ===== TOOLTIP SYSTEM (CSS-ONLY - OTIMIZADO) ===== */
/* Sistema de tooltips usando apenas CSS ::before/::after
 * Alta performance - sem criar elementos DOM extras
 * Uso: <element data-tooltip="Texto" data-tooltip-position="top">
 */

/* Base: Elementos com tooltip */
[data-tooltip] {
    position: relative;
}

/* Conteúdo do tooltip (usando ::before) */
[data-tooltip]::before {
    content: attr(data-tooltip);
    position: absolute;
    padding: 6px 12px;
    background: rgba(20, 20, 25, 0.96);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: #ffffff;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base) 0.3s, transform var(--transition-base) 0.3s;
    z-index: var(--z-toast);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    line-height: 1.4;
}

/* Seta do tooltip (usando ::after) */
[data-tooltip]::after {
    content: '';
    position: absolute;
    border: 5px solid transparent;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--transition-base) 0.3s, transform var(--transition-base) 0.3s;
    z-index: var(--z-toast);
}

/* Mostrar tooltip ao hover (com delay de 300ms) */
[data-tooltip]:hover::before,
[data-tooltip]:hover::after {
    opacity: 1;
    transition-delay: 0.3s;
}

/* ===== POSIÇÃO: TOP (padrão) ===== */
[data-tooltip]:not([data-tooltip-position])::before,
[data-tooltip][data-tooltip-position="top"]::before {
    bottom: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
}

[data-tooltip]:not([data-tooltip-position])::after,
[data-tooltip][data-tooltip-position="top"]::after {
    bottom: calc(100% + 5px);
    left: 50%;
    transform: translateX(-50%) translateY(4px);
    border-top-color: rgba(20, 20, 25, 0.96);
}

[data-tooltip]:not([data-tooltip-position]):hover::before,
[data-tooltip][data-tooltip-position="top"]:hover::before {
    transform: translateX(-50%) translateY(0);
}

[data-tooltip]:not([data-tooltip-position]):hover::after,
[data-tooltip][data-tooltip-position="top"]:hover::after {
    transform: translateX(-50%) translateY(0);
}

/* ===== POSIÇÃO: BOTTOM ===== */
[data-tooltip][data-tooltip-position="bottom"]::before {
    top: calc(100% + 10px);
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
}

[data-tooltip][data-tooltip-position="bottom"]::after {
    top: calc(100% + 5px);
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    border-bottom-color: rgba(20, 20, 25, 0.96);
}

[data-tooltip][data-tooltip-position="bottom"]:hover::before {
    transform: translateX(-50%) translateY(0);
}

[data-tooltip][data-tooltip-position="bottom"]:hover::after {
    transform: translateX(-50%) translateY(0);
}

/* ===== POSIÇÃO: LEFT ===== */
[data-tooltip][data-tooltip-position="left"]::before {
    right: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%) translateX(4px);
}

[data-tooltip][data-tooltip-position="left"]::after {
    right: calc(100% + 5px);
    top: 50%;
    transform: translateY(-50%) translateX(4px);
    border-left-color: rgba(20, 20, 25, 0.96);
}

[data-tooltip][data-tooltip-position="left"]:hover::before {
    transform: translateY(-50%) translateX(0);
}

[data-tooltip][data-tooltip-position="left"]:hover::after {
    transform: translateY(-50%) translateX(0);
}

/* ===== POSIÇÃO: RIGHT ===== */
[data-tooltip][data-tooltip-position="right"]::before {
    left: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%) translateX(-4px);
}

[data-tooltip][data-tooltip-position="right"]::after {
    left: calc(100% + 5px);
    top: 50%;
    transform: translateY(-50%) translateX(-4px);
    border-right-color: rgba(20, 20, 25, 0.96);
}

[data-tooltip][data-tooltip-position="right"]:hover::before {
    transform: translateY(-50%) translateX(0);
}

[data-tooltip][data-tooltip-position="right"]:hover::after {
    transform: translateY(-50%) translateX(0);
}


/* ===== TOOLTIP MULTILINE (para textos longos com quebra de linha) ===== */
.tooltip-multiline[data-tooltip]::before {
    white-space: normal;
    max-width: 280px;
    text-align: left;
    line-height: 1.4;
    padding: 8px 12px;
    font-size: 0.75rem;
}

/* ===== LOADING SPINNER MODERNO (PADRÃO DO SISTEMA) ===== */
/* Uso: <div class="loading-container"><div class="loading-spinner"><span></span></div><p class="loading-text">Carregando...</p></div> */

/* Container centralizado com texto */
.loading-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    padding: 2rem;
    min-height: 200px;
}

/* Spinner moderno - 3 círculos pulsantes */
.loading-spinner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.loading-spinner::before,
.loading-spinner::after,
.loading-spinner span {
    content: '';
    display: block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: var(--color-primary);
    animation: loading-pulse 1.4s ease-in-out infinite;
}

.loading-spinner::before {
    animation-delay: 0s;
}

.loading-spinner span {
    animation-delay: 0.2s;
}

.loading-spinner::after {
    animation-delay: 0.4s;
}

@keyframes loading-pulse {
    0%, 80%, 100% {
        opacity: 0.3;
        transform: scale(0.8);
    }
    40% {
        opacity: 1;
        transform: scale(1.1);
    }
}

/* Texto de loading */
.loading-text {
    color: var(--color-text-secondary);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    animation: loading-fade 1.5s ease-in-out infinite;
}

@keyframes loading-fade {
    0%, 100% {
        opacity: 0.5;
    }
    50% {
        opacity: 1;
    }
}

/* Spinner alternativo - círculo girando (para compatibilidade com ícones antigos) */
.loading-spinner-circle {
    display: inline-block;
    width: 40px;
    height: 40px;
    border: 3px solid var(--color-bg-700);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: loading-spin 0.8s linear infinite;
}

@keyframes loading-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Variantes de tamanho */
.loading-spinner-sm {
    gap: 0.25rem;
}

.loading-spinner-sm::before,
.loading-spinner-sm::after,
.loading-spinner-sm span {
    width: 8px;
    height: 8px;
}

.loading-spinner-lg {
    gap: 0.75rem;
}

.loading-spinner-lg::before,
.loading-spinner-lg::after,
.loading-spinner-lg span {
    width: 16px;
    height: 16px;
}

/* ===== TOAST NOTIFICATIONS MELHORADO (Sprint 1.2) ===== */

/* Container no topo direito (padrão moderno) */
.toast-container-top-right {
    position: fixed;
    top: var(--spacing-2xl);
    right: 100px; /* Alinhado com o início do conteúdo principal (cards de filtro) */
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    max-width: 420px;
    pointer-events: none;
}

.toast-container-top-right > * {
    pointer-events: auto;
}

/* Toast melhorado com ícones - Estilo "Invertido" Premium (alinhado com LP) */
.toast {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    background: hsl(var(--color-bg-800-hsl));
    backdrop-filter: blur(16px);
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.35), 0 8px 10px -6px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(37, 99, 235, 0.06);
    animation: slideInRight 0.3s ease;
    position: relative;
    overflow: hidden;
}

@keyframes slideInRight {
    from {
        transform: translateX(100%);
        opacity: 0;
    }
    to {
        transform: translateX(0);
        opacity: 1;
    }
}

@keyframes slideOutRight {
    from {
        transform: translateX(0);
        opacity: 1;
    }
    to {
        transform: translateX(100%);
        opacity: 0;
    }
}

.toast.is-leaving {
    animation: slideOutRight 0.2s ease forwards;
}

.toast-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-md);
    flex-shrink: 0;
}

.toast--success .toast-icon {
    background: rgba(16, 185, 129, 0.15);
    color: #34d399;
}

.toast--error .toast-icon {
    background: rgba(239, 68, 68, 0.15);
    color: #fb7185;
}

.toast--info .toast-icon {
    background: rgba(37, 99, 235, 0.15);
    color: #818cf8;
}

.toast--warning .toast-icon {
    background: rgba(245, 158, 11, 0.15);
    color: #fbbf24;
}

.toast-content {
    flex: 1;
    min-width: 0;
}

.toast-title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    margin: 0 0 4px 0;
}

.toast-message {
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    margin: 0;
    line-height: var(--line-height-normal);
}

.toast-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-sm);
}

.toast-action {
    padding: 6px 12px;
    background: transparent;
    border: 1px solid hsl(var(--color-bg-600-hsl));
    border-radius: var(--radius-sm);
    color: hsl(var(--color-text-main-hsl));
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: all var(--transition-base);
}

.toast-action:hover {
    background: hsl(var(--color-bg-700-hsl));
}

.toast-close {
    width: 24px;
    height: 24px;
    padding: 0;
    background: transparent;
    border: none;
    color: hsl(var(--color-text-muted-hsl));
    cursor: pointer;
    transition: color var(--transition-base);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.toast-close:hover {
    color: hsl(var(--color-text-main-hsl));
}

/* Progress bar do toast */
.toast-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: hsl(var(--color-bg-700-hsl));
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    overflow: hidden;
}

.toast-progress-bar {
    height: 100%;
    background: linear-gradient(90deg, #2563eb, #1d4ed8);
    animation: toastProgress 5s linear forwards;
}

@keyframes toastProgress {
    from { width: 100%; }
    to { width: 0%; }
}

/* ===== EMPTY STATES (Sprint 2.3) ===== */

.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-4xl) var(--spacing-2xl);
    text-align: center;
    min-height: 400px;
}

.empty-state-icon {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-xl);
    color: var(--text-tertiary);
    margin-bottom: var(--spacing-2xl);
}

.empty-state-icon svg,
.empty-state-icon i {
    width: 40px;
    height: 40px;
    opacity: 0.6;
}

.empty-state-title {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    color: var(--text-primary);
    margin: 0 0 var(--spacing-md) 0;
}

.empty-state-description {
    font-size: var(--font-size-base);
    color: var(--text-secondary);
    max-width: 480px;
    line-height: var(--line-height-relaxed);
    margin: 0 0 var(--spacing-2xl) 0;
}

.empty-state-actions {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    justify-content: center;
}

/* Empty state com ilustração */
.empty-state--illustration {
    min-height: 500px;
}

.empty-state-illustration {
    width: 200px;
    height: 200px;
    margin-bottom: var(--spacing-2xl);
    opacity: 0.8;
}

/* ===== KANBAN DRAG & DROP FEEDBACK (Sprint 2.2) ===== */

/* Card sendo arrastado */
.kanban-card.is-dragging {
    opacity: 0.5;
    cursor: grabbing;
    transform: rotate(3deg);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.4);
}

/* Coluna recebendo drag over */
.kanban-column.drag-over {
    background-color: hsla(var(--color-primary-hsl), 0.08);
    border-color: hsl(var(--color-primary-hsl));
}

.kanban-column.drag-over .kanban-cards {
    background-color: hsla(var(--color-primary-hsl), 0.05);
    border: 2px dashed hsl(var(--color-primary-hsl));
    border-radius: var(--radius-md);
}

/* Placeholder durante drag */
.kanban-card-placeholder {
    height: 120px;
    background: hsl(var(--color-bg-700-hsl));
    border: 2px dashed hsl(var(--color-primary-hsl));
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-tertiary);
    font-size: var(--font-size-sm);
}

/* Quick actions no hover do card */
.kanban-card-actions {
    position: absolute;
    top: var(--spacing-sm);
    right: var(--spacing-sm);
    display: flex;
    gap: var(--spacing-xs);
    opacity: 0;
    transition: opacity var(--transition-base);
}

.kanban-card:hover .kanban-card-actions {
    opacity: 1;
}

.kanban-card-action {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: hsl(var(--color-bg-900-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-sm);
    color: var(--text-tertiary);
    cursor: pointer;
    transition: all var(--transition-base);
}

.kanban-card-action:hover {
    background: hsl(var(--color-bg-700-hsl));
    color: var(--text-primary);
    border-color: hsl(var(--color-primary-hsl));
}

/* ========================================================================= */
/* PADRONIZAÇÃO UI KIT - TIPOGRAFIA, KANBAN, TABS, DASHBOARD                */
/* ========================================================================= */

/* ===== HIERARQUIA TIPOGRÁFICA GLOBAL ===== */
h1, h2, .text-2xl, .text-3xl, .text-4xl {
    font-weight: 700;
    letter-spacing: -0.02em;
}

h3, h4, .text-xl {
    font-weight: 600;
    letter-spacing: -0.01em;
}

/* Tabular Nums - Alinhamento perfeito para colunas numéricas */
.tabular-nums,
[data-countup],
.font-bold.text-secondary,
.font-bold.text-dark-text,
.font-bold.text-orange-400,
td:nth-child(n) .font-bold {
    font-variant-numeric: tabular-nums;
}

/* Kanban card values, CNPJ columns, monetary values */
.kanban-card .text-sm.font-bold,
.kanban-column .font-bold.text-secondary,
[class*="text-"][class*="font-bold"]:not(h1):not(h2):not(h3) {
    font-variant-numeric: tabular-nums;
}

/* ===== KANBAN - COLUNAS COM FUNDO SUTIL ===== */
.kanban-column > .bg-dark-800:first-child {
    border-radius: var(--radius-xl);
}

.kanban-cards {
    padding: var(--spacing-xs);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    background: hsl(var(--color-bg-900-hsl) / 0.5);
}

/* Kanban column header title: uppercase + tracking */
.kanban-column .column-title span.truncate {
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: var(--font-size-xs);
}

/* Kanban card hover: blue border */
.kanban-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.15);
    border-color: hsl(var(--color-primary-hsl) / 0.5) !important;
}

/* ===== ABAS/TABS - DARK THEME (Borda inferior) ===== */
.aba-btn {
    position: relative;
    color: hsl(var(--color-text-subtle-hsl));
    border-bottom: 2px solid transparent;
    margin-bottom: -1px;
    font-weight: 500;
    transition: all var(--transition-base);
}

.aba-btn:hover:not(.active) {
    color: hsl(var(--color-text-main-hsl));
    background-color: hsl(var(--color-primary-hsl) / 0.05);
}

.aba-btn.active {
    color: hsl(var(--color-primary-hsl));
    border-bottom-color: hsl(var(--color-primary-hsl));
    font-weight: 600;
}

/* ===== SIDEBAR - LINKS COM PESO 500 ===== */
aside nav a,
#app-sidebar nav a,
#sidebar nav a,
.menu-link {
    font-weight: 500;
}

/* ===== DASHBOARD KPI - ÍCONE CIRCULAR ===== */
.bg-dark-800 > .flex > [class*="rounded-lg"][class*="bg-"] {
    border-radius: var(--radius-full);
}

/* ===== LABELS GLOBAIS ===== */
label {
    font-weight: 500;
    color: hsl(var(--color-text-subtle-hsl));
}

/* ===== TEXTO CORRIDO - LINE-HEIGHT RELAXADO ===== */
.leading-relaxed,
.aba-conteudo p,
.timeline-lista p.text-sm,
textarea {
    line-height: 1.625;
}

/* ===== CARDS DE RESULTADO OTIMIZADOS (Sprint 1.4) ===== */

/* Card de resultado de busca */
.result-card {
    background: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all var(--transition-base);
    position: relative;
}

.result-card:hover {
    border-color: hsl(var(--color-primary-hsl) / 0.6);
    background: hsl(var(--color-bg-700-hsl) / 0.3);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.result-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-lg);
}

.result-card-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-primary-hsl));
    margin: 0 0 var(--spacing-xs) 0;
}

.result-card-badge {
    padding: 4px 12px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    background: rgba(139, 92, 246, 0.15);
    color: #a78bfa;
    border: 1px solid rgba(139, 92, 246, 0.3);
}

.result-card-meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-lg);
}

.result-meta-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--text-secondary);
}

.result-meta-icon {
    width: 16px;
    height: 16px;
    opacity: 0.6;
    flex-shrink: 0;
}

.result-meta-label {
    font-weight: var(--font-weight-medium);
}

.result-meta-value {
    color: var(--text-primary);
    font-family: var(--font-mono);
    font-weight: var(--font-weight-medium);
}

/* Botão de copiar */
.btn-copy {
    padding: 4px;
    background: transparent;
    border: none;
    cursor: pointer;
    opacity: 0;
    transition: opacity var(--transition-base);
    color: var(--text-tertiary);
}

.result-meta-item:hover .btn-copy {
    opacity: 0.6;
}

.btn-copy:hover {
    opacity: 1 !important;
    color: hsl(var(--color-primary-hsl));
}

.result-card-actions {
    display: flex;
    gap: var(--spacing-md);
    padding-top: var(--spacing-lg);
    border-top: 1px solid hsl(var(--color-bg-700-hsl));
}

.result-card-actions .btn {
    flex: 1;
}

/* ===== INPUTS DE BUSCA MELHORADOS (Sprint 1.4) ===== */

.search-input-wrapper {
    position: relative;
    width: 100%;
}

.search-input {
    width: 100%;
    padding: 14px 20px 14px 48px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-lg);
    color: var(--text-primary);
    font-size: var(--font-size-base);
    transition: all var(--transition-base);
}

.search-input:hover {
    border-color: rgba(99, 102, 241, 0.4);
    background: rgba(255, 255, 255, 0.08);
}

.search-input:focus {
    border-color: hsl(var(--color-bg-600-hsl));
    background: rgba(255, 255, 255, 0.08);
    box-shadow: none;
    outline: none;
}

.search-input-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    color: var(--text-tertiary);
    pointer-events: none;
}

/* ===== BADGES MELHORADOS ===== */

.badge {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: 4px 12px;
    border-radius: var(--radius-full);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    white-space: nowrap;
}

.badge-dot {
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: currentColor;
}

.badge--primary {
    background: rgba(99, 102, 241, 0.15);
    color: #a5b4fc;
    border: 1px solid rgba(99, 102, 241, 0.3);
}

.badge--success {
    background: rgba(34, 197, 94, 0.15);
    color: #86efac;
    border: 1px solid rgba(34, 197, 94, 0.3);
}

.badge--warning {
    background: rgba(245, 158, 11, 0.15);
    color: #fcd34d;
    border: 1px solid rgba(245, 158, 11, 0.3);
}

.badge--error {
    background: rgba(239, 68, 68, 0.15);
    color: #fca5a5;
    border: 1px solid rgba(239, 68, 68, 0.3);
}

.badge--info {
    background: rgba(59, 130, 246, 0.15);
    color: #93c5fd;
    border: 1px solid rgba(59, 130, 246, 0.3);
}

/* ========================================================================= */
/* SISTEMA DE DROPDOWNS PADRONIZADO                                         */
/* ========================================================================= */

/* Container do dropdown (absolute posicionado) */
.dropdown-container {
    position: absolute;
    right: 0;
    margin-top: var(--spacing-sm);
    width: 24rem; /* w-96 = 384px */
    max-height: 500px;
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    overflow: hidden;
    z-index: var(--z-dropdown);
    display: flex;
    flex-direction: column;
}

/* Header do dropdown */
.dropdown-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl));
    background-color: hsl(var(--color-bg-800-hsl));
}

.dropdown-header-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-weight: var(--font-weight-semibold);
    font-size: var(--font-size-base);
    color: hsl(var(--color-text-main-hsl));
}

.dropdown-header-title i,
.dropdown-header-title svg {
    width: 1.125rem;
    height: 1.125rem;
    color: hsl(var(--color-primary-hsl));
}

.dropdown-header-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 var(--spacing-xs);
    background-color: hsl(var(--color-primary-hsl));
    color: #ffffff;
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-bold);
    border-radius: var(--radius-full);
}

.dropdown-header-action {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-text-subtle-hsl));
    background-color: transparent;
    border: none;
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-base);
}

.dropdown-header-action:hover {
    color: hsl(var(--color-primary-hsl));
    background-color: hsl(var(--color-primary-hsl) / 0.1);
}

.dropdown-header-action i,
.dropdown-header-action svg {
    width: 0.875rem;
    height: 0.875rem;
}

/* Lista de itens do dropdown */
.dropdown-list {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-xs);
}

/* Item do dropdown */
.dropdown-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-base);
    text-decoration: none;
    color: inherit;
}

.dropdown-item:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08);
}

.dropdown-item.is-unread {
    background-color: hsl(var(--color-primary-hsl) / 0.05);
    border-left: 3px solid hsl(var(--color-primary-hsl));
}

.dropdown-item.is-unread:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.1);
}

/* Ícone do item */
.dropdown-item-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: var(--radius-md);
    background-color: hsl(var(--color-bg-700-hsl));
    color: hsl(var(--color-text-subtle-hsl));
}

.dropdown-item-icon i,
.dropdown-item-icon svg {
    width: 1rem;
    height: 1rem;
}

.dropdown-item-icon.icon-primary {
    background-color: hsl(var(--color-primary-hsl) / 0.15);
    color: hsl(var(--color-primary-hsl));
}

.dropdown-item-icon.icon-success {
    background-color: hsl(var(--color-success-hsl) / 0.15);
    color: hsl(var(--color-success-hsl));
}

.dropdown-item-icon.icon-warning {
    background-color: hsl(var(--color-warning-hsl) / 0.15);
    color: hsl(var(--color-warning-hsl));
}

.dropdown-item-icon.icon-error {
    background-color: hsl(var(--color-error-hsl) / 0.15);
    color: hsl(var(--color-error-hsl));
}

/* Conteúdo do item */
.dropdown-item-content {
    flex: 1;
    min-width: 0; /* Permite text truncation */
}

.dropdown-item-title {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-text-main-hsl));
    margin-bottom: var(--spacing-xs);
    line-height: var(--line-height-tight);
}

.dropdown-item-description {
    font-size: var(--font-size-xs);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-tight);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dropdown-item-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-xs);
    font-size: var(--font-size-xs);
    color: hsl(var(--color-text-subtle-hsl) / 0.8);
}

.dropdown-item-meta i,
.dropdown-item-meta svg {
    width: 0.75rem;
    height: 0.75rem;
}

/* Estado vazio */
.dropdown-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-md);
    padding: var(--spacing-3xl) var(--spacing-xl);
    text-align: center;
}

.dropdown-empty-icon {
    width: 3rem;
    height: 3rem;
    color: hsl(var(--color-text-subtle-hsl) / 0.4);
}

.dropdown-empty-icon i,
.dropdown-empty-icon svg {
    width: 100%;
    height: 100%;
}

.dropdown-empty-text {
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-normal);
}

/* Footer do dropdown */
.dropdown-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md);
    border-top: 1px solid hsl(var(--color-bg-700-hsl));
    background-color: hsl(var(--color-bg-800-hsl));
}

.dropdown-footer-link {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: hsl(var(--color-primary-hsl));
    text-decoration: none;
    transition: all var(--transition-base);
}

.dropdown-footer-link:hover {
    color: #5b21b6;
    text-decoration: underline;
}

/* Scroll customizado para dropdowns */
.dropdown-list::-webkit-scrollbar {
    width: 6px;
}

.dropdown-list::-webkit-scrollbar-track {
    background: transparent;
}

.dropdown-list::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-full);
}

.dropdown-list::-webkit-scrollbar-thumb:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.5);
}


/* ========================================================================= */
/* SISTEMA DE MODAIS PADRONIZADO                                            */
/* ========================================================================= */

/* Backdrop do modal */
.modal-backdrop {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(4px);
    z-index: var(--z-modal-backdrop);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
    animation: fadeIn var(--transition-base);
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

.modal-backdrop.closing {
    animation: fadeOut var(--transition-base);
}

@keyframes fadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
    }
}

/* Container do modal */
.modal-container {
    position: relative;
    width: 100%;
    background-color: hsl(var(--color-bg-800-hsl));
    border: 1px solid hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-2xl);
    z-index: var(--z-modal);
    animation: slideIn var(--transition-base);
    display: flex;
    flex-direction: column;
    max-height: 90vh;
}

@keyframes slideIn {
    from {
        opacity: 0;
        transform: scale(0.95) translateY(-10px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.modal-container.closing {
    animation: slideOut var(--transition-base);
}

@keyframes slideOut {
    from {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
    to {
        opacity: 0;
        transform: scale(0.95) translateY(-10px);
    }
}

/* Tamanhos de modal */
.modal-container.modal-sm {
    max-width: 400px;
}

.modal-container.modal-md {
    max-width: 600px;
}

.modal-container.modal-lg {
    max-width: 800px;
}

.modal-container.modal-xl {
    max-width: 1000px;
}

.modal-container.modal-full {
    max-width: 95vw;
}

/* Header do modal */
.modal-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-xl);
    border-bottom: 1px solid hsl(var(--color-bg-700-hsl));
    flex-shrink: 0;
}

.modal-header-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-lg);
    background-color: hsl(var(--color-bg-700-hsl));
}

.modal-header-icon i,
.modal-header-icon svg {
    width: 1.25rem;
    height: 1.25rem;
}

.modal-header-content {
    flex: 1;
    min-width: 0;
}

.modal-header-title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: hsl(var(--color-text-main-hsl));
    margin-bottom: var(--spacing-xs);
    line-height: var(--line-height-tight);
}

.modal-header-subtitle {
    font-size: var(--font-size-sm);
    color: hsl(var(--color-text-subtle-hsl));
    line-height: var(--line-height-tight);
}

.modal-header-close {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: none;
    background-color: transparent;
    color: hsl(var(--color-text-subtle-hsl));
    border-radius: var(--radius-md);
    cursor: pointer;
    transition: all var(--transition-base);
}

.modal-header-close:hover {
    background-color: hsl(var(--color-bg-700-hsl));
    color: hsl(var(--color-text-main-hsl));
}

.modal-header-close i,
.modal-header-close svg {
    width: 1.25rem;
    height: 1.25rem;
}

/* Body do modal */
.modal-body {
    flex: 1;
    padding: var(--spacing-xl);
    overflow-y: auto;
    color: hsl(var(--color-text-main-hsl));
    font-size: var(--font-size-sm);
    line-height: var(--line-height-normal);
}

.modal-body::-webkit-scrollbar {
    width: 6px;
}

.modal-body::-webkit-scrollbar-track {
    background: transparent;
}

.modal-body::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-full);
}

.modal-body::-webkit-scrollbar-thumb:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.5);
}

/* Footer do modal */
.modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--spacing-md);
    padding: var(--spacing-xl);
    border-top: 1px solid hsl(var(--color-bg-700-hsl));
    flex-shrink: 0;
}

/* Tipos de modal (cores do ícone e borda) */
.modal-container.modal-info .modal-header-icon {
    background-color: hsl(var(--color-info-hsl) / 0.15);
    color: hsl(var(--color-info-hsl));
}

.modal-container.modal-success .modal-header-icon {
    background-color: hsl(var(--color-success-hsl) / 0.15);
    color: hsl(var(--color-success-hsl));
}

.modal-container.modal-warning .modal-header-icon {
    background-color: hsl(var(--color-warning-hsl) / 0.15);
    color: hsl(var(--color-warning-hsl));
}

.modal-container.modal-danger .modal-header-icon {
    background-color: hsl(var(--color-error-hsl) / 0.15);
    color: hsl(var(--color-error-hsl));
}

.modal-container.modal-primary .modal-header-icon {
    background-color: hsl(var(--color-primary-hsl) / 0.15);
    color: hsl(var(--color-primary-hsl));
}

/* Bordas coloridas para modais críticos */
.modal-container.modal-danger {
    border-top: 3px solid hsl(var(--color-error-hsl));
}

.modal-container.modal-warning {
    border-top: 3px solid hsl(var(--color-warning-hsl));
}


/* ===== RESPONSIVE ADJUSTMENTS ===== */

@media (max-width: 768px) {
    /* Toast (bottom-center) */
    #toast-container {
        left: 50% !important;
        transform: translateX(-50%) !important;
        bottom: 12px !important;
        width: calc(100vw - 24px) !important;
        max-width: 360px !important;
    }

    .toast-modern {
        padding: 12px 14px 12px 18px !important;
    }

    /* Toast antigo (top-right) */
    .toast-container-top-right {
        left: 12px !important;
        right: 12px !important;
        top: 12px !important;
        max-width: none !important;
        gap: 8px !important;
    }

    .toast {
        padding: 12px 14px !important;
        gap: 10px !important;
        max-width: calc(100vw - 24px) !important;
        min-height: 56px !important;
        font-size: 0.9375rem !important;
    }

    .toast-icon {
        width: 20px !important;
        height: 20px !important;
        flex-shrink: 0;
    }

    .toast-icon svg,
    .toast-icon i {
        width: 20px !important;
        height: 20px !important;
    }

    .toast-content {
        flex: 1 !important;
        min-width: 0 !important;
    }

    .toast-title {
        font-size: 0.9375rem !important;
        font-weight: 600 !important;
        line-height: 1.3 !important;
    }

    .toast-message {
        font-size: 0.8125rem !important;
        line-height: 1.25 !important;
    }

    .toast-close {
        padding: 4px !important;
        width: 28px !important;
        height: 28px !important;
        flex-shrink: 0;
    }

    .toast-close svg {
        width: 14px !important;
        height: 14px !important;
    }

    .empty-state {
        padding: var(--spacing-2xl) var(--spacing-lg);
        min-height: 300px;
    }

    .empty-state-icon {
        width: 60px;
        height: 60px;
    }

    .empty-state-icon svg,
    .empty-state-icon i {
        width: 30px;
        height: 30px;
    }

    .result-card-actions {
        flex-direction: column;
    }

    .result-card-actions .btn {
        width: 100%;
    }
}

/* ========================================
   FASE 1: Melhorias UX/UI C6 Bank Pattern
   ======================================== */

/* Botão de Conversão (Upgrade, Compra, CTAs) - Cor da Marca LeadCNPJ */
.btn-conversion {
    background: linear-gradient(135deg, #10b981, #059669);
    color: white;
    border: none;
    box-shadow: 0 4px 14px rgba(16, 185, 129, 0.25);
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
}

.btn-conversion:hover {
    background: linear-gradient(135deg, #059669, #047857);
    box-shadow: 0 6px 20px rgba(16, 185, 129, 0.4);
    transform: translateY(-1px);
}

.btn-conversion:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(16, 185, 129, 0.3);
}

/* Cards Clicáveis (Menu de Configurações, CRM, Admin) */
.card-clickable {
    cursor: pointer;
    border: 1.5px solid hsl(var(--color-bg-700-hsl));
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

.card-clickable:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.05);
    border-color: hsl(var(--color-primary-hsl) / 0.3);
    transform: translateY(-2px) scale(1.01);
    box-shadow: 0 10px 25px -3px rgb(0 0 0 / 0.2), 0 4px 6px -2px rgb(0 0 0 / 0.1);
}

/* ========================================================================= */
/* OVERRIDE GLOBAL - Hover azulado em todos os elementos                    */
/* ========================================================================= */

/* Override Tailwind hover:bg-dark-* classes com alta especificidade */
body .hover\:bg-dark-600:hover,
body .hover\:bg-dark-700:hover,
body .hover\:bg-dark-800:hover,
html .hover\:bg-dark-600:hover,
html .hover\:bg-dark-700:hover,
html .hover\:bg-dark-800:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08) !important;
    --tw-bg-opacity: 1 !important;
}

/* Override usando seletor de atributo para garantir */
[class*="hover:bg-dark-700"]:hover,
[class*="hover:bg-dark-600"]:hover,
[class*="hover:bg-dark-800"]:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.08) !important;
}

/* Elementos interativos genéricos */
label.cursor-pointer:hover,
.cursor-pointer:hover:not(.btn):not([class*="bg-primary"]) {
    background-color: hsl(var(--color-primary-hsl) / 0.08) !important;
}

.card-clickable:active {
    transform: translateY(0);
}

.card-clickable.active,
.card-clickable.border-primary {
    border-color: hsl(var(--color-primary-hsl));
    box-shadow: 0 0 0 3px hsl(var(--color-primary-hsl) / 0.1);
}

/* Grid Responsivo para Menus (Padrão C6 Bank) */
.menu-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}

@media (min-width: 425px) {
    .menu-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .menu-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 16px;
    }
}

@media (min-width: 1024px) {
    .menu-grid {
        grid-template-columns: repeat(5, 1fr);
        gap: 20px;
    }
}

/* Ícones maiores em cards de menu (Mobile-friendly) */
.menu-grid .card i[data-lucide],
.menu-grid .card svg {
    width: 28px;
    height: 28px;
}

@media (min-width: 768px) {
    .menu-grid .card i[data-lucide],
    .menu-grid .card svg {
        width: 32px;
        height: 32px;
    }
}

/* Cor de conversão para textos e ícones */
.text-conversion {
    color: #10b981;
}

.bg-conversion {
    background-color: #10b981;
}

/* ===== SIDEBAR SCROLL PADRONIZADO ===== */

/* Sidebar sempre com largura adequada para o scroll */
aside.md\:flex {
    width: 80px !important;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Scrollbar padronizada (mesmo estilo do main content) */
aside::-webkit-scrollbar {
    width: 8px;
}

aside::-webkit-scrollbar-track {
    background: hsl(var(--color-bg-800-hsl));
}

aside::-webkit-scrollbar-thumb {
    background-color: hsl(var(--color-bg-700-hsl));
    border-radius: var(--radius-sm);
    transition: background-color var(--transition-base);
}

aside::-webkit-scrollbar-thumb:hover {
    background-color: hsl(var(--color-primary-hsl) / 0.6);
}

/* Firefox scrollbar */
aside {
    scrollbar-width: thin;
    scrollbar-color: hsl(var(--color-bg-700-hsl)) hsl(var(--color-bg-800-hsl));
}

/* ========================================================================= */
/* CORREÇÕES TEMA CLARO                                                      */
/* ========================================================================= */


/* ========================================================================= */
/* MELHORIAS TEMA CLARO - PÁGINA DE OPORTUNIDADES                           */
/* ========================================================================= */


/* ========================================================================= */
/* ÍCONES DE CONTATO NO FOOTER - MANTÉM CORES DO TEMA ESCURO                */
/* ========================================================================= */


/* ========================================================================= */
/* MELHORIAS TEMA CLARO - PÁGINA DE LEADS CRM                                */
/* ========================================================================= */


/* ===== FIX CRÍTICO: TABELA DE LEADS - TEXTOS VISÍVEIS ===== */


/* ========================================================================= */
/* CORREÇÕES BUSCA AVANÇADA - CAMPOS CIDADE E CNAE                          */
/* ========================================================================= */


/* ========================================================================= */
/* MELHORIAS TEMA CLARO - PÁGINA DE OPORTUNIDADE                            */
/* ========================================================================= */


/* ========================================================================= */
/* TEMA CLARO - DESIGN PROFISSIONAL COMPLETO                               */
/* ========================================================================= */


/* ===== 4. BOTÕES E ELEMENTOS COM BG-PRIMARY ===== */


/* ========================================================================= */
/* CORREÇÕES FINAIS - TEMA CLARO (MÁXIMA PRIORIDADE)                        */
/* ========================================================================= */


/* (regras movidas para início do arquivo para maior prioridade) */


/* ========================================================================= */
/* TEMA CLARO - OVERRIDE FINAL COM MÁXIMA ESPECIFICIDADE                    */
/* ========================================================================= */


/* ========================================================================= */
/* TEMA CLARO - REGRAS COM ID (MÁXIMA ESPECIFICIDADE)                       */
/* ========================================================================= */


/* ========================================================================= */
/* CORREÇÕES TEMA CLARO - 2026-01-26                                        */
/* ========================================================================= */


/* ===== TRANSIÇÃO DE TEMAS - EVITAR CACHE DE CORES ===== */


/* A logo no sidebar permanece com brilho normal (sidebar é escuro) */
/* Não precisa de ajuste pois sidebar já é escuro */


/* ========================================================================= */
/* TEMA CLARO - ESTILO PIPEDRIVE (REDESIGN COMPLETO)                        */
/* Criado em: 2026-01-26                                                    */
/* Baseado no design system do Pipedrive                                    */
/* ========================================================================= */

/* ===== 1. VARIÁVEIS CSS DO TEMA CLARO ===== */
body.light-theme {
    /* Paleta de fundos - Slate (Tech-Corp Vibe, alinhado com LP) */
    --color-bg-900-hsl: 210 40% 98%;         /* #f8fafc Slate 50 - Fundo principal */
    --color-bg-800-hsl: 0 0% 100%;           /* #ffffff - Cards/containers */
    --color-bg-700-hsl: 214 32% 91%;         /* #e2e8f0 Slate 200 - Bordas/separadores */
    --color-bg-600-hsl: 213 27% 84%;         /* #cbd5e1 Slate 300 - Hover states */

    /* Textos - Slate para tom frio tecnológico */
    --color-text-main-hsl: 222 47% 11%;      /* #0f172a Slate 900 - Texto principal */
    --color-text-subtle-hsl: 215 25% 27%;    /* #475569 Slate 600 - Texto secundário (contraste melhorado) */
    --color-text-muted-hsl: 215 16% 47%;     /* #64748b Slate 500 - Texto terciário/placeholders */

    /* Primary color override para tema claro (Indigo) */
    --color-primary-hsl: 221 83% 53%;        /* #2563eb Indigo 600 */

    /* Ícones para dashboard/cards - Indigo primary */
    --color-icon-bg: rgba(37, 99, 235, 0.08);
    --color-icon-text: #2563eb;
    --color-icon-bg-amber: rgba(245, 158, 11, 0.08);
    --color-icon-text-amber: #d97706;
    --color-icon-bg-purple: rgba(139, 92, 246, 0.08);
    --color-icon-text-purple: #7c3aed;
    --color-icon-bg-orange: rgba(234, 88, 12, 0.08);
    --color-icon-text-orange: #ea580c;
    --color-icon-bg-green: rgba(22, 163, 74, 0.08);
    --color-icon-text-green: #16a34a;

    /* Sombras - Tintura Indigo sutil (conexão subconsciente com LP) */
    --shadow-xs: 0 1px 2px 0 rgba(37, 99, 235, 0.04);
    --shadow-sm: 0 1px 3px 0 rgba(37, 99, 235, 0.06), 0 1px 2px -1px rgba(37, 99, 235, 0.04);
    --shadow-md: 0 4px 6px -1px rgba(37, 99, 235, 0.08), 0 2px 4px -2px rgba(37, 99, 235, 0.05);
    --shadow-lg: 0 10px 15px -3px rgba(37, 99, 235, 0.1), 0 4px 6px -4px rgba(37, 99, 235, 0.06);
    --shadow-xl: 0 20px 25px -5px rgba(37, 99, 235, 0.1), 0 8px 10px -6px rgba(37, 99, 235, 0.06);
    --shadow-card: 0 1px 3px 0 rgba(37, 99, 235, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.03);
}

/* ===== 2. ESTILOS GLOBAIS ===== */
body.light-theme {
    background-color: #f8fafc !important;
    color: #0f172a !important;
}

body.light-theme #main-content {
    background-color: #f8fafc !important;
}

/* ===== 3. BACKGROUNDS (Slate tones) ===== */
body.light-theme .bg-dark-900,
body.light-theme [class*="bg-dark-900"] {
    background-color: #f8fafc !important;
}

body.light-theme .bg-dark-800,
body.light-theme [class*="bg-dark-800"] {
    background-color: #ffffff !important;
}

body.light-theme .bg-dark-700,
body.light-theme [class*="bg-dark-700"] {
    background-color: #f1f5f9 !important;
}

/* ===== 4. BORDAS (Slate 200/300) ===== */
body.light-theme .border-dark-700,
body.light-theme [class*="border-dark-700"] {
    border-color: #e2e8f0 !important;
}

body.light-theme .border-dark-600,
body.light-theme [class*="border-dark-600"] {
    border-color: #cbd5e1 !important;
}

/* ===== 5. TEXTOS (Slate - quase preto azulado) ===== */
body.light-theme .text-dark-text,
body.light-theme [class*="text-dark-text"] {
    color: #0f172a !important;
}

body.light-theme .text-dark-subtext,
body.light-theme [class*="text-dark-subtext"] {
    color: #475569 !important;
}

body.light-theme .text-white:not(.bg-primary):not(.bg-green-500):not(.bg-red-500):not(.bg-blue-500):not([class*="bg-"]) {
    color: #0f172a !important;
}

/* Preservar texto branco na barra de período de testes */
body.light-theme #trial-banner,
body.light-theme #trial-banner * {
    color: #ffffff !important;
}

/* Textos grandes - Estatísticas */
body.light-theme .text-3xl,
body.light-theme .text-4xl,
body.light-theme .text-5xl {
    color: #0f172a !important;
    font-weight: 700 !important;
}

/* ===== 6. HEADER ===== */
body.light-theme header,
body.light-theme header.bg-dark-800,
body.light-theme header[class*="bg-dark"],
body.light-theme #app-header {
    background-color: #ffffff !important;
    background: #ffffff !important;
    border-bottom: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 3px rgba(37, 99, 235, 0.04) !important;
}

body.light-theme header h1,
body.light-theme header .text-lg,
body.light-theme header .font-semibold,
body.light-theme #app-header h1 {
    color: #0f172a !important;
}

/* Botões e links do header */
body.light-theme header button,
body.light-theme header a:not(.btn-primary):not([class*="bg-primary"]):not([class*="bg-green"]),
body.light-theme #app-header button,
body.light-theme #app-header a:not(.btn-primary):not([class*="bg-"]) {
    color: #475569 !important;
}

body.light-theme header button:hover,
body.light-theme header a:not(.btn-primary):not([class*="bg-"]):hover,
body.light-theme #app-header button:hover,
body.light-theme #app-header a:not([class*="bg-"]):hover {
    background-color: #f1f5f9 !important;
    color: #0f172a !important;
}

/* Ícones do header */
body.light-theme header i[data-lucide],
body.light-theme header svg:not(.text-white),
body.light-theme #app-header i[data-lucide],
body.light-theme #app-header svg:not(.text-white) {
    color: #475569 !important;
    stroke: #475569 !important;
}

body.light-theme header button:hover i[data-lucide],
body.light-theme header button:hover svg,
body.light-theme #app-header button:hover i[data-lucide],
body.light-theme #app-header button:hover svg {
    color: #2563eb !important;
    stroke: #2563eb !important;
}

/* Ícones dentro de elementos com fundo colorido (ex: botão de créditos) */
body.light-theme header a.bg-primary i[data-lucide],
body.light-theme header a.bg-primary svg,
body.light-theme header a[class*="bg-primary"] i[data-lucide],
body.light-theme header a[class*="bg-primary"] svg,
body.light-theme header .bg-primary i[data-lucide],
body.light-theme header .bg-primary svg {
    color: #ffffff !important;
    stroke: #ffffff !important;
}

/* Input de busca no header */
body.light-theme header input[type="text"],
body.light-theme header input[type="search"],
body.light-theme header input[name="q"],
body.light-theme #app-header input {
    background-color: #f1f5f9 !important;
    border: 1px solid #e2e8f0 !important;
    color: #0f172a !important;
}

body.light-theme header input::placeholder,
body.light-theme #app-header input::placeholder {
    color: #94a3b8 !important;
}

body.light-theme header input:focus,
body.light-theme #app-header input:focus {
    background-color: #ffffff !important;
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}

/* ===== 7. SIDEBAR ===== */
/* Mobile: sidebar sempre oculta (exclui hamburger menu mobile) */
@media (max-width: 767px) {
    aside:not(.mobile-hamburger-menu),
    #app-sidebar,
    body.light-theme aside:not(.mobile-hamburger-menu),
    body.light-theme #app-sidebar {
        display: none !important;
    }
}

body.light-theme aside,
body.light-theme aside.bg-dark-800,
body.light-theme nav[class*="sidebar"],
body.light-theme .sidebar,
body.light-theme #sidebar,
body.light-theme #app-sidebar,
body.light-theme aside.w-\[72px\] {
    background-color: #ffffff !important;
    background: #ffffff !important;
    border-right: 1px solid #e2e8f0 !important;
}

/* Links da sidebar (exclui hamburger menu) */
body.light-theme aside:not(.mobile-hamburger-menu) a,
body.light-theme aside:not(.mobile-hamburger-menu) span,
body.light-theme #sidebar a,
body.light-theme #app-sidebar a {
    color: #475569 !important;
}

/* Ícones da sidebar (exclui hamburger menu) */
body.light-theme aside:not(.mobile-hamburger-menu) i[data-lucide],
body.light-theme aside:not(.mobile-hamburger-menu) svg,
body.light-theme #sidebar i[data-lucide],
body.light-theme #sidebar svg,
body.light-theme #app-sidebar i[data-lucide],
body.light-theme #app-sidebar svg {
    color: #475569 !important;
    stroke: #475569 !important;
}

/* Hover na sidebar */
body.light-theme aside a:hover,
body.light-theme #sidebar a:hover,
body.light-theme #app-sidebar a:hover {
    background-color: #f1f5f9 !important;
    color: #0f172a !important;
}

body.light-theme aside a:hover i[data-lucide],
body.light-theme aside a:hover svg,
body.light-theme #app-sidebar a:hover i[data-lucide],
body.light-theme #app-sidebar a:hover svg {
    color: #2563eb !important;
    stroke: #2563eb !important;
}

/* Link ativo na sidebar - Sólido Premium */
body.light-theme aside a.active,
body.light-theme #sidebar a.active,
body.light-theme #app-sidebar a.active,
body.light-theme aside nav a.active {
    background: #2563eb !important;
    color: #ffffff !important;
}

body.light-theme aside a.active i[data-lucide],
body.light-theme aside a.active svg,
body.light-theme #app-sidebar a.active i[data-lucide],
body.light-theme #app-sidebar a.active svg,
body.light-theme aside nav a.active i[data-lucide] {
    color: #ffffff !important;
    stroke: #ffffff !important;
}

/* Subtextos da sidebar */
body.light-theme aside .text-dark-subtext,
body.light-theme #app-sidebar .text-dark-subtext {
    color: #94a3b8 !important;
}

/* Logo na sidebar */
body.light-theme aside img,
body.light-theme #sidebar img,
body.light-theme #app-sidebar img {
    filter: none !important;
}

/* Scrollbar da sidebar */
body.light-theme aside::-webkit-scrollbar-track,
body.light-theme #app-sidebar::-webkit-scrollbar-track {
    background: #f8fafc !important;
}

body.light-theme aside::-webkit-scrollbar-thumb,
body.light-theme #app-sidebar::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
}

body.light-theme aside::-webkit-scrollbar-thumb:hover,
body.light-theme #app-sidebar::-webkit-scrollbar-thumb:hover {
    background: #2563eb !important;
}

/* ===== 8. CARDS (Indigo-tinted shadows for LP connection) ===== */
body.light-theme .card,
body.light-theme .rounded-xl[class*="bg-dark-800"],
body.light-theme .rounded-lg[class*="bg-dark-800"] {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.06), 0 2px 4px -1px rgba(37, 99, 235, 0.04) !important;
}

body.light-theme .card:hover {
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.1), 0 4px 6px -2px rgba(37, 99, 235, 0.06) !important;
    border-color: #c7d2fe !important;
}

/* Cards com glow - Indigo tinted */
body.light-theme .card-glow-primary,
body.light-theme .card-glow-secondary,
body.light-theme .card-glow-success,
body.light-theme .card-glow-warning,
body.light-theme .card-glow-yellow,
body.light-theme .card-glow-orange {
    box-shadow: 0 4px 6px -1px rgba(37, 99, 235, 0.06), 0 2px 4px -1px rgba(37, 99, 235, 0.04) !important;
}

body.light-theme .card-glow-primary::before,
body.light-theme .card-glow-secondary::before,
body.light-theme .card-glow-success::before,
body.light-theme .card-glow-warning::before,
body.light-theme .card-glow-yellow::before,
body.light-theme .card-glow-orange::before {
    opacity: 0.15 !important;
}

body.light-theme .card-glow-primary:hover,
body.light-theme .card-glow-secondary:hover,
body.light-theme .card-glow-success:hover,
body.light-theme .card-glow-warning:hover,
body.light-theme .card-glow-yellow:hover,
body.light-theme .card-glow-orange:hover {
    box-shadow: 0 10px 15px -3px rgba(37, 99, 235, 0.1), 0 4px 6px -2px rgba(37, 99, 235, 0.06) !important;
}

body.light-theme .card-glow-primary:hover::before,
body.light-theme .card-glow-secondary:hover::before,
body.light-theme .card-glow-success:hover::before,
body.light-theme .card-glow-warning:hover::before,
body.light-theme .card-glow-yellow:hover::before,
body.light-theme .card-glow-orange:hover::before {
    opacity: 0.25 !important;
}

/* ===== 9. TABELAS ===== */
body.light-theme table {
    background-color: #ffffff !important;
}

body.light-theme table thead {
    background-color: #f8fafc !important;
}

body.light-theme table thead th {
    color: #475569 !important;
    border-color: #e2e8f0 !important;
    font-weight: 600 !important;
    background-color: #f8fafc !important;
}

body.light-theme table tbody tr {
    background-color: #ffffff !important;
    border-color: #f1f5f9 !important;
    transition: all 0.15s ease !important;
}

body.light-theme table tbody tr:hover {
    background-color: #f1f5f9 !important;
    border-left: 3px solid #2563eb !important;
}

body.light-theme table tbody td {
    color: #0f172a !important;
    border-color: #f1f5f9 !important;
}

body.light-theme table tbody td * {
    color: inherit;
}

body.light-theme tbody td .text-dark-subtext,
body.light-theme tbody td small,
body.light-theme tbody td .text-xs,
body.light-theme tbody td .text-sm {
    color: #475569 !important;
}

/* Hover em linhas de tabela */
body.light-theme tr:hover {
    background-color: #f1f5f9 !important;
}

/* ===== 10. FORMULÁRIOS E INPUTS ===== */
body.light-theme input,
body.light-theme select,
body.light-theme textarea {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    color: #0f172a !important;
}

body.light-theme input:focus,
body.light-theme select:focus,
body.light-theme textarea:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
    outline: none !important;
}

body.light-theme input::placeholder,
body.light-theme textarea::placeholder {
    color: #94a3b8 !important;
}

/* Inputs específicos */
body.light-theme input[type="text"],
body.light-theme input[type="email"],
body.light-theme input[type="password"],
body.light-theme input[type="search"],
body.light-theme input[type="number"],
body.light-theme input[type="tel"],
body.light-theme input[type="url"] {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    color: #0f172a !important;
}

/* Checkboxes */
body.light-theme input[type="checkbox"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    min-height: 18px !important;
    background-color: #ffffff !important;
    border: 2px solid #cbd5e1 !important;
    border-radius: 9999px !important;
    cursor: pointer !important;
    position: relative !important;
    transition: all 0.15s ease !important;
    flex-shrink: 0 !important;
}

body.light-theme input[type="checkbox"]:hover:not(:checked) {
    border-color: #94a3b8 !important;
}

body.light-theme input[type="checkbox"]:checked {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
}

body.light-theme input[type="checkbox"]:checked::after {
    content: '' !important;
    position: absolute !important;
    left: 5px !important;
    top: 1px !important;
    width: 5px !important;
    height: 10px !important;
    border: solid white !important;
    border-width: 0 2px 2px 0 !important;
    transform: rotate(45deg) !important;
}

body.light-theme input[type="checkbox"]:focus {
    outline: 2px solid rgba(37, 99, 235, 0.2) !important;
    outline-offset: 2px !important;
}

/* Radio buttons */
body.light-theme input[type="radio"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    width: 18px !important;
    height: 18px !important;
    background-color: #ffffff !important;
    border: 2px solid #cbd5e1 !important;
    border-radius: 50% !important;
    cursor: pointer !important;
}

body.light-theme input[type="radio"]:checked {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
    box-shadow: inset 0 0 0 4px #ffffff !important;
}

/* ===== 11. BOTÕES (Sólido Premium com Glow - LP alignment) ===== */
body.light-theme .btn-primary {
    background: #2563eb !important;
    color: #ffffff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.3) !important;
}

body.light-theme .btn-primary:hover {
    background: #1d4ed8 !important;
    border-color: transparent !important;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.45) !important;
    transform: translateY(-1px);
}

body.light-theme .btn-secondary {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    color: #475569 !important;
}

body.light-theme .btn-secondary:hover {
    background-color: #f8fafc !important;
    border-color: #c7d2fe !important;
}

/* Botões de ação - Sólido Premium */
body.light-theme button.bg-primary,
body.light-theme a.bg-primary,
body.light-theme [type="submit"].bg-primary {
    background: #2563eb !important;
    color: #ffffff !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.3) !important;
}

body.light-theme button.bg-primary:hover,
body.light-theme a.bg-primary:hover {
    background: #1d4ed8 !important;
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.45) !important;
    transform: translateY(-1px);
}

/* Botões genéricos */
body.light-theme button:not([class*="bg-"]):hover,
body.light-theme a:not([class*="bg-"]):hover {
    opacity: 0.9;
}

/* ===== 12. MODAIS ===== */
body.light-theme #modal-lead-content,
body.light-theme .modal-container,
body.light-theme .modal-content {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 25px 50px -12px rgba(37, 99, 235, 0.15), 0 10px 20px -5px rgba(0, 0, 0, 0.08) !important;
}

body.light-theme .modal-footer-fixed {
    background-color: #f8fafc !important;
    border-color: #e2e8f0 !important;
}

body.light-theme .border-b.border-dark-700 {
    border-color: #e2e8f0 !important;
}

/* ===== 13. DROPDOWNS ===== */
body.light-theme #profile-menu-dropdown,
body.light-theme #notifications-dropdown,
body.light-theme .dropdown-container {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 10px 25px rgba(37, 99, 235, 0.1), 0 4px 6px rgba(0, 0, 0, 0.04) !important;
}

body.light-theme .dropdown-container * {
    color: #475569 !important;
}

/* Menu de perfil - itens sem destaque por padrão, destaque no hover */
body.light-theme #profile-menu-dropdown a {
    background-color: transparent !important;
    color: #475569 !important;
}

body.light-theme #profile-menu-dropdown a:hover {
    background-color: #f1f5f9 !important;
    color: #0f172a !important;
}

body.light-theme #profile-menu-dropdown a.text-red-400 {
    color: #dc2626 !important;
}

body.light-theme #profile-menu-dropdown a.text-red-400:hover {
    background-color: rgba(220, 38, 38, 0.1) !important;
    color: #dc2626 !important;
}

body.light-theme #profile-menu-dropdown a [data-lucide],
body.light-theme #profile-menu-dropdown a svg {
    color: inherit !important;
    stroke: currentColor !important;
}

body.light-theme #profile-menu-dropdown a .text-green-500 {
    color: #16a34a !important;
    stroke: #16a34a !important;
}

body.light-theme #profile-menu-dropdown a .text-yellow-500 {
    color: #d97706 !important;
    stroke: #d97706 !important;
}

/* Widget de ajuda - itens sem destaque por padrão, destaque no hover */
body.light-theme #help-widget-card {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
}

body.light-theme #help-widget-card a {
    background-color: transparent !important;
}

body.light-theme #help-widget-card a:hover {
    background-color: #f1f5f9 !important;
}

body.light-theme #help-widget-card .text-dark-text {
    color: #475569 !important;
}

body.light-theme #help-widget-card .text-dark-subtext {
    color: #475569 !important;
}

body.light-theme #help-widget-card a:hover .text-dark-text {
    color: #0f172a !important;
}

body.light-theme #help-widget-card .bg-primary\/10 {
    background-color: rgba(37, 99, 235, 0.1) !important;
}

body.light-theme #help-widget-card a:hover .bg-primary\/10 {
    background-color: rgba(37, 99, 235, 0.15) !important;
}

body.light-theme .dropdown-header {
    border-bottom-color: #e2e8f0 !important;
}

/* ===== 13.5. KANBAN - TEMA CLARO ===== */
body.light-theme .kanban-cards {
    background: rgba(241, 245, 249, 0.5) !important; /* bg-slate-100/50 */
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

body.light-theme .kanban-card {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
}

body.light-theme .kanban-card:hover {
    border-color: #60a5fa !important; /* blue-400 */
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.1) !important;
}

/* Kanban value highlight - green on light */
body.light-theme .kanban-card .text-secondary.font-bold {
    color: #047857 !important; /* emerald-700 */
    background: rgba(236, 253, 245, 0.8);
    padding: 1px 6px;
    border-radius: var(--radius-sm);
}

/* ===== 13.6. INPUTS - TEMA CLARO (Foco Azul Ring) ===== */
body.light-theme #main-content input:not([type="checkbox"]):not([type="radio"]),
body.light-theme #main-content select,
body.light-theme #main-content textarea {
    background-color: #ffffff !important;
    border-color: #cbd5e1 !important; /* slate-300 */
    border-radius: var(--radius-lg) !important;
    font-size: var(--font-size-base) !important;
}

body.light-theme #main-content input:focus:not([type="checkbox"]):not([type="radio"]),
body.light-theme #main-content select:focus,
body.light-theme #main-content textarea:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2) !important;
}

/* ===== 13.7. BOTÃO SECUNDÁRIO - TEMA CLARO (Outline style) ===== */
body.light-theme .btn-secondary {
    background-color: transparent !important;
    color: #475569 !important; /* slate-600 */
    border-color: #cbd5e1 !important; /* slate-300 */
}

body.light-theme .btn-secondary:hover {
    background-color: #f8fafc !important; /* slate-50 */
    border-color: #94a3b8 !important;
}

/* ===== 13.8. DASHBOARD KPI - ÍCONE CIRCULAR (TEMA CLARO) ===== */
body.light-theme [class*="rounded-lg"][class*="bg-primary"],
body.light-theme [class*="rounded-lg"][class*="bg-orange"],
body.light-theme [class*="rounded-lg"][class*="bg-secondary"] {
    border-radius: var(--radius-full) !important;
}

/* Dashboard sombras coloridas nos cards */
body.light-theme .bg-dark-800.rounded-xl {
    box-shadow: 0 1px 3px rgba(37, 99, 235, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04) !important;
}

/* ===== 14. TOM SELECT (AUTOCOMPLETE) ===== */
body.light-theme .ts-control,
body.light-theme .ts-wrapper .ts-control {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    color: #0f172a !important;
}

body.light-theme .ts-control input,
body.light-theme .ts-wrapper .ts-control input {
    color: #0f172a !important;
}

body.light-theme .ts-control input::placeholder {
    color: #94a3b8 !important;
}

body.light-theme .ts-control > .item,
body.light-theme .ts-wrapper .ts-control .item {
    background-color: #f1f5f9 !important;
    border-color: #e2e8f0 !important;
    color: #0f172a !important;
}

body.light-theme .ts-dropdown,
body.light-theme .ts-wrapper .ts-dropdown {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

body.light-theme .ts-dropdown .option,
body.light-theme .ts-wrapper .ts-dropdown .option {
    color: #0f172a !important;
}

body.light-theme .ts-dropdown .option:hover,
body.light-theme .ts-dropdown .option.active,
body.light-theme .ts-wrapper .ts-dropdown .option:hover,
body.light-theme .ts-wrapper .ts-dropdown .option.active {
    background-color: #2563eb !important;
    color: #ffffff !important;
}

body.light-theme .ts-dropdown .option.selected,
body.light-theme .ts-wrapper .ts-dropdown .option.selected {
    background-color: rgba(37, 99, 235, 0.1) !important;
    color: #2563eb !important;
}

/* ===== 15. FLATPICKR (DATE PICKER) ===== */
body.light-theme .flatpickr-calendar {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

body.light-theme .flatpickr-day {
    color: #0f172a !important;
}

body.light-theme .flatpickr-day.prevMonthDay,
body.light-theme .flatpickr-day.nextMonthDay {
    color: #94a3b8 !important;
}

body.light-theme .flatpickr-day:hover {
    background-color: #f1f5f9 !important;
}

body.light-theme .flatpickr-day.selected {
    background-color: #2563eb !important;
    color: #ffffff !important;
}

/* ===== 16. ABAS/TABS ===== */
body.light-theme nav[aria-label="Tabs"] {
    border-color: #e2e8f0 !important;
}

body.light-theme .aba-btn {
    color: #475569 !important;
}

body.light-theme .aba-btn.active {
    color: #2563eb !important;
    border-bottom-color: #2563eb !important;
}

body.light-theme .aba-btn:hover:not(.active) {
    background-color: #f8fafc !important;
    color: #0f172a !important;
}

body.light-theme .tab-btn.active {
    background-color: rgba(37, 99, 235, 0.1) !important;
    color: #2563eb !important;
}

/* ===== 17. BADGES E TAGS ===== */
body.light-theme .badge-primary {
    background-color: rgba(37, 99, 235, 0.08) !important;
    color: #2563eb !important;
    border-color: rgba(37, 99, 235, 0.2) !important;
}

body.light-theme .badge-secondary {
    background-color: rgba(22, 163, 74, 0.1) !important;
    color: #16a34a !important;
    border-color: rgba(22, 163, 74, 0.2) !important;
}

body.light-theme .badge-success {
    background-color: rgba(22, 163, 74, 0.1) !important;
    color: #16a34a !important;
    border-color: rgba(22, 163, 74, 0.2) !important;
}

body.light-theme .badge-warning {
    background-color: rgba(245, 158, 11, 0.1) !important;
    color: #d97706 !important;
    border-color: rgba(245, 158, 11, 0.2) !important;
}

body.light-theme .badge-error {
    background-color: rgba(239, 68, 68, 0.1) !important;
    color: #dc2626 !important;
    border-color: rgba(239, 68, 68, 0.2) !important;
}

body.light-theme .badge-neutral {
    background-color: #f1f5f9 !important;
    color: #475569 !important;
    border-color: #e2e8f0 !important;
}

/* Badges de score com fundo sólido */
body.light-theme .bg-green-500,
body.light-theme .bg-emerald-500 {
    background-color: #16a34a !important;
    color: #ffffff !important;
}

body.light-theme .bg-green-500 *,
body.light-theme .bg-emerald-500 * {
    color: #ffffff !important;
}

body.light-theme .bg-amber-500,
body.light-theme .bg-yellow-500 {
    background-color: #f59e0b !important;
    color: #0f172a !important;
}

body.light-theme .bg-amber-500 *,
body.light-theme .bg-yellow-500 * {
    color: #0f172a !important;
}

body.light-theme .bg-orange-500 {
    background-color: #ea580c !important;
    color: #ffffff !important;
}

body.light-theme .bg-red-500 {
    background-color: #dc2626 !important;
    color: #ffffff !important;
}

body.light-theme .bg-red-500 [data-lucide],
body.light-theme .bg-red-500 svg {
    color: #ffffff !important;
    stroke: #ffffff !important;
}

body.light-theme .bg-blue-500 {
    background-color: #2563eb !important;
    color: #ffffff !important;
}

body.light-theme .bg-blue-500 [data-lucide],
body.light-theme .bg-blue-500 svg {
    color: #ffffff !important;
    stroke: #ffffff !important;
}

body.light-theme .bg-violet-500,
body.light-theme .bg-purple-500 {
    background-color: #7c3aed !important;
    color: #ffffff !important;
}

body.light-theme .bg-violet-500 [data-lucide],
body.light-theme .bg-violet-500 svg,
body.light-theme .bg-purple-500 [data-lucide],
body.light-theme .bg-purple-500 svg {
    color: #ffffff !important;
    stroke: #ffffff !important;
}

/* Badge de notificações */
body.light-theme #notifications-badge {
    background-color: #dc2626 !important;
    color: #ffffff !important;
}

/* ===== 18. CORES DE TEXTO ESPECÍFICAS ===== */
body.light-theme .text-primary {
    color: #2563eb !important;
}

body.light-theme .text-secondary {
    color: #16a34a !important;
}

body.light-theme .text-blue-400,
body.light-theme .text-blue-500,
body.light-theme .text-blue-600 {
    color: #2563eb !important;
}

body.light-theme .text-green-400,
body.light-theme .text-green-500,
body.light-theme .text-green-600 {
    color: #16a34a !important;
}

body.light-theme .text-yellow-400,
body.light-theme .text-yellow-500,
body.light-theme .text-yellow-600,
body.light-theme .text-amber-400,
body.light-theme .text-amber-500,
body.light-theme .text-amber-600 {
    color: #d97706 !important;
}

body.light-theme .text-orange-400,
body.light-theme .text-orange-500,
body.light-theme .text-orange-600 {
    color: #ea580c !important;
}

body.light-theme .text-red-400,
body.light-theme .text-red-500,
body.light-theme .text-red-600 {
    color: #dc2626 !important;
}

/* Ícones dentro de badges/tags de temperatura - herdar cor do texto */
body.light-theme .text-amber-400 [data-lucide],
body.light-theme .text-amber-400 svg,
body.light-theme .text-amber-500 [data-lucide],
body.light-theme .text-amber-500 svg {
    color: #d97706 !important;
    stroke: #d97706 !important;
}

body.light-theme .text-red-400 [data-lucide],
body.light-theme .text-red-400 svg,
body.light-theme .text-red-500 [data-lucide],
body.light-theme .text-red-500 svg {
    color: #dc2626 !important;
    stroke: #dc2626 !important;
}

body.light-theme .text-dark-subtext [data-lucide],
body.light-theme .text-dark-subtext svg {
    color: #475569 !important;
    stroke: #475569 !important;
}

body.light-theme .text-purple-400,
body.light-theme .text-purple-500,
body.light-theme .text-purple-600,
body.light-theme .text-violet-500 {
    color: #7c3aed !important;
}

body.light-theme .text-cyan-500,
body.light-theme .text-teal-500 {
    color: #0891b2 !important;
}

/* ===== 19. BACKGROUNDS DE ÍCONES ===== */
body.light-theme .bg-blue-500\/10 {
    background-color: rgba(37, 99, 235, 0.08) !important;
}

body.light-theme .bg-green-500\/10 {
    background-color: rgba(22, 163, 74, 0.08) !important;
}

body.light-theme .bg-green-500\/20 {
    background-color: rgba(22, 163, 74, 0.15) !important;
}

body.light-theme .bg-purple-500\/10 {
    background-color: rgba(124, 58, 237, 0.08) !important;
}

body.light-theme .bg-orange-500\/10 {
    background-color: rgba(234, 88, 12, 0.08) !important;
}

body.light-theme .bg-primary\/10 {
    background-color: rgba(37, 99, 235, 0.08) !important;
}

body.light-theme .bg-secondary\/10 {
    background-color: rgba(22, 163, 74, 0.08) !important;
}

/* ===== 20. GRADIENTES ===== */
body.light-theme .bg-gradient-to-br.from-primary\/20 {
    background: linear-gradient(to bottom right, rgba(37, 99, 235, 0.08), transparent) !important;
}

body.light-theme .bg-secondary\/30 {
    background-color: rgba(22, 163, 74, 0.15) !important;
}

body.light-theme .bg-gradient-to-r.from-secondary.to-primary {
    background: linear-gradient(to right, #16a34a, #2563eb) !important;
    color: #ffffff !important;
}

/* Gradient CTAs - Brand signature (LP alignment) */
body.light-theme .btn-primary-gradient {
    background: linear-gradient(to right, #2563eb, #1d4ed8) !important;
    color: #ffffff !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(37, 99, 235, 0.3) !important;
}

body.light-theme .btn-primary-gradient:hover {
    box-shadow: 0 6px 20px rgba(37, 99, 235, 0.4) !important;
    transform: translateY(-1px);
}

body.light-theme [class*="from-purple"] {
    background-color: rgba(124, 58, 237, 0.08) !important;
}

body.light-theme [class*="bg-purple"]:not(.bg-purple-500) {
    background-color: rgba(124, 58, 237, 0.08) !important;
}

/* ===== 21. TOOLTIPS ===== */
body.light-theme [data-tooltip]::before {
    background-color: #0f172a !important;
    color: #ffffff !important;
}

body.light-theme [data-tooltip][data-tooltip-position="top"]::after,
body.light-theme [data-tooltip]:not([data-tooltip-position])::after {
    border-top-color: #0f172a !important;
}

body.light-theme [data-tooltip][data-tooltip-position="bottom"]::after {
    border-bottom-color: #0f172a !important;
}

body.light-theme [data-tooltip][data-tooltip-position="left"]::after {
    border-left-color: #0f172a !important;
}

body.light-theme [data-tooltip][data-tooltip-position="right"]::after {
    border-right-color: #0f172a !important;
}

/* ===== 22. NOTIFICAÇÕES ===== */
body.light-theme .notification-item {
    border-color: #e2e8f0 !important;
}

body.light-theme .notification-title {
    color: #0f172a !important;
}

body.light-theme .notification-message {
    color: #475569 !important;
}

/* ===== 23. SCROLLBAR GLOBAL ===== */
body.light-theme ::-webkit-scrollbar-track {
    background: #f1f5f9 !important;
}

body.light-theme ::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 4px !important;
}

body.light-theme ::-webkit-scrollbar-thumb:hover {
    background: #2563eb !important;
}

/* ===== 24. HOVER STATES ===== */
body.light-theme .hover\:bg-dark-700:hover {
    background-color: #f1f5f9 !important;
    border-color: #c7d2fe !important;
}

body.light-theme .hover\:bg-dark-900\/50:hover {
    background-color: #f8fafc !important;
}

body.light-theme .hover\:border-primary\/50:hover {
    border-color: rgba(37, 99, 235, 0.5) !important;
}

/* ===== 25. ELEMENTOS ESPECÍFICOS ===== */
/* Links de empresas e contatos */
body.light-theme a[href*="/app/empresa"],
body.light-theme a[href*="/app/qsa_empresas"] {
    color: #2563eb !important;
}

body.light-theme a[href*="/app/empresa"]:hover,
body.light-theme a[href*="/app/qsa_empresas"]:hover {
    color: #1d4ed8 !important;
}

/* Favoritos */
body.light-theme a[href*="/app/favoritos"],
body.light-theme a[href*="/app/socios_favoritos"] {
    color: #d97706 !important;
}

body.light-theme a[href*="/app/favoritos"]:hover,
body.light-theme a[href*="/app/socios_favoritos"]:hover {
    color: #b45309 !important;
}

/* Cards de empresa nos resultados */
body.light-theme [data-company-card] {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
}

body.light-theme [data-company-card]:hover {
    border-color: #c7d2fe !important;
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.08) !important;
}

body.light-theme [data-company-card] .text-dark-text {
    color: #0f172a !important;
}

body.light-theme [data-company-card] .text-dark-subtext {
    color: #475569 !important;
}

body.light-theme [data-company-card] i[data-lucide],
body.light-theme [data-company-card] svg {
    color: #475569 !important;
    stroke: #475569 !important;
}

/* Formulário de busca avançada */
body.light-theme #advanced-search-form select,
body.light-theme #advanced-search-form input:not([type="checkbox"]):not([type="radio"]) {
    background-color: #ffffff !important;
    border-color: #e2e8f0 !important;
    color: #0f172a !important;
}

body.light-theme #advanced-search-form select:focus,
body.light-theme #advanced-search-form input:focus {
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}

body.light-theme #advanced-search-form label,
body.light-theme #advanced-search-form .text-dark-subtext {
    color: #475569 !important;
}

body.light-theme #advanced-search-form .text-dark-text {
    color: #0f172a !important;
}

body.light-theme #advanced-search-form .bg-dark-900:not(input) {
    background-color: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
}

/* Checkbox e radio button - cor indigo quando selecionado (ambos os temas) */
input[type="checkbox"],
input[type="radio"] {
    accent-color: #2563eb !important;
}

input[type="checkbox"]:checked,
input[type="radio"]:checked {
    background-color: #2563eb !important;
    border-color: #2563eb !important;
}

/* Right sidebar */
body.light-theme #right-sidebar .space-y-6 > div.border.border-dark-700 {
    border-color: #e2e8f0 !important;
}

body.light-theme #right-sidebar .space-y-6 > div.border.border-dark-700:hover {
    border-color: #cbd5e1 !important;
}

/* Badge de créditos - ícone sempre branco */
#credits-badge [data-lucide],
body.light-theme header #credits-badge [data-lucide],
body.light-theme header #credits-badge svg,
body.light-theme #app-header #credits-badge [data-lucide],
body.light-theme #app-header #credits-badge svg {
    stroke: #ffffff !important;
    color: #ffffff !important;
}

/* ===== 26. ÍCONES GLOBAIS (Outline fino - 1.5px) ===== */
[data-lucide] {
    stroke-width: 1.5 !important;
}

body.light-theme h3 i[data-lucide].text-primary,
body.light-theme h3 i[data-lucide].text-secondary {
    opacity: 1 !important;
}

/* ===== 27. LABELS E TEXTO PEQUENO ===== */
body.light-theme label {
    color: #475569 !important;
    font-weight: 500 !important;
}

body.light-theme .text-sm {
    color: inherit;
}

/* ===== 28. RESETS DE CORES HARDCODED ===== */
body.light-theme .bg-\[\#1a1a1a\],
body.light-theme .bg-\[\#121212\],
body.light-theme .bg-\[\#2d2d2d\] {
    background-color: #ffffff !important;
}

body.light-theme .border-\[\#2d2d2d\],
body.light-theme .border-\[\#1a1a1a\] {
    border-color: #e2e8f0 !important;
}

body.light-theme .text-\[\#a0a0a0\] {
    color: #475569 !important;
}

/* ===== 29. TRANSIÇÕES SUAVES ===== */
body.light-theme * {
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

/* Exceções para animações existentes */
body.light-theme .btn,
body.light-theme .card,
body.light-theme a,
body.light-theme button {
    transition: all 0.2s ease;
}

/* ===== 30. BG-WHITE ESPECÍFICOS ===== */
/* Nota: Não usar [class*="bg-white"] pois afeta bg-white/20, bg-white/30 etc (trial banner) */
body.light-theme .bg-white {
    background-color: #ffffff !important;
    border: 1px solid #e2e8f0 !important;
    box-shadow: 0 1px 3px rgba(37, 99, 235, 0.04) !important;
}

body.light-theme .bg-gray-100,
body.light-theme .bg-gray-200 {
    background-color: #f1f5f9 !important;
}

/* ===== 31. DARK MODE GLOW EFFECTS (LP alignment) ===== */
body:not(.light-theme) .btn.btn-primary:hover:not(:disabled) {
    box-shadow: 0 8px 24px rgba(37, 99, 235, 0.45) !important;
}

/* Sidebar active glow in dark mode */
body:not(.light-theme) aside#app-sidebar nav a.menu-link.active {
    box-shadow: 0 0 12px rgba(37, 99, 235, 0.25) !important;
}

/* ===== 32. TOAST - LIGHT THEME (Premium Dark Toast on Light UI) ===== */
/* Estratégia: Sonner-inspired. Toasts usam fundo claro no light theme
   com sombra suave e borda - clean, minimal, profissional */

body.light-theme .toast-modern {
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(226, 232, 240, 0.8) !important;
    box-shadow:
        0 8px 32px -4px rgba(0, 0, 0, 0.08),
        0 4px 12px -2px rgba(0, 0, 0, 0.04),
        0 0 0 1px rgba(0, 0, 0, 0.03) !important;
}

body.light-theme .toast-modern-message {
    color: #1e293b !important;
}

body.light-theme .toast-modern-close {
    color: #94a3b8 !important;
}

body.light-theme .toast-modern-close:hover {
    color: #334155 !important;
    background: rgba(0, 0, 0, 0.04) !important;
}

body.light-theme .toast-modern-undo {
    color: var(--toast-accent) !important;
}

body.light-theme .toast-modern-undo:hover {
    background: rgba(0, 0, 0, 0.04) !important;
}

body.light-theme .toast-modern-progress {
    background: rgba(0, 0, 0, 0.04) !important;
}

/* Legacy toast overrides for light theme */
body.light-theme .toast-inverted,
body.light-theme #toast-container > div:not(.toast-modern) {
    background: rgba(255, 255, 255, 0.98) !important;
    color: #1e293b !important;
    border-color: rgba(226, 232, 240, 0.8) !important;
    box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.03) !important;
}

body.light-theme #toast-container > div:not(.toast-modern) span {
    color: #1e293b !important;
}

body.light-theme .toast {
    background: rgba(255, 255, 255, 0.98) !important;
    border-color: rgba(226, 232, 240, 0.8) !important;
    box-shadow: 0 8px 32px -4px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.03) !important;
}

body.light-theme .toast-title {
    color: #1e293b !important;
}

body.light-theme .toast-message {
    color: #64748b !important;
}

body.light-theme .toast-close {
    color: #94a3b8 !important;
}

body.light-theme .toast-close:hover {
    color: #1e293b !important;
}

body.light-theme .toast-action {
    color: #1e293b !important;
    border-color: #e2e8f0 !important;
}

body.light-theme .toast-action:hover {
    background: rgba(0, 0, 0, 0.04) !important;
}

body.light-theme .toast-progress {
    background: rgba(0, 0, 0, 0.04) !important;
}

body.light-theme .toast-progress-bar {
    background: linear-gradient(90deg, #2563eb, #1d4ed8) !important;
}
