/*
  QiLog Sentinel — Design System
  Baseado no padrão erp.css do ERP Confecção (NFASoft).
  Paleta: zinc + accent blue. Fontes: system-ui + JetBrains Mono pra dados.
*/

:root {
  /* Paleta neutra (zinc) */
  --zinc-50:  #fafafa;
  --zinc-100: #f4f4f5;
  --zinc-200: #e4e4e7;
  --zinc-300: #d4d4d8;
  --zinc-400: #a1a1aa;
  --zinc-500: #71717a;
  --zinc-600: #52525b;
  --zinc-700: #3f3f46;
  --zinc-800: #27272a;
  --zinc-900: #18181b;

  /* Accent (azul informativo) */
  --accent:   #0ea5e9;
  --accent-d: #0284c7;
  --accent-l: #e0f2fe;

  /* Semânticas */
  --green:   #16a34a;
  --green-l: #dcfce7;
  --amber:   #d97706;
  --amber-l: #fef3c7;
  --red:     #dc2626;
  --red-l:   #fee2e2;
  --purple:  #9333ea;
  --purple-l: #f3e8ff;

  /* Aliases pra Bootstrap-compat */
  --ink-6:  var(--zinc-500);
  --ink-10: var(--zinc-200);

  /* Tipografia */
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.5;
  color: var(--zinc-800);
  background: var(--zinc-50);
}

/* ============================================================
   LAYOUT — Sidebar fixa + main content
   ============================================================ */
.app-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
}

.sidebar {
  background: var(--zinc-900);
  color: var(--zinc-300);
  padding: 1.25rem 0;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  /* z-index alto pra ficar acima dos banners globais (apolices, billing,
     atualizações regulatórias, simulação) que são inseridos como primeiro
     filho do body com z-index 1029-1060. Sem isto, banners invisíveis ou
     com altura zero podem interceptar cliques no topo da sidebar (busca de
     menu não recebia foco). */
  z-index: 1100;
}

/* Garante que o input de busca da sidebar não seja sobreposto */
.sidebar .brand,
.sidebar .sidebar-search,
.sidebar #sidebarSearch {
  position: relative;
  z-index: 1;
}

.sidebar .brand {
  padding: 0 1.25rem 1rem 1.25rem;
  border-bottom: 1px solid var(--zinc-800);
  margin-bottom: 1rem;
}
.sidebar .brand h1 {
  color: white;
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0;
  letter-spacing: -0.01em;
}
.sidebar .brand .subtitle {
  color: var(--zinc-500);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 0.15rem;
}

.sidebar .nav-group {
  padding: 0.5rem 1.25rem 0.25rem;
  color: var(--zinc-500);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  user-select: none;
  margin-top: .35rem;
  transition: background .12s ease, color .12s ease;
}
.sidebar .nav-group:hover { color: var(--zinc-300); background: rgba(255,255,255,.02); }
.sidebar .nav-group .ng-label { flex: 1 1 auto; }
.sidebar .nav-group .ng-count {
  font-size: .58rem; font-weight: 700; color: var(--zinc-600);
  background: var(--zinc-800); padding: 1px 6px; border-radius: 9999px;
  letter-spacing: .02em;
}
.sidebar .nav-group .ng-chevron {
  font-size: .7rem; color: var(--zinc-500);
  transition: transform .18s ease;
  display: inline-block;
}
.sidebar .nav-group.expandido .ng-chevron { transform: rotate(180deg); color: var(--zinc-300); }

.sidebar .nav-group-itens {
  max-height: 0;
  overflow: hidden;
  transition: max-height .22s ease;
}
.sidebar .nav-group-itens.expandido { max-height: 1500px; }

.sidebar a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 1.25rem;
  color: var(--zinc-400);
  text-decoration: none;
  font-size: 0.85rem;
  border-left: 2px solid transparent;
  transition: all 0.15s ease;
}
.sidebar a:hover {
  background: var(--zinc-800);
  color: white;
  border-left-color: var(--accent);
}
.sidebar a.active {
  background: var(--zinc-800);
  color: white;
  border-left-color: var(--accent);
  font-weight: 600;
}

