/* ============================================
   ECOVISION IA — Global CSS
   Fundação visual do sistema ambiental
   ============================================ */

/* --- Variáveis CSS (Design Tokens) --- */
:root {
  /* Paleta Principal - Verde Ambiental */
  --cor-primaria: #059669;
  --cor-primaria-clara: #10b981;
  --cor-primaria-escura: #047857;
  --cor-primaria-fundo: #ecfdf5;
  --cor-primaria-borda: #a7f3d0;

  /* Cores de Apoio */
  --cor-sucesso: #10b981;
  --cor-sucesso-fundo: #d1fae5;
  --cor-atencao: #f59e0b;
  --cor-atencao-fundo: #fef3c7;
  --cor-perigo: #ef4444;
  --cor-perigo-fundo: #fee2e2;
  --cor-info: #3b82f6;
  --cor-info-fundo: #dbeafe;

  /* Neutras */
  --cor-branca: #ffffff;
  --cor-fundo: #f8fafc;
  --cor-fundo-escuro: #f1f5f9;
  --cor-texto: #0f172a;
  --cor-texto-secundario: #475569;
  --cor-texto-terciario: #94a3b8;
  --cor-borda: #e2e8f0;
  --cor-borda-clara: #f1f5f9;

  /* Sombras */
  --sombra-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
  --sombra-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
  --sombra-md: 0 4px 6px rgba(0, 0, 0, 0.05), 0 2px 4px rgba(0, 0, 0, 0.04);
  --sombra-lg: 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04);
  --sombra-xl: 0 20px 50px rgba(0, 0, 0, 0.12);

  /* Tipografia */
  --fonte-principal: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --fonte-mono: 'JetBrains Mono', 'Courier New', monospace;
  
  --tamanho-xs: 0.75rem;
  --tamanho-sm: 0.8125rem;
  --tamanho-base: 0.875rem;
  --tamanho-md: 1rem;
  --tamanho-lg: 1.125rem;
  --tamanho-xl: 1.25rem;
  --tamanho-2xl: 1.5rem;
  --tamanho-3xl: 1.875rem;

  --peso-normal: 400;
  --peso-medio: 500;
  --peso-semibold: 600;
  --peso-bold: 700;

  --linha-altura: 1.6;

  /* Espaçamentos */
  --espaco-1: 0.25rem;
  --espaco-2: 0.5rem;
  --espaco-3: 0.75rem;
  --espaco-4: 1rem;
  --espaco-5: 1.25rem;
  --espaco-6: 1.5rem;
  --espaco-8: 2rem;
  --espaco-10: 2.5rem;
  --espaco-12: 3rem;

  /* Bordas */
  --raio-xs: 6px;
  --raio-sm: 8px;
  --raio-md: 12px;
  --raio-lg: 16px;
  --raio-xl: 20px;
  --raio-2xl: 24px;
  --raio-full: 9999px;

  /* Transições */
  --transicao-rapida: 150ms ease;
  --transicao-media: 250ms ease;
  --transicao-lenta: 350ms ease;

  /* Layout */
  --largura-maxima: 1200px;
  --altura-header: 60px;
  --altura-nav-inferior: 64px;
}

/* ============================================
   TRANSIÇÃO DE TEMA
   ============================================ */
.tema-transicionando,
.tema-transicionando *,
.tema-transicionando *::before,
.tema-transicionando *::after {
  transition: background-color 0.4s ease,
              color 0.3s ease,
              border-color 0.3s ease,
              box-shadow 0.3s ease,
              fill 0.3s ease,
              stroke 0.3s ease !important;
}

/* ============================================
   RESET CSS
   ============================================ */
*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}

body {
  font-family: var(--fonte-principal);
  font-size: var(--tamanho-base);
  font-weight: var(--peso-normal);
  line-height: var(--linha-altura);
  color: var(--cor-texto);
  background-color: var(--cor-fundo);
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

/* ============================================
   TIPOGRAFIA
   ============================================ */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--peso-semibold);
  line-height: 1.3;
  color: var(--cor-texto);
  margin-bottom: 0.5em;
}

