/* ==========================================================================
   SISTEMA DE DESIGN - CONTROLE DE PRODUÇÃO (USINA DE ASFALTO)
   CONSTRUTORA ROCHA CAVALCANTE LTDA
   VANILLA CSS - TOTALMENTE RESPONSIVO (ATÉ 360PX)
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. CONFIGURAÇÕES GERAIS E PALETA DE CORES (HSL)
   -------------------------------------------------------------------------- */
:root {
    --cor-fundo-escuro: #121214;
    --cor-fundo-cartao: rgba(30, 30, 36, 0.75);
    --cor-fundo-cartao-solido: #1e1e24;
    --cor-fundo-campo: #161619;
    --cor-linha: rgba(255, 255, 255, 0.06);

    /* Cores de Acento */
    --cor-primaria: #ff9000; /* Laranja Asfalto Quente */
    --cor-primaria-hover: #e68200;
    --cor-secundaria: #3b82f6; /* Azul Operacional */
    --cor-sucesso: #10b981;
    --cor-sucesso-fundo: rgba(16, 185, 129, 0.1);
    --cor-erro: #ef4444;
    --cor-erro-fundo: rgba(239, 68, 68, 0.1);
    --cor-alerta: #f59e0b;
    --cor-alerta-fundo: rgba(245, 158, 11, 0.1);

    /* Tipografia e Textos */
    --cor-texto-principal: #e1e1e6;
    --cor-texto-segundario: #87868b;
    --cor-texto-claro: #ffffff;
    --fonte-principal: 'Outfit', sans-serif;
    
    /* Sombras e Efeitos */
    --sombra-cartao: 0 8px 32px 0 rgba(0, 0, 0, 0.37);
    --sombra-glow: 0 0 12px rgba(255, 144, 0, 0.45);
    --raio-borda: 12px;
    --raio-borda-pequeno: 8px;
    --transicao-suave: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

/* Reset básico */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--fonte-principal);
    background-color: var(--cor-fundo-escuro);
    color: var(--cor-texto-principal);
    -webkit-font-smoothing: antialiased;
    line-height: 1.5;
}

/* --------------------------------------------------------------------------
   2. ESTRUTURA E LAYOUT (SIDEBAR + CONTENT WRAPPER)
   -------------------------------------------------------------------------- */
.layout-wrapper {
    display: flex;
    min-height: 100vh;
    overflow: hidden;
}

/* Sidebar */
.sidebar {
    width: 280px;
    background-color: #0d0d0f;
    border-right: 1px solid var(--cor-linha);
    display: flex;
    flex-direction: column;
    z-index: 100;
    transition: var(--transicao-suave);
    flex-shrink: 0;
}

.sidebar-cabecalho {
    padding: 24px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--cor-linha);
    position: relative;
}

.icone-usina {
    font-size: 2rem;
    color: var(--cor-primaria);
    margin-right: 12px;
}

.titulo-grupo h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
    letter-spacing: 0.5px;
}

.titulo-grupo span {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
    text-transform: uppercase;
    font-weight: 600;
}

.botao-fechar-sidebar {
    display: none;
    background: none;
    border: none;
    color: var(--cor-texto-principal);
    font-size: 1.5rem;
    cursor: pointer;
    position: absolute;
    right: 20px;
}

/* Perfil Usuário na Sidebar */
.perfil-sidebar {
    padding: 20px 24px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--cor-linha);
    background-color: rgba(255, 255, 255, 0.01);
}

.avatar-usuario {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--cor-primaria), #ff6b00);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    color: var(--cor-fundo-escuro);
    margin-right: 12px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.3);
}

.info-usuario {
    display: flex;
    flex-direction: column;
}

.nome-usuario {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--cor-texto-claro);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 170px;
}

.badge-perfil {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    margin-top: 4px;
    width: fit-content;
}

.badge-admin {
    background-color: var(--cor-sucesso-fundo);
    color: var(--cor-sucesso);
}

.badge-apontador,
.badge-operador {
    background-color: var(--cor-alerta-fundo);
    color: var(--cor-alerta);
}

/* Menu Navegação */
.sidebar-nav {
    flex-grow: 1;
    padding: 24px 16px;
}

.sidebar-nav ul {
    list-style: none;
}

.sidebar-nav li {
    margin-bottom: 8px;
}

.nav-link {
    display: flex;
    align-items: center;
    padding: 12px 16px;
    color: var(--cor-texto-segundario);
    text-decoration: none;
    border-radius: var(--raio-borda-pequeno);
    font-weight: 500;
    font-size: 0.95rem;
    transition: var(--transicao-suave);
}

.nav-link i {
    font-size: 1.2rem;
    margin-right: 14px;
    width: 20px;
    text-align: center;
}

.nav-link:hover {
    color: var(--cor-texto-claro);
    background-color: rgba(255, 255, 255, 0.04);
}

/* Estado Ativo do Link da Rota */
.nav-link.ativo {
    color: var(--cor-texto-claro);
    background-color: rgba(255, 144, 0, 0.1);
    border-left: 4px solid var(--cor-primaria);
    padding-left: 12px;
    font-weight: 600;
}

.sidebar-rodape {
    padding: 24px 16px;
    border-top: 1px solid var(--cor-linha);
}

.botao-sair {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 12px;
    color: var(--cor-erro);
    background-color: var(--cor-erro-fundo);
    text-decoration: none;
    border-radius: var(--raio-borda-pequeno);
    font-weight: 600;
    transition: var(--transicao-suave);
}

.botao-sair:hover {
    background-color: var(--cor-erro);
    color: var(--cor-texto-claro);
}

/* Área de Conteúdo */
.conteudo-principal {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    height: 100vh;
    overflow-y: auto;
    background-color: var(--cor-fundo-escuro);
}

/* Topbar */
.topbar {
    height: 70px;
    background-color: #0d0d0f;
    border-bottom: 1px solid var(--cor-linha);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 30px;
    flex-shrink: 0;
}

.botao-menu-hamburguer {
    display: none;
    background: none;
    border: none;
    color: var(--cor-texto-principal);
    font-size: 1.5rem;
    cursor: pointer;
}

.identificacao-sistema h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--cor-texto-claro);
}

.hora-atual {
    display: flex;
    align-items: center;
    font-size: 0.95rem;
    color: var(--cor-texto-segundario);
    background-color: rgba(255, 255, 255, 0.02);
    padding: 6px 14px;
    border-radius: 30px;
    border: 1px solid var(--cor-linha);
}

.hora-atual i {
    margin-right: 8px;
    color: var(--cor-primaria);
}

/* Container do Conteúdo Geral */
.conteudo-container {
    padding: 30px;
    flex-grow: 1;
}

