        /* Manter o CSS Grid e os estilos que você definiu */
        html, body {
            margin: 0;
            padding: 0;
            height: 100%;
            overflow: hidden;
            font-family: 'Inter', sans-serif;
            background-color: #f0f4f8; /* Fundo claro para contrastar */
        }

        /* Mantemos o Z-index alto na NAV inteira para proteção contra elementos do sistema */
        .z-high-menu { z-index: 9999 !important; }

        /* Força a cor do texto a ser azul escuro ao passar o mouse, superando quaisquer estilos herdados (como text-white) */
        .submenu-hover-fix:hover { color: #0C101C !important; /* Cor slate-950 definida no tailwind.config */ }
        
        #dynamicCrudModal.modal { opacity: 1 !important; } /* Mantém-no visível */

        .modal-content { background-color: #f0f8ff; }

        /* Layout principal da aplicação usando CSS Grid */
        .app-layout {
            display: grid;
            grid-template-areas:
                "header header"
                "sidebar content";
            grid-template-rows: 60px 1fr;
            grid-template-columns: 250px 1fr;
            height: 100vh;
            width: 100vw;
        }

        .app-header { grid-area: header; background-color: #343a40; box-shadow: 0 2px 4px rgba(0,0,0,.1); z-index: 1080; padding: 10px 0; box-sizing: border-box; }
        .app-sidebar { grid-area: sidebar; background-color: #343a40; color: #FFF; padding-top: 1rem; overflow-y: auto; transition: all 0.3s ease; z-index: 1020; box-shadow: 2px 0 5px rgba(0,0,0,0.1); }
        .app-content { grid-area: content; padding: 20px; padding-top: 80px; overflow-y: auto; box-sizing: border-box; background-color: #f8f9fa; }

        /* Ajustes de Z-index e Modal (Essencial para BS5) */
        .modal-dialog { margin-top: 150px !important; }
        .modal-backdrop { z-index: 1049 !important; }
        .navbar.fixed-top { z-index: 1050; }
        .modal { z-index: 1055 !important; }
        .ui-autocomplete { position: absolute; cursor: default; z-index:1060 !important;}
        .saidas-mat-row { display: none; }
        
        .modal label { text-align: left !important; }
        .modal .form-label { text-align: left !important; }
 
        /* Uma regra mais específica sobrescreve a sua */
        #mainDynamicModal form label.form-label { text-align: left !important; }
        
        /* Container da lista */
.lista-sugestoes {
    /* Garante que o container esteja alinhado com o input */
    position: absolute; /* Importante para que fique sobre o conteúdo */
    z-index: 1000;      /* Garante que fique acima de outros elementos */
    width: 25%;         /* Ajuste para a largura do seu input (w-75) */
    
    /* Remove a centralização de texto, se houver */
    text-align: left; 
}

/* A lista não ordenada (ul) dentro do container */
.lista-sugestoes ul {
    list-style-type: none; /* Remove os marcadores de lista */
    padding: 0;           /* Remove o padding padrão */
    margin: 0;            /* Remove a margem padrão */
    border: 1px solid #ccc; /* Adiciona uma borda para visualização */
    background-color: #fff; /* Fundo branco */
    max-height: 200px;      /* Limita a altura para que a lista role */
    overflow-y: auto;       /* Adiciona barra de rolagem se necessário */
}

/* Os itens da lista (li) */
.lista-sugestoes li {
    padding: 8px 12px; /* Espaçamento interno */
    cursor: pointer;   /* Indica que é clicável */
    color: #333;       /* Cor de texto padrão */
    border-bottom: 1px solid #eee; /* Linha divisória */
    white-space: nowrap; /* Impede quebras de linha em nomes longos */
    overflow: hidden; /* Oculta o que ultrapassar */
    text-overflow: ellipsis; /* Adiciona "..." se o texto for cortado */
}

/* Remove a linha divisória do último item */
.lista-sugestoes li:last-child {
    border-bottom: none; 
}

/* Efeito Hover (passar o mouse) */
#cadAltModal .lista-sugestoes li:hover {
    background-color: #007bff; 
    color: #fff;             
}

/* Estilo para a lista de resultados do Autocomplete */
.autocomplete-results {
    /* (Se precisar de mais estilos para o container da lista) */
    border: 1px solid #ccc; 
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

.autocomplete-results .autocomplete-item-hover:hover,
.autocomplete-results .autocomplete-item-hover:focus {
    /* Use 'var(--bs-primary)' para azul (padrão Bootstrap) ou 'var(--bs-success)' para verde */
    background-color: var(--bs-primary) !important; 
    color: white !important; /* Assegura que o texto seja branco */
    cursor: pointer;
}

/* Estilo base para o contador */
.contador-caracteres {
    font-size: 1em; /* Fonte pequena */
    color: #6c7573;    /* Cor cinza discreta */
    margin-top: 4px;   /* Espaçamento acima */
    text-align: left; /* Alinha o contador à direita */
    padding-right: 5px; /* Um pouco de padding */
}

/* Estilo de alerta para quando o limite é atingido */
.contador-caracteres.limite-atingido {
    color: #dc3545; /* Cor vermelha de alerta */
    font-weight: bold;
}

.contador-caracteres.limite-atingido {
    color: #dc3545; /* Cor vermelha de alerta */
    font-weight: bold;
}

/* NOVO: Alerta quando estiver próximo de atingir o limite (ex: 10 ou menos) */
.contador-caracteres.chegando-ao-limite {
    color: #ffc107; /* Cor amarela/laranja para pré-alerta */
}

.overlay-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.75); /* Fundo bem escuro */
    z-index: 1500; 
    display: flex; 
    justify-content: center; 
    align-items: center; 
}

/* 2. ALERTA MODIFICADO (Mais parecido com SweetAlert) */
.floating-alert {
    position: relative; 
    /* Tamanho e Estilo do SweetAlert */
    max-width: 450px; /* Largura elegante */
    width: 90%;
    padding: 30px; /* Mais padding interno */
    text-align: center; /* Centraliza o texto */
    background-color: #fff; /* Fundo branco fixo, independente do tipo */
    border-radius: 15px; /* Bordas bem arredondadas */
    /* Sombra para destaque */
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4); 
    border: none !important; /* Remove a borda padrão do Bootstrap */
    color: #333; /* Cor de texto padrão */
    z-index: 1510;
}

/* 3. ÍCONE DE STATUS (Para Sessão Expirada - Warning/Danger) */
.alert-icon {
    font-size: 4rem; /* Ícone bem grande */
    margin-bottom: 15px;
    display: block;
}

.autocomplete-results {
    position: absolute;
    z-index: 1055 !important; /* Maior que o Modal do Bootstrap (que é 1050) */
    background-color: white;
    border: 1px solid #dee2e6;
    border-radius: 0.375rem;
    box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
    max-height: 250px;
    overflow-y: auto;
    width: 100%;
    list-style: none;
    padding-left: 0;
    margin-top: 2px;
    text-align: left !important;
}

/* Efeito Hover para saber que é clicável */
.autocomplete-results li:hover {
    background-color: #0000FF;
    color: #ffffff;
}

.autocomplete-results:empty {
    display: none !important;
    border: none !important;
}

#calendar {
    /* Altura Mínima Garantida: Essencial para o FullCalendar */
    min-height: 500px; 
    
    /* Largura Garantida (ou 100% se for para preencher o pai) */
    width: 100%; 
    
    /* Se estiver dentro de um Modal, adicione um z-index alto para prevenção */
    z-index: 100;
}

#resposta {
    position: fixed;
    top: 70px; /* Abaixo do cabeçalho */
    right: 20px;
    z-index: 2000; /* Garante que fique acima de modais (z-index do modal é 1055) */
    width: 350px; /* Largura definida para o alerta flutuante */
}