h1 { font-size: var(--tamanho-3xl); letter-spacing: -0.02em; }
h2 { font-size: var(--tamanho-2xl); letter-spacing: -0.015em; }
h3 { font-size: var(--tamanho-xl); }
h4 { font-size: var(--tamanho-lg); }
h5 { font-size: var(--tamanho-md); }
h6 { font-size: var(--tamanho-base); }

p {
  margin-bottom: var(--espaco-3);
  color: var(--cor-texto-secundario);
}

a {
  color: var(--cor-primaria);
  text-decoration: none;
  transition: color var(--transicao-rapida);
}

a:hover {
  color: var(--cor-primaria-escura);
  text-decoration: underline;
}

small, .texto-pequeno {
  font-size: var(--tamanho-xs);
  color: var(--cor-texto-terciario);
}

strong, b {
  font-weight: var(--peso-semibold);
}

code, pre {
  font-family: var(--fonte-mono);
  font-size: var(--tamanho-sm);
}

/* ============================================
   UTILITÁRIOS DE LAYOUT
   ============================================ */
.container {
  width: 100%;
  max-width: var(--largura-maxima);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--espaco-4);
  padding-right: var(--espaco-4);
}

.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.flex-1 { flex: 1; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.items-end { align-items: flex-end; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-around { justify-content: space-around; }
.justify-end { justify-content: flex-end; }

.gap-1 { gap: var(--espaco-1); }
.gap-2 { gap: var(--espaco-2); }
.gap-3 { gap: var(--espaco-3); }
.gap-4 { gap: var(--espaco-4); }
.gap-6 { gap: var(--espaco-6); }
.gap-8 { gap: var(--espaco-8); }

.grid { display: grid; }
.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }

/* ============================================
   UTILITÁRIOS DE TEXTO
   ============================================ */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-success { color: var(--cor-sucesso); }
.text-atencao { color: var(--cor-atencao); }
.text-perigo { color: var(--cor-perigo); }
.text-info { color: var(--cor-info); }
.text-primaria { color: var(--cor-primaria); }
.text-secundario { color: var(--cor-texto-secundario); }
.text-terciario { color: var(--cor-texto-terciario); }

.font-normal { font-weight: var(--peso-normal); }
.font-medio { font-weight: var(--peso-medio); }
.font-semibold { font-weight: var(--peso-semibold); }
.font-bold { font-weight: var(--peso-bold); }

.text-xs { font-size: var(--tamanho-xs); }
.text-sm { font-size: var(--tamanho-sm); }
.text-base { font-size: var(--tamanho-base); }
.text-md { font-size: var(--tamanho-md); }
.text-lg { font-size: var(--tamanho-lg); }
.text-xl { font-size: var(--tamanho-xl); }
.text-2xl { font-size: var(--tamanho-2xl); }
.text-3xl { font-size: var(--tamanho-3xl); }

.truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.uppercase { text-transform: uppercase; }
.lowercase { text-transform: lowercase; }
.capitalize { text-transform: capitalize; }

/* ============================================
   UTILITÁRIOS DE ESPAÇAMENTO
   ============================================ */
.m-0 { margin: 0; }
.m-1 { margin: var(--espaco-1); }
.m-2 { margin: var(--espaco-2); }
.m-3 { margin: var(--espaco-3); }
.m-4 { margin: var(--espaco-4); }
.m-6 { margin: var(--espaco-6); }
.m-8 { margin: var(--espaco-8); }

.mt-1 { margin-top: var(--espaco-1); }
.mt-2 { margin-top: var(--espaco-2); }
.mt-3 { margin-top: var(--espaco-3); }
.mt-4 { margin-top: var(--espaco-4); }
.mt-6 { margin-top: var(--espaco-6); }
.mt-8 { margin-top: var(--espaco-8); }
.mt-auto { margin-top: auto; }

.mb-1 { margin-bottom: var(--espaco-1); }
.mb-2 { margin-bottom: var(--espaco-2); }
.mb-3 { margin-bottom: var(--espaco-3); }
.mb-4 { margin-bottom: var(--espaco-4); }
.mb-6 { margin-bottom: var(--espaco-6); }
.mb-8 { margin-bottom: var(--espaco-8); }

.ml-auto { margin-left: auto; }
.mr-auto { margin-right: auto; }

.p-0 { padding: 0; }
.p-1 { padding: var(--espaco-1); }
.p-2 { padding: var(--espaco-2); }
.p-3 { padding: var(--espaco-3); }
.p-4 { padding: var(--espaco-4); }
.p-6 { padding: var(--espaco-6); }
.p-8 { padding: var(--espaco-8); }

.px-2 { padding-left: var(--espaco-2); padding-right: var(--espaco-2); }
.px-3 { padding-left: var(--espaco-3); padding-right: var(--espaco-3); }
.px-4 { padding-left: var(--espaco-4); padding-right: var(--espaco-4); }
.px-6 { padding-left: var(--espaco-6); padding-right: var(--espaco-6); }

.py-1 { padding-top: var(--espaco-1); padding-bottom: var(--espaco-1); }
.py-2 { padding-top: var(--espaco-2); padding-bottom: var(--espaco-2); }
.py-3 { padding-top: var(--espaco-3); padding-bottom: var(--espaco-3); }
.py-4 { padding-top: var(--espaco-4); padding-bottom: var(--espaco-4); }
.py-6 { padding-top: var(--espaco-6); padding-bottom: var(--espaco-6); }

/* ============================================
   UTILITÁRIOS VISUAIS
   ============================================ */
.hidden { display: none !important; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.block { display: block; }
.inline-block { display: inline-block; }
.inline { display: inline; }

.relative { position: relative; }
.absolute { position: absolute; }
.fixed { position: fixed; }
.sticky { position: sticky; }

.w-full { width: 100%; }
.h-full { height: 100%; }
.min-h-screen { min-height: 100vh; min-height: 100dvh; }

.overflow-hidden { overflow: hidden; }
.overflow-auto { overflow: auto; }
.overflow-y-auto { overflow-y: auto; }
.overflow-x-auto { overflow-x: auto; }

.rounded-xs { border-radius: var(--raio-xs); }
.rounded-sm { border-radius: var(--raio-sm); }
.rounded-md { border-radius: var(--raio-md); }
.rounded-lg { border-radius: var(--raio-lg); }
.rounded-xl { border-radius: var(--raio-xl); }
.rounded-2xl { border-radius: var(--raio-2xl); }
.rounded-full { border-radius: var(--raio-full); }

.shadow-xs { box-shadow: var(--sombra-xs); }
.shadow-sm { box-shadow: var(--sombra-sm); }
.shadow-md { box-shadow: var(--sombra-md); }
.shadow-lg { box-shadow: var(--sombra-lg); }
.shadow-xl { box-shadow: var(--sombra-xl); }

.bg-white { background-color: var(--cor-branca); }
.bg-fundo { background-color: var(--cor-fundo); }
.bg-fundo-escuro { background-color: var(--cor-fundo-escuro); }
.bg-primaria { background-color: var(--cor-primaria); }
.bg-primaria-clara { background-color: var(--cor-primaria-fundo); }
.bg-sucesso { background-color: var(--cor-sucesso-fundo); }
.bg-atencao { background-color: var(--cor-atencao-fundo); }
.bg-perigo { background-color: var(--cor-perigo-fundo); }
.bg-info { background-color: var(--cor-info-fundo); }

.border { border: 1px solid var(--cor-borda); }
.border-b { border-bottom: 1px solid var(--cor-borda); }
.border-t { border-top: 1px solid var(--cor-borda); }
.border-none { border: none; }

.cursor-pointer { cursor: pointer; }
.select-none { user-select: none; }
.pointer-events-none { pointer-events: none; }

/* ============================================
   ANIMAÇÕES GLOBAIS
   ============================================ */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

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

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

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

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

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

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

.animar-fade-in {
  animation: fadeIn var(--transicao-media) ease forwards;
}

.animar-scale-in {
  animation: scaleIn var(--transicao-media) ease forwards;
}

/* ============================================
   SCROLLBAR ESTILIZADA
   ============================================ */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--cor-borda);
  border-radius: var(--raio-full);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--cor-texto-terciario);
}