/* --------------------------------------------------------------------------
   3. DESIGN DA TELA DE LOGIN (GLASSMORPHISM)
   -------------------------------------------------------------------------- */
.corpo-login {
    background: radial-gradient(circle at top right, rgba(255, 144, 0, 0.15), transparent), var(--cor-fundo-escuro);
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.login-container {
    width: 100%;
    max-width: 440px;
    z-index: 10;
}

.login-cartao {
    background: var(--cor-fundo-cartao);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 40px;
    box-shadow: var(--sombra-cartao);
}

.login-cabecalho {
    text-align: center;
    margin-bottom: 30px;
}

.logo-area {
    width: 60px;
    height: 60px;
    border-radius: var(--raio-borda-pequeno);
    background-color: rgba(255, 144, 0, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px auto;
}

.logo-icone {
    font-size: 2.2rem;
    color: var(--cor-primaria);
}

.login-cabecalho h2 {
    color: var(--cor-texto-claro);
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 6px;
}

.login-cabecalho p {
    color: var(--cor-texto-segundario);
    font-size: 0.9rem;
}

/* Formulário de Login */
.login-formulario .campo-grupo {
    margin-bottom: 20px;
}

.campo-grupo label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--cor-texto-principal);
    margin-bottom: 8px;
}

.input-icone {
    position: relative;
    display: flex;
    align-items: center;
}

.input-icone i {
    position: absolute;
    left: 16px;
    color: var(--cor-texto-segundario);
    font-size: 1.1rem;
}

.input-icone input {
    width: 100%;
    padding: 14px 14px 14px 46px;
    background-color: var(--cor-fundo-campo);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-texto-claro);
    font-family: var(--fonte-principal);
    font-size: 0.95rem;
    transition: var(--transicao-suave);
}

.input-icone input::placeholder {
    color: #4e4e54;
}

.input-icone input:focus {
    outline: none;
    border-color: var(--cor-primaria);
    box-shadow: 0 0 0 2px rgba(255, 144, 0, 0.15);
}

.botao-login {
    width: 100%;
    padding: 14px;
    background-color: var(--cor-primaria);
    border: none;
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-fundo-escuro);
    font-family: var(--fonte-principal);
    font-weight: 700;
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transicao-suave);
    margin-top: 10px;
}

.botao-login i {
    margin-left: 8px;
    font-size: 1.1rem;
    transition: transform 0.2s;
}

.botao-login:hover {
    background-color: var(--cor-primaria-hover);
    box-shadow: var(--sombra-glow);
}

.botao-login:hover i {
    transform: translateX(4px);
}

.login-rodape {
    text-align: center;
    margin-top: 35px;
    border-top: 1px solid var(--cor-linha);
    padding-top: 20px;
}

.login-rodape p {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
}

/* --------------------------------------------------------------------------
   4. COMPONENTES: ALERTAS (NOTIFICATIONS)
   -------------------------------------------------------------------------- */
.alerta {
    padding: 16px;
    border-radius: var(--raio-borda-pequeno);
    margin-bottom: 24px;
    display: flex;
    align-items: flex-start;
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.4;
    position: relative;
    border-left: 4px solid transparent;
}

.alerta i {
    font-size: 1.2rem;
    margin-right: 12px;
    margin-top: 1px;
}

.alerta-erro {
    background-color: var(--cor-erro-fundo);
    color: var(--cor-erro);
    border-left-color: var(--cor-erro);
}

.alerta-sucesso {
    background-color: var(--cor-sucesso-fundo);
    color: var(--cor-sucesso);
    border-left-color: var(--cor-sucesso);
}

.alerta-dismissible {
    padding-right: 40px;
}

.fechar-alerta {
    position: absolute;
    right: 16px;
    top: 14px;
    background: none;
    border: none;
    color: currentColor;
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    opacity: 0.7;
    transition: 0.2s;
}

.fechar-alerta:hover {
    opacity: 1;
}

/* --------------------------------------------------------------------------
   5. COMPONENTES: WIDGETS E METRICAS (DASHBOARD)
   -------------------------------------------------------------------------- */
.painel-boas-vindas {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
}

.painel-boas-vindas h1 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.painel-boas-vindas p {
    color: var(--cor-texto-segundario);
    font-size: 0.95rem;
    margin-top: 4px;
}

/* Grade de Métricas */
.grid-metricas {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    margin-bottom: 30px;
}

.cartao-metrica {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 24px;
    display: flex;
    align-items: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    transition: var(--transicao-suave);
}

.cartao-metrica:hover {
    transform: translateY(-4px);
    border-color: rgba(255, 255, 255, 0.15);
}

.metrica-icone {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-right: 20px;
    flex-shrink: 0;
}

.cartao-producao .metrica-icone {
    background-color: rgba(255, 144, 0, 0.1);
    color: var(--cor-primaria);
}

.cartao-bpf .metrica-icone {
    background-color: rgba(59, 130, 246, 0.1);
    color: var(--cor-secundaria);
}

.cartao-diesel .metrica-icone {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--cor-sucesso);
}

.cartao-status .metrica-icone {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--cor-alerta);
}

.cartao-custo .metrica-icone {
    background-color: rgba(168, 85, 247, 0.1);
    color: #a855f7;
}

.metrica-conteudo h3 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
    line-height: 1.2;
}

.metrica-conteudo h3 .unidade {
    font-size: 1rem;
    font-weight: 600;
    color: var(--cor-texto-segundario);
    margin-left: 4px;
}

.metrica-conteudo p {
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--cor-texto-segundario);
    letter-spacing: 0.5px;
    margin-top: 4px;
}

.metrica-conteudo .subtexto {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
    display: block;
    margin-top: 2px;
}

/* --------------------------------------------------------------------------
   6. COMPONENTES: NÍVEL DE ESTOQUES (DASHBOARD)
   -------------------------------------------------------------------------- */
.secao-dashboard-estoques {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 30px;
    margin-bottom: 30px;
}

.cartao-dashboard-titulo {
    margin-bottom: 24px;
}

.cartao-dashboard-titulo h3 {
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
    display: flex;
    align-items: center;
}

.cartao-dashboard-titulo h3 i {
    margin-right: 10px;
    color: var(--cor-primaria);
}

.cartao-dashboard-titulo p {
    font-size: 0.85rem;
    color: var(--cor-texto-segundario);
    margin-top: 4px;
}

.grid-estoques-barras {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
}

.barra-estoque-item {
    display: flex;
    flex-direction: column;
}

.barra-estoque-meta {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8px;
    font-size: 0.9rem;
    font-weight: 600;
}

.barra-estoque-nome {
    color: var(--cor-texto-principal);
}

.barra-estoque-qtd {
    color: var(--cor-texto-claro);
}

