/* ======================================================================
   Cristã Modesta - Painel de Controle CSS v2.0
   Análise e Consolidação por Gemini
   ====================================================================== */

/* 1. VARIÁVEIS E ESTILOS GLOBAIS
----------------------------------------------------------------*/
:root {
  /* Paleta de Cores Refinada */
  --cor-primaria: #D98BBD;
  --cor-primaria-hover: #C77EAB;
  --cor-primaria-suave: rgba(217, 139, 189, 0.1);
  --cor-primaria-foco: rgba(217, 139, 189, 0.25);

  --cor-secundaria: #4A5568;
  --cor-secundaria-hover: #2D3748;

  --cor-texto-principal: #2D3748;
  --cor-texto-secundario: #718096;
  --cor-texto-branco: #FFFFFF;
  
  --fundo-body: #F7FAFC;
  --fundo-painel: #FFFFFF;
  --fundo-header: #FFFFFF;
  
  --cor-borda: #E2E8F0;
  --cor-borda-tabela: #EDF2F7;
  
  --cor-sucesso: #38A169;
  --cor-erro: #E53E3E;
  --cor-aviso: #DD6B20;
  --cor-info: #3182CE;

  /* Fontes e Sizing */
  --font-principal: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --border-radius-padrao: 8px;
  --border-radius-grande: 12px;
  --sombra-padrao: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --sombra-interna: rgba(0, 0, 0, 0.06) 0px 2px 4px 0px inset;
  --transition-padrao: all 0.2s ease-in-out;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-principal);
  background: linear-gradient(to bottom, #7c6a70b7, #b5bbc293),
              url('fundo-flores.png');
  color: var(--cor-texto-principal);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4 {
  color: var(--cor-texto-principal);
  margin-bottom: 1rem;
  margin-top: 1.5rem;
  font-weight: 600;
  letter-spacing: -0.5px;
}
h1 { font-size: 2rem; }
h2 { font-size: 1.5rem; border-bottom: 1px solid var(--cor-borda); padding-bottom: 0.75rem; }
h3 { font-size: 1.25rem; }
h1:first-child, h2:first-child, h3:first-child { margin-top: 0; }

a { color: var(--cor-primaria); text-decoration: none; }
a:hover { text-decoration: underline; }

hr {
    border: none;
    border-top: 1px solid var(--cor-borda);
    margin: 2.5rem 0;
}

/* 2. LAYOUT PRINCIPAL
----------------------------------------------------------------*/
header {
  background-color: var(--fundo-header);
  padding: 0.8rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-shadow: var(--sombra-padrao);
  position: sticky;
  top: 0;
  z-index: 1000;
}
.logo { height: 50px; }

.painel-main {
  padding: 1.5rem 2rem;
  max-width: 1400px;
  margin: 2rem auto;
  background-color: var(--fundo-painel);
  border-radius: var(--border-radius-grande);
  box-shadow: var(--sombra-padrao);
}

/* 3. COMPONENTES GLOBAIS
----------------------------------------------------------------*/

/* --- Navegação --- */
.menu { list-style: none; display: flex; align-items: center; gap: 0.5rem; }
.menu li a, .btn-logout {
  color: var(--cor-texto-secundario);
  text-decoration: none;
  padding: 0.6rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: var(--border-radius-padrao);
  transition: var(--transition-padrao);
  border: none;
  background-color: transparent;
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
}
.btn-logout { cursor: pointer; }
.menu li a:hover, .btn-logout:hover, .menu li a.active {
  background-color: var(--cor-primaria-suave);
  color: var(--cor-primaria);
}
.submenu-container {
  position: relative;
}

.submenu {
  display: block; /* necessário para permitir transição */
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 110%;
  left: 0;
  background-color: var(--fundo-header);
  list-style: none;
  padding: 0.5rem;
  min-width: 200px;
  border-radius: var(--border-radius-grande);
  box-shadow: var(--sombra-padrao);
  z-index: 1010;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  pointer-events: none; /* evita cliques quando invisível */
}

.submenu-container.submenu-open > .submenu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.submenu li a {
  width: 100%;
}

.submenu-arrow {
  width: 16px;
  height: 16px;
  transition: transform 0.2s ease;
}

.menu-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--cor-texto-principal);
}
/* --- Botões --- */
.btn-principal, .btn-secundario, .btn-terciario {
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: var(--border-radius-padrao);
  cursor: pointer;
  font-family: var(--font-principal);
  font-size: 0.9rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  transition: var(--transition-padrao);
  text-decoration: none;
  line-height: 1.5;
}
.btn-principal:hover, .btn-secundario:hover, .btn-terciario:hover { 
  transform: translateY(-2px);
  box-shadow: var(--sombra-padrao);
}
.btn-principal {
  background-color: var(--cor-primaria);
  color: var(--cor-texto-branco);
}
.btn-principal:hover { background-color: var(--cor-primaria-hover); }
.btn-secundario {
  background-color: var(--cor-secundaria);
  color: var(--cor-texto-branco);
}
.btn-secundario:hover { background-color: var(--cor-secundaria-hover); }

