/* ═══════════════════════════════════════════════
   GIL — Base Styles
   ═══════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* Layout root: sem scroll global — cada modulo gerencia seu proprio scroll */
html, body { height: 100%; }

body {
  font-family: var(--font-family, Inter, system-ui, -apple-system, sans-serif);
  background: var(--bg-body);
  color: var(--text-primary);
  overflow: hidden; /* sem scroll na pagina — so dentro dos modulos */
  -webkit-font-smoothing: antialiased;
}

a { color: var(--blue-light); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; }

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* R$ symbol — muted so eye focuses on the number magnitude */
.brl-sym { display: none; }

/* Mini progress bar — used inside table/card rows next to % */
.pbar { display:inline-block; width:36px; height:3px; background:rgba(255,255,255,.1); border-radius:2px; vertical-align:middle; margin-left:3px; overflow:hidden; flex-shrink:0; }
.pbar-fill { display:block; height:100%; border-radius:2px; background:#38bdf8; }

/* Utilities */
.hidden { display: none !important; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-muted { color: var(--text-muted); }
.text-secondary { color: var(--text-secondary); }
.mt-8 { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mb-8 { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.gap-8 { gap: 8px; }
.gap-16 { gap: 16px; }
.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.flex-1 { flex: 1; }
.flex-wrap { flex-wrap: wrap; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* Typography */
h1 { font-size: 20px; font-weight: var(--fw-semibold, 600); }
h2 { font-size: var(--font-lg, 16px); font-weight: var(--fw-semibold, 600); }
h3 { font-size: var(--font-base, 14px); font-weight: var(--fw-medium, 500); }

/* Animations */
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes slideIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

.spinner {
  width: 40px; height: 40px;
  border: 3px solid var(--border);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
.spinner-sm {
  width: 16px; height: 16px;
  border: 2px solid var(--border);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  display: inline-block;
}

/* =========================================================
   MODO CLARO — REFINO VISUAL + PADRONIZAÇÃO TIPOGRÁFICA
   Escopo: somente [data-theme="light"]
   ========================================================= */

/* 1. BASE */
[data-theme="light"],
[data-theme="light"] body {
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  background: var(--bg-body);
  color: var(--text-secondary);
  font-size: var(--font-md, 13px);
  font-weight: var(--fw-regular, 400);
}
[data-theme="light"] * { font-family: inherit; }
[data-theme="light"] ::selection { background: rgba(31,95,174,.14); color: var(--text-primary); }

/* 2. TIPOGRAFIA */
[data-theme="light"] h1,
[data-theme="light"] h2,
[data-theme="light"] h3 {
  color: var(--text-primary);
  font-weight: var(--fw-semibold, 600);
}
[data-theme="light"] strong,
[data-theme="light"] b {
  font-weight: var(--fw-semibold, 600);
  color: var(--text-primary);
}
[data-theme="light"] .text-muted,
[data-theme="light"] small { color: var(--text-muted) !important; }

/* 3. APP SHELL */
[data-theme="light"] .app-header {
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-soft, #e7edf3);
  box-shadow: var(--shadow-card, 0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06));
}
[data-theme="light"] .sidebar {
  background: var(--bg-sidebar, #f6f9fc);
  border-right: 1px solid var(--border-soft, #e7edf3);
}

/* 4. INPUTS */
[data-theme="light"] input:not([type="range"]):not([type="checkbox"]):not([type="radio"]),
[data-theme="light"] select,
[data-theme="light"] textarea {
  background: var(--bg-input, #ffffff);
  border-color: var(--border, #d9e2ec);
  color: var(--text-primary);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
[data-theme="light"] input:not([type="range"]):not([type="checkbox"]):not([type="radio"]):hover,
[data-theme="light"] select:hover,
[data-theme="light"] textarea:hover { border-color: var(--border-strong, #c7d3df); }
[data-theme="light"] input:not([type="range"]):not([type="checkbox"]):not([type="radio"])::placeholder,
[data-theme="light"] textarea::placeholder { color: var(--text-muted); }
[data-theme="light"] input:not([type="range"]):not([type="checkbox"]):not([type="radio"]):focus,
[data-theme="light"] select:focus,
[data-theme="light"] textarea:focus {
  outline: none;
  border-color: var(--primary, #1f5fae);
  box-shadow: 0 0 0 3px rgba(31,95,174,.08);
}
[data-theme="light"] input[type="range"]    { accent-color: var(--primary, #1f5fae); }
[data-theme="light"] input[type="checkbox"],
[data-theme="light"] input[type="radio"]    { accent-color: var(--primary, #1f5fae); }

/* 5. BOTÕES */
[data-theme="light"] .btn {
  border: 1px solid var(--border, #d9e2ec);
  background: #fff;
  color: var(--text-secondary);
  transition: background 0.15s ease, border-color 0.15s ease;
}
[data-theme="light"] .btn:hover { background: var(--bg-surface-2, #f8fafc); border-color: var(--border-strong, #c7d3df); }
[data-theme="light"] .btn-primary {
  background: var(--primary-soft, #eaf2fd);
  color: var(--primary, #1f5fae);
  border-color: #c8dcf5;
}
[data-theme="light"] .btn-primary:hover { background: #d8ecfc; border-color: #b5cff0; }

/* 6. CHIPS */
[data-theme="light"] .chip {
  background: var(--bg-surface-2, #f8fafc);
  border: 1px solid var(--border, #d9e2ec);
  font-size: var(--font-sm, 12px);
  color: var(--text-secondary);
}
[data-theme="light"] .chip.active {
  background: var(--primary-soft, #eaf2fd);
  border-color: #c8dcf5;
  color: var(--primary, #1f5fae);
}

/* 7. TABELA */
[data-theme="light"] table {
  font-size: var(--font-md, 13px);
  color: var(--text-secondary);
}
[data-theme="light"] thead { background: #2a5a93; }
[data-theme="light"] thead th {
  color: #f0f7ff;
  font-size: var(--font-sm, 12px);
  font-weight: var(--fw-semibold, 600);
  letter-spacing: .04em;
}
[data-theme="light"] tbody tr              { background: #ffffff; }
[data-theme="light"] tbody tr:nth-child(even) { background: #fbfdff; }
[data-theme="light"] tbody tr:hover        { background: #f3f8fe; }
[data-theme="light"] tbody td {
  border-bottom: 1px solid var(--border-soft, #e7edf3);
  color: var(--text-secondary, #425466);
}

/* 8. BADGES */
[data-theme="light"] .badge,
[data-theme="light"] .status {
  font-size: var(--font-xs, 11px);
  font-weight: var(--fw-medium, 500);
  border-radius: 6px;
}
[data-theme="light"] .ativo   { background: var(--success-soft, #e8f7ef);  color: var(--success, #1f8f5f); border: 1px solid var(--success-border, #cdebd8); }
[data-theme="light"] .inativo { background: var(--danger-soft, #fdeeee); color: var(--danger, #c34a43); border: 1px solid var(--danger-border, #f3d0d0); }

/* 9. DIVISÓRIAS */
[data-theme="light"] hr,
[data-theme="light"] .divider { border: 0; border-top: 1px solid var(--border-soft, #e7edf3); }

/* 10. SCROLLBAR */
[data-theme="light"] ::-webkit-scrollbar { width: 8px; height: 8px; }
[data-theme="light"] ::-webkit-scrollbar-track { background: transparent; }
[data-theme="light"] ::-webkit-scrollbar-thumb {
  background: #c8d4e0;
  border-radius: 999px;
  border: 2px solid var(--bg-body, #f4f7fb);
}
[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: #a8b8cc; }

/* 11. HELPERS */
[data-theme="light"] .txt-primary   { color: var(--text-primary)   !important; }
[data-theme="light"] .txt-secondary { color: var(--text-secondary)  !important; }
[data-theme="light"] .txt-muted     { color: var(--text-muted)      !important; }
[data-theme="light"] .fw-400 { font-weight: 400 !important; }
[data-theme="light"] .fw-500 { font-weight: 500 !important; }
[data-theme="light"] .fw-600 { font-weight: 600 !important; }
[data-theme="light"] .tnum  { font-variant-numeric: tabular-nums !important; font-feature-settings: "tnum" !important; }