.barra-estoque-trilho {
    height: 10px;
    background-color: rgba(255, 255, 255, 0.05);
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 6px;
    border: 1px solid rgba(255, 255, 255, 0.02);
}

.barra-estoque-preenchimento {
    height: 100%;
    border-radius: 10px;
    transition: width 1s ease-out;
}

.estoque-ok {
    background: linear-gradient(90deg, var(--cor-sucesso), #34d399);
}

.estoque-atencao {
    background: linear-gradient(90deg, var(--cor-alerta), #fbbf24);
}

.estoque-critico {
    background: linear-gradient(90deg, var(--cor-erro), #f87171);
    box-shadow: 0 0 8px rgba(239, 68, 68, 0.5);
}

.barra-estoque-minimo {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
    text-align: right;
}

/* Alertas de Estoque Crítico */
.secao-alertas-criticos {
    margin-bottom: 30px;
}

.cartao-alerta-estoque {
    background-color: var(--cor-erro-fundo);
    border: 1px solid rgba(239, 68, 68, 0.2);
    border-left: 5px solid var(--cor-erro);
    border-radius: var(--raio-borda-pequeno);
    padding: 16px 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.cartao-alerta-estoque i {
    font-size: 1.6rem;
    color: var(--cor-erro);
    margin-right: 20px;
}

.alerta-detalhe {
    flex-grow: 1;
}

.alerta-detalhe h4 {
    color: var(--cor-texto-claro);
    font-weight: 700;
    font-size: 0.95rem;
}

.alerta-detalhe p {
    font-size: 0.85rem;
    color: var(--cor-texto-segundario);
    margin-top: 2px;
}

.botao-alerta-acao {
    padding: 8px 16px;
    background-color: var(--cor-erro);
    color: var(--cor-texto-claro);
    text-decoration: none;
    border-radius: var(--raio-borda-pequeno);
    font-size: 0.85rem;
    font-weight: 700;
    transition: var(--transicao-suave);
}

.botao-alerta-acao:hover {
    background-color: #b91c1c;
}

/* --------------------------------------------------------------------------
   7. COMPONENTES: GRÁFICOS (DASHBOARD)
   -------------------------------------------------------------------------- */
.grade-dashboard-graficos {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 20px;
    margin-bottom: 30px;
}

.cartao-grafico {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 24px;
    min-width: 0; /* Evita que o gráfico estoure a largura do grid no celular */
}

.grafico-cabecalho {
    margin-bottom: 20px;
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 12px;
}

.grafico-cabecalho h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.grafico-cabecalho h3 i {
    margin-right: 8px;
    color: var(--cor-primaria);
}

.grafico-corpo {
    height: 300px;
    position: relative;
}

.flex-centro {
    display: flex;
    justify-content: center;
    align-items: center;
}

/* --------------------------------------------------------------------------
   8. COMPONENTES: TABELAS E BOTÕES
   -------------------------------------------------------------------------- */
.secao-cabecalho-pagina {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
}

.secao-cabecalho-pagina h1 {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.secao-cabecalho-pagina p {
    color: var(--cor-texto-segundario);
    font-size: 0.95rem;
    margin-top: 4px;
}

/* Botões */
.botao {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    font-family: var(--fonte-principal);
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    border-radius: var(--raio-borda-pequeno);
    border: none;
    cursor: pointer;
    transition: var(--transicao-suave);
}

.botao i {
    margin-right: 8px;
}

.botao-primario {
    background-color: var(--cor-primaria);
    color: var(--cor-fundo-escuro);
}

.botao-primario:hover {
    background-color: var(--cor-primaria-hover);
    box-shadow: var(--sombra-glow);
}

.botao-secundario {
    background-color: rgba(59, 130, 246, 0.1);
    color: var(--cor-secundaria);
    border: 1px solid rgba(59, 130, 246, 0.3);
}

.botao-secundario:hover {
    background-color: var(--cor-secundaria);
    color: var(--cor-texto-claro);
}

.botao-terciario {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--cor-sucesso);
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.botao-terciario:hover {
    background-color: var(--cor-sucesso);
    color: var(--cor-texto-claro);
}

.botao-retorno {
    background-color: rgba(255, 255, 255, 0.03);
    color: var(--cor-texto-principal);
    border: 1px solid var(--cor-linha);
}

.botao-retorno:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

.botao-confirmar {
    background-color: var(--cor-sucesso);
    color: var(--cor-texto-claro);
}

.botao-confirmar:hover {
    background-color: #059669;
}

.botao-cancelar {
    background-color: rgba(239, 68, 68, 0.1);
    color: var(--cor-erro);
    border: 1px solid rgba(239, 68, 68, 0.3);
    margin-left: 10px;
}

.botao-cancelar:hover {
    background-color: var(--cor-erro);
    color: var(--cor-texto-claro);
}

/* Tabelas */
.grade-dashboard-tabelas {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.cartao-tabela {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 24px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    min-width: 0; /* Evita que a tabela force a largura e gere rolagem no corpo da página no celular */
}

.tabela-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 12px;
}

.tabela-cabecalho h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.tabela-cabecalho h3 i {
    margin-right: 8px;
    color: var(--cor-primaria);
}

.ver-tudo {
    font-size: 0.85rem;
    color: var(--cor-primaria);
    text-decoration: none;
    font-weight: 600;
    transition: var(--transicao-suave);
}

.ver-tudo:hover {
    color: var(--cor-primaria-hover);
}

.tabela-responsiva {
    overflow-x: auto;
    width: 100%;
}

.tabela-operacional {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
    font-size: 0.9rem;
}

.tabela-operacional th {
    padding: 12px 16px;
    border-bottom: 2px solid var(--cor-linha);
    color: var(--cor-texto-segundario);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.tabela-operacional td {
    padding: 14px 16px;
    border-bottom: 1px solid var(--cor-linha);
    color: var(--cor-texto-principal);
}

.tabela-operacional tr:last-child td {
    border-bottom: none;
}

.tabela-operacional tr:hover td {
    background-color: rgba(255, 255, 255, 0.015);
}

.tabela-vazia {
    text-align: center;
    padding: 30px !important;
    color: var(--cor-texto-segundario);
    font-style: italic;
}

/* Detalhes na coluna da tabela */
.col-detalhes {
    display: flex;
    flex-direction: column;
}

.col-detalhes .subtexto {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
}

.tag-material {
    display: inline-block;
    padding: 3px 8px;
    background-color: rgba(255, 255, 255, 0.05);
    border: 1px solid var(--cor-linha);
    color: var(--cor-texto-principal);
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 4px;
}

.tag-bpf {
    background-color: rgba(59, 130, 246, 0.1);
    color: var(--cor-secundaria);
    border-color: rgba(59, 130, 246, 0.2);
}

.tag-diesel {
    background-color: rgba(16, 185, 129, 0.1);
    color: var(--cor-sucesso);
    border-color: rgba(16, 185, 129, 0.2);
}

/* Ações em ícones da tabela */
.acoes-arquivo-icones {
    display: flex;
    gap: 12px;
}

.link-icone-xml, .link-icone-foto {
    font-size: 1.25rem;
    transition: var(--transicao-suave);
}

.link-icone-xml { color: var(--cor-alerta); }
.link-icone-xml:hover { color: #f59e0b; filter: drop-shadow(0 0 4px rgba(245, 158, 11, 0.4)); }

.link-icone-foto { color: var(--cor-secundaria); }
.link-icone-foto:hover { color: #2563eb; filter: drop-shadow(0 0 4px rgba(59, 130, 246, 0.4)); }

.botao-tabela-visualizar {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background-color: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--cor-linha);
    color: var(--cor-texto-principal);
    text-decoration: none;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    transition: var(--transicao-suave);
}

.botao-tabela-visualizar i {
    margin-right: 6px;
}

.botao-tabela-visualizar:hover {
    background-color: var(--cor-primaria);
    color: var(--cor-fundo-escuro);
    border-color: var(--cor-primaria);
}

.link-visualizar-foto-tabela {
    color: var(--cor-primaria);
    font-size: 1.2rem;
    transition: 0.2s;
}

.link-visualizar-foto-tabela:hover {
    color: var(--cor-primaria-hover);
    transform: scale(1.15);
}

.texto-mutado {
    color: var(--cor-texto-segundario);
    font-size: 0.85rem;
}

/* --------------------------------------------------------------------------
   9. COMPONENTES: FORMULÁRIOS DE CRIAÇÃO E LANÇAMENTO
   -------------------------------------------------------------------------- */
.painel-formulario-container {
    max-width: 900px;
    margin: 0 auto;
}

.cartao-formulario {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 30px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.cartao-formulario-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 16px;
    margin-bottom: 24px;
}

.cartao-formulario-cabecalho h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.cartao-formulario-cabecalho h3 i {
    color: var(--cor-primaria);
    margin-right: 8px;
}

.formulario-padrao .campo-grupo {
    display: flex;
    flex-direction: column;
    margin-bottom: 20px;
}

.obrigatorio {
    color: var(--cor-erro);
    margin-left: 2px;
}

.formulario-padrao input[type="text"],
.formulario-padrao input[type="number"],
.formulario-padrao input[type="date"],
.formulario-padrao input[type="time"],
.formulario-padrao input[type="email"],
.formulario-padrao input[type="password"],
.formulario-padrao select {
    padding: 12px;
    background-color: var(--cor-fundo-campo);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-texto-claro);
    font-family: var(--fonte-principal);
    font-size: 0.95rem;
    transition: var(--transicao-suave);
    width: 100%;
}

.formulario-padrao input:focus,
.formulario-padrao select:focus {
    outline: none;
    border-color: var(--cor-primaria);
}

/* Grids Internos do Formulário */
.campo-linha-dupla {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.campo-linha-tripla {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
}

.campo-uf-largura {
    max-width: 200px;
}

.subtexto {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
    margin-top: 4px;
}

.formulario-botoes-acoes {
    display: flex;
    justify-content: flex-start;
    border-top: 1px solid var(--cor-linha);
    padding-top: 24px;
    margin-top: 24px;
}

/* Componente de Upload do XML */
.cartao-importacao-xml {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 30px;
    margin-bottom: 24px;
}

.importacao-cabecalho {
    margin-bottom: 20px;
}

.importacao-cabecalho h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.importacao-cabecalho h3 i {
    color: var(--cor-primaria);
    margin-right: 8px;
}

.importacao-cabecalho p {
    font-size: 0.9rem;
    color: var(--cor-texto-segundario);
    margin-top: 4px;
}

.upload-dropzone {
    border: 2px dashed rgba(255, 144, 0, 0.3);
    background-color: rgba(255, 144, 0, 0.01);
    border-radius: var(--raio-borda-pequeno);
    padding: 40px 20px;
    text-align: center;
    cursor: pointer;
    transition: var(--transicao-suave);
    position: relative;
}

.upload-dropzone:hover {
    border-color: var(--cor-primaria);
    background-color: rgba(255, 144, 0, 0.03);
}

.icone-upload {
    font-size: 2.5rem;
    color: var(--cor-primaria);
    margin-bottom: 12px;
}

.upload-dropzone p {
    font-size: 0.95rem;
    color: var(--cor-texto-principal);
}

.upload-dropzone input[type="file"] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.importacao-divisor {
    text-align: center;
    position: relative;
    margin-top: 30px;
}

.importacao-divisor::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: 100%;
    height: 1px;
    background-color: var(--cor-linha);
    z-index: 1;
}

.importacao-divisor span {
    background-color: var(--cor-fundo-cartao-solido);
    padding: 0 16px;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--cor-texto-segundario);
    position: relative;
    z-index: 2;
    letter-spacing: 1px;
}

/* Captura de Foto Customizada */
.input-arquivo-customizado {
    display: inline-flex;
    align-items: center;
    padding: 12px 20px;
    background-color: rgba(255, 255, 255, 0.03);
    border: 1px dashed var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-texto-principal);
    font-weight: 600;
    cursor: pointer;
    position: relative;
    transition: var(--transicao-suave);
}

.input-arquivo-customizado:hover {
    border-color: var(--cor-primaria);
    color: var(--cor-texto-claro);
    background-color: rgba(255, 144, 0, 0.02);
}

.input-arquivo-customizado i {
    margin-right: 8px;
    color: var(--cor-primaria);
}

.input-arquivo-customizado input[type="file"] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

/* --------------------------------------------------------------------------
   10. TABELA DE ITENS NO FORMULÁRIO DE NOTAS FISCAIS
   -------------------------------------------------------------------------- */
.secao-formulario-itens {
    margin-top: 30px;
    border-top: 1px solid var(--cor-linha);
    padding-top: 24px;
}

.secao-itens-cabecalho {
    margin-bottom: 20px;
}

.secao-itens-cabecalho h3 {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.secao-itens-cabecalho p {
    font-size: 0.85rem;
    color: var(--cor-texto-segundario);
    margin-top: 2px;
}

.tabela-cadastro-itens {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 16px;
}

.tabela-cadastro-itens th {
    padding: 10px;
    color: var(--cor-texto-segundario);
    font-weight: 600;
    font-size: 0.8rem;
    text-transform: uppercase;
    border-bottom: 2px solid var(--cor-linha);
    text-align: left;
}

.tabela-cadastro-itens td {
    padding: 10px 6px;
    border-bottom: 1px solid var(--cor-linha);
    vertical-align: middle;
}

.nome-item-nota {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--cor-texto-principal);
    word-break: break-all;
}

.select-insumo-tabela {
    padding: 8px !important;
    font-size: 0.85rem !important;
    background-color: var(--cor-fundo-campo) !important;
}

.input-tabela-desc {
    padding: 8px !important;
    font-size: 0.85rem !important;
    background-color: var(--cor-fundo-campo) !important;
}

.input-tabela-qtd, .input-tabela-money {
    padding: 8px !important;
    font-size: 0.85rem !important;
    text-align: right;
    background-color: var(--cor-fundo-campo) !important;
}

.btn-remover-linha {
    background: none;
    border: none;
    color: var(--cor-erro);
    font-size: 1.1rem;
    cursor: pointer;
    padding: 6px;
    transition: 0.2s;
}

.btn-remover-linha:hover {
    color: #ef4444;
    transform: scale(1.15);
}

.botao-adicionar-linha-manual {
    background: none;
    border: 1px dashed var(--cor-primaria);
    color: var(--cor-primaria);
    padding: 8px 16px;
    border-radius: var(--raio-borda-pequeno);
    font-family: var(--fonte-principal);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transicao-suave);
    margin-top: 10px;
}

.botao-adicionar-linha-manual:hover {
    background-color: rgba(255, 144, 0, 0.05);
    border-style: solid;
}

/* --------------------------------------------------------------------------
   11. QUADROS DE RECEITA OPERACIONAL (SAÍDA DE PRODUÇÃO)
   -------------------------------------------------------------------------- */
.painel-informativo-receita {
    background-color: rgba(255, 144, 0, 0.03);
    border: 1px solid rgba(255, 144, 0, 0.15);
    border-radius: var(--raio-borda-pequeno);
    padding: 20px;
    margin: 24px 0;
}

.painel-informativo-receita h4 {
    color: var(--cor-primaria);
    font-weight: 700;
    font-size: 0.95rem;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
}

.painel-informativo-receita h4 i {
    margin-right: 8px;
}

.painel-informativo-receita p {
    font-size: 0.85rem;
    color: var(--cor-texto-principal);
    margin-bottom: 12px;
}

.lista-estimativa-consumo {
    list-style: none;
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}

.lista-estimativa-consumo li {
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    color: var(--cor-texto-principal);
}

.lista-estimativa-consumo li i {
    color: var(--cor-erro);
    margin-right: 6px;
    font-size: 0.75rem;
}

/* --------------------------------------------------------------------------
   12. TELA DE VISUALIZAÇÃO DETALHADA DE NOTA FISCAL
   -------------------------------------------------------------------------- */
.grade-visualizacao-nf {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 24px;
    margin-bottom: 30px;
}

.cartao-visualizacao-detalhes, .cartao-visualizacao-foto {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 30px;
}

.cartao-visualizacao-cabecalho {
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 14px;
    margin-bottom: 20px;
}

.cartao-visualizacao-cabecalho h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
}

.cartao-visualizacao-cabecalho h3 i {
    color: var(--cor-primaria);
    margin-right: 8px;
}

.corpo-dados-visualizacao .item-dado {
    display: flex;
    flex-direction: column;
    margin-bottom: 18px;
}

.dado-rotulo {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--cor-texto-segundario);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.dado-valor {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--cor-texto-principal);
}

.valor-destaque {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--cor-primaria);
}