/* 4. Cores do Ícone */
.alert-warning .alert-icon { color: #ffc107; /* Amarelo - Alerta */ }
.alert-danger .alert-icon { color: #dc3545; /* Vermelho - Erro */ }

.img-thumb {
    width: 40px;
    height: 40px;
    object-fit: cover;
    cursor: pointer;
    border-radius: 4px;
}

.image-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.75);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.image-overlay.show {
    display: flex;
}

.image-modal {
    position: relative;
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    max-width: 90%;
    max-height: 90%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.image-modal img {
    max-width: 100%;
    max-height: 60vh;
    object-fit: contain;
    border-radius: 8px;
}

/* Título / código */
.image-info {
    text-align: center;
    font-size: 14px;
}

/* Botões */
.image-actions {
    display: flex;
    gap: 10px;
    justify-content: center;
}

/* Botão fechar (X) */
.btn-close-overlay {
    position: absolute;
    top: 8px;
    right: 10px;
    background: none;
    border: none;
    font-size: 26px;
    cursor: pointer;
}

.dashboard-actions input[type="text"] {
    height: 36px;
    border: 1px solid #ced4da;
    border-radius: 6px;
    padding: 6px 10px;
    box-sizing: border-box;
}

.dashboard-actions input[type="text"] { border-color: #dee2e6; }
.dashboard-actions input[type="text"]:focus { box-shadow: none; }

/* Remove qualquer borda estranha herdada */
.dashboard-actions > * {
    border-collapse: separate;
}

/* Inputs mais alinhados */
.dashboard-actions input {
    height: 36px;
}

/* qnt menor */
.qnt-input {
    width: 60px;
    text-align: center;
}

.search-box {
    display: flex;
    align-items: center;   /* 👈 ESSENCIAL */
    gap: 8px;
    flex-wrap: wrap;       /* evita quebrar feio em telas menores */
}

        /* Ajustes responsivos para telas menores (mobile) */
        @media (max-width: 768px) {
            .app-layout {
                grid-template-areas:
                    "header"
                    "content";
                grid-template-rows: 60px 1fr;
                grid-template-columns: 1fr;
            }
            .app-sidebar {
                position: fixed;
                top: 60px;
                left: -250px;
                bottom: 0;
                width: 250px;
                z-index: 1020;
                background-color: #343a40;
            }
            .app-content {
                padding-left: 20px;
                margin-left: 0;
            }
        }

.whatsapp-icon::before {
    content: "\f232";
    font-family: "Font Awesome 6 Brands";
    color: white;
}

#autocomplete-list {
    text-align: left;
    all: unset;
    position: absolute;
    z-index: 1055;
    width: 100%;
    display: block;
    background: #fff;
    border: 1px solid #ddd;
}

#autocomplete-list .list-group-item {
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
}

#autocomplete-list .list-group-item:hover,
#autocomplete-list .list-group-item:focus {
    background-color: #0d6efd; /* azul Bootstrap */
    color: #fff;
}

.form-check-input { margin-left: .5rem; }

label + .form-check-input { margin-left: .5rem; }

.tabela-chamadas {
    width: 100%;
    table-layout: fixed; /* controla largura real */
    border: 2;
}

.tabela-chamadas th,
.tabela-chamadas td {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#modalCamera video { object-fit: contain; }