/* Botão de Link (para ações em tabela) */
.btn-link {
  background: none; border: 1px solid transparent; cursor: pointer;
  color: var(--cor-texto-secundario); padding: 0.4rem;
  border-radius: 50%; width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: var(--transition-padrao);
}
.btn-link:hover {
  background-color: var(--cor-primaria-suave);
  color: var(--cor-primaria);
  border-color: var(--cor-primaria-suave);
}
.btn-link svg {
  width: 20px; height: 20px;
  stroke: currentColor;
  transition: stroke 0.2s ease-in-out;
}

/* --- Formulários e Filtros --- */
form {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 1.2rem 1.5rem;
  margin-bottom: 2.5rem;
}
fieldset {
    border: 1px solid var(--cor-borda);
    border-radius: var(--border-radius-grande);
    padding: 1.5rem;
    margin: 0; /* Reset margin */
}
legend {
    font-weight: 600;
    padding: 0 0.5rem;
    color: var(--cor-primaria);
}
.campo { display: flex; flex-direction: column; gap: 0.5rem; }
.campo label {
  font-weight: 500;
  font-size: 0.875rem;
  color: var(--cor-texto-secundario);
}
.campo input, .campo select, .filtros input, .filtros select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid var(--cor-borda);
  border-radius: var(--border-radius-padrao);
  font-size: 1rem;
  background-color: var(--fundo-painel);
  transition: var(--transition-padrao);
  font-family: var(--font-principal);
}
.campo input:focus, .campo select:focus, .filtros input:focus, .filtros select:focus {
  outline: none;
  border-color: var(--cor-primaria);
  box-shadow: 0 0 0 3px var(--cor-primaria-foco);
}
.campo input[readonly] { background-color: var(--fundo-body); cursor: not-allowed; }

.form-actions {
    grid-column: 1 / -1;
    display: flex;
    justify-content: flex-end;
    gap: 1rem;
}
.filtros {
  width: 100%;
  margin: 1.5rem 0;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 1rem;
}
.filtros input, .filtros select { width: auto; flex-grow: 1; }

.campo-autocomplete { position: relative; }
.sugestoes {
  display: none; /* Hide by default */
  border: 1px solid var(--cor-borda);
  max-height: 220px; overflow-y: auto; background-color: #fff;
  position: absolute; width: 100%; left: 0; top: 100%; z-index: 1050;
  box-shadow: var(--sombra-padrao);
  border-radius: 0 0 var(--border-radius-padrao) var(--border-radius-padrao);
}
.sugestao-item { padding: 0.8rem 1rem; cursor: pointer; transition: background-color 0.15s ease-in-out; }
.sugestao-item:hover, .sugestao-item.active { background-color: var(--cor-primaria-suave); }