.sidebar .user-footer {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--zinc-800);
  margin-top: auto;
  font-size: 0.78rem;
}
.sidebar .user-footer .nome { color: white; font-weight: 600; }
.sidebar .user-footer .perfil { color: var(--zinc-500); font-size: 0.7rem; text-transform: capitalize; }

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.85rem 1.5rem;
  background: white;
  border-bottom: 1px solid var(--zinc-200);
  gap: 1rem;
}
.topbar h2 {
  font-size: 1.2rem;
  font-weight: 700;
  margin: 0;
  color: var(--zinc-900);
  letter-spacing: -0.01em;
}
.topbar .topbar-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

/* ============================================================
   PANEL / CARD genérico
   ============================================================ */
.panel,
.card-light {
  background: white;
  border: 1px solid var(--zinc-200);
  border-radius: 0.6rem;
  padding: 1.1rem 1.25rem;
}

.page-body {
  padding: 1.5rem;
}

.panel h6,
.card-light h6 {
  font-size: 0.85rem;
  font-weight: 600;
  margin: 0 0 0.75rem 0;
  color: var(--zinc-700);
}

/* ============================================================
   STAT CARDS / KPI
   ============================================================ */
.stat-card {
  background: white;
  border: 1px solid var(--zinc-200);
  border-radius: 0.6rem;
  padding: 1rem 1.2rem;
}
.stat-card .label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--zinc-500);
  font-weight: 600;
  margin-bottom: 0.4rem;
}
.stat-card .value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--zinc-900);
  font-family: var(--font-mono);
}
.stat-card .delta {
  font-size: 0.8rem;
  color: var(--green);
}
.stat-card .delta.neg { color: var(--red); }

/* ============================================================
   PILL (badge inline)
   ============================================================ */