* {
  scrollbar-width: thin;
  scrollbar-color: var(--cor-borda) transparent;
}

/* ============================================
   RESPONSIVIDADE - BREAKPOINTS
   ============================================ */
@media (min-width: 768px) {
  :root {
    --tamanho-base: 0.9375rem;
  }
  
  .md\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
  .md\:flex { display: flex; }
  .md\:hidden { display: none; }
  .md\:block { display: block; }
}

@media (min-width: 1024px) {
  :root {
    --tamanho-base: 1rem;
  }
  
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
  .lg\:flex { display: flex; }
  .lg\:hidden { display: none; }
  .lg\:block { display: block; }
}

/* ============================================
   SUPORTE A TEMA ESCURO
   ============================================ */
[data-theme="dark"] {
  --cor-branca: #1e293b;
  --cor-fundo: #0f172a;
  --cor-fundo-escuro: #1e293b;
  --cor-texto: #f1f5f9;
  --cor-texto-secundario: #cbd5e1;
  --cor-texto-terciario: #94a3b8;
  --cor-borda: #334155;
  --cor-borda-clara: #1e293b;
  
  --cor-primaria-fundo: #064e3b;
  --cor-primaria-borda: #047857;
  --cor-sucesso-fundo: #064e3b;
  --cor-atencao-fundo: #78350f;
  --cor-perigo-fundo: #7f1d1d;
  --cor-info-fundo: #1e3a5f;
  
  --sombra-xs: 0 1px 2px rgba(0, 0, 0, 0.3);
  --sombra-sm: 0 1px 3px rgba(0, 0, 0, 0.4);
  --sombra-md: 0 4px 6px rgba(0, 0, 0, 0.5);
  --sombra-lg: 0 10px 25px rgba(0, 0, 0, 0.6);
  --sombra-xl: 0 20px 50px rgba(0, 0, 0, 0.7);
}