.item-dado-linha-dupla {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.grade-botoes-arquivos {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}

.botao-arquivo-download {
    display: inline-flex;
    align-items: center;
    padding: 10px 16px;
    border-radius: var(--raio-borda-pequeno);
    font-family: var(--fonte-principal);
    font-size: 0.85rem;
    font-weight: 600;
    text-decoration: none;
    transition: var(--transicao-suave);
}

.botao-arquivo-download i {
    margin-right: 8px;
}

.btn-xml {
    background-color: rgba(245, 158, 11, 0.1);
    color: var(--cor-alerta);
    border: 1px solid rgba(245, 158, 11, 0.2);
}

.btn-xml:hover {
    background-color: var(--cor-alerta);
    color: var(--cor-fundo-escuro);
}

.btn-foto {
    background-color: rgba(59, 130, 246, 0.1);
    color: var(--cor-secundaria);
    border: 1px solid rgba(59, 130, 246, 0.2);
}

.btn-foto:hover {
    background-color: var(--cor-secundaria);
    color: var(--cor-texto-claro);
}

.imagem-anexo-nf {
    width: 100%;
    border-radius: var(--raio-borda-pequeno);
    border: 1px solid var(--cor-linha);
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    object-fit: contain;
    max-height: 400px;
}

/* --------------------------------------------------------------------------
   13. TELA DE RELATÓRIOS E COMPONENTES DE IMPRESSÃO
   -------------------------------------------------------------------------- */
.secao-filtros-relatorio {
    margin-bottom: 24px;
}

.cabecalho-impressao-exclusivo {
    display: none;
}

.grade-resumo-relatorio {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
    margin-bottom: 24px;
}

.cartao-resumo-relatorio {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 20px;
    display: flex;
    flex-direction: column;
}

.resumo-titulo {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--cor-texto-segundario);
    text-transform: uppercase;
}