/* --- Tabelas --- */
.tabela-responsiva {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1rem;
}
.tabela-responsiva th, .tabela-responsiva td {
  padding: 1rem;
  border-bottom: 1px solid var(--cor-borda-tabela);
  text-align: left;
  font-size: 0.9rem;
  vertical-align: middle;
}
.tabela-responsiva th {
  background-color: var(--fundo-body);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.5px;
  color: var(--cor-texto-secundario);
}
.tabela-responsiva tbody tr:hover { background-color: var(--fundo-body); }
.tabela-responsiva td[data-label="Ações"] {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

/* --- Cards --- */
.relatorio-card, .card-resumo {
    background-color: var(--fundo-painel);
    border-radius: var(--border-radius-grande);
    box-shadow: var(--sombra-padrao);
    padding: 1.5rem;
    transition: var(--transition-padrao);
    border: 1px solid var(--cor-borda);
}
.relatorio-card:hover, .card-resumo:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}
.grafico-wrapper {
  background-color: var(--fundo-painel);
  padding: 1.5rem;
  border-radius: var(--border-radius-grande);
  box-shadow: var(--sombra-padrao);
  margin-bottom: 2.5rem;
}

/* --- Status Badges --- */
.status {
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.75rem;
    color: var(--cor-texto-branco);
    text-align: center;
    white-space: nowrap;
}
.status.pago { background-color: var(--cor-sucesso); }
.status.atrasado { background-color: var(--cor-erro); }
.status.em-aberto { background-color: var(--cor-aviso); }
.status.parcial { background-color: var(--cor-info); }

/* 4. ESTILOS ESPECÍFICOS POR PÁGINA
----------------------------------------------------------------*/

/* --- Página Index (Dashboard) --- */
.pagina-index .subtitulo-painel {
  margin-bottom: 2.5rem;
  font-size: 1.1rem;
  color: var(--cor-texto-secundario);
}
.pagina-index .relatorios-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2.5rem;
}
.pagina-index .relatorio-card h3 {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cor-texto-secundario);
  margin: 0 0 0.5rem 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pagina-index .relatorio-card p {
  font-size: 2rem;
  font-weight: 700;
  margin: 0;
  color: var(--cor-primaria);
}
.pagina-index .botoes-atalho-grid {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
}

/* --- Página Clientes, Produtos, Entrada/Saída (Formulários Padrão) --- */
.pagina-clientes form, .pagina-produtos form, .pagina-entrada-saida form {
    background-color: var(--fundo-body);
    padding: 2rem;
    border-radius: var(--border-radius-grande);
    border: 1px solid var(--cor-borda);
}
.form-grid-2-col {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5rem;
}
.btn-acao-excluir:hover {
    background-color: rgba(229, 62, 62, 0.1);
    color: var(--cor-erro);
}

/* --- Página Vendas --- */
.pagina-vendas .fieldset-venda {
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    grid-column: 1 / -1;
}
.pagina-vendas .grid-venda-busca, .pagina-vendas .grid-venda-adicionar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem 1.5rem;
}
.pagina-vendas .info-produto-selecionado {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    background-color: var(--fundo-body);
    padding: 1rem;
    border-radius: var(--border-radius-padrao);
    margin-bottom: 1rem;
    border: 1px solid var(--cor-borda);
}
.pagina-vendas .info-produto-selecionado span { font-weight: 600; color: var(--cor-primaria); }
.pagina-vendas .controles-adicionar-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1rem;
    align-items: flex-end;
}
.pagina-vendas .tabela-venda-wrapper {
    grid-column: 1 / -1;
    max-height: 350px;
    overflow-y: auto;
    border: 1px solid var(--cor-borda);
    border-radius: var(--border-radius-padrao);
    margin-bottom: 1.5rem;
}
.pagina-vendas .btn-remover-item { color: var(--cor-erro); }
.pagina-vendas .btn-remover-item:hover { color: var(--cor-erro); background-color: rgba(229, 62, 62, 0.1); }
.pagina-vendas .campo-pagamento {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}
.pagina-vendas #campo-parcelas {
    display: none; /* JS will change this to grid */
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}
.pagina-vendas .preview-parcela {
    align-self: center;
    text-align: left;
    grid-column: 1 / -1;
    font-size: 1.1rem;
    color: var(--cor-texto-secundario);
}
.pagina-vendas #valor-parcela-preview { color: var(--cor-primaria); font-weight: 700; }
.pagina-vendas .total-finalizar-venda {
    grid-column: 1 / -1;
    text-align: right;
    margin-top: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.5rem;
}
.pagina-vendas .total-finalizar-venda h3 { font-size: 1.8rem; margin: 0; }
.pagina-vendas .total-finalizar-venda #total { color: var(--cor-primaria); }
.pagina-vendas .total-finalizar-venda h4 { font-size: 1.2rem; margin: 0; }
.pagina-vendas .total-finalizar-venda #saldo-a-parcelar { color: var(--cor-secundaria); }
.pagina-vendas .total-finalizar-venda .btn-principal { margin-top: 1rem; }