.pill {
  display: inline-block;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--zinc-100);
  color: var(--zinc-700);
  border: 1px solid var(--zinc-200);
}
.pill.accent { background: var(--accent-l); color: var(--accent-d); border-color: var(--accent); }
.pill.green  { background: var(--green-l);  color: var(--green);    border-color: #86efac; }
.pill.amber  { background: var(--amber-l);  color: var(--amber);    border-color: #fde68a; }
.pill.red    { background: var(--red-l);    color: var(--red);      border-color: #fca5a5; }
.pill.purple { background: var(--purple-l); color: var(--purple);   border-color: #d8b4fe; }

/* ============================================================
   BOTÕES (sobreescreve Bootstrap leve)
   ============================================================ */
.btn-icon {
  padding: 0.35rem 0.55rem;
  font-size: 0.82rem;
}
.btn-icon i { font-size: 1rem; }

/* ============================================================
   TABELAS
   ============================================================ */
table.dados {
  width: 100%;
  background: white;
  border-radius: 0.5rem;
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.88rem;
}
table.dados thead {
  background: var(--zinc-100);
}
table.dados th {
  text-align: left;
  padding: 0.65rem 0.85rem;
  font-weight: 600;
  color: var(--zinc-600);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 1px solid var(--zinc-200);
}
table.dados td {
  padding: 0.65rem 0.85rem;
  border-bottom: 1px solid var(--zinc-100);
}
table.dados tr:last-child td { border-bottom: none; }
table.dados tr:hover td { background: var(--zinc-50); }

/* Mono pra colunas de número de documento (001.001.0000000001)
   slashed-zero (Ø) ativado pra diferenciar 0 de 8 em códigos */
.mono { font-family: var(--font-mono); font-variant-numeric: slashed-zero; font-feature-settings: "zero" 1; }
.dado-numero { font-family: var(--font-mono); font-size: 0.88em; font-variant-numeric: slashed-zero; font-feature-settings: "zero" 1; }
.text-mono { font-variant-numeric: slashed-zero; font-feature-settings: "zero" 1; }
.doc-numero { font-variant-numeric: slashed-zero; font-feature-settings: "zero" 1; }

/* ============================================================
   LOGIN
   ============================================================ */
.login-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: linear-gradient(135deg, var(--zinc-900) 0%, var(--zinc-800) 100%);
}
.login-card {
  background: white;
  border-radius: 0.8rem;
  padding: 2.5rem;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3);
}
.login-card .logo-area {
  text-align: center;
  margin-bottom: 1.75rem;
}
.login-card .logo-area h1 {
  font-size: 1.6rem;
  font-weight: 800;
  margin: 0;
  color: var(--zinc-900);
  letter-spacing: -0.02em;
}
.login-card .logo-area .subtitle {
  color: var(--zinc-500);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 0.25rem;
}
.login-card .form-group {
  margin-bottom: 1rem;
}
.login-card label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
  color: var(--zinc-600);
  margin-bottom: 0.35rem;
}
.login-card input {
  width: 100%;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--zinc-300);
  border-radius: 0.4rem;
  font-size: 0.95rem;
  font-family: var(--font-sans);
}
.login-card input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-l);
}
.login-card .btn-primary {
  width: 100%;
  margin-top: 0.5rem;
  padding: 0.7rem;
  background: var(--accent);
  color: white;
  border: none;
  border-radius: 0.4rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.login-card .btn-primary:hover { background: var(--accent-d); }
.login-card .footer-text {
  text-align: center;
  color: var(--zinc-500);
  font-size: 0.78rem;
  margin-top: 1.5rem;
}

/* ============================================================
   UTILS
   ============================================================ */
.text-muted { color: var(--zinc-500); }
.text-mono { font-family: var(--font-mono); }
.flex-row { display: flex; align-items: center; gap: 0.5rem; }
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.mt-1 { margin-top: 0.25rem; }
.mt-2 { margin-top: 0.5rem; }
.mt-3 { margin-top: 0.75rem; }
.mb-0 { margin-bottom: 0; }

/* ============================================================
   FORM DENSE — padrão de formulário denso do QiLog
   Aplica no modal-body/drawer-body com class="form-dense"
   ============================================================ */
.form-dense { background: #fafafa; }

.form-dense .section-head {
  background: #0ea5e9;
  color: #fff;
  padding: 0.25rem 0.6rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  margin: 0.6rem 0 0.4rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.form-dense .section-head:first-child { margin-top: 0; }
.form-dense .section-head .btn { color: #fff; }

.form-dense .lbl {
  font-size: 0.7rem;
  font-weight: 600;
  color: #52525b;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin-bottom: 0.15rem;
  display: block;
}

.form-dense .form-control-sm,
.form-dense .form-select-sm {
  font-size: 0.82rem;
  padding: 0.2rem 0.5rem;
  height: auto;
}
.form-dense label.form-check-label { font-size: 0.78rem; }
.form-dense .mono { font-family: var(--font-mono); }

/* Info-doc — bloco read-only com dados do documento (identificação) */
.form-dense .info-doc {
  display: flex; flex-wrap: wrap; gap: 0.6rem;
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 4px;
  padding: 0.5rem 0.7rem;
}
.form-dense .info-doc-item {
  flex: 1 1 calc(25% - 0.6rem);
  min-width: 140px;
}
.form-dense .info-doc-lbl {
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #71717a;
  font-weight: 600;
}
.form-dense .info-doc-val {
  font-weight: 600;
  font-size: 0.85rem;
  color: #18181b;
}

/* Parte-row — card denso pra relacionado (participante, endereço, etc) */
.form-dense .parte-row {
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 4px;
  padding: 0.4rem 0.6rem;
  margin-bottom: 0.3rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.form-dense .parte-row .ico {
  width: 28px; height: 28px;
  border-radius: 4px;
  background: #e0f2fe;
  color: #0369a1;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.form-dense .parte-row .titulo {
  font-size: 0.7rem;
  color: #71717a;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  min-width: 88px;
  font-weight: 600;
}
.form-dense .parte-row .info { flex: 1; min-width: 0; }
.form-dense .parte-row .nome-line {
  display: flex; align-items: baseline; gap: 0.5rem; flex-wrap: wrap;
}
.form-dense .parte-row .nome {
  font-weight: 600;
  font-size: 0.85rem;
  color: #18181b;
}
.form-dense .parte-row .doc {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: #52525b;
}
.form-dense .parte-row .endereco {
  font-size: 0.72rem;
  color: #71717a;
  margin-top: 0.1rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.form-dense .parte-row .vazio { color: #a1a1aa; font-style: italic; }
.form-dense .parte-row .idsmall {
  font-family: var(--font-mono);
  color: #a1a1aa;
  font-size: 0.72rem;
}

/* Card headers existentes (.card-header.bg-light) viram section-head azul
   automaticamente quando dentro de .form-dense — sem precisar reescrever markup */
.form-dense .card {
  border: 1px solid #e4e4e7;
  border-radius: 4px;
  margin-bottom: 0.6rem;
  overflow: hidden;
}
.form-dense .card > .card-header,
.form-dense .card > .card-header.bg-light {
  background: #0ea5e9 !important;
  color: #fff !important;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.25rem 0.6rem;
  border-bottom: none;
  border-radius: 0;
}
.form-dense .card > .card-header strong,
.form-dense .card > .card-header b { color: #fff; font-weight: 700; }
.form-dense .card > .card-header .text-muted { color: rgba(255,255,255,0.85) !important; }
.form-dense .card > .card-body {
  padding: 0.6rem 0.75rem;
  background: #fff;
}

/* Headings semânticos (h5/h6) usados como cabeçalho de seção viram barra azul.
   Aceita os padrões mais comuns: text-uppercase, small text-uppercase, etc. */
.form-dense h5.text-uppercase,
.form-dense h6.text-uppercase,
.form-dense h5.small.text-uppercase,
.form-dense h6.small.text-uppercase,
.form-dense h6.section-head,
.form-dense .section-h {
  background: #0ea5e9;
  color: #fff !important;
  padding: 0.25rem 0.6rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  margin: 0.8rem 0 0.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.4;
}
.form-dense h5.text-uppercase:first-child,
.form-dense h6.text-uppercase:first-child,
.form-dense h6.section-head:first-child { margin-top: 0; }

/* Anula classes de texto muted que iam contra o fundo azul */
.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 { color: #fff !important; }
.form-dense h5.text-uppercase .text-secondary,
.form-dense h6.text-uppercase .text-secondary { color: rgba(255,255,255,0.85) !important; }

/* <hr> antes/depois das headings: ocultar pra não duplicar separação visual */
.form-dense h5.text-uppercase + hr,
.form-dense h6.text-uppercase + hr,
.form-dense hr + h5.text-uppercase,
.form-dense hr + h6.text-uppercase { display: none; }
.form-dense h5.text-uppercase ~ hr:has(+ h5.text-uppercase),
.form-dense h6.text-uppercase ~ hr:has(+ h6.text-uppercase) { display: none; }

/* Classe .secao-titulo (usada em telas que tinham CSS próprio) também vira barra azul */
.form-dense .secao-titulo {
  background: #0ea5e9;
  color: #fff !important;
  padding: 0.25rem 0.6rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  margin: 0.8rem 0 0.5rem;
  border-bottom: none;
}
.form-dense .secao-titulo:first-child { margin-top: 0; }

/* Cards sem header (panel-style) */
.form-dense .panel {
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 4px;
  padding: 0.6rem 0.75rem;
  margin-bottom: 0.6rem;
}

/* Forms diretos no modal-body (sem card wrapper) — agrupar via fieldset/h6 */
.form-dense fieldset { border: none; padding: 0; margin: 0 0 0.6rem; }
.form-dense fieldset > legend {
  background: #0ea5e9;
  color: #fff;
  padding: 0.25rem 0.6rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: 4px;
  width: auto;
  float: none;
  margin-bottom: 0.4rem;
}

/* Tabs dentro de form-dense ficam mais discretas */
.form-dense .nav-tabs .nav-link { font-size: 0.82rem; padding: 0.3rem 0.6rem; }
.form-dense .nav-tabs .nav-link.active { font-weight: 600; }

/* Alerts ficam mais compactos */
.form-dense .alert { padding: 0.4rem 0.6rem; font-size: 0.82rem; margin-bottom: 0.5rem; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* Tablet (<=992px) — sidebar mais estreita */
@media (max-width: 992px) {
  .app-layout { grid-template-columns: 200px 1fr; }
  .page-body  { padding: 1rem 1.25rem; }
}

/* Mobile (<=768px) — sidebar vira drawer slide-in via hambúrguer */
@media (max-width: 768px) {
  /* Bloqueia scroll horizontal global (tabelas/modais grandes não empurram a viewport) */
  html, body { overflow-x: hidden; max-width: 100vw; }
  /* TODOS os filhos diretos do app-layout (exceto sidebar) respeitam a viewport.
     Algumas telas usam <div class="main-content">, outras usam <div> direto. */
  .app-layout > *:not(.sidebar):not(#sidebar-mount) {
    min-width: 0;
    max-width: 100vw;
    overflow-x: hidden;
  }
  .main-content { min-width: 0; max-width: 100vw; overflow-x: hidden; }

  .app-layout { grid-template-columns: 1fr; }

  /* Sidebar fica fora da tela; .sidebar-open (no body) traz pra dentro */
  .sidebar {
    position: fixed;
    top: 0; bottom: 0; left: 0;
    width: 260px;
    z-index: 1040;
    transform: translateX(-100%);
    transition: transform .25s ease-out;
    box-shadow: 4px 0 18px rgba(0,0,0,.25);
    overflow-y: auto;
  }
  body.sidebar-open .sidebar { transform: translateX(0); }

  /* Backdrop atrás do drawer quando aberto */
  body.sidebar-open::after {
    content: ""; position: fixed; inset: 0; background: rgba(0,0,0,.45);
    z-index: 1039;
  }

  /* Botão hambúrguer flutuante (canto sup esquerdo) */
  .sidebar-toggle {
    position: fixed; top: .65rem; left: .65rem; z-index: 1041;
    width: 40px; height: 40px; border-radius: 8px;
    background: var(--zinc-900); color: #fff; border: 1px solid var(--zinc-700);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; cursor: pointer;
    box-shadow: 0 2px 8px rgba(0,0,0,.2);
  }

  /* Banner sticky de alerta (apolices-alerta-banner.js): texto não pode ficar embaixo
     do hambúrguer. Em vez de margem global, adicionar padding-left. */
  body > .alert {
    padding-left: 3.6rem !important;
    flex-wrap: wrap;
    gap: .35rem;
    font-size: .75rem !important;
    line-height: 1.3;
  }
  body > .alert .btn { padding: .25rem .55rem !important; font-size: .72rem !important; }
  body > .alert .btn-close { position: absolute; right: .5rem; top: .5rem; }
  /* !important pra sobrescrever regra de 992px do theme-modern.css */
  .topbar     { padding: 0.65rem 1rem 0.65rem 3.6rem !important; }
  .page-body  { padding: 0.85rem !important; }
  .page-title { font-size: 1.05rem !important; }
  .topbar-title    { font-size: .95rem; line-height: 1.2; }
  .topbar-subtitle { font-size: .7rem; line-height: 1.2; }

  /* Forms densos quebram em 1 coluna no mobile */
  .form-dense .row,
  .form-dense .row-cols-md-2,
  .form-dense .row-cols-md-3,
  .form-dense .row-cols-md-4 { row-gap: .5rem !important; }
  .form-dense [class*="col-md-"] { flex: 0 0 100% !important; max-width: 100% !important; }

  /* Cards e KPIs em 1 coluna */
  .kpi-bento, .stat-grid, .stats-row { grid-template-columns: 1fr !important; }
  .stat-card  { padding: .75rem !important; }
  .stat-num   { font-size: 1.4rem !important; }

  /* Estratégia correta de scroll horizontal:
     1. Container (.panel/.card) PRECISA ter `max-width: 100%` E `width: 100%`
        — senão ele cresce com a tabela e nunca cria overflow interno
     2. Container ganha `overflow-x: auto` — É AQUI que aparece a scrollbar
     3. Tabela usa `min-width: max-content` — força largura natural do conteúdo
     Resultado: tabela é maior que o panel → panel cria scroll horizontal. */
  .panel, .card-body, .card, .table-responsive {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #94a3b8 #f1f5f9;
  }
  /* Tabela mantém display normal mas força largura natural maior que o panel */
  .panel table.dados,
  .card table.dados,
  .card-body table.dados,
  .panel table.table,
  .card table.table,
  .card-body table.table {
    min-width: max-content !important;
    overflow: visible !important;   /* override do `overflow: hidden` do .dados base */
    width: max-content !important;
    border-radius: 0 !important;     /* sem border-radius pra evitar clipping do .dados */
  }
  /* Webkit: scrollbar de 10px visível mesmo sem hover (Chrome/Edge/Safari) */
  .panel::-webkit-scrollbar,
  .card::-webkit-scrollbar,
  .card-body::-webkit-scrollbar,
  .main-content > div::-webkit-scrollbar,
  .table-responsive::-webkit-scrollbar {
    height: 10px;
    width: 10px;
  }
  .panel::-webkit-scrollbar-track,
  .card::-webkit-scrollbar-track,
  .card-body::-webkit-scrollbar-track,
  .main-content > div::-webkit-scrollbar-track,
  .table-responsive::-webkit-scrollbar-track {
    background: #f1f5f9;
    border-radius: 5px;
  }
  .panel::-webkit-scrollbar-thumb,
  .card::-webkit-scrollbar-thumb,
  .card-body::-webkit-scrollbar-thumb,
  .main-content > div::-webkit-scrollbar-thumb,
  .table-responsive::-webkit-scrollbar-thumb {
    background: #94a3b8;
    border-radius: 5px;
  }
  .panel::-webkit-scrollbar-thumb:hover,
  .card::-webkit-scrollbar-thumb:hover,
  .card-body::-webkit-scrollbar-thumb:hover,
  .main-content > div::-webkit-scrollbar-thumb:hover,
  .table-responsive::-webkit-scrollbar-thumb:hover {
    background: #64748b;
  }

  /* Inputs/selects nunca estouram a coluna */
  .form-control, .form-select, textarea, input[type="text"], input[type="number"],
  input[type="date"], input[type="datetime-local"], input[type="email"], input[type="tel"] {
    max-width: 100%;
  }

  /* Bootstrap row não estoura por margens negativas */
  .row { margin-left: 0; margin-right: 0; }
  .row > [class*="col"] { padding-left: .35rem; padding-right: .35rem; }

  /* Drawers customizados (padrão do projeto: aside/div com class drawer/painel-lateral)
     ATENÇÃO: NÃO setar `right: 0` aqui — quebra a transição (drawer fica sempre visível).
     Em mobile, drawer ocupa 100% da viewport e desliza igual; o JS/classe ativa controla
     visibilidade. Reset do `right: -Npx` inline pra `-100vw` evita slide gigante.        */
  .drawer, .painel-lateral, .side-drawer {
    width: 100% !important; max-width: 100vw !important;
    right: -100vw;          /* posição inicial escondida em mobile (override de right:-960px etc) */
  }
  .drawer.active, .painel-lateral.active, .side-drawer.active { right: 0 !important; }
  .offcanvas { width: 100% !important; max-width: 100vw !important; }
  /* Padding interno reduzido em mobile pros drawers customizados */
  .drawer-header { padding: .75rem .85rem !important; }
  .drawer-body   { padding: .75rem .85rem !important; }
  .drawer-footer { padding: .65rem .85rem !important; flex-wrap: wrap; gap: .35rem !important; }
  .drawer-footer .btn { flex: 1 1 auto; min-height: 38px; }

  /* Tabs customizadas (.tabs-papel, .tabs-frota, .tab-*): quebra linha + alvo de toque */
  .tabs-papel, .tabs-frota, .tabs-recurso, .tabs-aba {
    flex-wrap: wrap !important; gap: .35rem !important;
  }
  .tab-papel, .tab-frota, .tab-recurso, .tab-aba {
    padding: .35rem .65rem !important;
    font-size: .78rem !important;
    flex: 0 1 auto;
  }

  /* Cards .oc-card / .nf-card / .re-card / .ce-card / .me-card e similares:
     padding e margem reduzidos no mobile (mantém shim global do theme-modern.css) */
  .oc-card, .nf-card, .re-card, .ce-card, .me-card,
  .panel-card, .info-card {
    margin-bottom: .55rem !important;
  }
  .oc-card > *:not(.oc-card-title),
  .nf-card > *:not(.nf-card-title),
  .re-card > *:not(.re-card-title),
  .ce-card > *:not(.ce-card-title),
  .me-card > *:not(.me-card-title) {
    padding-left: .55rem !important;
    padding-right: .55rem !important;
  }
  .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: .55rem !important;
  }
  .oc-card > *:last-child,
  .nf-card > *:last-child,
  .re-card > *:last-child,
  .ce-card > *:last-child,
  .me-card > *:last-child {
    padding-bottom: .55rem !important;
  }
  .oc-card-title, .nf-card-title, .re-card-title, .ce-card-title, .me-card-title,
  .panel-card-title {
    font-size: .7rem !important;
    padding: .35rem .55rem !important;
  }

  /* Galeria de fotos (frota) — colunas menores */
  .foto-grid { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)) !important; }

  /* Composição reboque inline: empilha em mobile */
  .composicao-reboque-row { flex-wrap: wrap; }

  /* Title da topbar (alguns templates usam h2 direto, não .topbar-title) */
  .topbar h1, .topbar h2, .topbar h3 {
    font-size: .95rem !important;
    margin: 0 !important;
    line-height: 1.2 !important;
    flex: 1 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  /* topbar-actions vira linha cheia em mobile (quebra abaixo do título) */
  .topbar-actions {
    width: 100% !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: .35rem !important;
    justify-content: flex-start !important;
  }
  .topbar-actions .btn,
  .topbar-actions a.btn {
    padding: .3rem .55rem !important;
    font-size: .75rem !important;
    flex: 0 0 auto;
  }

  /* Alerts (info/warning) dentro do page-body — menor altura, fonte reduzida */
  .page-body .alert {
    padding: .45rem .65rem !important;
    font-size: .72rem !important;
    line-height: 1.3 !important;
    margin-bottom: .65rem !important;
  }
  .page-body .alert i.bi { font-size: .85rem; }
  .page-body .alert code {
    font-size: .68rem;
    word-break: break-all;
  }

  /* KPIs e bento em 1 coluna — seletor mais amplo */
  .kpi-bento, .stats-row, .stat-grid,
  [class*="kpi-grid"], [class*="bento-grid"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: .55rem !important;
  }

  /* Filtros avançados em coluna única */
  .filtros, .filtros-avancados, .ba-painel, .busca-avancada-painel {
    grid-template-columns: 1fr !important;
  }

  /* Botões grupo em mobile: wrap pra não estourar */
  .btn-group, .btn-toolbar { flex-wrap: wrap; gap: .25rem; }
  .btn { white-space: normal; }

  /* Listagens de cards: 1 coluna */
  .grid-cards, .card-grid, [class*="grid-3"], [class*="grid-4"] {
    grid-template-columns: 1fr !important;
  }

  /* Topbar: ações encolhem (esconde texto, mantém ícone) */
  .topbar .btn { padding: .35rem .55rem; font-size: .78rem; }
  .topbar .btn .label-desktop { display: none; }

  /* Topbar quebra linha — ações vão pra linha de baixo se necessário */
  .topbar {
    flex-wrap: wrap !important;
    gap: .5rem !important;
    padding: .6rem .85rem .6rem 3.4rem !important;
  }
  .topbar > * { min-width: 0; }
  /* Search inline com width fixo (style="width:220px") perde a largura em mobile */
  .topbar input[type="search"],
  .topbar .form-control { width: 100% !important; min-width: 0 !important; }
  .topbar .ms-auto { margin-left: 0 !important; width: 100%; flex-wrap: wrap; }
  /* Switches/checkboxes ficam menores */
  .topbar .form-switch, .topbar .form-check { font-size: .72rem; }
  /* Botões grupo da topbar: quebram linha sem estourar */
  .topbar .d-flex.gap-2 { flex-wrap: wrap; gap: .35rem !important; }

  /* Modais ocupam quase a tela toda em mobile */
  .modal-dialog        { margin: .5rem; max-width: calc(100% - 1rem); }
  .modal-dialog.modal-lg, .modal-dialog.modal-xl { max-width: calc(100% - 1rem); }

  /* Botões cheios em modais (footer) pra alvo maior de toque */
  .modal-footer { flex-wrap: wrap; gap: .35rem; }
  .modal-footer .btn { flex: 1 1 auto; min-height: 38px; }

  /* User footer fica menos chamativo */
  .user-footer { padding-bottom: .8rem; }
}

@media (min-width: 769px) {
  .sidebar-toggle { display: none; }
}

/* ──────────────────────────────────────────────────────────────
   Fix: modal scrollable quando o <form> envolve body+footer
   Bootstrap espera .modal-body filho direto de .modal-content.
   Quando há um <form> wrapper, o cálculo de altura quebra e o
   conteúdo passa a viewport, escondendo os botões do footer.
   Esta regra propaga o flex pelo form e devolve o scroll ao body.
   ────────────────────────────────────────────────────────────── */
.modal-dialog-scrollable .modal-content > form {
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: 100%;
  overflow: hidden;
}
.modal-dialog-scrollable .modal-content > form > .modal-body {
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}

