/* ============================================================
   QiLog Sentinel — Theme Modern (Premium SaaS layer)

   Camada de design system MODERNO aplicada sobre Bootstrap 5.3 +
   erp.css existente. Não substitui nada — só refina.

   Carregar SEMPRE após bootstrap.min.css e erp.css em cada HTML:
     <link href=".../bootstrap.min.css" rel="stylesheet">
     <link href="/assets/css/erp.css" rel="stylesheet">
     <link href="/assets/css/theme-modern.css" rel="stylesheet">

   Referências visuais: Linear, Stripe, ClickUp, Ramp, Retool.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ============================================================
   TOKENS — Design tokens centrais
   ============================================================ */
:root {
  /* === BRAND === */
  --brand-primary: #2563eb;             /* azul corporativo principal */
  --brand-primary-hover: #1d4ed8;
  --brand-primary-pressed: #1e40af;
  --brand-primary-soft: #eff6ff;
  --brand-primary-soft-border: #bfdbfe;
  --brand-primary-ring: rgba(37, 99, 235, 0.15);

  /* === SURFACES === */
  --surface-page: #f5f7fb;              /* fundo geral da app */
  --surface-card: #ffffff;
  --surface-hover: #f8fafc;
  --surface-muted: #f1f5f9;
  --surface-sunken: #f1f5f9;

  /* === TEXT === */
  --text-primary: #0f172a;              /* slate-900 */
  --text-secondary: #475569;            /* slate-600 */
  --text-tertiary: #64748b;             /* slate-500 */
  --text-muted: #94a3b8;                /* slate-400 */
  --text-on-brand: #ffffff;

  /* === BORDERS === */
  --border-soft: #f1f5f9;
  --border-default: #e2e8f0;
  --border-strong: #cbd5e1;

  /* === STATUS === */
  --success: #16a34a;
  --success-hover: #15803d;
  --success-soft: #f0fdf4;
  --success-soft-border: #bbf7d0;
  --success-on: #166534;

  --danger: #dc2626;
  --danger-hover: #b91c1c;
  --danger-soft: #fef2f2;
  --danger-soft-border: #fecaca;
  --danger-on: #991b1b;

  --warning: #f59e0b;
  --warning-hover: #d97706;
  --warning-soft: #fffbeb;
  --warning-soft-border: #fde68a;
  --warning-on: #92400e;

  --info: #0ea5e9;
  --info-soft: #f0f9ff;
  --info-soft-border: #bae6fd;
  --info-on: #075985;

  /* === RADIUS === */
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 10px;
  --radius-xl: 14px;
  --radius-pill: 9999px;

  /* === SHADOWS === */
  --shadow-xs: 0 1px 2px 0 rgba(15, 23, 42, 0.04);
  --shadow-sm: 0 1px 3px 0 rgba(15, 23, 42, 0.06), 0 1px 2px -1px rgba(15, 23, 42, 0.04);
  --shadow-md: 0 4px 6px -1px rgba(15, 23, 42, 0.07), 0 2px 4px -2px rgba(15, 23, 42, 0.04);
  --shadow-lg: 0 10px 15px -3px rgba(15, 23, 42, 0.08), 0 4px 6px -4px rgba(15, 23, 42, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(15, 23, 42, 0.10), 0 8px 10px -6px rgba(15, 23, 42, 0.05);
  --shadow-ring: 0 0 0 3px var(--brand-primary-ring);

  /* === TIPOGRAFIA === */
  --font-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  /* === COMPAT — sobrescreve tokens do erp.css === */
  --accent: var(--brand-primary);
  --accent-d: var(--brand-primary-hover);
  --accent-l: var(--brand-primary-soft);
}

/* ============================================================
   BASE — Body, scrollbar, focus
   ============================================================ */
html, body {
  font-family: var(--font-sans);
  background: var(--surface-page);
  color: var(--text-primary);
  font-feature-settings: 'cv11', 'ss01';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.005em;
}

/* Scrollbar elegante (WebKit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--border-strong);
  border-radius: var(--radius-pill);
  border: 2px solid var(--surface-page);
}
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* Focus universal acessível */
*:focus-visible { outline: none; }

/* ============================================================
   NÚMERO DE DOCUMENTO — destaque global
   Padrão de exibição "001.001.0000000001" usado em CT-e, MDF-e,
   Romaneio, OC, Fatura, Acerto, etc. Pedido user 2026-05-21:
   fonte maior + negrito em TODAS as telas pra destacar a chave de
   identificação do documento.
   ============================================================ */
.doc-numero,
input.doc-numero {
  font-family: 'JetBrains Mono', 'Menlo', monospace !important;
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  letter-spacing: .02em;
  color: #1e293b;
}
input.doc-numero[readonly],
input.doc-numero:disabled {
  background: #f8fafc !important;
  color: #0f172a !important;
  border-color: #cbd5e1 !important;
}
/* Variação compacta (em tabelas/células) */
.doc-numero-compact,
td.doc-numero-compact {
  font-family: 'JetBrains Mono', 'Menlo', monospace !important;
  font-size: .92rem !important;
  font-weight: 700 !important;
  color: #1e293b;
}

/* ============================================================
   SIDEBAR — slate refinada (mantém dark Linear-style)
   ============================================================ */
.sidebar {
  background: #0f172a;                  /* slate-950 */
  border-right: 1px solid #1e293b;
  color: #cbd5e1;
}
.sidebar .brand {
  padding: 1.15rem 1.25rem 1rem;
  border-bottom: 1px solid #1e293b;
  margin-bottom: 0.5rem;
}
.sidebar .brand h1 {
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.sidebar .brand .subtitle {
  color: #64748b;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 500;
}
.sidebar .nav-group {
  color: #64748b;
  font-size: 0.67rem;
  letter-spacing: 0.12em;
  font-weight: 600;
  padding: 0.85rem 1.25rem 0.35rem;
}
.sidebar a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.42rem 1.25rem;
  color: #94a3b8;
  font-size: 0.85rem;
  font-weight: 500;
  border-left: 2px solid transparent;
  border-radius: 0;
  transition: background-color 0.12s ease, color 0.12s ease, border-color 0.12s ease;
}
.sidebar a:hover {
  background: #1e293b;
  color: #ffffff;
  border-left-color: transparent;
}
.sidebar a.active {
  background: #1e293b;
  color: #ffffff;
  border-left-color: var(--brand-primary);
  font-weight: 600;
}
.sidebar a i {
  color: #64748b;
  font-size: 0.95rem;
  width: 18px;
  text-align: center;
  flex-shrink: 0;
}
.sidebar a:hover i,
.sidebar a.active i { color: #e2e8f0; }

.sidebar .user-footer {
  padding: 0.85rem 1.25rem;
  border-top: 1px solid #1e293b;
  font-size: 0.78rem;
}
.sidebar .user-footer .nome { color: #ffffff; font-weight: 600; }
.sidebar .user-footer .perfil { color: #64748b; font-weight: 500; }

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  background: var(--surface-card);
  border-bottom: 1px solid var(--border-default);
  padding: 0.9rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.topbar h2,
.topbar-title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.015em;
  margin: 0;
}
.topbar-subtitle {
  font-size: 0.78rem;
  color: var(--text-tertiary);
  margin-top: 2px;
  font-weight: 400;
}
.topbar-title i,
.topbar h2 i { color: var(--text-tertiary); }

/* ============================================================
   PAGE LAYOUT
   ============================================================ */
.page-body { padding: 1.5rem; }

/* ============================================================
   CARD
   ============================================================ */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.card-header {
  background: transparent;
  border-bottom: 1px solid var(--border-default);
  padding: 0.7rem 1rem;
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.875rem;
}
.card-header.bg-light {
  background: var(--surface-muted) !important;
  color: var(--text-primary);
  font-weight: 600;
}
.card-body { padding: 1rem 1rem; }

/* Panel custom do erp.css — refinado */
.panel,
.card-light {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1rem 1.15rem;
  box-shadow: var(--shadow-xs);
}

/* ============================================================
   BUTTONS — modernos, focus ring, transições
   ============================================================ */
.btn {
  font-weight: 500;
  font-size: 0.875rem;
  border-radius: var(--radius-md);
  padding: 0.45rem 0.85rem;
  border: 1px solid transparent;
  letter-spacing: -0.005em;
  transition: background-color 0.12s ease, border-color 0.12s ease,
              color 0.12s ease, box-shadow 0.12s ease, transform 0.06s ease;
}
.btn:active { transform: translateY(0.5px); }
.btn:focus, .btn:focus-visible { outline: none; box-shadow: var(--shadow-ring); }
.btn-sm { font-size: 0.8rem; padding: 0.3rem 0.65rem; }
.btn-lg { font-size: 0.95rem; padding: 0.6rem 1.1rem; }

.btn-primary {
  background: var(--brand-primary);
  color: #fff;
  border-color: var(--brand-primary);
}
.btn-primary:hover,
.btn-primary:focus { background: var(--brand-primary-hover); border-color: var(--brand-primary-hover); color: #fff; }
.btn-primary:active { background: var(--brand-primary-pressed); border-color: var(--brand-primary-pressed); }

.btn-secondary {
  background: var(--surface-card);
  color: var(--text-secondary);
  border-color: var(--border-default);
}
.btn-secondary:hover,
.btn-secondary:focus {
  background: var(--surface-hover);
  color: var(--text-primary);
  border-color: var(--border-strong);
}

.btn-outline-secondary {
  background: var(--surface-card);
  color: var(--text-secondary);
  border-color: var(--border-default);
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
  background: var(--surface-hover);
  color: var(--text-primary);
  border-color: var(--border-strong);
}

.btn-outline-primary {
  background: transparent;
  color: var(--brand-primary);
  border-color: var(--brand-primary-soft-border);
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background: var(--brand-primary-soft);
  color: var(--brand-primary-pressed);
  border-color: var(--brand-primary);
}

.btn-success {
  background: var(--success);
  border-color: var(--success);
  color: #fff;
}
.btn-success:hover,
.btn-success:focus { background: var(--success-hover); border-color: var(--success-hover); color: #fff; }

.btn-danger {
  background: var(--danger);
  border-color: var(--danger);
  color: #fff;
}
.btn-danger:hover,
.btn-danger:focus { background: var(--danger-hover); border-color: var(--danger-hover); color: #fff; }

.btn-outline-danger {
  background: transparent;
  color: var(--danger);
  border-color: var(--danger-soft-border);
}
.btn-outline-danger:hover,
.btn-outline-danger:focus {
  background: var(--danger-soft);
  color: var(--danger-on);
  border-color: var(--danger);
}

.btn-outline-warning {
  background: transparent;
  color: var(--warning-on);
  border-color: var(--warning-soft-border);
}
.btn-outline-warning:hover,
.btn-outline-warning:focus {
  background: var(--warning-soft);
  color: var(--warning-on);
  border-color: var(--warning);
}

.btn-light {
  background: var(--surface-card);
  color: var(--text-secondary);
  border-color: var(--border-default);
}
.btn-light:hover,
.btn-light:focus {
  background: var(--surface-hover);
  color: var(--text-primary);
  border-color: var(--border-strong);
}

.btn-link {
  color: var(--brand-primary);
  text-decoration: none;
  font-weight: 500;
}
.btn-link:hover { color: var(--brand-primary-hover); text-decoration: underline; }

.btn-close {
  background: transparent;
  border: none;
  opacity: 0.6;
  padding: 0.4rem;
  border-radius: var(--radius-md);
  transition: background-color 0.12s, opacity 0.12s;
}
.btn-close:hover { background: var(--surface-hover); opacity: 1; }

/* ============================================================
   FORM CONTROLS
   ============================================================ */
.form-control,
.form-select {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  color: var(--text-primary);
  font-size: 0.875rem;
  font-family: var(--font-sans);
  border-radius: var(--radius-md);
  padding: 0.5rem 0.75rem;
  box-shadow: none;
  transition: border-color 0.12s ease, box-shadow 0.12s ease, background-color 0.12s ease;
}
.form-control::placeholder { color: var(--text-muted); }

/* ============================================================
   UPPER global em SELECTS — regra do projeto (feedback_dados_upper):
   todo dado textual fica em UPPER. Aplica em <select> e <option>
   automaticamente, sem precisar editar HTML cada um.
   Inputs (text) — usar upper-input.js OU adicionar opt-in:
   <input class="form-control" data-upper> pra ativar individual.
   Excluir um select específico: <select class="form-select no-upper">.
   ============================================================ */
select.form-select,
select.form-select option,
select.form-control,
select.form-control option {
  text-transform: uppercase;
}
.no-upper,
.no-upper option {
  text-transform: none !important;
}
/* Placeholders / disabled options ficam normais */
select option[disabled],
select option[value=""] {
  text-transform: none;
}

.form-control:hover,
.form-select:hover { border-color: var(--border-strong); }
.form-control:focus,
.form-select:focus {
  border-color: var(--brand-primary);
  box-shadow: var(--shadow-ring);
  background: var(--surface-card);
}
.form-control:disabled,
.form-control[readonly] {
  background: var(--surface-muted);
  color: var(--text-secondary);
  cursor: not-allowed;
}

.form-control-sm,
.form-select-sm {
  font-size: 0.82rem;
  padding: 0.35rem 0.6rem;
  border-radius: var(--radius-sm);
}
.form-control-lg,
.form-select-lg {
  font-size: 0.95rem;
  padding: 0.6rem 0.95rem;
  border-radius: var(--radius-lg);
}

.form-label {
  color: var(--text-secondary);
  font-weight: 500;
  font-size: 0.8125rem;
  margin-bottom: 0.3rem;
}

/* .lbl standalone — funciona DENTRO E FORA de .form-dense
   (antes só estava definido em .form-dense .lbl no erp.css) */
.lbl {
  color: var(--text-tertiary);
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 0.25rem;
  display: block;
}

.input-group .form-control,
.input-group .form-select { box-shadow: none; }
.input-group-text {
  background: var(--surface-muted);
  border-color: var(--border-default);
  color: var(--text-secondary);
  font-size: 0.825rem;
  border-radius: var(--radius-md);
}

.form-check-input {
  border: 1.5px solid var(--border-strong);
  background-color: var(--surface-card);
  width: 1rem;
  height: 1rem;
  margin-top: 0.18rem;
}
.form-check-input:checked {
  background-color: var(--brand-primary);
  border-color: var(--brand-primary);
}
.form-check-input:focus { box-shadow: var(--shadow-ring); border-color: var(--brand-primary); }
.form-check-label { color: var(--text-secondary); font-size: 0.875rem; }

.form-switch .form-check-input {
  height: 1.15rem;
  border-radius: var(--radius-pill);
}

/* ============================================================
   MODAL — premium
   ============================================================ */
.modal-content {
  background: var(--surface-card);
  border: 2px solid #1e293b;          /* slate-800 — cinza escuro forte */
  border-radius: var(--radius-xl);
  box-shadow: 0 10px 40px rgba(15, 23, 42, 0.45),
              0 4px 12px rgba(15, 23, 42, 0.30);
  overflow: hidden;
}
.modal-header {
  background: #2563eb;            /* azul corporativo (brand-primary) */
  color: #ffffff;
  border-bottom: 1px solid #1d4ed8;
  padding: 1rem 1.25rem;
  align-items: center;
}
.modal-header .modal-title,
.modal-header .modal-title i,
.modal-header h5,
.modal-header h4 {
  color: #ffffff !important;
}
/* Texto secundário (.text-muted) dentro do header azul: cinza fica ilegível
   sobre o azul. Branco translúcido mantém legível e ainda subordinado ao
   título. Vale pra todos os modais (header é sempre #2563eb). */
.modal-header .text-muted {
  color: rgba(255, 255, 255, .8) !important;
}
/* Botão de fechar (X) precisa ficar branco no header azul */
.modal-header .btn-close {
  filter: invert(1) grayscale(100%) brightness(200%);
}
.modal-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.015em;
}
.modal-body {
  padding: 1.25rem;
  background: var(--surface-card);
}
.modal-footer {
  background: transparent;
  border-top: 1px solid var(--border-default);
  padding: 0.85rem 1.25rem;
  gap: 0.5rem;
}
.modal-backdrop.show { opacity: 0.45; }

/* form-dense dentro de modal: fundo apenas sutil */
.modal-body.form-dense { background: var(--surface-page); }

/* ============================================================
   TABLE — limpo enterprise
   ============================================================ */
.table {
  --bs-table-bg: transparent;
  font-size: 0.875rem;
  color: var(--text-primary);
  margin-bottom: 0;
}
.table thead th,
.table > thead > tr > th,
.table-light > thead > tr > th {
  background: var(--surface-muted);
  color: var(--text-tertiary);
  font-weight: 600;
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border-default);
  padding: 0.55rem 0.85rem;
  border-top: none;
}
.table tbody td {
  border-top: 1px solid var(--border-soft);
  padding: 0.65rem 0.85rem;
  color: var(--text-primary);
  vertical-align: middle;
}
.table-hover tbody tr:hover {
  background: var(--surface-hover);
}
.table-sm thead th { padding: 0.4rem 0.65rem; font-size: 0.7rem; }
.table-sm tbody td { padding: 0.4rem 0.65rem; }

/* Table dentro de card: sem borda extra */
.card > .table,
.card > .card-body > .table { margin-bottom: 0; }

/* ============================================================
   DROPDOWN
   ============================================================ */
.dropdown-menu {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: 0.35rem;
  font-size: 0.875rem;
}
.dropdown-item {
  border-radius: var(--radius-sm);
  padding: 0.4rem 0.65rem;
  color: var(--text-primary);
  font-weight: 500;
}
.dropdown-item:hover,
.dropdown-item:focus {
  background: var(--surface-hover);
  color: var(--text-primary);
}
.dropdown-divider { border-color: var(--border-soft); margin: 0.25rem 0; }

/* ============================================================
   BADGES — soft modern
   ============================================================ */
.badge {
  font-weight: 500;
  font-size: 0.72rem;
  padding: 0.25rem 0.55rem;
  border-radius: var(--radius-sm);
  letter-spacing: 0.005em;
}
.bg-primary-subtle,    .badge.bg-primary-subtle    { background: var(--brand-primary-soft) !important; color: var(--brand-primary-pressed) !important; }
.bg-success-subtle,    .badge.bg-success-subtle    { background: var(--success-soft) !important; color: var(--success-on) !important; }
.bg-danger-subtle,     .badge.bg-danger-subtle     { background: var(--danger-soft) !important; color: var(--danger-on) !important; }
.bg-warning-subtle,    .badge.bg-warning-subtle    { background: var(--warning-soft) !important; color: var(--warning-on) !important; }
.bg-info-subtle,       .badge.bg-info-subtle       { background: var(--info-soft) !important; color: var(--info-on) !important; }
.bg-secondary-subtle,  .badge.bg-secondary-subtle  { background: var(--surface-muted) !important; color: var(--text-secondary) !important; }

/* Pills do erp.css — refinado */
.pill {
  border: none;
  background: var(--surface-muted);
  color: var(--text-secondary);
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-sm);
  font-weight: 500;
  font-size: 0.7rem;
  letter-spacing: 0.005em;
  text-transform: none;
  display: inline-block;
}
.pill.accent { background: var(--brand-primary-soft); color: var(--brand-primary-pressed); }
.pill.green  { background: var(--success-soft); color: var(--success-on); }
.pill.amber  { background: var(--warning-soft); color: var(--warning-on); }
.pill.red    { background: var(--danger-soft); color: var(--danger-on); }
.pill.purple { background: #f3e8ff; color: #6b21a8; }

/* ============================================================
   ALERTS — soft variants (override Bootstrap 5.3 --bs-alert-*)
   ============================================================ */
.alert {
  --bs-alert-bg: transparent;
  --bs-alert-color: inherit;
  --bs-alert-border-color: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  padding: 0.6rem 0.85rem;
  margin-bottom: 0.75rem;
}
.alert-info    {
  --bs-alert-bg: var(--info-soft);
  --bs-alert-color: var(--info-on);
  --bs-alert-border-color: var(--info-soft-border);
  background-color: var(--info-soft) !important;
  color: var(--info-on) !important;
  border-color: var(--info-soft-border) !important;
}
.alert-success {
  --bs-alert-bg: var(--success-soft);
  --bs-alert-color: var(--success-on);
  --bs-alert-border-color: var(--success-soft-border);
  background-color: var(--success-soft) !important;
  color: var(--success-on) !important;
  border-color: var(--success-soft-border) !important;
}
.alert-warning {
  --bs-alert-bg: var(--warning-soft);
  --bs-alert-color: var(--warning-on);
  --bs-alert-border-color: var(--warning-soft-border);
  background-color: var(--warning-soft) !important;
  color: var(--warning-on) !important;
  border-color: var(--warning-soft-border) !important;
}
.alert-danger  {
  --bs-alert-bg: var(--danger-soft);
  --bs-alert-color: var(--danger-on);
  --bs-alert-border-color: var(--danger-soft-border);
  background-color: var(--danger-soft) !important;
  color: var(--danger-on) !important;
  border-color: var(--danger-soft-border) !important;
}
.alert-light   {
  background-color: var(--surface-muted) !important;
  color: var(--text-secondary) !important;
  border-color: var(--border-default) !important;
}
.alert a { color: inherit; text-decoration: underline; font-weight: 600; }

/* ============================================================
   NAV TABS — underline minimalista
   ============================================================ */
.nav-tabs {
  border-bottom: 1px solid var(--border-default);
  gap: 0.25rem;
}
.nav-tabs .nav-link {
  border: none;
  background: transparent;
  color: var(--text-secondary);
  padding: 0.55rem 0.9rem;
  font-weight: 500;
  font-size: 0.875rem;
  border-bottom: 2px solid transparent;
  border-radius: 0;
  margin-bottom: -1px;
  transition: color 0.12s, border-color 0.12s;
}
.nav-tabs .nav-link:hover { color: var(--text-primary); }
.nav-tabs .nav-link.active {
  background: transparent;
  color: var(--brand-primary);
  border-bottom-color: var(--brand-primary);
  font-weight: 600;
}

/* ============================================================
   STAT CARD / KPI — refinado com ícone lateral (estilo Linear/Stripe)
   ============================================================ */
.stat-card {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 1rem 1.2rem;
  box-shadow: var(--shadow-xs);
  transition: box-shadow 0.15s, border-color 0.15s;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}
.stat-card:hover { box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.stat-card .stat-content { flex: 1; min-width: 0; }
.stat-card .label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-tertiary);
  font-weight: 600;
  margin-bottom: 0.4rem;
}
.stat-card .value {
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.025em;
  line-height: 1.15;
  margin-bottom: 0.25rem;
}
.stat-card .delta { font-size: 0.78rem; color: var(--success); font-weight: 500; }
.stat-card .delta.neg { color: var(--danger); }
.stat-card .delta.neutral { color: var(--text-tertiary); font-weight: 400; }
.stat-card .stat-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  background: var(--brand-primary-soft);
  color: var(--brand-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.05rem;
  flex-shrink: 0;
}
.stat-card.stat-success .stat-icon { background: var(--success-soft); color: var(--success); }
.stat-card.stat-warning .stat-icon { background: var(--warning-soft); color: var(--warning-on); }
.stat-card.stat-danger  .stat-icon { background: var(--danger-soft); color: var(--danger); }
.stat-card.stat-info    .stat-icon { background: var(--info-soft); color: var(--info-on); }
.stat-card.stat-neutral .stat-icon { background: var(--surface-muted); color: var(--text-tertiary); }

/* ============================================================
   .section-head e variantes — PADRÃO NOVO (estilo .oc-card-title)
   Title sutil com border-bottom, sem background azul forte.
   Aplica em TODO o sistema pra alinhar com tabelas-pagamento, cotacao-edicao
   e ordem-coleta-edicao que já usam esse padrão.
   ============================================================ */
.form-dense .section-head,
.form-dense .secao-titulo,
.form-dense h5.text-uppercase,
.form-dense h6.text-uppercase,
.form-dense h5.small.text-uppercase,
.form-dense h6.small.text-uppercase,
.form-dense h5.text-uppercase.text-muted,
.form-dense h6.text-uppercase.text-muted,
.form-dense h5.small.text-uppercase.text-muted,
.form-dense h6.small.text-uppercase.text-muted,
.form-dense h6.section-head,
.form-dense .section-h {
  background: transparent !important;
  color: #1e40af !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px;
  margin: 0.5rem 0 0.55rem 0 !important;
  padding: 0 0 0.45rem 0 !important;
  border-bottom: 1px solid var(--zinc-200) !important;
  border-left: none !important;
  border-radius: 0 !important;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  line-height: 1.2;
}
.form-dense .card > .card-header,
.form-dense .card > .card-header.bg-light {
  background: #f8fafc !important;
  color: #1e40af !important;
  font-weight: 600;
  border-bottom: 1px solid var(--zinc-200) !important;
}
/* Override do erp.css que pintava strong/b de BRANCO (pra fundo cyan que não existe mais).
   Sem isso, strong fica branco sobre fundo quase-branco — texto invisível. */
.form-dense .card > .card-header strong,
.form-dense .card > .card-header b {
  color: #1e40af !important;
  font-weight: 700;
}
.form-dense .card > .card-header .text-muted {
  color: var(--text-secondary) !important;
}

/* Botões DENTRO desses títulos — estilo normal (não mais "ghost branco") */
.form-dense .section-head .btn,
.form-dense .secao-titulo .btn,
.form-dense h5.text-uppercase .btn,
.form-dense h6.text-uppercase .btn,
.form-dense h5.small.text-uppercase .btn,
.form-dense h6.small.text-uppercase .btn,
.form-dense .card > .card-header .btn,
.form-dense .card > .card-header.bg-light .btn {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  padding: 0.22rem 0.55rem;
  font-size: 0.78rem;
  border-radius: var(--radius-sm);
}
.form-dense .section-head .btn i,
.form-dense .secao-titulo .btn i,
.form-dense h6.text-uppercase .btn i,
.form-dense h6.small.text-uppercase .btn i,
.form-dense .card > .card-header .btn i { color: inherit; }

/* Ícones (info/tooltip) dentro dos títulos — herdam cor azul-índigo */
.form-dense .section-head i,
.form-dense .secao-titulo i,
.form-dense h6.text-uppercase i,
.form-dense h6.small.text-uppercase i { color: inherit; }

/* Sub-cards (grupo-flag de ocorrencias, blocos similares) — render compacto */
.grupo-flag {
  border: 1px solid rgba(0, 0, 0, .1);
  border-radius: .25rem;
  margin-bottom: .65rem;
  background: #fff;
}
.grupo-flag-header {
  background: #f8f9fa;
  padding: .35rem .65rem;
  border-bottom: 1px solid rgba(0, 0, 0, .08);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .78rem;
  font-weight: 600;
  color: #3f3f46;
}

/* ============================================================
   CARDS BOOTSTRAP REAL — garante shadow-sm em todo .card.mb-3
   (arquivos que já usam Bootstrap nativo mas esqueceram shadow-sm)
   ============================================================ */
.card.mb-3,
.modal-body .card,
.card:not(.no-shadow) {
  box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
}
/* Header bootstrap nativo padronizado — TODO card com header bg-light
   (não só em modal/form, mas também página direto). Body sempre BRANCO. */
.card > .card-header,
.card > .card-header.bg-light {
  background: #f8f9fa !important;
  border-bottom: 1px solid rgba(0, 0, 0, .125) !important;
  padding: .5rem .85rem !important;
}
.card > .card-header strong,
.card > .card-header h6 {
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: #3f3f46;
  margin: 0;
}
/* GARANTIR card-body branco — sobrescreve qualquer herança azulada */
.card > .card-body {
  background: #ffffff !important;
}

/* FIX: erp.css:572 aplica justify-content:space-between + background azul
   em .form-dense h6.text-uppercase (legacy "barra azul"). Quando esse h6
   está DENTRO de .card-header novo, override pra render como título
   normal (icon + texto juntos à esquerda, sem fundo azul). */
.form-dense .card > .card-header h6.text-uppercase,
.form-dense .card > .card-header h6.small.text-uppercase,
.modal-body .card > .card-header h6.text-uppercase,
.modal-body .card > .card-header h6.small.text-uppercase {
  background: transparent !important;
  color: #3f3f46 !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  justify-content: flex-start !important;
  gap: .4rem !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
}

/* ============================================================
   CARDS UNIFICADOS — shim que faz classes legacy (.oc-card, .nf-card,
   .re-card, .ce-card, .me-card) renderem visualmente IDÊNTICAS ao
   padrão Bootstrap `card mb-3 shadow-sm + card-header bg-light`.

   Estratégia: cards legacy ficam com mesmo border-radius, shadow-sm,
   margin-bottom, e o `*-card-title` recebe bg-light + padding interno
   + margin negativo pra colar nas bordas e parecer um card-header.
   ============================================================ */
.oc-card, .nf-card, .re-card, .ce-card, .me-card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, .125);   /* Bootstrap card border */
  border-radius: .375rem;                   /* Bootstrap border-radius */
  padding: 0;                               /* header e body têm padding próprio */
  margin-bottom: 1rem;                      /* Bootstrap mb-3 */
  box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);  /* Bootstrap shadow-sm */
  overflow: hidden;                         /* radius corta header */
}
.oc-card > .oc-card-title,
.nf-card > .nf-card-title,
.re-card > .re-card-title,
.ce-card > .ce-card-title,
.me-card > .me-card-title,
.oc-card-title, .nf-card-title, .re-card-title, .ce-card-title, .me-card-title {
  background: #f8f9fa !important;           /* Bootstrap bg-light */
  color: #3f3f46 !important;                /* zinc-700 — neutro */
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin: 0 !important;
  padding: .5rem .85rem !important;
  border: none !important;
  border-bottom: 1px solid rgba(0, 0, 0, .125) !important;
  border-radius: 0 !important;
  display: flex;
  align-items: center;
  gap: .4rem;
  line-height: 1.2;
}
/* Body: TODO conteúdo direto dentro do card (irmão do title) recebe padding */
.oc-card > *:not(.oc-card-title):not(.card-title),
.nf-card > *:not(.nf-card-title):not(.card-title),
.re-card > *:not(.re-card-title):not(.card-title),
.ce-card > *:not(.ce-card-title):not(.card-title),
.me-card > *:not(.me-card-title):not(.card-title) {
  padding-left: .85rem;
  padding-right: .85rem;
}
.oc-card > *:not(.oc-card-title):first-child,
.nf-card > *:not(.nf-card-title):first-child,
.re-card > *:not(.re-card-title):first-child,
.ce-card > *:not(.ce-card-title):first-child,
.me-card > *:not(.me-card-title):first-child {
  padding-top: .85rem;
}
.oc-card > *:last-child,
.nf-card > *:last-child,
.re-card > *:last-child,
.ce-card > *:last-child,
.me-card > *:last-child {
  padding-bottom: .85rem;
}
.oc-card > .oc-card-title + *,
.nf-card > .nf-card-title + *,
.re-card > .re-card-title + *,
.ce-card > .ce-card-title + *,
.me-card > .me-card-title + * {
  padding-top: .85rem;
}
.oc-card-title i, .nf-card-title i, .re-card-title i,
.ce-card-title i, .me-card-title i {
  font-size: .95rem;
  color: #2563eb;  /* azul accent */
}
.oc-lbl {
  font-size: 0.72rem;
  font-weight: 500;
  color: #475569;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-bottom: 0.18rem;
  display: block;
}