.resumo-valor {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
    margin-top: 6px;
}

.valor-sucesso { color: var(--cor-sucesso); }
.valor-erro { color: var(--cor-erro); }
.valor-alerta { color: var(--cor-alerta); }

.badge-status {
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
}

.badge-sucesso {
    background-color: var(--cor-sucesso-fundo);
    color: var(--cor-sucesso);
}

.badge-erro {
    background-color: var(--cor-erro-fundo);
    color: var(--cor-erro);
}

.badge-alerta {
    background-color: var(--cor-alerta-fundo);
    color: var(--cor-alerta);
}

.linha-total-consolidado td {
    background-color: rgba(255, 255, 255, 0.02);
    border-top: 2px solid var(--cor-primaria) !important;
}

/* --------------------------------------------------------------------------
   14. RESPONSIVIDADE E ADAPTAÇÃO PARA DISPOSITIVOS MÓVEIS (ATÉ 360PX)
   -------------------------------------------------------------------------- */

/* Telas Médias (Tablets e Desktops Pequenos) */
@media (max-width: 1024px) {
    .grade-dashboard-graficos {
        grid-template-columns: 1fr;
    }
    .grade-visualizacao-nf {
        grid-template-columns: 1fr;
    }
}

/* Telas Mobile (Smartphones) */
@media (max-width: 768px) {
    .layout-wrapper {
        flex-direction: column;
    }

    /* Menu Lateral Mobile - Retrátil */
    .sidebar {
        position: fixed;
        left: -280px;
        top: 0;
        bottom: 0;
        width: 280px;
        height: 100vh;
        box-shadow: 10px 0 30px rgba(0,0,0,0.5);
    }

    .sidebar.aberta {
        left: 0;
    }

    .botao-fechar-sidebar {
        display: block;
    }

    .botao-menu-hamburguer {
        display: block;
        margin-right: 16px;
    }

    .topbar {
        padding: 0 20px;
        justify-content: flex-start;
    }

    .identificacao-sistema {
        flex-grow: 1;
    }

    .hora-atual {
        display: none; /* Esconde relógio em telas menores */
    }

    .conteudo-principal {
        height: calc(100vh - 70px);
    }

    .conteudo-container {
        padding: 20px 15px;
    }

    /* Cabeçalho de Página Responsivo */
    .secao-cabecalho-pagina {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }
    
    .secao-cabecalho-pagina > div:last-child {
        width: 100%;
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .secao-cabecalho-pagina > div:last-child .botao {
        width: 100%;
        text-align: center;
    }

    /* Boas vindas do dashboard */
    .painel-boas-vindas {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .painel-acoes-rapidas {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 10px;
    }

    .painel-acoes-rapidas .botao {
        width: 100%;
        text-align: center;
    }

    /* Grids */
    .grade-dashboard-tabelas {
        grid-template-columns: 1fr;
    }

    /* Formulários */
    .campo-linha-dupla, .campo-linha-tripla {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .campo-uf-largura {
        max-width: 100%;
    }

    .formulario-botoes-acoes {
        flex-direction: column;
        gap: 12px;
    }

    .formulario-botoes-acoes .botao {
        width: 100%;
        margin-left: 0 !important;
    }

    /* Visualização NF e Arquivos */
    .grade-botoes-arquivos {
        flex-direction: column;
    }

    .botao-arquivo-download {
        width: 100%;
        justify-content: center;
    }
}

/* Telas Extremamente Pequenas (360px) */
@media (max-width: 360px) {
    .identificacao-sistema h2 {
        font-size: 1.05rem;
    }
    
    .painel-boas-vindas h1 {
        font-size: 1.5rem;
    }

    .cartao-formulario {
        padding: 20px 15px;
    }
}

/* ==========================================================================
   PERSONALIZAÇÕES DO MÓDULO DE OBRAS
   ========================================================================== */
.cidade-wrapper {
    display: flex;
    gap: 10px;
    align-items: center;
}

.cidade-wrapper select {
    flex: 1;
}

.btn-acao-adicionar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 47px;
    height: 47px;
    background-color: rgba(255, 144, 0, 0.1);
    border: 1px solid rgba(255, 144, 0, 0.3);
    color: var(--cor-primaria);
    border-radius: var(--raio-borda-pequeno);
    cursor: pointer;
    font-size: 1.1rem;
    transition: var(--transicao-suave);
    flex-shrink: 0;
}

.btn-acao-adicionar:hover {
    background-color: var(--cor-primaria);
    color: var(--cor-fundo-escuro);
    box-shadow: var(--sombra-glow);
}

.botao-tabela-editar {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background-color: rgba(59, 130, 246, 0.1);
    border: 1px solid rgba(59, 130, 246, 0.3);
    color: var(--cor-secundaria);
    text-decoration: none;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    transition: var(--transicao-suave);
    margin-right: 6px;
}

.botao-tabela-editar i {
    margin-right: 6px;
}

.botao-tabela-editar:hover {
    background-color: var(--cor-secundaria);
    color: var(--cor-texto-claro);
    border-color: var(--cor-secundaria);
}

.botao-tabela-excluir {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background-color: rgba(239, 68, 68, 0.1);
    border: 1px solid rgba(239, 68, 68, 0.3);
    color: var(--cor-erro);
    text-decoration: none;
    border-radius: 4px;
    font-size: 0.8rem;
    font-weight: 600;
    transition: var(--transicao-suave);
}

.botao-tabela-excluir i {
    margin-right: 6px;
}

.botao-tabela-excluir:hover {
    background-color: var(--cor-erro);
    color: var(--cor-texto-claro);
    border-color: var(--cor-erro);
}

/* Modal Cidade Custom styles */
.modal-cidade {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(10, 10, 12, 0.85);
    backdrop-filter: blur(8px);
    z-index: 1000;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
}

.modal-conteudo {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    width: 100%;
    max-width: 450px;
    box-shadow: var(--sombra-cartao);
    animation: modalFadeIn 0.3s ease-out;
}

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

.modal-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--cor-linha);
}