/* --- Página Consultar Vendas --- */
.pagina-consultar-vendas .filtros-relatorios h2 { font-size: 1.25rem; border: none; }
.pagina-consultar-vendas .filtros-relatorios > div {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
}
.pagina-consultar-vendas .campo { align-self: flex-end; }
.pagina-consultar-vendas .linha-detalhes-itens td {
    background-color: var(--fundo-body);
    padding: 1.5rem;
}
.pagina-consultar-vendas .btn-detalhes-venda { transition: transform 0.3s ease; }
.pagina-consultar-vendas .venda-principal-row.expandido .btn-detalhes-venda { transform: rotate(180deg); }

/* --- Página Carnês --- */
.pagina-carne .dashboard-resumo {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}
.pagina-carne .card-resumo h4 { margin: 0 0 0.5rem; color: var(--cor-texto-secundario); font-weight: 500; font-size: 0.9rem; }
.pagina-carne .card-resumo span { font-size: 1.8rem; font-weight: 700; }
.pagina-carne #total-atrasado span { color: var(--cor-erro); }
.pagina-carne #total-pago span { color: var(--cor-sucesso); }
.pagina-carne .cliente-group {
    background-color: var(--fundo-painel);
    border-radius: var(--border-radius-grande);
    padding: 1.5rem; margin-bottom: 1.5rem; box-shadow: var(--sombra-padrao);
    border: 1px solid var(--cor-borda);
}
.pagina-carne .cliente-group-header {
    margin-bottom: 1rem; padding-bottom: 1rem;
    border-bottom: 1px solid var(--cor-borda);
    display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 1rem;
}
.pagina-carne .cliente-nome-header { color: var(--cor-primaria); margin: 0; font-size: 1.4rem; }
.pagina-carne .carne-item {
    background: var(--fundo-body); border: 1px solid var(--cor-borda);
    border-radius: var(--border-radius-grande); padding: 1rem 1.5rem;
    margin-top: 1rem;
}
.pagina-carne .carne-item-header {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 1rem;
    cursor: pointer;
}
.pagina-carne .header-info .carne-info { font-size: 0.875rem; color: var(--cor-texto-secundario); margin: 0; }
.pagina-carne .header-acoes { display: flex; align-items: center; gap: 0.5rem; }
.pagina-carne .tabela-parcelas-wrapper {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-in-out;
}
.pagina-carne .carne-item.expandido .tabela-parcelas-wrapper {
    max-height: 2000px; /* Large value */
    padding-top: 1rem;
}
.pagina-carne .btn-expandir { transition: transform 0.3s ease; }
.pagina-carne .carne-item.expandido .btn-expandir { transform: rotate(180deg); }
.pagina-carne .btn-pequeno { padding: 0.5rem 1rem; font-size: 0.8rem; }
.pagina-carne .btn-pdf-individual { gap: 0.5rem; }

/* --- Página Relatórios --- */
.pagina-relatorios .filtros-relatorios { margin-bottom: 2rem; }
.pagina-relatorios .filtros-relatorios .filtro-controles {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 1.5rem;
}
.pagina-relatorios .filtro-controles > .campo { flex: 1 1 200px; }
.pagina-relatorios .filtro-controles .btn-principal { flex-grow: 0; }
.pagina-relatorios .relatorios-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}
.pagina-relatorios .relatorio-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.5rem; }
.pagina-relatorios .relatorio-card p { font-size: 1.75rem; font-weight: 700; color: var(--cor-primaria); }
.pagina-relatorios .pagamentos-detalhe, 
.pagina-relatorios #produtosMaisVendidos, 
.pagina-relatorios #melhoresClientes {
    font-size: 0.9rem;
    line-height: 1.8;
}