[data-theme="dark"] .header-app {
  background-color: rgba(30, 41, 59, 0.95);
}

[data-theme="dark"] .nav-inferior {
  background-color: rgba(30, 41, 59, 0.95);
}

[data-theme="dark"] .card {
  background-color: var(--cor-branca);
}

[data-theme="dark"] .input {
  background-color: var(--cor-fundo-escuro);
  color: var(--cor-texto);
}

[data-theme="dark"] .input::placeholder {
  color: var(--cor-texto-terciario);
}

[data-theme="dark"] .modal {
  background-color: #1e293b;
}

[data-theme="dark"] .modal-footer {
  background-color: #0f172a;
}

[data-theme="dark"] .tabela thead {
  background-color: #0f172a;
}

[data-theme="dark"] .tabela tbody tr:hover {
  background-color: #1e293b;
}

[data-theme="dark"] .tabela-zebrada tbody tr:nth-child(even) {
  background-color: #1a2332;
}

[data-theme="dark"] .tag {
  background-color: var(--cor-fundo-escuro);
}

[data-theme="dark"] .tag:hover {
  background-color: var(--cor-primaria-fundo);
}

[data-theme="dark"] .upload-zona {
  background-color: var(--cor-fundo-escuro);
}

[data-theme="dark"] .chat-mensagens {
  background-color: var(--cor-fundo);
}

[data-theme="dark"] .mensagem-bot .mensagem-balao {
  background-color: #1e293b;
}

[data-theme="dark"] .chat-input-container {
  background-color: #1e293b;
}

[data-theme="dark"] .preview-documento {
  background-color: #1a1a2e;
  color: #e2e8f0;
  border-color: #334155;
}

[data-theme="dark"] .preview-tabela th {
  background-color: #162032;
  color: #cbd5e1;
}

[data-theme="dark"] .preview-tabela td {
  border-color: #334155;
}

[data-theme="dark"] .preview-resumo-item {
  background-color: #162032;
  border-color: #334155;
}

[data-theme="dark"] .doc-texto-extraido {
  background-color: #0f172a;
  color: #cbd5e1;
}

[data-theme="dark"] .resultado-item {
  background-color: #0f172a;
}

[data-theme="dark"] .alerta-card.nao-lido {
  background-color: #1a2332;
}

[data-theme="dark"] .empty-state {
  color: #64748b;
}

/* ============================================
   IMPRESSÃO
   ============================================ */
@media print {
  body {
    background: white;
    color: black;
  }
  
  .no-print {
    display: none !important;
  }
}