.modal-cabecalho h3 {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cor-texto-claro);
    display: flex;
    align-items: center;
    gap: 10px;
}

.modal-cabecalho h3 i {
    color: var(--cor-primaria);
}

.btn-fechar-modal {
    background: none;
    border: none;
    color: var(--cor-texto-segundario);
    font-size: 1.5rem;
    cursor: pointer;
    line-height: 1;
    transition: var(--transicao-suave);
}

.btn-fechar-modal:hover {
    color: var(--cor-texto-claro);
}

.modal-corpo {
    padding: 24px;
}

.modal-corpo .campo-grupo input,
.modal-corpo .campo-grupo select {
    padding: 12px;
    background-color: var(--cor-fundo-campo);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-texto-claro);
    font-family: var(--fonte-principal);
    font-size: 0.95rem;
    width: 100%;
    outline: none;
    transition: var(--transicao-suave);
}

.modal-corpo .campo-grupo input:focus,
.modal-corpo .campo-grupo select:focus {
    border-color: var(--cor-primaria);
}

.modal-rodape {
    display: flex;
    justify-content: flex-end;
    padding: 20px 24px;
    border-top: 1px solid var(--cor-linha);
}

/* Split Layout para Gerenciamento de Cidades */
.grade-split-layout {
    display: grid;
    grid-template-columns: 0.35fr 0.65fr;
    gap: 24px;
    align-items: start;
}

@media (max-width: 768px) {
    .grade-split-layout {
        grid-template-columns: 1fr;
    }
}

/* --------------------------------------------------------------------------
   15. ESTILOS ESPECÍFICOS DE IMPRESSÃO (Window.print())
   -------------------------------------------------------------------------- */