/* 5. RESPONSIVIDADE
----------------------------------------------------------------*/
@media (max-width: 991px) {
  .painel-main { margin: 1rem; padding: 1.5rem; }
  
  header { justify-content: flex-start; }
  .menu-toggle { display: block; margin-left: auto; }
  nav .menu {
      position: fixed; top: 0; left: -280px; width: 280px; height: 100vh;
      background-color: var(--fundo-header); padding-top: 60px;
      box-shadow: 3px 0 15px rgba(0,0,0,0.1);
      transition: left 0.3s ease-in-out;
      flex-direction: column; align-items: flex-start; gap: 0;
  }
  nav .menu.active { left: 0; }
  .menu li { width: 100%; }
  .menu li a, .btn-logout {
      padding: 1rem 1.5rem;
      border-radius: 0;
      width: 100%;
      justify-content: flex-start;
  }
  .submenu {
      position: static; display: none;
      box-shadow: none; padding-left: 2rem;
      background-color: var(--fundo-body);
      border-radius: 0;
      min-width: 100%;
  }
  .submenu-container.submenu-open > .submenu { display: block; }
  .submenu-container.submenu-open > a { background-color: var(--cor-primaria-suave); }
  .submenu-arrow { transition: transform 0.2s ease; }
  .submenu-container.submenu-open .submenu-arrow { transform: rotate(180deg); }

  /* Tabela Responsiva */
  .tabela-responsiva thead { display: none; }
  .tabela-responsiva tr {
      display: block;
      margin-bottom: 1rem;
      border: 1px solid var(--cor-borda);
      border-radius: var(--border-radius-grande);
      box-shadow: var(--sombra-padrao);
      padding: 0.5rem;
  }
  .tabela-responsiva td {
      display: flex; justify-content: space-between; align-items: center;
      padding: 0.8rem 1rem; text-align: right;
      border-bottom: 1px solid var(--cor-borda-tabela);
  }
  .tabela-responsiva tr td:last-child { border-bottom: none; }
  .tabela-responsiva td::before {
      content: attr(data-label); font-weight: 600;
      color: var(--cor-texto-principal); text-align: left; padding-right: 1rem;
  }
  .tabela-responsiva td[data-label="Ações"] {
      gap: 0.5rem;
  }
}

@media (min-width: 992px) {
  .submenu-container:hover > .submenu { display: block; }
  .submenu-container:hover > a { background-color: var(--cor-primaria-suave); }
  .submenu-container:hover .submenu-arrow { transform: rotate(180deg); }
}
/* ======================================================= */
/* --- ESTILOS PÁGINA CONSULTA DE CLIENTES --- */
/* ======================================================= */

.pagina-consultar-cliente .consulta-wrapper {
    display: grid;
    grid-template-columns: 300px 1fr; /* Coluna lateral fixa e coluna de conteúdo flexível */
    gap: 2rem;
    align-items: flex-start;
}

.pagina-consultar-cliente .coluna-busca {
    position: sticky;
    top: 100px; /* Leva em conta a altura do header */
    background: var(--fundo-body);
    padding: 1rem;
    border-radius: var(--border-radius-grande);
}

.pagina-consultar-cliente .lista-nomes-clientes {
    max-height: 60vh;
    overflow-y: auto;
    margin-top: 1rem;
    border-top: 1px solid var(--cor-borda);
}

.pagina-consultar-cliente .cliente-nome-item {
    padding: 0.8rem;
    cursor: pointer;
    border-bottom: 1px solid var(--cor-borda);
    transition: var(--transition-padrao);
    font-weight: 500;
}

.pagina-consultar-cliente .cliente-nome-item:hover {
    background-color: var(--cor-primaria-suave);
    color: var(--cor-primaria);
}

.pagina-consultar-cliente .cliente-nome-item.selecionado {
    background-color: var(--cor-primaria);
    color: var(--cor-texto-branco);
    font-weight: 600;
}

.pagina-consultar-cliente .coluna-detalhes {
    background-color: #fff;
    padding: 2rem;
    border-radius: var(--border-radius-grande);
}

.pagina-consultar-cliente .placeholder-detalhes {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 400px;
    text-align: center;
    color: var(--cor-texto-secundario);
    border: 2px dashed var(--cor-borda);
}