/* ============================================================
   PALETA SEMÂNTICA — pills/badges utilitários pra todo o sistema.
   Cada cor tem significado:
     verde   = OK/ativo/aprovado/concluído/principal
     azul    = padrão/cliente/em curso/rodoviário
     azul-cl = variante (FOB, funcionário, modal aéreo)
     amarelo = atenção/pendente/coletada
     laranja = motorista/terceiro/redespacho
     vermelho= cancelado/bloqueado/prejuízo
     roxo    = fiscal/seguro/vendedor/transportadora
     cinza   = inativo/rascunho/neutro
   Uso:  <span class="pill pill-ok">Ativo</span>
   ============================================================ */
.pill {
  display: inline-block;
  padding: 0.18rem 0.55rem;
  border-radius: 9999px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.3px;
  border: 1px solid transparent;
  text-transform: uppercase;
  line-height: 1.2;
  white-space: nowrap;
}
/* Variantes — fundo claro + texto da cor */
.pill-ok       { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-azul     { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-azul-cl  { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }
.pill-warn     { background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-laranja  { background: #ffedd5; color: #9a3412; border-color: #fdba74; }
.pill-err      { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.pill-roxo     { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
.pill-indigo   { background: #e0e7ff; color: #4338ca; border-color: #a5b4fc; }
.pill-rosa     { background: #fce7f3; color: #9d174d; border-color: #f9a8d4; }
.pill-cinza    { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }

/* Mapeamento semântico — atalhos com nomes do negócio */
/* Papéis de participante */
.pill-cliente        { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-fornecedor     { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-motorista      { background: #ffedd5; color: #9a3412; border-color: #fdba74; }
.pill-vendedor       { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
.pill-contador       { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-funcionario    { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }
.pill-redespacho     { background: #fce7f3; color: #9d174d; border-color: #f9a8d4; }
.pill-transportadora { background: #e0e7ff; color: #4338ca; border-color: #a5b4fc; }
.pill-seguradora     { background: #ccfbf1; color: #115e59; border-color: #5eead4; }

/* Tipos de frete (cotação/OC) */
.pill-cif      { background: #2563eb; color: #fff; border-color: #1d4ed8; }
.pill-fob      { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }
.pill-terceiro { background: #ffedd5; color: #9a3412; border-color: #fdba74; }

/* Status de OC */
.pill-st-solicitada  { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-st-coletada    { background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-st-em_transito { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-st-entregue    { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-st-cancelada   { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }

/* Status de Cotação */
.pill-st-rascunho      { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-st-enviada       { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-st-em_negociacao { background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-st-aprovada      { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-st-reprovada     { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.pill-st-expirada      { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-st-convertida_oc { background: #e0e7ff; color: #4338ca; border-color: #a5b4fc; }

/* Tipos de execução operacional */
.pill-op-propria        { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-op-terceirizada   { background: #ffedd5; color: #9a3412; border-color: #fdba74; }
.pill-op-subcontratacao { background: #fce7f3; color: #9d174d; border-color: #f9a8d4; }
.pill-op-redespacho     { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
.pill-op-transferencia  { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }

/* Tipos de carga */
.pill-c-geral          { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-c-frigorificada  { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }
.pill-c-granel_solido  { background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-c-granel_liquido { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-c-perigosa       { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.pill-c-conteinerizada { background: #e0e7ff; color: #4338ca; border-color: #a5b4fc; }
.pill-c-veiculos       { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
.pill-c-viva_animais   { background: #ffedd5; color: #9a3412; border-color: #fdba74; }

/* Status fiscal CT-e/MDF-e */
.pill-fiscal-rascunho   { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }
.pill-fiscal-assinado   { background: #e0f2fe; color: #075985; border-color: #7dd3fc; }
.pill-fiscal-transmitido{ background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-fiscal-autorizado { background: #dcfce7; color: #15803d; border-color: #86efac; }
.pill-fiscal-rejeitado  { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }
.pill-fiscal-cancelado  { background: #f1f5f9; color: #991b1b; border-color: #fca5a5; }
.pill-fiscal-denegado   { background: #fee2e2; color: #991b1b; border-color: #fca5a5; }

/* Tipos de tabela de pagamento */
.pill-exec-motorista  { background: #dbeafe; color: #1e40af; border-color: #93c5fd; }
.pill-exec-parceiro   { background: #fef3c7; color: #92400e; border-color: #fbbf24; }
.pill-exec-redespacho { background: #e0e7ff; color: #4338ca; border-color: #a5b4fc; }
.pill-exec-ajudante   { background: #fce7f3; color: #9d174d; border-color: #f9a8d4; }

/* Variante "section-soft" — sem barra azul, mais clean (para uso futuro)
   Usar adicionando: <div class="modal-body form-dense section-soft"> */
.form-dense.section-soft .section-head,
.form-dense.section-soft .secao-titulo,
.form-dense.section-soft h5.text-uppercase,
.form-dense.section-soft h6.text-uppercase,
.form-dense.section-soft h5.small.text-uppercase,
.form-dense.section-soft h6.small.text-uppercase,
.form-dense.section-soft .card > .card-header,
.form-dense.section-soft .card > .card-header.bg-light {
  background: transparent !important;
  color: var(--text-secondary) !important;
  border-bottom: 1px solid var(--border-default);
  border-radius: 0;
  padding: 0.5rem 0 0.4rem !important;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 1rem 0 0.6rem;
  display: block;
}

/* ============================================================
   AUDIT TIMELINE — bullets discretos
   ============================================================ */
.audit-timeline {
  border-left: 1px solid var(--border-default);
  padding-left: 1rem;
  margin-left: 0.5rem;
}
.audit-timeline .audit-item {
  position: relative;
  padding: 0.4rem 0;
  font-size: 0.85rem;
}
.audit-timeline .audit-item::before {
  content: '';
  position: absolute;
  left: -1.18rem;
  top: 0.85rem;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--surface-card);
  border: 2px solid var(--border-strong);
}
.audit-timeline .audit-item.success::before { border-color: var(--success); }
.audit-timeline .audit-item.danger::before { border-color: var(--danger); }
.audit-timeline .audit-item.warning::before { border-color: var(--warning); }
.audit-timeline .audit-item.info::before { border-color: var(--brand-primary); }

/* ============================================================
   LINKS, MONO, UTILITIES
   ============================================================ */
a {
  color: var(--brand-primary);
  text-decoration: none;
  transition: color 0.12s ease;
}
a:hover { color: var(--brand-primary-hover); text-decoration: underline; }

.mono, code, .text-mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

.text-muted    { color: var(--text-tertiary) !important; }
.text-primary  { color: var(--brand-primary) !important; }
.text-success  { color: var(--success) !important; }
.text-danger   { color: var(--danger) !important; }
.text-warning  { color: var(--warning-on) !important; }
.text-info     { color: var(--info-on) !important; }

.fw-semibold { font-weight: 600 !important; }

hr { border-color: var(--border-default); margin: 1rem 0; opacity: 1; }

/* ============================================================
   SPINNER ELEGANTE
   ============================================================ */
.spinner-border-sm { width: 0.95rem; height: 0.95rem; border-width: 2px; }

/* ============================================================
   FORM-DENSE override — refinado com nova paleta
   ============================================================ */
.form-dense { background: var(--surface-page); }
.form-dense .lbl {
  color: var(--text-tertiary);
  font-weight: 500;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
}
.form-dense .form-control-sm,
.form-dense .form-select-sm {
  font-size: 0.825rem;
  padding: 0.38rem 0.6rem;
  border-radius: var(--radius-sm);
}

/* Parte-row dentro de form-dense — visual moderno */
.form-dense .parte-row {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.85rem;
  transition: border-color 0.12s, box-shadow 0.12s;
}
.form-dense .parte-row:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-xs);
}
.form-dense .parte-row .ico {
  background: var(--brand-primary-soft);
  color: var(--brand-primary);
}
.form-dense .parte-row .titulo {
  color: var(--text-tertiary);
  font-size: 0.7rem;
  letter-spacing: 0.05em;
  font-weight: 600;
}
.form-dense .parte-row .nome { color: var(--text-primary); font-weight: 600; }
.form-dense .parte-row .doc { color: var(--text-tertiary); }
.form-dense .parte-row .endereco { color: var(--text-tertiary); }

/* Info-doc refinado */
.form-dense .info-doc {
  background: var(--surface-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: 0.6rem 0.85rem;
}
.form-dense .info-doc-lbl {
  font-size: 0.65rem;
  color: var(--text-tertiary);
  letter-spacing: 0.06em;
  font-weight: 600;
}
.form-dense .info-doc-val {
  color: var(--text-primary);
  font-weight: 600;
}

/* ============================================================
   RESPONSIVE - micro-ajustes
   ============================================================ */
@media (max-width: 992px) {
  .page-body { padding: 1rem; }
  .topbar { padding: 0.7rem 1rem; }
  .modal-body { padding: 1rem; }
}

/* ============================================================
   BOTÕES — borda + sombra sutil em todos os .btn pra dar definição
   visual consistente. Aplica em solid (primary/success/etc.) e em
   outline. Mantém cor original como background; borda é da mesma
   família ligeiramente mais escura. Hover ganha sombra reforçada.
   ============================================================ */
.btn {
  border-width: 1px !important;
  border-style: solid !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
  transition: box-shadow 0.15s ease, transform 0.10s ease, border-color 0.15s ease;
}
.btn:hover { box-shadow: 0 2px 5px rgba(0, 0, 0, 0.12); }
.btn:active { box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08); transform: translateY(1px); }

/* Solid: borda 12% mais escura que o background pra ter contorno visível */
.btn-primary   { border-color: rgba(0, 0, 0, 0.18); }
.btn-success   { border-color: rgba(0, 0, 0, 0.18); }
.btn-danger    { border-color: rgba(0, 0, 0, 0.18); }
.btn-warning   { border-color: rgba(0, 0, 0, 0.18); }
.btn-info      { border-color: rgba(0, 0, 0, 0.18); }
.btn-dark      { border-color: rgba(255, 255, 255, 0.15); }
.btn-secondary { border-color: rgba(0, 0, 0, 0.18); }

/* Light/branco: borda cinza explícita pra não desaparecer no fundo branco */
.btn-light,
.btn-outline-secondary,
.btn-outline-light { border-color: var(--zinc-300, #d4d4d8); }

/* btn-close (X) Bootstrap não é .btn — preserva visual nativo */
.btn-close { box-shadow: none !important; border: none !important; }

/* btn-link: text-only, não força borda (visual de link) */
.btn-link { border-color: transparent !important; box-shadow: none !important; }
.btn-link:hover { box-shadow: none !important; }

/* ============================================================
   CORES VIVAS — paleta saturada pra todos os botões solid.
   Sobrescreve as cores derivadas de vars pra ter máximo impacto visual.
   ============================================================ */
.btn-primary,
.btn-primary:visited {
  background: #2563eb !important; /* azul vibrante */
  border-color: #1d4ed8 !important;
  color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
  background: #1d4ed8 !important;
  border-color: #1e3a8a !important;
  color: #fff !important;
}

.btn-success,
.btn-success:visited {
  background: #16a34a !important; /* verde vivo */
  border-color: #15803d !important;
  color: #fff !important;
}
.btn-success:hover, .btn-success:focus {
  background: #15803d !important;
  border-color: #14532d !important;
}

.btn-danger,
.btn-danger:visited {
  background: #dc2626 !important; /* vermelho vivo */
  border-color: #b91c1c !important;
  color: #fff !important;
}
.btn-danger:hover, .btn-danger:focus {
  background: #b91c1c !important;
  border-color: #991b1b !important;
}

.btn-warning,
.btn-warning:visited {
  background: #f59e0b !important; /* amarelo-âmbar saturado */
  border-color: #d97706 !important;
  color: #1f2937 !important; /* texto escuro pra contraste */
}
.btn-warning:hover, .btn-warning:focus {
  background: #d97706 !important;
  border-color: #b45309 !important;
  color: #1f2937 !important;
}

.btn-info,
.btn-info:visited {
  background: #06b6d4 !important; /* ciano vivo */
  border-color: #0891b2 !important;
  color: #fff !important;
}
.btn-info:hover, .btn-info:focus {
  background: #0891b2 !important;
  border-color: #0e7490 !important;
}

.btn-secondary,
.btn-secondary:visited {
  background: #475569 !important; /* slate-600 saturado (não esmaecido) */
  border-color: #334155 !important;
  color: #fff !important;
}
.btn-secondary:hover, .btn-secondary:focus {
  background: #334155 !important;
  border-color: #1e293b !important;
  color: #fff !important;
}

.btn-dark,
.btn-dark:visited {
  background: #0f172a !important; /* slate-900 */
  border-color: #020617 !important;
  color: #fff !important;
}

/* Outlines: borda + texto saturados, hover preenche */
.btn-outline-primary { color: #2563eb !important; border-color: #2563eb !important; }
.btn-outline-primary:hover { background: #2563eb !important; color: #fff !important; }

.btn-outline-success { color: #16a34a !important; border-color: #16a34a !important; }
.btn-outline-success:hover { background: #16a34a !important; color: #fff !important; }

.btn-outline-danger { color: #dc2626 !important; border-color: #dc2626 !important; }
.btn-outline-danger:hover { background: #dc2626 !important; color: #fff !important; }

.btn-outline-warning { color: #d97706 !important; border-color: #f59e0b !important; }
.btn-outline-warning:hover { background: #f59e0b !important; color: #1f2937 !important; }

.btn-outline-info { color: #0891b2 !important; border-color: #06b6d4 !important; }
.btn-outline-info:hover { background: #06b6d4 !important; color: #fff !important; }

/* Sombra mais forte em todos os solids (sensação "elevado") */
.btn-primary, .btn-success, .btn-danger, .btn-warning, .btn-info, .btn-dark, .btn-secondary {
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.10);
}
.btn-primary:hover, .btn-success:hover, .btn-danger:hover, .btn-warning:hover,
.btn-info:hover, .btn-dark:hover, .btn-secondary:hover {
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.18);
  transform: translateY(-1px);
}
.btn { transition: transform 0.08s ease, box-shadow 0.12s ease, background 0.12s ease; }

/* ============================================================
   OUTLINES COM FUNDO SUAVE — cor sempre visível, sem hover
   ============================================================ */
.btn-outline-primary {
  background: #dbeafe !important; /* azul claro */
  color: #1d4ed8 !important;
  border-color: #2563eb !important;
}
.btn-outline-primary:hover, .btn-outline-primary:focus {
  background: #2563eb !important;
  color: #fff !important;
  border-color: #1d4ed8 !important;
}

/* Radio toggle buttons (.btn-check + label): estado selecionado preenche
   solid pra contraste claro vs. não-selecionado. Sem isso, ambos ficam
   azul-claro idênticos e user não consegue identificar a opção ativa. */
.btn-check:checked + .btn-outline-primary,
.btn-check:active + .btn-outline-primary {
  background: #2563eb !important;
  color: #fff !important;
  border-color: #1d4ed8 !important;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.15) !important;
}
.btn-check:checked + .btn-outline-success {
  background: #16a34a !important; color: #fff !important; border-color: #15803d !important;
}
.btn-check:checked + .btn-outline-danger {
  background: #dc2626 !important; color: #fff !important; border-color: #b91c1c !important;
}
.btn-check:checked + .btn-outline-warning {
  background: #f59e0b !important; color: #1f2937 !important; border-color: #d97706 !important;
}
.btn-check:checked + .btn-outline-info {
  background: #06b6d4 !important; color: #fff !important; border-color: #0891b2 !important;
}
.btn-check:checked + .btn-outline-secondary {
  background: #475569 !important; color: #fff !important; border-color: #334155 !important;
}

.btn-outline-success {
  background: #dcfce7 !important; /* verde claro */
  color: #15803d !important;
  border-color: #16a34a !important;
}
.btn-outline-success:hover, .btn-outline-success:focus {
  background: #16a34a !important;
  color: #fff !important;
  border-color: #15803d !important;
}

.btn-outline-danger {
  background: #fee2e2 !important; /* vermelho claro */
  color: #b91c1c !important;
  border-color: #dc2626 !important;
}
.btn-outline-danger:hover, .btn-outline-danger:focus {
  background: #dc2626 !important;
  color: #fff !important;
  border-color: #b91c1c !important;
}

.btn-outline-warning {
  background: #fef3c7 !important; /* amarelo claro */
  color: #b45309 !important;
  border-color: #f59e0b !important;
}
.btn-outline-warning:hover, .btn-outline-warning:focus {
  background: #f59e0b !important;
  color: #1f2937 !important;
  border-color: #d97706 !important;
}

.btn-outline-info {
  background: #cffafe !important; /* ciano claro */
  color: #0e7490 !important;
  border-color: #06b6d4 !important;
}
.btn-outline-info:hover, .btn-outline-info:focus {
  background: #06b6d4 !important;
  color: #fff !important;
  border-color: #0891b2 !important;
}

.btn-outline-secondary {
  background: #f1f5f9 !important; /* slate claro */
  color: #334155 !important;
  border-color: #94a3b8 !important;
}
.btn-outline-secondary:hover, .btn-outline-secondary:focus {
  background: #475569 !important;
  color: #fff !important;
  border-color: #334155 !important;
}