@media print {
    /* Ocultar elementos desnecessários na impressão */
    .sidebar,
    .topbar,
    .nao-imprimivel,
    .botao,
    .ver-tudo,
    .fechar-alerta,
    .alerta,
    .botao-alerta-acao,
    .secao-alertas-criticos,
    .grade-dashboard-graficos {
        display: none !important;
    }

    /* Ajustar corpo da página */
    body, .conteudo-principal, .layout-wrapper {
        background-color: #ffffff !important;
        color: #000000 !important;
        display: block !important;
        height: auto !important;
        overflow: visible !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .conteudo-container {
        padding: 0 !important;
    }

    /* Mostrar cabeçalho exclusivo de impressão */
    .cabecalho-impressao-exclusivo {
        display: block !important;
        border-bottom: 2px solid #000000;
        padding-bottom: 16px;
        margin-bottom: 30px;
    }

    .impressao-logo {
        display: flex;
        align-items: center;
        margin-bottom: 12px;
    }

    .impressao-logo i {
        font-size: 2.5rem;
        color: #000000;
        margin-right: 16px;
    }

    .impressao-logo h2 {
        font-size: 1.4rem;
        font-weight: 700;
        margin: 0;
    }

    .impressao-logo span {
        font-size: 0.8rem;
        font-weight: 600;
        color: #555555;
    }

    .impressao-meta {
        display: flex;
        justify-content: space-between;
        font-size: 0.85rem;
    }

    /* Estilizar cartões de resumo na impressão */
    .grade-resumo-relatorio {
        grid-template-columns: 1fr 1fr !important;
        margin-bottom: 24px;
        gap: 15px;
    }

    .cartao-resumo-relatorio {
        background-color: #f8f9fa !important;
        border: 1px solid #dee2e6 !important;
        border-radius: 4px !important;
        padding: 12px !important;
        color: #000000 !important;
        box-shadow: none !important;
    }

    .resumo-valor {
        color: #000000 !important;
        font-size: 1.4rem !important;
    }

    /* Estilizar tabela na impressão */
    .cartao-tabela {
        background-color: #ffffff !important;
        border: none !important;
        padding: 0 !important;
        box-shadow: none !important;
    }

    .tabela-operacional {
        font-size: 0.85rem !important;
    }

    .tabela-operacional th {
        color: #000000 !important;
        border-bottom: 2px solid #000000 !important;
        background-color: #f1f3f5 !important;
        padding: 8px 10px !important;
    }

    .tabela-operacional td {
        color: #000000 !important;
        border-bottom: 1px solid #dee2e6 !important;
        padding: 8px 10px !important;
    }

    .linha-total-consolidado td {
        border-top: 2px solid #000000 !important;
        background-color: #f8f9fa !important;
    }

    .tag-material {
        background-color: transparent !important;
        border: 1px solid #000000 !important;
        color: #000000 !important;
        padding: 2px 6px !important;
    }

    .badge-status {
        background-color: transparent !important;
        border: 1px solid #000000 !important;
        color: #000000 !important;
        padding: 2px 6px !important;
    }
}

/* Sidebar Nav Dropdown (Collapsible Submenu) */
.nav-dropdown {
    position: relative;
}

.nav-dropdown-menu {
    list-style: none;
    padding-left: 20px;
    margin-top: 4px;
    display: none;
}

.nav-dropdown.aberto .nav-dropdown-menu {
    display: block;
}

.seta-dropdown {
    margin-left: auto;
    font-size: 0.8rem !important;
    transition: transform 0.2s ease;
}

.nav-dropdown.aberto .seta-dropdown {
    transform: rotate(180deg);
}

.sub-nav-link {
    font-size: 0.9rem !important;
    padding: 10px 16px !important;
}

/* --------------------------------------------------------------------------
   SISTEMA DE NOTIFICAÇÕES (TOPBAR BELL)
   -------------------------------------------------------------------------- */
.topbar-direita {
    display: flex;
    align-items: center;
    gap: 20px;
}

.topbar-notificacao-container {
    position: relative;
}

.botao-notificacao {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--cor-linha);
    color: var(--cor-texto-segundario);
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    position: relative;
    font-size: 1.15rem;
    transition: var(--transicao-suave);
}

.botao-notificacao:hover {
    color: var(--cor-texto-claro);
    background-color: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.15);
}

/* Badge com exclamação "!" */
.badge-notificacao {
    position: absolute;
    top: -2px;
    right: -2px;
    background-color: var(--cor-erro);
    color: var(--cor-texto-claro);
    border: 2px solid #0d0d0f; /* Combina com fundo da topbar */
    border-radius: 50%;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    font-weight: 900;
    box-shadow: 0 0 8px rgba(239, 68, 68, 0.5);
    animation: pulsar-badge 2s infinite;
}

@keyframes pulsar-badge {
    0% {
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.7);
    }
    70% {
        box-shadow: 0 0 0 6px rgba(239, 68, 68, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(239, 68, 68, 0);
    }
}

/* Dropdown de Notificações */
.notificacoes-dropdown {
    position: absolute;
    top: 50px;
    right: 0;
    width: 320px;
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    box-shadow: var(--sombra-cartao);
    z-index: 1000;
    display: none;
    flex-direction: column;
    overflow: hidden;
    animation: slideDownNotification 0.25s cubic-bezier(0.25, 0.8, 0.25, 1);
}

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

.notificacoes-dropdown.show {
    display: flex;
}

.notificacoes-cabecalho {
    padding: 15px 20px;
    border-bottom: 1px solid var(--cor-linha);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: rgba(255, 255, 255, 0.01);
}

.notificacoes-cabecalho h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--cor-texto-claro);
    margin: 0;
}

.badge-contador {
    background-color: var(--cor-erro-fundo);
    color: var(--cor-erro);
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

.notificacoes-lista {
    max-height: 280px;
    overflow-y: auto;
}

/* Scrollbar personalizado para a lista */
.notificacoes-lista::-webkit-scrollbar {
    width: 5px;
}
.notificacoes-lista::-webkit-scrollbar-track {
    background: transparent;
}
.notificacoes-lista::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 4px;
}

.notificacao-vazia {
    padding: 30px;
    text-align: center;
    color: var(--cor-texto-segundario);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}

.notificacao-vazia i {
    font-size: 2rem;
    color: var(--cor-sucesso);
}

.notificacao-vazia p {
    font-size: 0.85rem;
    margin: 0;
}

.notificacao-item {
    padding: 15px 20px;
    border-bottom: 1px solid var(--cor-linha);
    display: flex;
    gap: 12px;
    transition: var(--transicao-suave);
}

.notificacao-item:hover {
    background-color: rgba(255, 255, 255, 0.02);
}

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

.icone-alerta {
    color: var(--cor-alerta);
    font-size: 1.1rem;
    margin-top: 2px;
    flex-shrink: 0;
}

.notificacao-conteudo {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex-grow: 1;
}

.notificacao-conteudo h4 {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--cor-texto-principal);
    margin: 0;
}

.notificacao-conteudo p {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
    margin: 0;
    line-height: 1.4;
}

.link-abastecer {
    align-self: flex-start;
    color: var(--cor-primaria);
    font-size: 0.75rem;
    font-weight: 600;
    text-decoration: none;
    margin-top: 4px;
    border-bottom: 1px dashed transparent;
    transition: var(--transicao-suave);
}