.pagina-consultar-cliente .placeholder-detalhes i {
    width: 60px;
    height: 60px;
    margin-bottom: 1rem;
}

.pagina-consultar-cliente .perfil-cliente {
    margin-bottom: 2rem;
}

.pagina-consultar-cliente .perfil-cliente #nomeClienteHeader {
    border-bottom: 2px solid var(--cor-primaria);
    padding-bottom: 0.5rem;
}

.pagina-consultar-cliente .detalhes-contato {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem 1.5rem;
    font-size: 0.9rem;
    color: var(--cor-texto-secundario);
}

.pagina-consultar-cliente .detalhes-contato p {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.pagina-consultar-cliente .dashboard-cliente {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2.5rem;
}

.pagina-consultar-cliente .historico-container h3 {
    margin-top: 2rem;
    border-bottom: 1px solid var(--cor-borda);
    padding-bottom: 0.5rem;
}

.pagina-consultar-cliente .venda-historico-item,
.pagina-consultar-cliente .carne-historico-item {
    background: var(--fundo-body);
    padding: 1rem;
    border-radius: var(--border-radius-padrao);
    margin-bottom: 1rem;
    border-left: 4px solid var(--cor-primaria);
}

.pagina-consultar-cliente .venda-historico-item p,
.pagina-consultar-cliente .carne-historico-item p {
    margin: 0;
    font-size: 0.9rem;
}

/* Responsividade para a nova página */
@media (max-width: 991px) {
    .pagina-consultar-cliente .consulta-wrapper {
        grid-template-columns: 1fr;
    }
    .pagina-consultar-cliente .coluna-busca {
        position: static;
        top: auto;
    }
}
/* ======================================================= */
/* --- ESTILOS PÁGINA CONSULTA DE PRODUTOS --- */
/* ======================================================= */

.pagina-consultar-produtos .dashboard-resumo {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
}

.pagina-consultar-produtos .card-resumo h4 {
    font-size: 0.9rem;
    font-weight: 500;
    margin: 0 0 0.5rem 0;
}

.pagina-consultar-produtos .card-resumo span {
    font-size: 1.8rem;
    font-weight: 700;
}

.pagina-consultar-produtos .status-estoque {
    font-weight: 700;
    padding: 0.25rem 0.5rem;
    border-radius: var(--border-radius-padrao);
    font-size: 0.9rem;
}

.pagina-consultar-produtos .status-estoque.normal {
    color: var(--cor-sucesso);
}

.pagina-consultar-produtos .status-estoque.baixo {
    color: var(--cor-aviso);
}

.pagina-consultar-produtos .status-estoque.zerado {
    color: var(--cor-erro);
}
/* Rodapé */
.rodape-site {
  text-align: center;
  padding: 1.5rem 1rem;
  background-color: var(--fundo-header); /* ou um tom mais escuro, se preferir */
  color: var(--cor-texto-secundario);
  font-size: 0.875rem;
  border-top: 1px solid var(--cor-borda);
  margin-top: 4rem;
}

/* Borboleta decorativa no canto da tela */
body::before {
  content: "🌸";
  position: fixed;
  top: 10px;
  left: 10px;
  font-size: 1.5rem;
  color: #c42b8c;
  animation: flutter 5s infinite ease-in-out;
  pointer-events: none;
  opacity: 0.5;
}

/* Detalhe floral sutil no rodapé */
body::after {
  content: "";
  position: fixed;
  bottom: 0;
  right: 0;
  width: 250px;
  height: 250px;
  background-image: url('flores.png');
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 0.1;
  pointer-events: none;
}

/* Animação sutil da borboleta */
@keyframes flutter {
  0% { transform: translateY(0px) rotate(0deg); }
  50% { transform: translateY(8px) rotate(5deg); }
  100% { transform: translateY(0px) rotate(0deg); }
}


/* Links animados estilo borboleta */
a {
  color: #c42b8c;
  position: relative;
  transition: color 0.3s ease;
}
a:hover::after {
  content: "🌸";
  position: absolute;
  right: -1.2rem;
  font-size: 0.9rem;
  animation: flutter 3s infinite ease-in-out;
  opacity: 0.6;
}