.link-abastecer:hover {
    color: var(--cor-primaria-hover);
    border-color: var(--cor-primaria-hover);
}

/* --------------------------------------------------------------------------
   ESTILOS ADICIONAIS: MODAL E GRUPO DE BOTÕES
   -------------------------------------------------------------------------- */
.input-grupo-botoes {
    display: flex;
    gap: 8px;
    width: 100%;
}

.input-grupo-botoes select {
    flex-grow: 1;
}

.botao-adicionar-rapido {
    background-color: var(--cor-primaria);
    color: var(--cor-texto-claro);
    border: none;
    width: 44px;
    height: 44px;
    border-radius: var(--raio-borda-pequeno);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    cursor: pointer;
    transition: var(--transicao-suave);
    flex-shrink: 0;
}

.botao-adicionar-rapido:hover {
    background-color: var(--cor-primaria-hover);
    box-shadow: var(--sombra-glow);
}

/* Modal Estilos */
.modal-sobreposto {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(5px);
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: fadeInModal 0.25s ease;
}

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

.modal-conteudo {
    background-color: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    width: 100%;
    max-width: 480px;
    box-shadow: var(--sombra-cartao);
    overflow: hidden;
    animation: slideUpModal 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

@keyframes slideUpModal {
    from { transform: translateY(30px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-cabecalho {
    padding: 20px 24px;
    border-bottom: 1px solid var(--cor-linha);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: rgba(255, 255, 255, 0.01);
}

.modal-cabecalho h3 {
    margin: 0;
    font-size: 1.15rem;
    color: var(--cor-texto-claro);
    display: flex;
    align-items: center;
    gap: 10px;
}

.modal-cabecalho h3 i {
    color: var(--cor-primaria);
}

.botao-fechar-modal {
    background: none;
    border: none;
    color: var(--cor-texto-segundario);
    font-size: 1.5rem;
    cursor: pointer;
    transition: var(--transicao-suave);
    line-height: 1;
}

.botao-fechar-modal:hover {
    color: var(--cor-texto-claro);
}

.modal-corpo {
    padding: 24px;
}

.modal-botoes-acoes {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 24px;
}

.alerta-modal {
    margin-bottom: 16px;
    padding: 10px 14px;
    font-size: 0.85rem;
}

/* Badges de Verificação do CAP 50/70 */
.badge-cap {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 4px;
    margin-left: 5px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

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

.badge-cap-verificado {
    background-color: rgba(16, 185, 129, 0.15);
    color: #10b981;
    border: 1px solid rgba(16, 185, 129, 0.3);
}

/* Animação de Pulsar para Pendências Críticas */
.animate-pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

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

/* Ficha de Verificação CAP */
.cap-grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 20px;
    margin-bottom: 24px;
}

.cap-card-item {
    background: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cap-card-item h4 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--cor-texto-claro);
    margin: 0 0 4px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cap-card-item h4 i {
    color: var(--cor-primaria);
}

.cap-preview-img {
    width: 100%;
    height: 150px;
    object-fit: cover;
    border-radius: var(--raio-borda-pequeno);
    border: 1px solid var(--cor-linha);
    background-color: rgba(0, 0, 0, 0.2);
}

.cap-preview-empty {
    width: 100%;
    height: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 1px dashed var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    color: var(--cor-texto-segundario);
    font-size: 0.8rem;
    background-color: rgba(255, 255, 255, 0.01);
}

.cap-preview-empty i {
    font-size: 1.8rem;
    margin-bottom: 8px;
}

.cap-input-file {
    position: relative;
    overflow: hidden;
    display: inline-block;
    width: 100%;
}

.cap-input-file input[type="file"] {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
}

.cap-btn-upload {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 10px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--cor-linha);
    color: var(--cor-texto-principal);
    border-radius: var(--raio-borda-pequeno);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transicao-suave);
}

.cap-btn-upload:hover {
    background: var(--cor-primaria);
    color: var(--cor-fundo-escuro);
    border-color: var(--cor-primaria);
}

/* Lacres Secção Dinâmica */
.secao-lacres {
    background: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 24px;
    margin-bottom: 24px;
}

.secao-lacres-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 12px;
}

.secao-lacres-cabecalho h3 {
    margin: 0;
    font-size: 1.05rem;
    color: var(--cor-texto-claro);
    display: flex;
    align-items: center;
    gap: 8px;
}

.secao-lacres-cabecalho h3 i {
    color: var(--cor-primaria);
}

.lacre-linha {
    display: grid;
    grid-template-columns: 1fr 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.lacre-linha:last-child {
    border-bottom: none;
}

/* Galeria de Fotos e Detalhes da Auditoria CAP */
.cap-auditoria-container {
    background: var(--cor-fundo-cartao-solido);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda);
    padding: 24px;
    margin-top: 24px;
}

.cap-auditoria-cabecalho {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--cor-linha);
    padding-bottom: 16px;
    margin-bottom: 20px;
}

.cap-auditoria-cabecalho h3 {
    margin: 0;
    font-size: 1.15rem;
    color: var(--cor-texto-claro);
    display: flex;
    align-items: center;
    gap: 8px;
}

.cap-auditoria-cabecalho h3 i {
    color: var(--cor-primaria);
}

.cap-auditoria-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 20px;
}

.cap-foto-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.cap-foto-item span {
    font-size: 0.8rem;
    color: var(--cor-texto-segundario);
    font-weight: 500;
}

.cap-foto-item strong {
    font-size: 0.9rem;
    color: var(--cor-texto-principal);
}

.cap-foto-thumbnail {
    width: 100%;
    height: 140px;
    object-fit: cover;
    border-radius: var(--raio-borda-pequeno);
    border: 1px solid var(--cor-linha);
    cursor: pointer;
    transition: var(--transicao-suave);
    background-color: rgba(0, 0, 0, 0.2);
}

.cap-foto-thumbnail:hover {
    transform: scale(1.03);
    border-color: var(--cor-primaria);
    box-shadow: 0 4px 12px rgba(245, 158, 11, 0.15);
}

/* Lacres Lista Miniaturas */
.cap-lacres-galeria {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 16px;
    margin-top: 16px;
}

.cap-lacre-thumb-box {
    background: rgba(255, 255, 255, 0.02);
    border: 1px solid var(--cor-linha);
    border-radius: var(--raio-borda-pequeno);
    padding: 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    text-align: center;
}

.cap-lacre-thumb-box span {
    font-size: 0.75rem;
    color: var(--cor-texto-segundario);
}

.cap-lacre-thumb-box img {
    width: 100%;
    height: 90px;
    object-fit: cover;
    border-radius: var(--raio-borda-pequeno);
}
