/* =====================================================
   FRM-047 · Inspeção Veicular GNV — CSS Completo
   ===================================================== */

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --primary:       #2563eb;
  --primary-dark:  #1d4ed8;
  --primary-light: #3b82f6;
  --success:       #16a34a;
  --danger:        #dc2626;
  --neutral:       #64748b;
  --bg:            #f8fafc;
  --card:          #ffffff;
  --text:          #0f172a;
  --text-sec:      #64748b;
  --border:        #e2e8f0;
  --warn-bg:       #fef3c7;
  --warn-border:   #f59e0b;
  --radius:        10px;
  --shadow:        0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.06);

  /* === V121 minimalist · grayscale tokens + accent soft/glow + phosphor === */
  --gray-100:      #F4F4F5;
  --gray-200:      #E4E4E7;
  --gray-300:      #D4D4D8;
  --gray-400:      #A1A1AA;
  --gray-500:      #71717A;
  --gray-600:      #52525B;
  --gray-700:      #3F3F46;
  --gray-800:      #27272A;
  --gray-900:      #18181B;
  --gray-950:      #09090B;

  --primary-soft:  rgba(37, 99, 235, 0.10);
  --primary-glow:  rgba(59, 130, 246, 0.40);
  --success-soft:  rgba(22, 163, 74, 0.08);
  --danger-soft:   rgba(220, 38, 38, 0.08);
  --neutral-soft:  rgba(100, 116, 139, 0.10);

  --phosphor:      #FFFFFF;                  /* V11: branco · usado pelo eyebrow dot */
  --phosphor-live: #10B981;                  /* V11: verde · usado SÓ pelo Online breathing */
  --phosphor-glow: rgba(16, 185, 129, 0.55);

  /* Surface tokens for dark login (V11: pretos neutros, sem cast azul) */
  --bg-deep:       #000000;
  --bg-mid:        #09090B;

  /* Elevation system (3 níveis sutis) */
  --elev-1:        0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.05);
  --elev-2:        0 2px 4px rgba(15,23,42,0.04), 0 4px 12px rgba(15,23,42,0.06);
  --elev-3:        0 4px 8px rgba(15,23,42,0.05), 0 12px 32px rgba(15,23,42,0.10);

  /* Easing canonical */
  --ease:          cubic-bezier(0.4, 0, 0.2, 1);
  --t-fast:        150ms var(--ease);
  --t-base:        200ms var(--ease);
  --t-slow:        300ms var(--ease);
}

html, body {
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', system-ui, Roboto, 'Helvetica Neue', Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 15px;
  line-height: 1.55;
  min-height: 100vh;
  transition: background 0.2s, color 0.2s;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'cv02', 'cv03', 'cv04', 'cv11';
}

/* ═══════════════ TEMA ESCURO ═══════════════ */
body.theme-dark {
  --bg:          #0f172a;
  --card:        #1e293b;
  --text:        #e2e8f0;
  --text-sec:    #94a3b8;
  --border:      #334155;
  --warn-bg:     #3a2e00;
  --warn-border: #f59e0b;
  --shadow:      0 1px 2px rgba(0,0,0,0.3), 0 4px 12px rgba(0,0,0,0.25);
}
body.theme-dark .field-input,
body.theme-dark .field-select,
body.theme-dark .field-textarea,
body.theme-dark .cell-select,
body.theme-dark .insp-table input,
body.theme-dark .insp-table select {
  background: #2a2a2a;
  color: var(--text);
  border-color: var(--border);
}
body.theme-dark .insp-table th {
  background: #1e3a5f;
  color: #e8e8e8;
}
body.theme-dark .insp-table td {
  border-color: var(--border);
}
body.theme-dark .insp-table .row-header {
  background: #2a2a2a;
  color: var(--text);
}
body.theme-dark .check3-btn {
  background: #2a2a2a;
  color: #bbb;
  border-color: #3a3a3a;
}
body.theme-dark .check3-btn:hover {
  background: #333;
  border-color: #555;
}
/* V121 minimalist · selected states no tema dark precisam de alpha maior pra visibilidade */
body.theme-dark .check3-btn.selected.aprov  { background: rgba(22, 163, 74, 0.18); color: #4ade80; border-color: #4ade80; }
body.theme-dark .check3-btn.selected.reprov { background: rgba(220, 38, 38, 0.18); color: #fca5a5; border-color: #fca5a5; }
body.theme-dark .check3-btn.selected.na     { background: rgba(148, 163, 184, 0.18); color: #cbd5e1; border-color: #cbd5e1; }
body.theme-dark .subitem-item {
  background: #2a2a2a;
  border-color: var(--border);
}
body.theme-dark .subitem-label {
  color: #cacaca;
}
body.theme-dark .radio-option {
  background: #2a2a2a;
  border-color: var(--border);
}
body.theme-dark .radio-option.radio-selected {
  background: #1e3a5f;
  border-color: var(--primary);
}
body.theme-dark .home-header h1,
body.theme-dark .section-title,
body.theme-dark .insp-placa,
body.theme-dark .insp-veic-info {
  color: #80b9f5;
}
body.theme-dark .field-label,
body.theme-dark .step-counter,
body.theme-dark .section-code,
body.theme-dark .section-page {
  color: #bbb;
}
body.theme-dark .inspection-item {
  background: var(--card);
  border-color: var(--border);
}
body.theme-dark .mini-progress { background: #2a2a2a; }
body.theme-dark .filter-panel { background: var(--card); border-color: var(--border); }
body.theme-dark .filter-header { background: #1a2433; border-bottom-color: var(--border); }
body.theme-dark .filter-label { color: var(--text-sec); }
body.theme-dark .date-group-header { color: #a8c2e0; border-bottom-color: var(--primary); }
body.theme-dark .eval-summary.eval-aprov { background: #1b3a1f; color: #a6e3b0; }
body.theme-dark .eval-summary.eval-reprov { background: #3a1f22; color: #f3a3ab; }
body.theme-dark .step-hint { background: #3a2e00; color: #e8d08a; border-left-color: #c88a0f; }
body.theme-dark .radio-na-mark { background: #2a2a2a; color: var(--text-sec); border-color: #555; }
body.theme-dark .input-unit, body.theme-dark .cell-unit { background: #3a3a3a; color: #cacaca; }
body.theme-dark .limit-info { color: var(--text-sec); }
body.theme-dark .idx-done    { background: #1b3a1f; color: #a6e3b0; }
body.theme-dark .idx-reprov  { background: #3a1f22; color: #f3a3ab; }
body.theme-dark .idx-na      { background: #2a2a2a; color: #aab4bc; }
body.theme-dark .idx-partial { background: #3a2e00; color: #f0c76d; }
body.theme-dark .idx-empty   { background: #2a2a2a; color: #6a6a6a; }
body.theme-dark .idx-step-row:hover { background: #1a2433; }
body.theme-dark .idx-step-row.idx-active { background: #1e3a5f; }
body.theme-dark .idx-row-reprov { background: #2a1a1c; }
body.theme-dark .step-index-panel { background: var(--card); }
body.theme-dark .step-index-legend { background: #1a1a1a; border-bottom-color: var(--border); }
body.theme-dark .card.card-warn { background: #3a1f22; }
body.theme-dark .card.card-ok   { background: #1b3a1f; }
body.theme-dark .reprov-item { border-bottom-color: var(--border); }

/* Botão de alternar tema no cabeçalho */
.theme-toggle-btn {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
  font-size: 18px;
  line-height: 1;
  transition: background 0.15s;
}
.theme-toggle-btn:hover { background: rgba(255,255,255,0.15); }
body.theme-dark .theme-toggle-btn:hover { background: rgba(255,255,255,0.1); }
.home-theme-toggle {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 10;
  background: rgba(0,0,0,0.06);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  font-size: 20px;
}
body.theme-dark .home-theme-toggle { background: rgba(255,255,255,0.1); color: #ffd66b; }

/* =====================================================
   TELA BASE
   ===================================================== */
.screen {
  padding: 16px;
  max-width: 600px;
  margin: 0 auto;
  padding-bottom: 90px;
}

.wizard-screen {
  padding-top: 8px;
}

/* =====================================================
   BARRA DE PROGRESSO
   ===================================================== */
.progress-bar-wrap {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 6px;
  background: #bbdefb;
  z-index: 100;
}

.progress-bar {
  height: 100%;
  background: var(--primary);
  transition: width 0.3s ease;
}

/* =====================================================
   HEADER DO WIZARD
   ===================================================== */
.wizard-header {
  position: sticky;
  top: 6px;
  z-index: 99;
  background: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.wizard-header-info {
  flex: 1;
}

.vehicle-info {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.5px;
}

.step-counter {
  font-size: 12px;
  opacity: 0.85;
  margin-top: 1px;
}

.btn-back, .btn-home {
  background: rgba(255,255,255,0.15);
  border: none;
  color: #fff;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
  flex-shrink: 0;
}

.btn-back:hover, .btn-home:hover {
  background: rgba(255,255,255,0.25);
}

/* =====================================================
   CARD
   ===================================================== */
.card {
  background: var(--card);
  border-radius: var(--radius);
  padding: 18px;
  margin-bottom: 14px;
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
}

.card-warn {
  background: var(--warn-bg);
  border-color: var(--warn-border);
}

.card-ok {
  background: #e8f5e9;
  border-color: #a5d6a7;
  color: var(--success);
  font-weight: 600;
  padding: 16px;
  border-radius: var(--radius);
  margin-bottom: 12px;
  box-shadow: var(--shadow);
}

.equip-card {
  padding: 12px 16px;
}

/* =====================================================
   SECTION HEADER
   ===================================================== */
/* Painel resumo da avaliação final (no passo 32) */
.eval-summary {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  margin-bottom: 12px;
  border-left: 5px solid;
}
.eval-summary .eval-icon {
  font-size: 24px;
  line-height: 1;
  font-weight: 700;
  flex-shrink: 0;
}
.eval-summary .eval-text {
  font-size: 14px;
  line-height: 1.4;
}
.eval-summary .eval-sub {
  font-size: 12px;
  margin-top: 4px;
  opacity: 0.85;
  font-weight: 500;
}
.eval-summary.eval-aprov {
  background: #e8f5e9;
  border-left-color: var(--success);
  color: #1b5e20;
}
.eval-summary.eval-reprov {
  background: #ffebee;
  border-left-color: var(--danger);
  color: #b71c1c;
}
.eval-summary.eval-incompleta {
  background: #fff4e5;
  border-left-color: #ef6c00;
  color: #b45309;
}
body.theme-dark .eval-summary.eval-incompleta { background: #3a2a15; color: #fbbf77; }

.text-incompleta { color: #ef6c00; }

.card-warn-incompleta {
  background: #fff4e5;
  border-color: #ffcc80;
}
body.theme-dark .card-warn-incompleta { background: #3a2a15; border-color: #a56422; }
.reprov-item-incompleta .reprov-section { color: #ef6c00; }

/* Botão para atualizar o cache da FIPE no passo 1 */
.fipe-refresh-wrap {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 10px;
}
.fipe-refresh-btn {
  background: transparent;
  color: var(--primary);
  border: 1px dashed var(--primary);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.fipe-refresh-btn:hover {
  background: #e8f0fe;
}

/* Botão de ajuda ao lado do label de uma tabela */
.label-help-btn {
  background: var(--primary-light);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  margin-left: 8px;
  letter-spacing: 0.3px;
}
.label-help-btn:hover { background: var(--primary-dark); }

/* Select dentro de célula de tabela (rowOptions) */
.cell-select {
  width: 100%;
  height: 32px;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 0 6px;
  background: #fff;
  font-size: 13px;
  cursor: pointer;
}
.cell-select:focus { outline: none; border-color: var(--primary); }

/* Modal de ajuda (overlay + painel central) */
.help-modal-overlay {
  position: fixed; inset: 0; z-index: 1100;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s;
}
.help-modal-overlay.open { opacity: 1; pointer-events: all; }
.help-modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.55); }
.help-modal-panel {
  position: relative; z-index: 1;
  background: #fff; border-radius: 10px;
  max-width: 95vw; width: 960px;
  max-height: 90vh; display: flex; flex-direction: column;
  box-shadow: 0 8px 40px rgba(0,0,0,0.3);
}
.help-modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  background: var(--primary-dark); color: #fff;
  font-size: 15px; font-weight: 700;
  border-radius: 10px 10px 0 0;
}
.help-modal-close {
  background: none; border: none; color: #fff;
  font-size: 20px; cursor: pointer; padding: 2px 6px;
}
.help-modal-close:hover { background: rgba(255,255,255,0.15); border-radius: 4px; }
.help-modal-body {
  padding: 16px 18px; overflow-y: auto; overflow-x: auto;
}

/* Tabela de especificações técnicas dentro do modal */
.spec-table-wrap { width: 100%; }
.spec-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
  border: 1px solid #999;
}
.spec-table th, .spec-table td {
  border: 1px solid #999; padding: 6px 8px; text-align: center;
}
.spec-table thead th {
  background: #6b8e4e; color: #fff; font-weight: 700;
}
.spec-table tbody td:first-child {
  background: #cfe2bc; font-weight: 700; text-align: left;
}
.spec-note {
  margin-top: 12px; font-size: 11px; line-height: 1.5;
  color: var(--text-sec); padding: 8px 10px;
  background: #f5f5f5; border-radius: 6px;
}

/* Conteúdo de fórmula dentro do modal (suporteDimFormula) */
.formula-help .formula-big {
  text-align: center;
  font-size: 32px;
  font-weight: 800;
  letter-spacing: 3px;
  color: var(--primary-dark);
  padding: 16px 12px;
  margin-bottom: 16px;
  background: #f0f4ff;
  border: 2px solid var(--primary-light);
  border-radius: 10px;
}
.formula-dl {
  display: grid;
  grid-template-columns: 50px 1fr;
  column-gap: 14px;
  row-gap: 10px;
  margin: 0;
}
.formula-dl dt {
  font-size: 22px;
  font-weight: 800;
  color: var(--primary);
  text-align: center;
  background: #e8f0fe;
  border-radius: 6px;
  padding: 8px 6px;
  line-height: 1;
}
.formula-dl dd {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text);
  padding: 6px 0;
}

/* Aviso/hint logo abaixo do cabeçalho do passo */
.step-hint {
  background: #fff8e1;
  border-left: 4px solid #fbc02d;
  color: #5d4037;
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 12px;
  line-height: 1.4;
}

/* Cabeçalho principal de grupo de seções (ex: SISTEMA GNV) */
.mega-header {
  background: var(--primary-dark);
  color: #fff;
  padding: 14px 18px;
  border-radius: 12px;
  margin-bottom: 10px;
  font-size: 17px;
  font-weight: 800;
  text-align: center;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  border: 2px solid var(--primary);
  box-shadow: 0 3px 10px rgba(13, 71, 161, 0.25);
}

.section-header {
  background: var(--primary);
  color: #fff;
  padding: 12px 16px;
  border-radius: 8px;
  margin-bottom: 12px;
}

.section-title {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
}

.section-code {
  font-size: 12px;
  opacity: 0.8;
  margin-bottom: 2px;
  font-weight: 500;
  letter-spacing: 0.5px;
}

.section-page {
  font-size: 11px;
  opacity: 0.7;
  margin-top: 3px;
}

/* =====================================================
   BOTÕES
   ===================================================== */
.btn-primary {
  display: block;
  width: 100%;
  min-height: 44px;
  background: var(--primary);
  color: #fff;
  border: 1px solid var(--primary);
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease, transform 0.08s ease;
  text-align: center;
  padding: 10px 18px;
  line-height: 1.3;
}

.btn-primary:hover  { background: var(--primary-dark); border-color: var(--primary-dark); }
.btn-primary:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 28%, transparent);
}
.btn-primary:active { transform: translateY(1px); }

.btn-primary.btn-disabled {
  background: var(--neutral);
  border-color: var(--neutral);
  cursor: not-allowed;
  opacity: 0.55;
}

.btn-secondary {
  display: block;
  width: 100%;
  min-height: 44px;
  background: transparent;
  color: var(--primary);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
  text-align: center;
  padding: 10px 18px;
  line-height: 1.3;
}

.btn-secondary:hover {
  background: color-mix(in srgb, var(--primary) 7%, transparent);
  border-color: color-mix(in srgb, var(--primary) 40%, var(--border));
  color: var(--primary-dark);
}
.btn-secondary:focus-visible {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent);
}

/* =====================================================
   NAVEGAÇÃO INFERIOR
   ===================================================== */
.nav-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--card);
  box-shadow: 0 -2px 12px rgba(0,0,0,0.12);
  padding: 12px 16px;
  display: flex;
  gap: 10px;
  z-index: 98;
  max-width: 100%;
}

.nav-bar .btn-secondary {
  flex: 1;
  max-width: 160px;
}

.nav-bar .btn-primary {
  flex: 2;
}

/* =====================================================
   CHECK3 — Aprovado / Reprovado / N.A.
   ===================================================== */
.check3-group {
  display: flex;
  gap: 8px;
  margin-top: 8px;
}

.check3-btn {
  flex: 1;
  height: 50px;
  border: 1.5px solid var(--border);
  border-radius: 9px;
  font-size: 17px;
  font-weight: 700;
  cursor: pointer;
  background: #FFFFFF;
  color: var(--text-sec);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 150ms cubic-bezier(.4,0,.2,1);
  line-height: 1;
  text-align: center;
  padding: 0;
  letter-spacing: -0.02em;
}

.check3-btn:hover {
  border-color: #90a4ae;
  background: #f8fafc;
}
.check3-btn:active {
  transform: scale(0.97);
}

/* V128 wizard-faithful · botões A/R/N (V4 mockup soft bg sólido) */
.check3-btn.selected.aprov {
  background: #ECFDF5;
  border-color: #10B981;
  color: #10B981;
}

.check3-btn.selected.reprov {
  background: #FEF2F2;
  border-color: var(--danger);
  color: var(--danger);
}

.check3-btn.selected.na {
  background: #F8FAFC;
  border-color: #475569;
  color: #475569;
}

/* =====================================================
   CHECKBOX OBRIG. (Lista de Itens de Inspeção)
   Item marcado como obrigatório oculta o botão N/A no wizard.
   Visual: caixa branca com borda; quando marcado, ✓ vermelho bold.
   ===================================================== */
.obrig-cell {
  text-align: center;
  vertical-align: middle;
}
.obrig-checkbox {
  position: relative;
  display: inline-block;
  width: 18px;
  height: 18px;
  cursor: pointer;
  vertical-align: middle;
}
.obrig-checkbox input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  cursor: pointer;
  z-index: 1;
}
.obrig-checkbox .obrig-box {
  display: block;
  width: 18px;
  height: 18px;
  border: 1.5px solid #94a3b8;
  border-radius: 3px;
  background: #fff;
  position: relative;
  transition: border-color 0.15s;
}
.obrig-checkbox:hover .obrig-box {
  border-color: #475569;
}
.obrig-checkbox input:checked + .obrig-box {
  border-color: #dc2626;
  background: #fff;
}
.obrig-checkbox input:checked + .obrig-box::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  font-size: 16px;
  font-weight: 900;
  color: #dc2626;
  line-height: 1;
}
body.theme-dark .obrig-checkbox .obrig-box {
  background: var(--card-bg);
  border-color: var(--border);
}
body.theme-dark .obrig-checkbox input:checked + .obrig-box {
  border-color: #f87171;
}
body.theme-dark .obrig-checkbox input:checked + .obrig-box::after {
  color: #f87171;
}

/* =====================================================
   FAIXA DE ALERTA DE OBRIGATORIEDADE (Plano B, V23)
   Banner amber inline mostrado acima dos botões A/R/N-A no
   check3 do wizard quando o item é obrigatório para o veículo.
   Ocupa ~50px de altura — visibilidade > elegância.
   ===================================================== */
.obrig-alert {
  background: #FEF3C7;
  border-left: 3px solid #F59E0B;
  border-radius: 0 7px 7px 0;
  padding: 9px 11px;
  margin: 12px 0 9px;
  display: flex;
  align-items: flex-start;
  gap: 7px;
  line-height: 1.45;
}
.obrig-alert-ic {
  width: 14px;
  height: 14px;
  color: #B45309;
  flex-shrink: 0;
  margin-top: 1px;
}
.obrig-alert-txt {
  flex: 1;
  font-size: 11.5px;
  color: #92400E;
  line-height: 1.45;
}
.obrig-alert-txt strong {
  display: block;
  color: #92400E;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-size: 11.5px;
}
.obrig-alert-txt > div { margin-top: 1px; }
.obrig-alert-fonte {
  font-size: 10.5px !important;
  color: #a16207 !important;
  font-style: italic;
  margin-top: 2px !important;
}
body.theme-dark .obrig-alert {
  background: #78350f;
  border-color: #d97706;
}
body.theme-dark .obrig-alert-txt,
body.theme-dark .obrig-alert-txt strong {
  color: #fef3c7;
}
body.theme-dark .obrig-alert-fonte { color: #fcd34d !important; }

/* Marca compacta de obrigatoriedade nos sub-itens (grid compacto).
   Ponto vermelho próximo ao código, indica que o item é obrig
   sem ocupar espaço de banner — sub-itens têm pouca altura. */
.subitem-obrig-mark {
  color: #dc2626;
  font-weight: 900;
  font-size: 14px;
  margin: 0 4px;
  vertical-align: middle;
  cursor: help;
}

/* =====================================================
   PAINEL · REGRAS DE OBRIGATORIEDADE (Plano B, V24)
   ===================================================== */
.obrig-edit-panel {
  background: #eff6ff;
  border: 1px solid #93c5fd;
  border-radius: 8px;
  padding: 14px 18px;
  margin: 0 0 14px;
}
.obrig-form-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  margin-bottom: 4px;
}
.obrig-cat-picker {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.obrig-cat-group {
  display: inline-flex;
  gap: 0;
  border: 1px solid #cbd5e1;
  border-radius: 5px;
  overflow: hidden;
  background: #fff;
}
.obrig-cat-pick {
  padding: 6px 11px;
  font-size: 12px;
  background: #fff;
  cursor: pointer;
  margin: 0;
  font-weight: 500;
  color: #334155;
  border-right: 1px solid #cbd5e1;
  user-select: none;
}
.obrig-cat-group .obrig-cat-pick:last-child { border-right: 0; }
.obrig-cat-pick.checked {
  background: #dbeafe;
  color: #1e3a8a;
  font-weight: 700;
}
.obrig-cat-pick input[type="checkbox"] { display: none; }

/* Chips de categoria na lista de regras */
.obrig-cat {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 9px;
  font-size: 10.5px;
  font-weight: 700;
  margin: 0 2px 2px 0;
  border: 1px solid;
}
.obrig-cat.cat-M { background: #dbeafe; color: #1e3a8a; border-color: #93c5fd; }
.obrig-cat.cat-N { background: #fef3c7; color: #92400e; border-color: #fcd34d; }
.obrig-cat.cat-O { background: #dcfce7; color: #14532d; border-color: #86efac; }
.obrig-cat.cat-L { background: #fce7f3; color: #831843; border-color: #f9a8d4; }
.obrig-cat.cat-T { background: #f3e8ff; color: #6b21a8; border-color: #d8b4fe; }
.obrig-cat.cat-all { background: #f1f5f9; color: #475569; border-color: #cbd5e1; }

/* Condições (ano, PBT, CMT) e código do field */
.obrig-cond {
  display: inline-block;
  background: #fff7ed;
  color: #9a3412;
  padding: 1px 7px;
  border-radius: 3px;
  font-size: 10.5px;
  font-weight: 600;
  margin: 0 2px 1px 0;
  white-space: nowrap;
}
.obrig-field-code {
  background: #f1f5f9;
  color: #1e293b;
  font-family: Consolas, ui-monospace, monospace;
  font-weight: 700;
  font-size: 11.5px;
  padding: 2px 7px;
  border-radius: 3px;
}

/* =====================================================
   MODAL DE IMPORTAÇÃO Res. 993 (Plano B, V25)
   ===================================================== */
.modal-backdrop {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(15, 23, 42, 0.5);
  z-index: 999;
  cursor: pointer;
}
.modal-mock.import-res993-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
  max-width: 580px;
  width: calc(100vw - 40px);
  z-index: 1000;
  overflow: hidden;
}
.modal-mock .modal-head {
  background: #0d47a1;
  color: #fff;
  padding: 12px 16px;
  font-weight: 700;
  font-size: 14px;
}
.modal-mock .modal-body { padding: 14px 18px; font-size: 13px; line-height: 1.55; }
.modal-mock .modal-foot {
  padding: 11px 18px;
  background: #f8fafc;
  border-top: 1px solid #e5e7eb;
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.modal-mock .stat-mini {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 5px;
  padding: 8px 10px;
  text-align: center;
}
.modal-mock .stat-mini .n { font-size: 18px; font-weight: 800; color: #0d47a1; line-height: 1; }
.modal-mock .stat-mini .l { font-size: 11px; color: #64748b; margin-top: 3px; }

/* =====================================================
   ITEM CUSTOM IMPORTADO DA RES. 993 — destaque laranja
   na Lista de Itens (admin). Identificado por isFromRes993:true.
   ===================================================== */
.itens-row-res993 td {
  background: #fff7ed !important;
  border-left: 3px solid #f59e0b;
}
.itens-row-res993:hover td { background: #ffedd5 !important; }
.badge-res993 {
  display: inline-block;
  background: #f59e0b;
  color: #fff;
  padding: 1px 7px;
  border-radius: 9px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.4px;
  margin-left: 6px;
  vertical-align: middle;
}
.item-code-res993 {
  background: #fed7aa !important;
  color: #9a3412 !important;
}

/* =====================================================
   ITEM ANINHADO (nestedItem: true) — wrapper visual usado quando
   um check3 é "filho" de outro pai (ex: G0501 dentro de G0500).
   Apresenta um card cinza-claro com badge azul do código no topo
   e abaixo todos os sub-fields do item até o próximo nestedItem.
   ===================================================== */
.nested-card {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 12px;
  margin-bottom: 10px;
}
body.theme-dark .nested-card {
  background: var(--card-bg);
  border-color: var(--border);
}
.nested-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px dashed #cbd5e1;
}
body.theme-dark .nested-title {
  border-bottom-color: var(--border);
}
.nested-badge {
  background: var(--primary);
  color: #fff;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.nested-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
}

/* =====================================================
   SUB-ITENS EM GRID (até 4 colunas)
   ===================================================== */
.subitem-card {
  padding: 14px;
}

.subitem-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  gap: 8px;
}

.subitem-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-sec);
}

.btn-aprovar-todos {
  background: var(--success);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}
.btn-aprovar-todos:hover {
  background: #1b5e20;
}
.btn-aprovar-todos:active {
  background: #145214;
}

.subitem-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

@media (min-width: 540px) {
  .subitem-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .screen {
    max-width: 900px;
  }
}

.subitem-item {
  background: #f8f9fa;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.subitem-num {
  display: inline-block;
  background: var(--primary);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: 4px;
  padding: 2px 6px;
  margin-right: 5px;
  margin-bottom: 3px;
  vertical-align: middle;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.subitem-label {
  font-size: 11px;
  color: #424242;
  line-height: 1.35;
  flex: 1;
}

.check3-compact {
  gap: 4px;
  margin-top: 0;
}

.check3-compact .check3-btn {
  height: 30px;
  font-size: 13px;
  font-weight: 700;
  flex-direction: row;
  border-radius: 6px;
}

/* =====================================================
   CAMPOS DE FORMULÁRIO
   ===================================================== */
.field-group {
  margin-bottom: 12px;
}

.field-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-sec);
  margin-bottom: 6px;
  line-height: 1.3;
}

/* Tabela de ensaio embutida em itens check3 com tableSpec (ex: G0603_MOTOS) */
.ensaio-table-wrap { margin: 8px 0 12px; }
.ensaio-table {
  width: 100%; max-width: 640px; border-collapse: collapse;
  background: var(--card); border: 1px solid #94a3b8;
  font-size: 12px; margin: 0 auto;
}
.ensaio-table th, .ensaio-table td {
  border: 1px solid #94a3b8; padding: 5px 6px; text-align: center;
}
.ensaio-table .col-head { font-weight: 600; background: var(--card); }
.ensaio-table .row-label {
  font-weight: 600; padding: 5px 10px; text-align: left; background: var(--card);
}
.ensaio-table input[type="text"] {
  width: 100%; padding: 4px 6px; border: 1px solid transparent;
  border-radius: 3px; font-size: 12px; text-align: center;
  background: #fffbeb; font-family: inherit; color: var(--text);
}
.ensaio-table input[type="text"]:focus {
  outline: 1px solid var(--primary); outline-offset: -1px; background: var(--card);
}
.ensaio-table input[type="text"][readonly] {
  background: transparent; color: var(--text);
}
.ensaio-table .limit-cell {
  background: #f1f5f9; color: #475569; font-weight: 500; font-style: italic;
}
.ensaio-table .limit-row-head { background: #f1f5f9; }
.ensaio-table .limits-section-head td {
  background: #e2e8f0; font-weight: 700; font-size: 10px;
  text-transform: uppercase; letter-spacing: .4px;
  color: #475569; padding: 4px 6px;
}
.ensaio-table .footer-note {
  font-size: 11px; color: var(--text-sec); font-style: italic;
  text-align: center; padding: 6px;
}
.ensaio-equip {
  display: flex; gap: 14px; flex-wrap: wrap; max-width: 640px; margin: 8px auto 0;
  align-items: center; font-size: 12px;
}
.ensaio-equip-label { font-weight: 600; }
.ensaio-equip-opt {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--text-sec); padding: 4px 10px; border: 1px solid var(--border);
  border-radius: 6px; cursor: pointer; background: #f8fafc;
}
.ensaio-equip-opt:hover { background: #f1f5f9; }
.ensaio-equip-text { gap: 8px; }
.ensaio-equip-text .ensaio-equip-label {
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px;
  font-size: 11px; color: var(--text);
}
.ensaio-equip-text input[type="text"] {
  flex: 1; min-width: 0; padding: 5px 8px;
  border: 1px solid var(--border); border-radius: 5px;
  font-size: 12px; font-family: inherit;
  background: #fffbeb; color: var(--text);
}
.ensaio-equip-text input[type="text"]:focus {
  outline: 2px solid var(--primary); outline-offset: -1px; background: var(--card);
}
.ensaio-equip-text input[type="text"][readonly],
.ensaio-equip-text input[type="text"][disabled] {
  background: var(--bg); color: var(--text-sec);
}
body.theme-dark .ensaio-table input[type="text"] { background: #2d3748; color: var(--text); }
body.theme-dark .ensaio-table .limit-cell { background: #2a3344; color: var(--text-sec); }
body.theme-dark .ensaio-table .limits-section-head td { background: #1f2937; color: var(--text-sec); }
body.theme-dark .ensaio-equip-opt { background: #1f2937; }
body.theme-dark .ensaio-equip-text input[type="text"] { background: #2d3748; }

.req {
  color: var(--danger);
  margin-left: 3px;
}

.field-input {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 15px;
  color: var(--text);
  background: var(--card);
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease;
  appearance: none;
}

.field-input:hover:not(:focus):not([readonly]) {
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
}

.field-input:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}

.field-input[readonly] {
  background: color-mix(in srgb, var(--bg) 70%, transparent);
  color: var(--text-sec);
  cursor: default;
}

.field-input.input-warn {
  border-color: var(--warn-border);
  background: var(--warn-bg);
}

.field-select {
  background-color: #fff;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'><path fill='%23616161' d='M7 10l5 5 5-5z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 32px;
}

.field-textarea {
  width: 100%;
  border: 1.5px solid #ccc;
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 14px;
  color: var(--text);
  background: #fff;
  font-family: inherit;
  resize: vertical;
  min-height: 100px;
  transition: border-color 0.2s;
}

.field-textarea:focus {
  border-color: var(--primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(21,101,192,0.12);
}

.limit-info {
  font-size: 12px;
  color: var(--primary);
  margin-bottom: 6px;
  font-weight: 500;
}

.computed-hint {
  font-size: 11px;
  color: var(--neutral);
  margin-top: 4px;
  font-style: italic;
}

/* =====================================================
   ALERTAS
   ===================================================== */
.alert {
  background: var(--warn-bg);
  border: 1px solid var(--warn-border);
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 13px;
  color: #f57f17;
  margin-top: 6px;
  font-weight: 500;
}

/* =====================================================
   RADIO GROUP
   ===================================================== */
.radio-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
}

/* Modo inline — label e opções na mesma linha */
.card.radio-inline-card {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.card.radio-inline-card .field-label {
  flex-shrink: 0;
  margin-bottom: 0;
}
.card.radio-inline-card .radio-group {
  flex: 1;
  display: flex;
  flex-direction: row;
  gap: 8px;
  margin-top: 0;
  min-width: 200px;
}
.card.radio-inline-card .radio-option {
  flex: 1;
  justify-content: center;
  padding: 10px 8px;
  font-weight: 600;
  text-align: center;
}

/* Modo grid — usado para opções curtas como Nº de Eixos */
.radio-group.radio-cols-2,
.radio-group.radio-cols-3,
.radio-group.radio-cols-4 {
  display: grid;
  gap: 8px;
}
.radio-group.radio-cols-2 { grid-template-columns: repeat(2, 1fr); }
.radio-group.radio-cols-3 { grid-template-columns: repeat(3, 1fr); }
.radio-group.radio-cols-4 { grid-template-columns: repeat(4, 1fr); }

.radio-group[class*="radio-cols-"] .radio-option {
  justify-content: center;
  padding: 10px 8px;
  font-weight: 600;
  text-align: center;
}

.radio-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
  font-size: 14px;
  line-height: 1.4;
}

.radio-option:hover {
  border-color: var(--primary-light);
  background: #e3f2fd;
}

.radio-option.radio-selected {
  border-color: var(--primary);
  background: #e3f2fd;
  font-weight: 600;
  color: var(--primary-dark);
}

.radio-option input[type="radio"] {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  accent-color: var(--primary);
  cursor: pointer;
}

/* =====================================================
   EQUIPAMENTOS
   ===================================================== */
.equip-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.equip-input {
  flex: 1;
  height: 38px;
  font-size: 13px;
}

.equip-cal {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
  color: var(--text-sec);
  font-weight: 500;
}

.equip-cal input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--primary);
  cursor: pointer;
}

/* =====================================================
   TABELAS DE INSPEÇÃO
   ===================================================== */
.table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-top: 8px;
}

.insp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  min-width: 300px;
}

/* Tabela de pneus (G0900) — 4 colunas: Pneu / Descrição / Sulco / Reforma.
   Larguras fixas para acomodar a coluna Descrição (texto livre) e estreitar
   Sulco para ~5 caracteres numéricos. */
.insp-table.pneus-table {
  table-layout: fixed;
}
.insp-table.pneus-table th:nth-child(1),
.insp-table.pneus-table td:nth-child(1) { width: 14%; }
.insp-table.pneus-table th:nth-child(2),
.insp-table.pneus-table td:nth-child(2) { width: 50%; }
.insp-table.pneus-table th:nth-child(3),
.insp-table.pneus-table td:nth-child(3) { width: 11%; }
.insp-table.pneus-table th:nth-child(4),
.insp-table.pneus-table td:nth-child(4) { width: 25%; }
.insp-table.pneus-table td:nth-child(3) input { text-align: center; padding: 5px 4px; }
/* O cabeçalho já mostra "Sulco (mm)" — esconde o badge mm dentro da célula
   pra não sobrepor o número quando ele tem 3+ dígitos na coluna estreita. */
.insp-table.pneus-table td:nth-child(3) .cell-unit { display: none !important; }
.insp-table.pneus-table td:nth-child(3) .cell-unit-wrap input { padding-right: 4px; }

.insp-table th {
  background: var(--primary);
  color: #fff;
  padding: 8px 6px;
  text-align: left;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}

.insp-table td {
  border: 1px solid var(--border);
  padding: 5px 6px;
  vertical-align: middle;
}

.insp-table td.row-header {
  background: #f5f5f5;
  font-weight: 600;
  font-size: 12px;
  color: var(--text-sec);
  white-space: nowrap;
}
.insp-table td.cell-readonly {
  background: #fafafa;
  font-size: 11px;
  color: var(--text-sec, #555);
  font-style: italic;
  padding: 6px 10px;
  text-align: center;
}
body.theme-dark .insp-table td.cell-readonly {
  background: #232936;
  color: #9aa4b2;
}

/* cellPrefix: rótulo (ex: "C", "D") encostado à esquerda do input. */
.insp-table .cell-prefix-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
}
.insp-table .cell-prefix-wrap > .cell-unit-wrap,
.insp-table .cell-prefix-wrap > input {
  flex: 1 1 auto;
  min-width: 0;
}
.insp-table .cell-prefix {
  flex: 0 0 auto;
  font-weight: 700;
  font-size: 12px;
  color: #111;
  min-width: 14px;
  text-align: center;
}
body.theme-dark .insp-table .cell-prefix { color: #e5e7eb; }

/* autoDiff: célula calculada (DIFERENÇA |esq − dir|). */
.insp-table td.cell-auto-diff {
  font-style: normal;
  font-weight: 600;
  color: #15803d;
  background: #f0fdf4;
}
.insp-table td.cell-auto-diff.cell-out-of-limit {
  color: #b91c1c;
  background: #fef2f2;
}
body.theme-dark .insp-table td.cell-auto-diff {
  background: #14302a;
  color: #6ee7b7;
}
body.theme-dark .insp-table td.cell-auto-diff.cell-out-of-limit {
  background: #3a1c1c;
  color: #fca5a5;
}

/* Botão "APROVAR TODOS" — aparece em steps com approveAllButton: true */
.approve-all-bar {
  display: flex;
  justify-content: flex-end;
  margin: 8px 0 14px;
}
.btn-approve-all {
  background: #2e7d32;
  color: #fff;
  border: none;
  padding: 10px 22px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  box-shadow: 0 2px 6px rgba(46, 125, 50, 0.3);
}
.btn-approve-all:hover {
  background: #1b5e20;
  transform: translateY(-1px);
}
.btn-approve-all:active { transform: translateY(0); }
body.theme-dark .btn-approve-all {
  background: #388e3c;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
}
body.theme-dark .btn-approve-all:hover { background: #2e7d32; }

.insp-table input {
  width: 100%;
  border: none;
  background: transparent;
  padding: 3px 4px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text);
}

.insp-table input:focus {
  outline: 1px solid var(--primary);
  border-radius: 3px;
}

.insp-table input.input-warn {
  background: #ffebee;
  color: var(--danger);
  font-weight: 700;
  border: 1.5px solid var(--danger);
}

/* =====================================================
   TELA HOME
   ===================================================== */
.home-screen {
  padding-bottom: 40px;
}

/* ═══════════════ LAYOUT HOME: TOPBAR + SIDEBAR + CONTEÚDO ═══════════════ */
.home-layout {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--bg);
}

/* Barra superior · V128 painel-faithful (mockup minimalista — borda sutil, tipografia compacta) */
.home-topbar {
  height: 60px;
  background: var(--card);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
}
.topbar-brand {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px; font-weight: 600;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0 6px;
  border-radius: 6px;
  color: inherit;
  letter-spacing: -0.01em;
  transition: background var(--t-fast);
}
.topbar-brand:hover { background: var(--gray-100); }
body.theme-dark .topbar-brand:hover { background: rgba(255,255,255,0.08); }
.topbar-brand .brand-icon {
  color: var(--text); font-size: 20px;
}
.topbar-brand .brand-name {
  color: var(--text); letter-spacing: -0.01em;
}
.topbar-right {
  display: flex; align-items: center; gap: 10px;
}
.topbar-user {
  font-size: 13px; color: var(--gray-600); font-weight: 500;
  letter-spacing: -0.005em;
}
.topbar-user strong { color: var(--text); font-weight: 600; }
.topbar-user-tipo { color: var(--gray-500); font-weight: 500; font-size: 11px; }

/* Nome do usuário como botão clicável (sai ao clicar) */
.topbar-user-btn {
  background: transparent;
  border: 1px solid transparent;
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.topbar-user-btn:hover {
  background: rgba(198, 40, 40, 0.08);
  border-color: rgba(198, 40, 40, 0.3);
}
.topbar-user-btn:hover strong { color: var(--danger); }
body.theme-dark .topbar-user-btn:hover {
  background: rgba(198, 40, 40, 0.15);
  border-color: rgba(198, 40, 40, 0.4);
}

/* ═══════════════ TELA DE LOGIN · V121 minimalist (Three.js + glass) ═══════════════
   Estrutura: split 50/50 desktop · branding overlay esquerdo · glass panel direito
   Mobile: stack vertical 32vh top + 68vh glass; gradient border vira horizontal.
   Dark-first (sempre dark, ignora theme-dark/light no body). */

.login-screen {
  position: fixed; inset: 0;
  background: var(--bg-deep);
  color: #FFFFFF;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  overflow: hidden;
  z-index: 1;
}

/* L0 · Poster fallback (V11: gradients branco neutro · sempre renderiza) */
.login-poster {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(255, 255, 255, 0.06) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(255, 255, 255, 0.04) 0%, transparent 50%),
    linear-gradient(180deg, var(--bg-deep) 0%, var(--bg-mid) 100%);
  pointer-events: none;
}

/* L1 · Three.js volumétrico */
.login-screen #three-canvas {
  position: absolute; inset: 0; z-index: 1;
  width: 100%; height: 100%;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1500ms var(--ease);
}
.login-screen #three-canvas.is-ready { opacity: 1; }

/* L2 · WebGL dot-matrix (canvas 2D) */
.login-screen #dots-canvas {
  position: absolute; inset: 0; z-index: 2;
  width: 100%; height: 100%;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0;
  transition: opacity 2000ms var(--ease) 400ms;
}
.login-screen #dots-canvas.is-ready { opacity: 0.65; }

/* L3 · Vinheta + grid (V11: "Grid: Strong" NeuroSync — pretos puros sem cast azul) */
.login-vignette {
  position: absolute; inset: 0; z-index: 3;
  pointer-events: none;
  background:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px) 0 0 / 100% 80px,
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px) 0 0 / 80px 100%,
    radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,0.55) 100%);
}

/* L4 · Stage UI · split 50/50 */
.login-stage {
  position: relative; z-index: 4;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

/* ─── LEFT · branding ─── */
.login-left {
  padding: 56px 48px 40px;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative;
  overflow: hidden;
}

.login-brand {
  display: flex; align-items: center; gap: 14px;
  opacity: 0;
  animation: loginRevealUp 800ms var(--ease) 100ms forwards;
}
.login-brand-mark {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(255,255,255,0.95); color: var(--bg-deep);
  display: grid; place-items: center;
  font-weight: 800; font-size: 15px;
  letter-spacing: -0.04em;
  box-shadow: 0 4px 14px rgba(0,0,0,0.25);
  overflow: hidden;
  position: relative;
}
.login-brand-mark img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
}
.login-brand-name {
  font-size: 14px; font-weight: 600; letter-spacing: -0.01em; color: #FFFFFF;
  line-height: 1.15;
}
.login-brand-name small {
  display: block;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px; color: var(--gray-500);
  font-weight: 400;
  margin-top: 2px;
  letter-spacing: 0.04em;
}

.login-statement {
  max-width: 540px;
}
/* V11 · eyebrow como chip glass com texto cinza, dot branco pulsando */
.login-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--gray-300);
  text-transform: uppercase;
  padding: 6px 12px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.02);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  margin-bottom: 24px;
  opacity: 0;
  animation: loginRevealUp 800ms var(--ease) 200ms forwards;
}
.login-eyebrow::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--phosphor);
  box-shadow: 0 0 8px var(--phosphor);
  animation: loginPulseDot 2.4s ease-in-out infinite;
}
@keyframes loginPulseDot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%      { opacity: 0.5; transform: scale(1.3); }
}

/* V11 · Display lg: Inter 60/600/-0.05em (NeuroSync display-lg) */
.login-h1 {
  font-size: clamp(40px, 5vw, 60px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.05em;
  margin: 0 0 24px;
  color: #FFFFFF;
  opacity: 0;
  animation: loginRevealUp 1000ms var(--ease) 350ms forwards;
}
/* V11 · accent é grayscale puro (white → gray-400), NÃO azul */
.login-h1 .login-h1-accent {
  color: transparent;
  background: linear-gradient(135deg, #FFFFFF 0%, var(--gray-400) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  font-weight: 700;
}
/* V11 · mono-tag é chip pequeno bordado (não texto solto) */
.login-h1 .login-h1-mono {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-weight: 500;
  color: var(--gray-300);
  font-size: 0.6em;
  letter-spacing: 0.04em;
  vertical-align: 0.16em;
  padding: 0 6px;
  border: 1px solid var(--gray-500);
  margin: 0 4px;
}

.login-lead {
  font-size: 14px;
  font-weight: 400;
  color: var(--gray-300);
  line-height: 20px;
  max-width: 480px;
  margin: 0 0 32px;
  opacity: 0;
  animation: loginRevealUp 1000ms var(--ease) 500ms forwards;
}

/* V11 · Telemetry como grid panel 4-col com backdrop-blur (Grid: Strong NeuroSync) */
.login-telemetry {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  opacity: 0;
  animation: loginRevealUp 1000ms var(--ease) 700ms forwards;
}
.login-telemetry__col {
  padding: 16px 20px;
  border-right: 1px solid rgba(255,255,255,0.08);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.login-telemetry__col:last-child { border-right: 0; }
.login-telemetry__lbl {
  display: block;
  font-size: 10px;
  color: var(--gray-500);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.login-telemetry__val {
  display: block;
  font-size: 18px;
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: -0.02em;
  line-height: 1;
}
/* Online em verde phosphor (hardcoded #10B981) · breathing 3.6s + halo */
.login-telemetry__val.is-live {
  color: #10B981;
  animation: loginBreathText 3.6s ease-in-out infinite;
}
.login-telemetry__val.is-live::before {
  content: '';
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #10B981;
  margin-right: 7px;
  vertical-align: 1px;
  box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.55);
  animation: loginBreathDot 3.6s ease-in-out infinite;
}
@keyframes loginBreathText {
  0%, 100% { opacity: 1.0; }
  50%      { opacity: 0.55; }
}
@keyframes loginBreathDot {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(16, 185, 129, 0), 0 0 4px 0 rgba(16, 185, 129, 0.35);
  }
  50% {
    transform: scale(1.15);
    box-shadow: 0 0 0 8px rgba(16, 185, 129, 0), 0 0 12px 2px rgba(16, 185, 129, 0.65);
  }
}

.login-foot {
  display: flex; align-items: center; gap: 16px;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px;
  color: var(--gray-500);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 18px;
  opacity: 0;
  animation: loginRevealUp 1000ms var(--ease) 850ms forwards;
}

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

/* ─── RIGHT · glass panel inteiro ─── */
.login-right {
  padding: 56px 48px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  box-shadow:
    rgba(255, 255, 255, 0.06) 0px 0px 0px 1px inset,
    rgba(0, 0, 0, 0.35)       -18px 0px 40px -12px,
    rgba(25, 28, 33, 0.40)    -6px 0px 16px -8px;
  overflow: hidden;
}

/* Gradient border shell — linha vertical 1px na borda esquerda (recipe NeuroSync literal) */
.login-right::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0; left: 0;
  width: 1px;
  background: linear-gradient(
    to top,
    rgb(9, 9, 11),
    rgba(9, 9, 11, 0.6),
    rgba(255, 255, 255, 0.10)
  );
  z-index: 5;
  pointer-events: none;
}

/* Halo radial branco bem sutil — luz suave puxando o olho pro form */
.login-right::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 720px; height: 720px;
  background: radial-gradient(circle,
    rgba(255,255,255,0.04) 0%,
    rgba(255,255,255,0.02) 30%,
    transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.login-form-wrap {
  width: 100%; max-width: 420px;
  position: relative; z-index: 1;
  opacity: 0;
  transform: translateY(16px);
  animation: loginRevealUp 1100ms var(--ease) 600ms forwards;
}

.login-head { margin-bottom: 24px; display: flex; align-items: flex-end; justify-content: space-between; gap: 12px; }
.login-head h2 {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.025em;
  margin: 0 0 6px;
  color: #FFFFFF;
  line-height: 1.1;
}
.login-head p {
  font-size: 14px;
  color: var(--gray-300);
  margin: 0;
}
.login-head__live {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10px;
  font-family: 'JetBrains Mono', monospace;
  color: var(--phosphor);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding-bottom: 4px;
  flex-shrink: 0;
  animation: loginBreathText 3.6s ease-in-out infinite;
}
.login-head__live::before {
  content: '';
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--phosphor);
  animation: loginBreathDot 3.6s ease-in-out infinite;
}

.login-field {
  margin-bottom: 14px; position: relative;
  display: block;
}
.login-field label {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11.5px; font-weight: 600;
  color: var(--gray-300);
  margin-bottom: 7px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.login-field label .hint {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 10px;
  text-transform: none;
  letter-spacing: 0;
  color: var(--gray-500);
  font-weight: 400;
}

.login-input-wrap { position: relative; }
.login-field input.field-input {
  width: 100%;
  height: auto;
  padding: 12px 14px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 6px;
  font-family: 'Inter', inherit;
  font-size: 16px; /* base 16 evita zoom iOS */
  color: #FFFFFF;
  background: rgba(0, 0, 0, 0.30);
  transition: var(--t-base);
  outline: none;
  letter-spacing: -0.005em;
}
.login-field input.field-input::placeholder { color: var(--gray-500); }
.login-field input.field-input:hover {
  border-color: rgba(255,255,255,0.20);
  background: rgba(0, 0, 0, 0.40);
}
.login-field input.field-input:focus {
  border-color: var(--primary);
  background: rgba(0, 0, 0, 0.45);
  box-shadow: 0 0 0 3px var(--primary-soft), 0 0 22px var(--primary-glow);
}
.login-field-pass { padding-right: 44px; }

.login-pass-toggle {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px;
  border: 0; background: transparent;
  cursor: pointer;
  color: var(--gray-500);
  border-radius: 4px;
  transition: var(--t-fast);
  display: grid; place-items: center;
}
.login-pass-toggle:hover { background: rgba(255,255,255,0.06); color: #FFFFFF; }
.login-pass-toggle svg { width: 18px; height: 18px; }

.login-row-options {
  display: flex; align-items: center; justify-content: space-between;
  margin: 6px 0 18px;
  font-size: 12.5px;
}
.login-row-options label {
  display: inline-flex; align-items: center; gap: 7px;
  color: var(--gray-300);
  cursor: pointer;
  user-select: none;
  transition: color var(--t-fast);
  font-size: 12.5px;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
  margin-bottom: 0;
}
.login-row-options label:hover { color: #FFFFFF; }
.login-row-options input[type="checkbox"] {
  width: 14px; height: 14px;
  accent-color: var(--gray-200);
  cursor: pointer;
}
.login-row-options a {
  color: #93C5FD;
  text-decoration: none;
  font-weight: 500;
  transition: var(--t-fast);
}
.login-row-options a:hover { color: #BFDBFE; text-shadow: 0 0 8px var(--primary-glow); }

.login-submit {
  width: 100%;
  padding: 13px 18px;
  background: rgba(255,255,255,0.95);
  color: var(--bg-deep);
  border: 0;
  border-radius: 6px;
  font-family: 'Inter', inherit;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: var(--t-base);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  letter-spacing: -0.005em;
  box-shadow: 0 6px 20px rgba(255,255,255,0.10), 0 0 0 1px rgba(255,255,255,0.08) inset;
  position: relative;
  overflow: hidden;
  height: auto;
  margin-top: 0;
  text-transform: none;
}
.login-submit::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--primary) 0%, #1E40AF 100%);
  opacity: 0;
  transition: opacity var(--t-base);
}
.login-submit > * { position: relative; z-index: 1; transition: var(--t-base); }
.login-submit:hover {
  background: #fff;
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(255,255,255,0.18), 0 0 0 1px rgba(37,99,235,0.4) inset;
  color: #fff;
}
.login-submit:hover::after { opacity: 1; }
.login-submit:active { transform: translateY(0); }
.login-submit:disabled { opacity: 0.55; cursor: not-allowed; }
.login-submit svg { width: 16px; height: 16px; transition: transform var(--t-base); }
.login-submit:hover svg { transform: translateX(4px); }

.login-error {
  margin-top: 14px;
  padding: 10px 12px;
  background: rgba(220, 38, 38, 0.18);
  color: #FCA5A5;
  border-radius: 6px;
  font-size: 12.5px;
  font-weight: 500;
  border-left: 2px solid #DC2626;
  display: none;
  align-items: center; gap: 8px;
  text-align: left;
  min-height: auto;
}
.login-error.is-shown { display: flex; }
.login-error svg { width: 14px; height: 14px; flex-shrink: 0; }

.login-footer {
  margin-top: 28px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  font-size: 12.5px;
  text-align: left;
}
.login-footer a {
  color: var(--gray-300);
  text-decoration: none;
  font-weight: 500;
  transition: var(--t-fast);
  font-size: 12.5px;
}
.login-footer a:hover { color: #FFFFFF; }

.login-theme-btn {
  width: 32px; height: 32px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
  border-radius: 50%;
  cursor: pointer;
  display: grid; place-items: center;
  color: var(--gray-300);
  transition: var(--t-base);
  font-size: 14px;
  flex-shrink: 0;
}
.login-theme-btn:hover {
  background: rgba(255,255,255,0.08);
  color: #FFFFFF;
  border-color: rgba(255,255,255,0.20);
}
.login-theme-btn svg { width: 14px; height: 14px; }

/* ─── Mobile · stack vertical 32vh top + 68vh glass ─── */
@media (max-width: 720px) {
  .login-stage {
    grid-template-columns: 1fr;
    grid-template-rows: 32vh 1fr;
  }
  .login-left {
    padding: 40px 24px 18px;
    gap: 16px;
    min-height: 0;
  }
  .login-brand-mark { width: 38px; height: 38px; font-size: 13px; border-radius: 11px; }
  .login-brand-name { font-size: 13px; }
  .login-brand-name small { font-size: 10px; }
  .login-h1 { font-size: 26px; line-height: 1.05; margin-bottom: 0; }
  .login-lead { display: none; }
  .login-telemetry { gap: 16px; flex-wrap: wrap; }
  .login-telemetry__lbl { font-size: 9px; }
  .login-telemetry__val { font-size: 12px; }
  .login-foot { font-size: 9px; padding-top: 12px; gap: 10px; }

  .login-right {
    padding: 24px 22px calc(20px + env(safe-area-inset-bottom, 0));
    align-items: flex-start;
    box-shadow:
      rgba(255, 255, 255, 0.06) 0px 0px 0px 1px inset,
      rgba(0, 0, 0, 0.35)       0px -18px 40px -12px,
      rgba(25, 28, 33, 0.40)    0px -6px 16px -8px;
  }
  /* Gradient border vira HORIZONTAL no topo */
  .login-right::before {
    top: 0; left: 0; right: 0; bottom: auto;
    width: 100%; height: 1px;
    background: linear-gradient(
      to right,
      rgba(255, 255, 255, 0.10),
      rgba(9, 9, 11, 0.6),
      rgb(9, 9, 11),
      rgba(9, 9, 11, 0.6),
      rgba(255, 255, 255, 0.10)
    );
  }
  .login-right::after {
    width: 480px; height: 480px;
  }
  .login-form-wrap { max-width: none; }
  .login-head h2 { font-size: 22px; }
  .login-field input.field-input { height: 48px; padding: 0 14px; }
  .login-pass-toggle { width: 36px; height: 36px; }
  .login-submit { padding: 14px 18px; height: 50px; }
  .login-footer { margin-top: 20px; padding-top: 14px; }
}

/* Reduced motion: desliga revealUp + breathing + pulseDot */
@media (prefers-reduced-motion: reduce) {
  .login-screen *,
  .login-screen *::before,
  .login-screen *::after {
    animation: none !important;
    transition: none !important;
  }
  .login-eyebrow,
  .login-h1,
  .login-lead,
  .login-telemetry,
  .login-brand,
  .login-foot,
  .login-form-wrap {
    opacity: 1 !important;
    transform: none !important;
  }
}

body.theme-dark .home-layout { background: #0f0f0f; }
body.theme-dark .home-topbar { background: #1a1a1a; border-bottom-color: #2a2a2a; }
body.theme-dark .topbar-brand .brand-name { color: #e8e8e8; }
body.theme-dark .topbar-user { color: #cacaca; }
body.theme-dark .topbar-user strong { color: #fff; }

/* ═══════════════ CAMPO NÃO PREENCHIDO PÓS-LOOKUP (V49) ═══════════════
   Após consulta IBRASCAN+WDAPI2, fields da tela de Identificação que
   ficaram vazios recebem essa classe — borda laranja chama atenção pro
   inspetor que precisa preencher manualmente. Auto-remove quando o
   usuário digita/seleciona algo. */
.card.card-needs-fill {
  border: 2px solid #f97316;
  background: #fff7ed;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.15);
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.card.card-needs-fill .field-label {
  color: #c2410c;
  font-weight: 700;
}
body.theme-dark .card.card-needs-fill {
  background: #2d1b0a;
  border-color: #fb923c;
}
body.theme-dark .card.card-needs-fill .field-label {
  color: #fdba74;
}

/* ═══════════════ IDENTIDADE VISUAL (V45+) ═══════════════
   Logo da empresa em diversos slots. Tamanhos por contexto;
   imagens preservam aspect-ratio via object-fit: contain.
   Quando há logo atribuída, .brand-name-secondary diminui o
   texto "O.S. MASTER" pra dar protagonismo à marca. */
.brand-logo {
  display: inline-block;
  vertical-align: middle;
  object-fit: contain;
  background: transparent;
}
.brand-logo-topbar       { height: 60px; max-width: 280px; }   /* V46.2: altura máxima = 60px (= altura da topbar) */
.brand-logo-login        { height: 120px; max-width: 320px; margin: 0 auto 6px; display: block; }   /* V47: logo maior na tela de login */
.brand-logo-pdf          { height: 50px; max-width: 200px; }
.brand-logo-agendamento  { height: 60px; max-width: 220px; }
.brand-logo-inline       { height: 18px; max-width: 80px; }
.brand-logo-config-tab   { height: 18px; max-width: 28px; }   /* tabs internas (Configurações, Regras...) */

/* Estilos default do nome (quando NÃO há logo — equivale ao texto em destaque legado) */
.brand-name-topbar {
  font-size: 22px;
  font-weight: 700;
  color: #333;
  letter-spacing: 0.5px;
}
body.theme-dark .brand-name-topbar { color: #e8e8e8; }
.brand-name-login {
  font-size: 28px;
  font-weight: 800;
  color: var(--primary-dark);
  letter-spacing: 1.5px;
  display: block;
  text-align: center;
  margin: 0;
}
body.theme-dark .brand-name-login { color: #80b9f5; }
.brand-name-pdf          { font-size: 14px; font-weight: 700; }
.brand-name-agendamento  { font-size: 16px; font-weight: 700; color: var(--primary-dark); }
.brand-name-inline       { font-size: 12px; font-weight: 600; color: inherit; }
.brand-name-config-tab   { font-size: 13px; font-weight: 600; }

/* Texto reduzido ao lado da logo (Regra #3 do dono: "deverá diminuir
   consideravelmente, principalmente na tela home e de LOGIN") */
.brand-name-secondary {
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #94a3b8 !important;
  letter-spacing: 0.4px !important;
  margin-left: 8px;
}
.brand-name-login.brand-name-secondary {
  font-size: 13px !important;
  display: block;
  text-align: center;
  margin: 0;
}
body.theme-dark .brand-name-secondary { color: #64748b !important; }

/* Fallback ⚙ — preserva tamanho proporcional ao slot */
.brand-icon-topbar       { font-size: 24px; }
.brand-icon-login        { font-size: 52px; display: block; margin-bottom: 8px; color: var(--primary); }
.brand-icon-pdf          { font-size: 28px; }
.brand-icon-agendamento  { font-size: 36px; }
.brand-icon-inline       { font-size: 14px; }
.brand-icon-config-tab   { font-size: 13px; }

/* ─── Tela de gestão (Configurações > Geral > Identidade Visual) ─── */
.logo-lib-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 6px;
}
.logo-card {
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 12px 10px 8px;
  background: #fff;
  text-align: center;
  position: relative;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.logo-card:hover {
  border-color: var(--primary);
  box-shadow: 0 2px 8px rgba(37,99,235,0.08);
}
.logo-card-thumb {
  height: 80px;
  background:
    linear-gradient(45deg, #f3f4f6 25%, transparent 25%),
    linear-gradient(-45deg, #f3f4f6 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, #f3f4f6 75%),
    linear-gradient(-45deg, transparent 75%, #f3f4f6 75%);
  background-size: 12px 12px;
  background-position: 0 0, 0 6px, 6px -6px, -6px 0;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 8px;
  overflow: hidden;
}
.logo-card-thumb img {
  max-height: 70px;
  max-width: 90%;
  object-fit: contain;
}
.logo-card-name {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.logo-card-meta {
  font-size: 10px;
  color: var(--text-sec, #64748b);
  margin-bottom: 8px;
}
.logo-card-actions {
  display: flex; gap: 6px; justify-content: center;
}
.logo-card-actions button {
  border: 1px solid var(--border, #e2e8f0);
  background: #fff;
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 12px;
  cursor: pointer;
  color: var(--text-sec, #64748b);
}
.logo-card-actions button:hover { border-color: var(--primary); color: var(--primary); }
.logo-card-actions button.btn-delete:hover { border-color: var(--danger); color: var(--danger); }
body.theme-dark .logo-card { background: #1e1e1e; border-color: #333; }
body.theme-dark .logo-card-actions button { background: #2a2a2a; border-color: #444; color: var(--text); }

.logo-lib-add {
  border: 2px dashed var(--border, #e2e8f0);
  border-radius: 10px;
  padding: 14px;
  background: #fafbfc;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--text-sec, #64748b);
  min-height: 162px;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  font-family: inherit;
}
.logo-lib-add:hover {
  border-color: var(--primary);
  background: #eff6ff;
  color: var(--primary);
}
body.theme-dark .logo-lib-add { background: #1a1a1a; border-color: #444; }
body.theme-dark .logo-lib-add:hover { background: #1a2540; }

.logo-slot-list {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: 6px;
}
.logo-slot-row {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 14px;
  align-items: center;
  padding: 10px 14px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 8px;
  background: #fff;
}
.logo-slot-row:hover { border-color: var(--primary); }
.logo-slot-info { display: flex; flex-direction: column; gap: 2px; }
.logo-slot-label { font-size: 13px; font-weight: 600; }
.logo-slot-desc { font-size: 11px; color: var(--text-sec, #64748b); }
.logo-slot-select {
  width: 100%;
  padding: 7px 10px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 6px;
  background: #fff;
  font-size: 13px;
  cursor: pointer;
  color: var(--text);
}
body.theme-dark .logo-slot-row { background: #1e1e1e; border-color: #333; }
body.theme-dark .logo-slot-select { background: #2a2a2a; border-color: #444; color: var(--text); }

.logo-name-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 10px 14px;
  align-items: center;
  padding: 14px;
  background: #f9fafb;
  border-radius: 8px;
  margin-top: 14px;
}
.logo-name-row > span { grid-column: 2; }
.logo-name-input {
  padding: 8px 12px;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 6px;
  font-size: 14px;
  width: 100%;
  font-family: inherit;
}
body.theme-dark .logo-name-row { background: #1a1a1a; }
body.theme-dark .logo-name-input { background: #2a2a2a; border-color: #444; color: var(--text); }

@media (max-width: 720px) {
  .logo-slot-row { grid-template-columns: 1fr; }
  .logo-name-row { grid-template-columns: 1fr; }
  .logo-name-row > span { grid-column: 1; }
}

/* Corpo: sidebar + conteúdo · V128 painel-faithful
   (mockup: sidebar light, nav-item ativo em var(--text) preto puro com texto branco;
    tipografia compacta, hover em gray-100, ícones em gray-500) */
.home-body {
  flex: 1;
  display: flex;
  min-height: 0;
}
.home-sidebar {
  width: 240px;
  background: var(--card);
  border-right: 1px solid var(--border);
  padding: 20px 14px;
  display: flex; flex-direction: column; gap: 1px;
  flex-shrink: 0;
}
.side-menu-item {
  display: flex; align-items: center; gap: 10px;
  background: none; border: none;
  color: var(--gray-600);
  padding: 8px 10px;
  cursor: pointer;
  font-size: 14px; font-weight: 500;
  text-align: left;
  transition: background var(--t-fast), color var(--t-fast);
  border-radius: 6px;
  border-left: 0;
  letter-spacing: -0.005em;
}
.side-menu-item:hover {
  background: var(--gray-100);
  color: var(--text);
}
.side-menu-item.active {
  background: var(--text);
  color: #fff;
}
.side-menu-item.active .side-menu-icon { color: #fff; }
.side-menu-icon {
  width: 20px; text-align: center; font-size: 15px;
  color: var(--gray-500);
  transition: color var(--t-fast);
  flex-shrink: 0;
}
.side-menu-item:hover .side-menu-icon { color: var(--text); }
.side-menu-label { flex: 1; }

/* Tema dark · sidebar volta pra dark com textos claros */
body.theme-dark .home-sidebar {
  background: var(--card);
  border-right-color: var(--border);
}
body.theme-dark .side-menu-item { color: var(--text-sec); }
body.theme-dark .side-menu-item:hover {
  background: rgba(255,255,255,0.06);
  color: var(--text);
}
body.theme-dark .side-menu-item.active {
  background: var(--primary);
  color: #fff;
}
body.theme-dark .side-menu-item.active .side-menu-icon { color: #fff; }
body.theme-dark .side-menu-icon { color: var(--text-sec); }

/* Conteúdo principal · V128 painel-faithful (whitespace mockup-style) */
.home-content {
  flex: 1;
  padding: 32px 40px 64px;
  overflow-y: auto;
  max-width: 100%;
}
.section-title-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 24px; gap: 12px; flex-wrap: wrap;
}
.section-title-bar h2 {
  font-size: 24px; color: var(--text); font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0;
}
.filter-active-chip {
  background: var(--primary);
  color: #fff;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
}

/* Badge "REINSPEÇÃO" — destaca inspeções reavaliadas */
.badge-reinspecao {
  background: #ffa000;
  color: #fff;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-left: 8px;
  display: inline-block;
}
.reinsp-candidate { border-left: 4px solid var(--danger); }

/* Título "GERENCIAL" — caixa alta + maior */
.gerencial-title {
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 26px;
  font-weight: 700;
}

/* TE — Tempo de Execução (sub-aba Gerencial) */
.te-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}
.te-card {
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e0e0e0);
  border-radius: 8px;
  padding: 12px 14px;
  cursor: pointer;
  transition: box-shadow 0.15s, transform 0.15s;
}
.te-card:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  transform: translateY(-1px);
}
.te-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.te-row-top   { margin-bottom: 6px; }
.te-row-bottom {
  font-size: 13px;
}
.te-top-right {
  display: flex;
  gap: 22px;
  align-items: center;
  font-size: 13px;
  color: var(--text-muted, #666);
}
.te-placa {
  font-weight: 700;
  font-size: 15px;
  color: var(--primary, #1976d2);
  letter-spacing: 0.5px;
}
.te-data {
  font-size: 13px;
  color: #2e7d32;
}
.te-value {
  color: var(--primary, #1976d2);
  font-size: 14px;
}
.te-value strong { color: var(--primary, #1976d2); }

/* Chips multi-seleção (Inspetor · Serviço) */
.te-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.te-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border: 1px solid var(--border, #ccc);
  border-radius: 999px;
  font-size: 13px;
  cursor: pointer;
  background: #fff;
  user-select: none;
  transition: all 0.15s;
}
.te-chip input { display: none; }
.te-chip:hover { border-color: var(--primary, #1976d2); }
.te-chip.active {
  background: var(--primary, #1976d2);
  color: #fff;
  border-color: var(--primary, #1976d2);
}
.te-chip code {
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-weight: 600;
}
.te-empty-opts {
  font-size: 12px;
  color: var(--text-muted, #888);
  font-style: italic;
}

/* Modal "- NOVA INSPEÇÃO -" */
.new-insp-panel {
  max-width: 720px;
  width: calc(100% - 40px);
}
.new-insp-panel .help-modal-header {
  justify-content: center;
  font-weight: 700;
  letter-spacing: 2px;
  font-size: 16px;
}
.new-insp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 4px;
}
.new-insp-field { display: flex; flex-direction: column; gap: 6px; }
.new-insp-label {
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.5px;
  color: var(--primary, #1976d2);
  text-transform: uppercase;
}
.new-insp-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 22px;
  padding-top: 14px;
  border-top: 1px solid var(--border, #e0e0e0);
}
@media (max-width: 600px) {
  .new-insp-grid { grid-template-columns: 1fr; }
}

/* ─── Lista FIFO de pré-agendados dentro do modal Nova Inspeção (V44) ───
   Aparece embaixo dos selects/botões; cada linha é um botão clicável que
   marca o pré como "pendente" e re-abre o modal já com banner azul. */
.preagend-divider {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 22px 0 14px;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.preagend-divider::before,
.preagend-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #cbd5e1;
}
body.theme-dark .preagend-divider { color: #94a3b8; }
body.theme-dark .preagend-divider::before,
body.theme-dark .preagend-divider::after { background: #334155; }

.preagend-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 18px 0 6px;
  flex-wrap: wrap;
  gap: 8px;
}
.preagend-section-title h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  color: #0f172a;
}
body.theme-dark .preagend-section-title h4 { color: #f1f5f9; }
.preagend-section-title .order-hint {
  font-size: 11px;
  color: #64748b;
  font-weight: 500;
  font-style: italic;
  margin-left: 6px;
}
body.theme-dark .preagend-section-title .order-hint { color: #94a3b8; }
.preagend-section-title .count-pill {
  background: #1565c0;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 12px;
  letter-spacing: 0.5px;
}

.preagend-pick-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-height: 280px;
  overflow-y: auto;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f8fafc;
  padding: 6px;
}
body.theme-dark .preagend-pick-list { background: #0f172a; border-color: #334155; }

.preagend-pick-row {
  display: grid;
  grid-template-columns: 60px 1fr auto auto;
  gap: 12px;
  align-items: center;
  padding: 10px 12px;
  background: #fff;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.12s;
  text-align: left;
  font-family: inherit;
}
body.theme-dark .preagend-pick-row { background: #1e293b; }
.preagend-pick-row:hover {
  border-color: #1565c0;
  background: #eff6ff;
  transform: translateX(2px);
}
body.theme-dark .preagend-pick-row:hover { background: #1e3a5f; }

.preagend-pick-row .pp-proto {
  font-weight: 700;
  font-size: 16px;
  color: #1565c0;
  letter-spacing: 0.5px;
  background: #e3f2fd;
  padding: 4px 8px;
  border-radius: 5px;
  text-align: center;
}
body.theme-dark .preagend-pick-row .pp-proto { background: #1e3a5f; color: #93c5fd; }

.preagend-pick-row .pp-info { line-height: 1.3; min-width: 0; }
.preagend-pick-row .pp-info strong {
  color: #0A4D8C;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
body.theme-dark .preagend-pick-row .pp-info strong { color: #93c5fd; }
.preagend-pick-row .pp-info small {
  display: block;
  color: #64748b;
  font-size: 12px;
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
body.theme-dark .preagend-pick-row .pp-info small { color: #94a3b8; }
.preagend-pick-row .pp-info small .pp-placa-inline {
  font-family: 'Courier New', monospace;
  font-weight: 700;
  letter-spacing: 1.2px;
  color: #0f172a;
}
body.theme-dark .preagend-pick-row .pp-info small .pp-placa-inline { color: #f1f5f9; }

.preagend-pick-row .pp-wa {
  font-size: 13px;
  width: 24px; height: 24px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.preagend-pick-row .pp-wa.ok { background: #dcfce7; color: #15803d; }
.preagend-pick-row .pp-wa.pending { background: #f1f5f9; color: #94a3b8; }
body.theme-dark .preagend-pick-row .pp-wa.ok { background: #14532d; color: #bbf7d0; }
body.theme-dark .preagend-pick-row .pp-wa.pending { background: #334155; color: #94a3b8; }

.preagend-pick-row .pp-age {
  font-size: 11.5px;
  color: #64748b;
  white-space: nowrap;
  font-weight: 600;
}
body.theme-dark .preagend-pick-row .pp-age { color: #94a3b8; }

.preagend-pick-help {
  margin: 10px 0 0;
  font-size: 11.5px;
  color: #94a3b8;
  text-align: center;
}

/* Estado vazio: aparece logo abaixo do título "Aguardando atendimento"
   quando não há nenhum pré-agendamento na fila. */
.preagend-pick-empty {
  padding: 22px;
  text-align: center;
  color: #94a3b8;
  font-size: 13px;
  background: #f8fafc;
  border: 1px dashed #cbd5e1;
  border-radius: 8px;
}
body.theme-dark .preagend-pick-empty {
  background: #0f172a;
  border-color: #334155;
  color: #64748b;
}

/* Tag de Reinspecionado (R em círculo + data) — aparece ao lado do REPROVADO */
.badge-group {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.tag-reinspected {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.r-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  font-weight: 900;
  font-size: 18px;
  letter-spacing: 0;
  line-height: 1;
  box-shadow: 0 1px 3px rgba(21,101,192,0.4);
}
body.theme-dark .r-circle { background: #1976D2; box-shadow: 0 0 6px rgba(128,185,245,0.5); }
.r-date {
  color: #999;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.2px;
}
body.theme-dark .r-date { color: #808080; }

/* Placa + Status em duas colunas na mesma linha */
.filter-placa-status .placa-status-row {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  flex-wrap: wrap;
}
.filter-placa-status .placa-col {
  flex: 0 0 220px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.filter-placa-status .status-col {
  flex: 1;
  min-width: 260px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Chips de status (O.S. Em Andamento / Aprovada / Reprovada) */
.status-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.status-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border: 1.5px solid var(--border);
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-sec);
  cursor: pointer;
  transition: all 0.15s;
  user-select: none;
}
.status-chip input[type="checkbox"] {
  width: 14px;
  height: 14px;
  accent-color: currentColor;
}
.status-chip:hover { border-color: #bdbdbd; }
.status-chip.active.chip-andamento {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.status-chip.active.chip-aprovada {
  background: var(--success);
  color: #fff;
  border-color: var(--success);
}
.status-chip.active.chip-reprovada {
  background: var(--danger);
  color: #fff;
  border-color: var(--danger);
}
.status-chip.active.chip-reinspecionada {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
body.theme-dark .status-chip { background: var(--card); color: var(--text-sec); border-color: var(--border); }
body.theme-dark .status-chip:hover { border-color: #555; }

/* Sub-abas do Cadastro · V128 painel-faithful (mockup-style: tipografia compacta,
   indicador monocromático em var(--text), letter-spacing negativo) */
.cad-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.cad-tab {
  background: transparent;
  border: none;
  padding: 10px 14px;
  font-size: 20px;          /* V68+: +50% sobre 13px → 19.5 → standard scale 20px */
  font-weight: 500;
  color: var(--gray-500);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  display: flex;
  align-items: center;
  gap: 8px;                  /* gap proporcional ao tamanho maior */
  transition: color var(--t-fast), border-color var(--t-fast);
  letter-spacing: -0.005em;
}
.cad-tab:hover { color: var(--text); }
.cad-tab.active {
  color: var(--text);
  border-bottom-color: var(--text);
  font-weight: 600;
}
body.theme-dark .cad-tab.active { color: #fff; border-bottom-color: #fff; }

/* Formulários em linha */
.form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
  margin-top: 8px;
}

/* Listas de entidades (usuário / serviço / placa) */
.entity-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
}
.entity-row {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #fff;
  padding: 12px 16px;
  border-radius: 8px;
  border: 1px solid var(--border);
  box-shadow: 0 1px 2px rgba(0,0,0,0.05);
}
body.theme-dark .entity-row { background: var(--card); }
.entity-main { flex: 1; min-width: 0; }
.entity-name { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
.entity-name code { background: #f0f4ff; color: var(--primary); padding: 1px 6px; border-radius: 4px; font-size: 12px; }
body.theme-dark .entity-name code { background: #1e3a5f; color: #80b9f5; }
.entity-sub { font-size: 12px; color: var(--text-sec); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

/* Badges para tipo de usuário */
.badge-tipo {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 999px;
  letter-spacing: 0.5px;
}
.badge-tipo-admin    { background: #8e24aa; color: #fff; }
.badge-tipo-inspetor { background: var(--primary); color: #fff; }
.badge-tipo-aux      { background: #00897b; color: #fff; }
.badge-inactive {
  font-size: 10px; font-weight: 700; color: var(--text-sec);
  background: #eceff1; padding: 2px 8px; border-radius: 999px;
}

.btn-del {
  background: none;
  border: none;
  color: var(--danger);
  font-size: 18px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
}
.btn-del:hover { background: #fdecea; }
body.theme-dark .btn-del:hover { background: #3a1f22; }

.btn-edit {
  background: none;
  border: none;
  color: var(--primary, #1976d2);
  font-size: 16px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
}
.btn-edit:hover { background: #e3f2fd; }
body.theme-dark .btn-edit:hover { background: #1a2a3a; }

.entity-row-editing {
  background: #f5faff;
  border-left: 3px solid var(--primary, #1976d2);
}
body.theme-dark .entity-row-editing { background: #1a2230; }

/* ═══════════════ PAINEL DE USUÁRIOS (Configurações → Usuários) ═══════════════ */
.usuarios-plano {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 14px 22px;
  margin: 14px 0 18px;
}
body.theme-dark .usuarios-plano { background: var(--card); }
.usuarios-plano .plano-label {
  color: var(--text-sec);
  font-size: 14px;
  font-weight: 500;
}
.usuarios-plano .plano-valor {
  color: var(--primary);
  font-size: 16px;
  font-weight: 700;
}
.usuarios-plano .plano-valor strong { font-size: 20px; }

.usuarios-toolbar {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.btn-usr {
  background: #fff;
  color: var(--text);
  border: 1px solid var(--border);
  padding: 9px 18px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.btn-usr:hover { background: #f5f5f5; }
.btn-usr:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-usr-add {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
}
.btn-usr-add:hover { background: var(--primary-dark); border-color: var(--primary-dark); }

/* Tabela de reprovações (Gerencial → Reprovações) */
.reprov-table .col-login code {
  background: #ffebee;
  color: var(--danger);
  padding: 2px 8px;
  border-radius: 4px;
  font-weight: 700;
}
body.theme-dark .reprov-table .col-login code { background: #3a1f22; color: #f3a3ab; }

.reprov-bar-wrap {
  position: relative;
  background: #f0f0f0;
  height: 22px;
  border-radius: 4px;
  overflow: hidden;
}
.reprov-bar {
  background: linear-gradient(90deg, #ef5350, var(--danger));
  height: 100%;
  transition: width 0.3s;
}
.reprov-bar-txt {
  position: absolute;
  top: 0; bottom: 0; left: 0; right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: #000;
  text-shadow: 0 0 3px rgba(255,255,255,0.7);
}
body.theme-dark .reprov-bar-wrap { background: #2a2a2a; }
body.theme-dark .reprov-bar-txt { color: #fff; text-shadow: 0 0 3px rgba(0,0,0,0.7); }

/* Aviso quando ação exige admin */
.admin-only-notice {
  background: #fff8e1;
  border: 1px solid #fbc02d;
  color: #5d4037;
  padding: 10px 16px;
  border-radius: 6px;
  font-size: 13px;
  margin-bottom: 14px;
}
body.theme-dark .admin-only-notice { background: #3a2e00; color: #e8d08a; border-color: #c88a0f; }

.btn-usr-edit {
  background: #fff;
  color: var(--primary);
  border-color: var(--primary);
}
.btn-usr-edit:hover:not(:disabled) { background: #e8f0fe; }
body.theme-dark .btn-usr-edit { background: var(--card); color: #80b9f5; border-color: #80b9f5; }
body.theme-dark .btn-usr-edit:hover:not(:disabled) { background: #1e3a5f; }
body.theme-dark .btn-usr { background: var(--card); color: var(--text); border-color: var(--border); }
body.theme-dark .btn-usr:hover { background: #2a2a2a; }

.usuarios-search {
  display: flex;
  margin-left: auto;
  min-width: 260px;
  max-width: 320px;
  flex: 1;
}
.usuarios-search input {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-right: none;
  border-radius: 6px 0 0 6px;
  font-size: 13px;
  background: #fff;
  color: var(--text);
}
body.theme-dark .usuarios-search input { background: var(--card); }
.usuarios-search-btn {
  background: var(--primary);
  color: #fff;
  border: 1px solid var(--primary);
  padding: 0 16px;
  border-radius: 0 6px 6px 0;
  font-size: 14px;
  cursor: pointer;
}
.usuarios-search-btn:hover { background: var(--primary-dark); }

/* Formulário completo "Dados do usuário" */
.user-form-panel {
  background: #fff;
  border-radius: 8px;
  padding: 22px 26px;
  margin-top: 8px;
}
body.theme-dark .user-form-panel { background: var(--card); }

.user-form-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px 18px;
}
@media (max-width: 900px) {
  .user-form-grid { grid-template-columns: repeat(2, 1fr); }
  .user-form-grid .user-form-field[style*="span 2"] { grid-column: 1 / -1 !important; }
}
.user-form-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.user-form-field label {
  font-size: 13px;
  color: var(--text-sec);
  font-weight: 500;
}
.user-form-field .field-input {
  height: 38px;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 0 10px;
  font-size: 13px;
  background: #fff;
  color: var(--text);
  transition: border-color 0.15s;
}
.user-form-field .field-input:focus {
  border-color: var(--primary);
  outline: none;
}
body.theme-dark .user-form-field .field-input { background: #2a2a2a; }

.senha-wrap {
  display: flex;
  align-items: stretch;
  gap: 8px;
}
.senha-wrap .field-input { flex: 1; }
.senha-toggle {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: #fafafa;
  font-size: 12px;
  color: var(--text-sec);
  cursor: pointer;
  font-weight: 500;
  user-select: none;
  white-space: nowrap;
}
.senha-toggle:hover { background: #f0f0f0; border-color: #bdbdbd; }
.senha-toggle input[type="checkbox"] {
  cursor: pointer;
  accent-color: var(--primary);
}
body.theme-dark .senha-toggle { background: #2a2a2a; color: #cacaca; }
body.theme-dark .senha-toggle:hover { background: #333; }

.email-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.email-wrap .field-input { flex: 1; padding-right: 38px; }
.email-check {
  position: absolute;
  right: 2px; top: 2px; bottom: 2px;
  width: 36px;
  display: flex; align-items: center; justify-content: center;
  background: #bdbdbd;
  color: #fff;
  font-weight: 700;
  border-radius: 3px;
  font-size: 12px;
  transition: background 0.2s;
}
.email-check.valid { background: var(--primary); }

.user-form-divider {
  border: none;
  border-top: 1px dashed var(--border);
  margin: 24px 0;
}

.user-form-tipo {
  display: flex;
  gap: 30px;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-bottom: 22px;
}
.user-form-tipo-help {
  font-size: 13px;
  color: var(--text);
  line-height: 1.7;
  padding-top: 22px;
}
.user-form-tipo-help strong { color: var(--text); }

.user-form-actions {
  display: flex;
  gap: 8px;
}
.btn-usr-cancel {
  background: #e0e0e0;
  color: #666;
  border-color: #d5d5d5;
}
.btn-usr-cancel:hover { background: #d5d5d5; }
body.theme-dark .btn-usr-cancel { background: #3a3a3a; color: #bbb; border-color: #3a3a3a; }

.usuarios-table-wrap {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}
body.theme-dark .usuarios-table-wrap { background: var(--card); }
.usuarios-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.usuarios-table thead {
  background: #f5f5f5;
  color: var(--text-sec);
  font-weight: 600;
}
body.theme-dark .usuarios-table thead { background: #1a1a1a; }
.usuarios-table th {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}
.usuarios-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--primary);
}
.usuarios-table tbody tr:hover { background: rgba(21, 101, 192, 0.04); }
body.theme-dark .usuarios-table tbody tr:hover { background: rgba(128, 185, 245, 0.07); }
.usuarios-table .col-login,
.usuarios-table .col-email { color: var(--primary); }
.usuarios-table .check-icon {
  color: var(--primary);
  font-weight: 700;
  background: #e8f0fe;
  border-radius: 50%;
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  margin-right: 4px;
}
body.theme-dark .usuarios-table .check-icon { background: #1e3a5f; }
.usuarios-table .row-action-btn {
  background: none;
  border: none;
  color: var(--primary);
  cursor: pointer;
  font-size: 16px;
  padding: 4px 8px;
  border-radius: 4px;
}
.usuarios-table .row-action-btn:hover { background: #e8f0fe; }
body.theme-dark .usuarios-table .row-action-btn:hover { background: #1e3a5f; }
.usuarios-table input[type="checkbox"] { cursor: pointer; }
.usuarios-empty {
  text-align: center;
  color: var(--text-sec);
  padding: 32px 16px;
  font-size: 14px;
}
.usuarios-footer {
  text-align: right;
  padding: 10px 16px;
  background: #f5f5f5;
  color: var(--text-sec);
  font-size: 12px;
}
body.theme-dark .usuarios-footer { background: #1a1a1a; }

/* Estatísticas do Gerencial */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}
.stat-card {
  background: #fff; border-radius: 10px; padding: 18px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
  border-left: 4px solid #999;
}
.stat-card .stat-num {
  font-size: 32px; font-weight: 800; line-height: 1;
  color: var(--text);
}
.stat-card .stat-lbl {
  margin-top: 6px; font-size: 12px; text-transform: uppercase;
  color: var(--text-sec); letter-spacing: 0.6px; font-weight: 600;
}
.stat-card.stat-blue  { border-left-color: var(--primary); }
.stat-card.stat-green { border-left-color: var(--success); }
.stat-card.stat-red   { border-left-color: var(--danger); }
body.theme-dark .stat-card { background: var(--card); }

/* Grupos de configuração */
.config-group {
  background: #fff; border-radius: 10px; padding: 16px 18px;
  margin-bottom: 14px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.config-group h3 { margin: 0 0 4px; font-size: 15px; color: var(--text); }
.config-group .config-help { margin: 0 0 10px; font-size: 12px; color: var(--text-sec); }
.config-group.danger-group { border: 1px solid #ffcdd2; }
body.theme-dark .config-group { background: var(--card); }
body.theme-dark .config-group.danger-group { border-color: #5a2626; }
.btn-secondary.danger {
  background: var(--danger); color: #fff; border-color: var(--danger);
}
.btn-secondary.danger:hover { background: #a01e1e; }

/* Responsivo: menu lateral vira topo em telas menores */
@media (max-width: 720px) {
  .home-body { flex-direction: column; }
  .home-sidebar {
    width: 100%; flex-direction: row; overflow-x: auto;
    padding: 6px 6px;
  }
  .side-menu-item { flex-direction: column; padding: 8px 10px; font-size: 11px; min-width: 90px; border-left: none; border-bottom: 3px solid transparent; }
  .side-menu-item.active { border-left: none; border-bottom-color: var(--primary); }
  .side-menu-icon { font-size: 18px; }
  .home-content { padding: 16px; }
  .topbar-user { font-size: 12px; }
}

.home-header {
  text-align: center;
  padding: 40px 20px 28px;
}

.home-logo {
  font-size: 52px;
  margin-bottom: 10px;
  display: block;
}

.home-header h1 {
  font-size: 22px;
  font-weight: 700;
  color: var(--primary-dark);
  margin-bottom: 4px;
}

.home-subtitle {
  font-size: 14px;
  color: var(--text-sec);
  font-weight: 500;
  letter-spacing: 0.5px;
}

/* =====================================================
   FILTROS
   ===================================================== */
.filter-panel {
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  margin: 16px 0 8px;
  overflow: hidden;
}

.filter-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: #f0f4ff;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  user-select: none;
  transition: background .12s ease;
}
.filter-header:hover { background: #e8efff; }
.filter-header.open { border-bottom-color: var(--border); }
.filter-header.closed { border-bottom: none; }
.filter-caret {
  margin-left: auto;       /* encosta à direita quando não há outros elementos após ele */
  font-size: 10px;
  color: #666;
  flex-shrink: 0;
}


/* Chips de resumo dos filtros ativos (exibidos no header quando colapsado) */
.filter-chips-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.filter-chip-summary {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  background: #eef1f7;
  color: #334;
  border: 1px solid #d6dce4;
  cursor: pointer;
  transition: background .12s ease, border-color .12s ease;
  white-space: nowrap;
}
.filter-chip-summary:hover { background: #e1e6ef; border-color: #9aa3ae; }
.filter-chip-summary .chip-x { color: #888; font-weight: 700; font-size: 13px; line-height: 1; }
.filter-chip-summary:hover .chip-x { color: #c62828; }
.filter-chip-summary.chip-date     { background:#e3f2fd; border-color:#90caf9; color:#0d47a1; }
.filter-chip-summary.chip-date:hover { background:#bbdefb; }
.filter-chip-summary.chip-placa    { background:#fff3e0; border-color:#ffcc80; color:#e65100; }
.filter-chip-summary.chip-placa:hover { background:#ffe0b2; }
.filter-chip-summary.chip-status   { background:#f3e5f5; border-color:#ce93d8; color:#4a148c; }
.filter-chip-summary.chip-status:hover { background:#e1bee7; }
.filter-chip-summary.chip-servicos { background:#e8f5e9; border-color:#a5d6a7; color:#1b5e20; }
.filter-chip-summary.chip-servicos:hover { background:#c8e6c9; }

/* Rodapé do body com o botão Limpar tudo */
.filter-body-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: 8px;
  margin-top: 4px;
  border-top: 1px dashed var(--border);
}

.filter-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--primary-dark);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Escopo: somente a seção Gerencial usa cinza (Operacional mantém azul) */
.gerencial-section .filter-header { background: #f3f4f6; }
.gerencial-section .filter-header:hover { background: #e5e7eb; }
.gerencial-section .filter-title { color: #475569; }

.filter-badge {
  background: var(--primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  border-radius: 10px;
  padding: 1px 7px;
}

.filter-clear {
  background: none;
  border: 1px solid var(--danger);
  color: var(--danger);
  border-radius: 6px;
  padding: 4px 12px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
}
.filter-clear:hover { background: #fdecea; }

.filter-body {
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.filter-body.collapsed { display: none; }

.filter-row {
  display: flex;
  gap: 10px;
}

.filter-field {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.filter-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-sec);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.filter-field .field-input {
  height: 38px;
  font-size: 13px;
}

.filter-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.filter-section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: 1px;
  text-transform: uppercase;
  padding-bottom: 4px;
  border-bottom: 2px solid var(--primary-light);
}

/* =====================================================
   AGRUPAMENTO POR DATA
   ===================================================== */
.date-group {
  margin-bottom: 12px;
}

/* V128 painel-faithful: date-header monocromático (mockup card-head style) */
.date-group-header {
  font-size: 13px;
  font-weight: 500;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 14px 4px 10px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.date-group-header::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gray-400);
  flex-shrink: 0;
}

.results-count {
  font-size: 12px;
  color: var(--gray-500);
  margin: 8px 4px 12px;
  font-variant-numeric: tabular-nums;
}

.list-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-sec);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin: 24px 0 10px;
}

.empty-state {
  text-align: center;
  color: var(--text-sec);
  margin: 40px 0;
  font-size: 15px;
  line-height: 1.7;
}

/* =====================================================
   LISTA DE INSPEÇÕES
   ===================================================== */
.inspection-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 12px;
}

/* V128 painel-faithful · card mockup: borda sutil, hover por border-color (sem lift),
   sombra mínima, tipografia compacta. Plate em tabular-nums monocromática. */
.inspection-item {
  background: var(--card);
  border-radius: var(--radius);
  padding: 16px 18px;
  box-shadow: var(--elev-1);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}

.inspection-item:hover {
  border-color: var(--gray-400);
  box-shadow: var(--elev-2);
}

.inspection-item:active {
  border-color: var(--gray-500);
}

.inspection-item-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
  gap: 8px;
}

.insp-ident {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.insp-placa {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.insp-veic-info {
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.insp-servico-desc {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted, #555);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 60%;
}
body.theme-dark .insp-servico-desc {
  color: #a6c5ea;
}

.inspection-item-sub {
  font-size: 12px;
  color: var(--text-sec);
  margin-bottom: 8px;
}

.inspection-item-progress {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--text-sec);
}

/* V128 painel-faithful · progress monocromático (track gray-200, fill text/charcoal) */
.mini-progress {
  flex: 1;
  height: 3px;
  background: var(--gray-200);
  border-radius: 999px;
  overflow: hidden;
}

.mini-progress-bar {
  height: 100%;
  background: var(--text);
  border-radius: 999px;
  transition: width 0.3s var(--ease);
}

/* =====================================================
   BADGES DE STATUS · V128 painel-faithful (palette mockup pill)
   ===================================================== */
.badge {
  font-size: 11px;
  font-weight: 500;
  padding: 3px 9px;
  border-radius: 999px;
  text-transform: capitalize;
  letter-spacing: 0;
  line-height: 1.4;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.badge-aprov {
  background: #ECFDF5;
  color: #047857;
  border: 0;
}

.badge-reprov {
  background: #FEF2F2;
  color: #B91C1C;
  border: 0;
}

.badge-draft {
  background: var(--gray-100);
  color: var(--gray-600);
  border: 0;
}

.badge-incompleto {
  background: #ffa726;
  color: #000;
  border: 1px solid #ef6c00;
  font-weight: 700;
}

/* =====================================================
   REVIEW SCREEN
   ===================================================== */
.reprov-item {
  display: flex;
  flex-direction: column;
  padding: 8px 0;
  border-bottom: 1px solid #ffe082;
  font-size: 13px;
}

.reprov-item:last-child {
  border-bottom: none;
}

.reprov-section {
  font-size: 11px;
  font-weight: 700;
  color: var(--neutral);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}

.text-aprov { color: var(--success); }
.text-reprov { color: var(--danger); }

/* =====================================================
   REPORT ACTIONS
   ===================================================== */
.report-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  padding: 16px;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.report-actions .btn-primary {
  flex: 2;
}

.report-actions .btn-secondary {
  flex: 1;
}

/* =====================================================
   PRINT FORM — RELATÓRIO IMPRIMÍVEL
   ===================================================== */
.print-form {
  font-size: 11px;
  color: #000;
  line-height: 1.4;
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
  background: #fff;
  box-shadow: 0 0 20px rgba(0,0,0,0.1);
  border-radius: 4px;
}

.rpt-header {
  border: 1.5px solid #0F172A;
  border-radius: 4px;
  padding: 10px 12px;
  margin-bottom: 10px;
  overflow: hidden;   /* clearfix do float da logo */
}
/* Logo da empresa no cabeçalho — flutua à esquerda do título */
.rpt-header .brand-logo-pdf {
  float: left;
  height: 50px;
  max-width: 180px;
  object-fit: contain;
  margin: 0 14px 4px 0;
}
@media print {
  .rpt-header .brand-logo-pdf { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}

.rpt-title {
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  color: var(--text);
  text-transform: uppercase;
  margin-bottom: 2px;
}

.rpt-subtitle {
  font-size: 11px;
  text-align: center;
  color: #475569;
  margin-bottom: 8px;
  letter-spacing: 0.04em;
}

.rpt-id-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 8px;
}

.rpt-id-item {
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  padding: 5px 8px;
  background: #F8FAFC;
}

.rpt-id-item label {
  display: block;
  font-size: 9px;
  font-weight: 700;
  color: #64748B;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}

.rpt-id-item span {
  font-size: 13px;
  font-weight: 700;
  color: #0F172A;
  letter-spacing: 0.02em;
  font-family: ui-monospace, Consolas, monospace;
}

.rpt-legenda {
  font-size: 10px;
  color: #475569;
  margin-top: 6px;
  text-align: center;
  background: #F8FAFC;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  padding: 4px 8px;
  letter-spacing: 0.04em;
}

.rpt-section {
  margin-bottom: 8px;
}

/* Imagens/pictogramas embutidos no relatório */
.rpt-image {
  margin: 6px 0;
  text-align: center;
  page-break-inside: avoid;
  break-inside: avoid;
}
.rpt-image img {
  max-width: 100%;
  height: auto;
  max-height: 220px;
  border: 1px solid #d0d0d0;
  border-radius: 4px;
  background: #fafafa;
  padding: 4px;
}
@media print {
  .rpt-image img {
    max-height: 180px;
    border: 1px solid #999;
  }
}

.rpt-section-title {
  background: #0F172A;
  color: #fff;
  padding: 4px 10px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 3px;
  margin-bottom: 4px;
}

/* Faixa âmbar/laranja em famílias C0xxx (GNV) — identificação visual
   no PDF do FRM-047. Mantém o título escuro e cria um ribbon "GNV"
   no canto direito. */
.rpt-section-title.is-c {
  background: linear-gradient(90deg, #0F172A 0%, #0F172A calc(100% - 60px), #2563EB 100%);
  position: relative;
  padding-right: 46px;
}
.rpt-section-title.is-c::after {
  content: 'GNV';
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 8px;
  font-weight: 800;
  background: rgba(255,255,255,0.18);
  padding: 1px 6px;
  border-radius: 999px;
  letter-spacing: 0.06em;
  color: #fff;
}

/* Rodapé de página do PDF — V130: identificação compacta com OS, placa,
   nº de página e OIA. Pequeno, monoespaçado, gray-500, com border-top
   discreta. */
.rpt-page-meta {
  margin-top: 18px;
  font-size: 9px;
  color: #64748B;
  text-align: center;
  border-top: 1px solid #E5E7EB;
  padding-top: 4px;
  letter-spacing: 0.04em;
  font-family: ui-monospace, 'Consolas', monospace;
}

.rpt-tipo {
  border: 1px solid #ccc;
  padding: 6px 8px;
  font-size: 11px;
  font-weight: 600;
}

.rpt-row3 {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.rpt-row3 > div {
  flex: 1;
  border: 1px solid #ccc;
  padding: 5px 8px;
  border-radius: 3px;
  font-size: 11px;
}

.rpt-row2 {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}

.rpt-row2 > div {
  flex: 1;
  font-size: 10px;
  border: 1px solid #e0e0e0;
  padding: 4px 6px;
  border-radius: 3px;
}

.rpt-columns {
  display: flex;
  gap: 12px;
  align-items: flex-start;
}

.rpt-col {
  flex: 1;
  min-width: 0;
}

.rpt-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 10px;
  margin-bottom: 4px;
}

.rpt-table th {
  background: #F1F5F9;
  color: #0F172A;
  padding: 3px 5px;
  text-align: left;
  font-size: 9px;
  border: 1px solid #E5E7EB;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.rpt-table td {
  border: 1px solid #e0e0e0;
  padding: 2px 5px;
  vertical-align: middle;
}

.rpt-table td.rpt-code {
  color: var(--neutral);
  font-size: 9px;
  width: 60px;
  font-weight: 600;
}

.rpt-table td.rpt-label {
  font-size: 10px;
}

/* V121 minimalist: ✓ verde aprovado · X vermelho bold reprovado · — em-dash N/A
   Garantem alto contraste em B&W e leitura instantânea no PDF impresso. */
.rpt-aprov {
  color: #15803D;
  font-weight: 700;
  font-size: 13px;
}

.rpt-reprov {
  color: #B91C1C;
  font-weight: 800;
  font-size: 14px;
  letter-spacing: -0.02em;
}

.rpt-na {
  color: #64748B;
  font-weight: 700;
  font-size: 14px;
}

.rpt-empty {
  color: #bdbdbd;
  font-size: 11px;
}

/* =====================================================
   ITEM-BLOCK (linha do item: ✓ à esquerda + código bold + label bold)
   Usado no bloco G0500 — Iluminação para uniformizar layout do relatório
   ===================================================== */
.rpt-item-block { margin-top: 6px; }
.rpt-item-block:first-of-type { margin-top: 0; }
.rpt-table td.rpt-mark-left {
  width: 18px;
  text-align: center;
  padding: 3px 4px;
}
.rpt-table td.rpt-code-bold {
  color: #1f2937;
  font-size: 9px;
  width: 50px;
  font-weight: 700;
}
.rpt-table td.rpt-label-bold {
  font-size: 10px;
  font-weight: 700;
}

.rpt-warn {
  background: #FEF3C7;
  color: #92400E;
  font-weight: 700;
  border-bottom: 1px solid #F59E0B !important;
}
@media print {
  .rpt-warn {
    background: #FEF3C7 !important;
    color: #92400E !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

.rpt-cil-table th,
.rpt-pneu-table th {
  background: #F1F5F9;
  color: #0F172A;
  font-weight: 700;
  font-size: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid #E5E7EB;
}
.rpt-cil-table td:first-child,
.rpt-pneu-table td:first-child {
  background: #F8FAFC;
  color: #475569;
  font-weight: 600;
  text-align: left;
}

.rpt-page-break {
  page-break-before: always;
  margin: 18px 0 12px;
  border-top: 1px dashed #E5E7EB;
  padding-top: 8px;
}

.rpt-obs {
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  min-height: 36px;
  padding: 6px 8px;
  font-size: 11px;
  color: #475569;
  background: #F8FAFC;
  white-space: pre-wrap;
  margin-top: 4px;
  margin-bottom: 8px;
}

.rpt-avaliacao {
  margin-top: 10px;
}

.rpt-aval-badge {
  text-align: center;
  font-size: 16px;
  font-weight: 800;
  padding: 8px 22px;
  border-radius: 6px;
  letter-spacing: 0.06em;
  border: 2px solid;
}

.aval-aprov {
  background: #DCFCE7;
  color: #15803D;
  border-color: #15803D;
}

.aval-reprov {
  background: #FEE2E2;
  color: #B91C1C;
  border-color: #B91C1C;
}

.aval-incompleta {
  background: #FEF3C7;
  color: #92400E;
  border-color: #F59E0B;
}

.rpt-ass {
  font-size: 10px;
  border: 1px solid #E5E7EB;
  border-radius: 4px;
  padding: 8px 10px;
  margin-top: 12px;
  background: #F8FAFC;
  color: #475569;
  line-height: 1.45;
}
.rpt-ass strong {
  color: #0F172A;
  font-weight: 700;
}

/* ─── Carimbo de Assinatura Eletrônica Avançada (v11) ───
   Carimbo inclui botão "Ver evidência" SEMPRE visível para garantir
   que o usuário saiba que é clicável — sem depender de tooltip. */
.sig-stamp {
  display: inline-block;
  padding: 8px 12px;
  border: 2px solid #0a6;
  border-radius: 6px;
  background: #f0fdf4;
  cursor: pointer;
  text-align: left;
  transition: background .12s ease, border-color .12s ease, box-shadow .12s ease;
  /* Container pode ter white-space: pre-line (.rpt-frm041-sig) — normalizamos aqui
     pra que o layout do carimbo dependa só das tags <br> explícitas. */
  white-space: normal;
  line-height: 1.4;
}
.sig-stamp:hover {
  background: #dcfce7;
  border-color: #10b981;
  box-shadow: 0 2px 8px rgba(16, 185, 129, .25);
}
.sig-stamp-badge {
  display: inline-block;
  margin-top: 4px;
  color: #0a6;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3px;
}
/* Botão permanente dentro do carimbo — garante que o usuário
   SEMPRE vê o chamado pra ação, independente de hover/tooltip. */
.sig-stamp-btn {
  display: inline-block;
  margin-left: 8px;
  padding: 3px 8px;
  background: #0a6;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.sig-stamp-btn:hover { background: #059669; }
/* No modo impressão, esconde o botão e o efeito de hover pra não poluir o laudo.
   Estilo passivo (V130): borda discreta, fundo verde claro semelhante ao mockup
   V2 (.rpt-ass.signed). Cor verde sucesso para o badge e o nome. */
@media print {
  .sig-stamp-btn { display: none !important; }
  .sig-stamp {
    display: block !important;
    box-shadow: none !important;
    cursor: default !important;
    border: 1px solid #15803D !important;
    background: #DCFCE7 !important;
    color: #15803D !important;
    padding: 6px 8px !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .sig-stamp strong { color: #0F172A !important; }
  .sig-stamp-badge {
    background: rgba(21, 128, 61, 0.15) !important;
    padding: 1px 6px !important;
    border-radius: 999px !important;
    font-size: 9px !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

.rpt-final {
  margin-top: 14px;
  border-top: 1.5px solid #0F172A;
  padding-top: 10px;
}

/* =====================================================
   UTILITÁRIOS
   ===================================================== */
.home-screen .btn-primary {
  margin-bottom: 4px;
}

/* =====================================================
   LINHA DE CAMPOS AGRUPADOS (flex — ex: X · W · Y)
   ===================================================== */
.field-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.field-row > .card {
  flex: 1;
  min-width: 140px;
  margin-bottom: 0;
}

/* Grade de campos em N colunas (ex: identificação do veículo em 3 col) */
.field-grid {
  display: grid;
  gap: 8px;
  margin-bottom: 12px;
}
.field-grid-2 { grid-template-columns: repeat(2, 1fr); }
.field-grid-3 { grid-template-columns: repeat(3, 1fr); }
.field-grid-4 { grid-template-columns: repeat(4, 1fr); }
.field-grid > .card { margin-bottom: 0; }

@media (max-width: 540px) {
  .field-grid-3, .field-grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 360px) {
  .field-grid-3, .field-grid-4 { grid-template-columns: 1fr; }
}

/* =====================================================
   IMAGEM / DIAGRAMA DENTRO DO CARD
   ===================================================== */
.image-card {
  background: #fff;
}

.image-wrap {
  margin-top: 10px;
  padding: 8px;
  background: #fafafa;
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex;
  justify-content: center;
  overflow-x: auto;
}

.image-content {
  max-width: 100%;
  height: auto;
  display: block;
}

/* =====================================================
   SUFIXO DE UNIDADE (mm, cm, %, °C) — campos e células
   ===================================================== */
.input-unit-wrap {
  position: relative;
  display: block;
}
.input-unit-wrap .field-input {
  padding-right: 42px;
}
.input-unit {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  font-weight: 700;
  color: var(--text-sec);
  pointer-events: none;
  background: #eceff1;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.3px;
  display: none;
}
.input-unit-wrap.has-value .input-unit { display: inline-block; }
.input-unit-wrap:not(.has-value) .field-input { padding-right: 12px; }

/* Versão compacta para células de tabela */
.cell-unit-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.cell-unit-wrap input {
  width: 100%;
  padding-right: 32px;
}
.cell-unit {
  position: absolute;
  right: 6px;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-sec);
  pointer-events: none;
  background: #eceff1;
  padding: 1px 4px;
  border-radius: 3px;
  display: none;
}
.cell-unit-wrap.has-value .cell-unit { display: inline-block; }
.cell-unit-wrap:not(.has-value) input { padding-right: 6px; }

/* =====================================================
   MARCADOR "N/A" NOS CAMPOS ESCRITOS
   ===================================================== */
.field-input.na-marked {
  color: var(--neutral);
  font-weight: 700;
  background: #f5f5f5;
  font-style: italic;
}

.radio-na-mark {
  margin-top: 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--neutral);
  background: #eceff1;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px dashed #90a4ae;
  text-align: center;
  letter-spacing: 0.5px;
}

/* =====================================================
   ÍNDICE DE PASSOS (OVERLAY LATERAL)
   ===================================================== */
.step-index-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.2s;
}
.step-index-overlay.open {
  pointer-events: all;
  opacity: 1;
}

.step-index-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
}

.step-index-panel {
  position: relative;
  z-index: 1;
  background: #fff;
  width: min(360px, 92vw);
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: 4px 0 24px rgba(0,0,0,0.2);
  transform: translateX(-100%);
  transition: transform 0.25s ease;
}
.step-index-overlay.open .step-index-panel {
  transform: translateX(0);
}

.step-index-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 18px;
  background: var(--primary-dark);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  flex-shrink: 0;
}

.idx-close {
  background: none;
  border: none;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  line-height: 1;
}
.idx-close:hover { background: rgba(255,255,255,0.15); }

.step-index-legend {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 18px;
  font-size: 11px;
  color: var(--text-sec);
  background: #f5f5f5;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.step-index-list {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0 24px;
}

.idx-page-group {
  margin-bottom: 4px;
}

.idx-page-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--primary);
  padding: 10px 18px 4px;
  border-top: 1px solid var(--border);
}

.idx-step-row {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 18px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 13px;
  color: var(--text);
  transition: background 0.12s;
  position: relative;
}
.idx-step-row:hover { background: #f0f4ff; }
.idx-step-row.idx-active {
  background: #e8f0fe;
  font-weight: 700;
}

.idx-step-num {
  font-size: 11px;
  color: var(--text-sec);
  min-width: 20px;
  text-align: right;
  flex-shrink: 0;
}

.idx-step-title {
  flex: 1;
  line-height: 1.3;
}
.idx-step-title em {
  font-style: normal;
  font-weight: 700;
  color: var(--primary);
}

.idx-equip-icon {
  font-size: 14px;
  filter: grayscale(1) brightness(0.3) contrast(1.5);
}

.idx-current-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary);
  flex-shrink: 0;
}

/* Status icons */
.idx-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
}
.idx-done    { background: #e8f5e9; color: #2e7d32; }
.idx-reprov  { background: #fdecea; color: #c62828; }
.idx-na      { background: #eceff1; color: #546e7a; }
.idx-partial { background: #fff8e1; color: #f57f17; }
.idx-empty   { background: #f5f5f5; color: #9e9e9e; }

/* Passo com reprovados — num e título em vermelho */
.idx-row-reprov .idx-step-num,
.idx-row-reprov .idx-step-title {
  color: var(--danger);
  font-weight: 700;
}
.idx-row-reprov .idx-step-title em {
  color: var(--danger);
}
.idx-row-reprov {
  background: #fff5f5;
}
.idx-row-reprov:hover { background: #ffe8e8; }

/* botão flutuante de índice — borda esquerda da tela */
.floating-index-btn {
  position: fixed;
  left: 0;
  top: 45%;
  transform: translateY(-50%);
  z-index: 800;
  background: var(--primary);
  color: #fff;
  border: none;
  padding: 10px 10px 10px 8px;
  border-radius: 0 10px 10px 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  box-shadow: 2px 2px 10px rgba(0,0,0,0.25);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  line-height: 1;
}
.floating-index-btn:hover  { background: var(--primary-dark); padding-left: 14px; }
.floating-index-btn:active { transform: translateY(-50%) scale(0.97); }
.floating-index-btn { cursor: grab; touch-action: none; user-select: none; }
.floating-index-btn.dragging { cursor: grabbing; opacity: 0.85; }

@media print {
  .floating-index-btn { display: none; }
}

/* botão índice no header do wizard */
.btn-index {
  background: none;
  border: none;
  color: #fff;
  font-size: 20px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 6px;
  line-height: 1;
}
.btn-index:hover { background: rgba(255,255,255,0.15); }

/* =====================================================
   MEDIA PRINT
   ===================================================== */
@media print {
  body {
    background: #fff;
  }

  .no-print {
    display: none !important;
  }

  .print-form {
    font-size: 10pt;
    box-shadow: none;
    padding: 0;
    max-width: 100%;
  }

  @page {
    margin: 1cm;
    size: A4;
  }

  .rpt-columns {
    display: flex;
    flex-direction: row;
  }

  .rpt-page-break {
    page-break-before: always;
    border: none;
    margin: 0;
    padding: 0;
  }

  .nav-bar,
  .wizard-header,
  .progress-bar-wrap,
  .report-actions {
    display: none !important;
  }

  .screen {
    max-width: 100%;
    padding: 0;
  }

  /* V121 minimalist · cores na impressão */
  .rpt-aprov  { color: #15803D !important; }
  .rpt-reprov { color: #B91C1C !important; font-weight: 800 !important; }
  .rpt-na     { color: #64748B !important; }

  .rpt-header {
    border: 2px solid #0F172A !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .rpt-section-title {
    background: #0F172A !important;
    color: #fff !important;
    border-radius: 3px !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  /* Preserva ribbon GNV das famílias C0xxx (FRM-047) na impressão */
  .rpt-section-title.is-c {
    background: linear-gradient(90deg, #0F172A 0%, #0F172A calc(100% - 60px), #2563EB 100%) !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .rpt-page-meta {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .rpt-aval-badge {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .rpt-id-item, .rpt-legenda, .rpt-obs, .rpt-ass {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  .insp-table th,
  .rpt-table th {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

/* =====================================================
   RESPONSIVO
   ===================================================== */
@media (max-width: 400px) {
  .check3-btn {
    font-size: 16px;
    height: 52px;
  }

  .rpt-id-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .rpt-columns {
    flex-direction: column;
  }
}

/* ═══════════════════════════════════════════════════════
   RELATÓRIO FRM-041 — Fiel ao DOCX F041.03.032 ED. 06
   ═══════════════════════════════════════════════════════ */

.rpt-frm041 {
  background: #fff;
  color: #000;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 9.5px;
  padding: 16px 22px 48px;
  line-height: 1.25;
  position: relative;
}
body.theme-dark .rpt-frm041 { background: #fff; color: #000; }

/* Cabeçalho */
.rpt-frm041-header { margin-bottom: 10px; }
.rpt-frm041-title {
  text-align: center;
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  border: 1.5px solid #000;
  padding: 6px 10px;
  margin-bottom: 6px;
}

/* Tabelas de identificação do cabeçalho */
.rpt-frm041-id {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 4px;
  font-size: 9px;
}
.rpt-frm041-id th,
.rpt-frm041-id td {
  border: 1px solid #000;
  padding: 3px 6px;
  text-align: center;
}
.rpt-frm041-id th {
  background: #d9d9d9;
  font-weight: 700;
  font-size: 8.5px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.rpt-frm041-id td { min-height: 16px; font-weight: 600; }
.rpt-frm041-subhead {
  background: #000 !important;
  color: #fff;
  text-align: left !important;
  padding-left: 8px !important;
}

.rpt-frm041-legenda {
  font-size: 9px;
  font-style: italic;
  margin: 6px 0;
  text-align: center;
  font-weight: 600;
}

/* Corpo 2 colunas */
.rpt-frm041 .rpt-columns {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.rpt-frm041 .rpt-col {
  flex: 1;
  min-width: 0;
}
.rpt-frm041 .rpt-section {
  margin-bottom: 6px;
  page-break-inside: avoid;
}
.rpt-frm041 .rpt-section-title {
  background: #0F172A;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 3px 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 3px;
}

/* Tabela de check-list (G0150, G0200, etc.) */
.rpt-frm041 .rpt-check-list {
  width: 100%;
  border-collapse: collapse;
  font-size: 8.5px;
}
.rpt-frm041 .rpt-check-list td {
  border: 1px solid #999;
  padding: 2px 4px;
  vertical-align: middle;
}
.rpt-frm041 .rpt-check-box {
  width: 22px;
  text-align: center;
  font-weight: 700;
}
.rpt-frm041 .rpt-code {
  width: 50px;
  font-family: ui-monospace, Consolas, monospace;
  font-size: 8px;
  font-weight: 700;
  background: #f0f0f0;
  text-align: center;
}
.rpt-frm041 .rpt-label {
  font-size: 8.5px;
  line-height: 1.2;
}

/* Tabelas inline de valores/limites (G0301, G0312, G0608, G0702, G0803, G0900, G1007, G1009) */
.rpt-frm041 .rpt-table-data {
  width: 100%;
  border-collapse: collapse;
  font-size: 8.5px;
  margin: 2px 0 4px;
}
.rpt-frm041 .rpt-table-data th,
.rpt-frm041 .rpt-table-data td {
  border: 1px solid #666;
  padding: 2px 4px;
}
.rpt-frm041 .rpt-table-data th {
  background: #e0e0e0;
  font-weight: 700;
  text-align: center;
  font-size: 8px;
  text-transform: uppercase;
}
.rpt-frm041 .rpt-cell-readonly {
  background: #f5f5f5;
  font-size: 8px;
  font-style: italic;
  color: #555;
  text-align: center;
}

/* Marcadores check3 A/R/X no relatório (V128 minimalist faithful) */
.rpt-frm041 .rpt-aprov { color: #15803D; font-size: 13px; font-weight: 700; }
.rpt-frm041 .rpt-reprov { color: #B91C1C; font-size: 14px; font-weight: 800; letter-spacing: -0.02em; }
.rpt-frm041 .rpt-na { color: #64748B; font-size: 14px; font-weight: 700; }
.rpt-frm041 .rpt-empty { color: #cbd5e1; }

/* Avaliação Final */
.rpt-frm041-final { margin-top: 10px; page-break-inside: avoid; }
.rpt-frm041-final-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 2px;
}
.rpt-frm041-obs-head {
  background: #000;
  color: #fff;
  padding: 4px 8px;
  font-size: 9px;
  text-align: left;
  font-weight: 700;
  border: 1px solid #000;
}
.rpt-frm041-obs {
  border: 1px solid #000;
  padding: 8px;
  min-height: 45px;
  font-size: 9px;
  white-space: pre-wrap;
  vertical-align: top;
}
.rpt-frm041-aval {
  width: 100%;
  border-collapse: collapse;
}
.rpt-frm041-aval th,
.rpt-frm041-aval td {
  border: 1px solid #000;
  padding: 6px;
  text-align: center;
  vertical-align: middle;
}
.rpt-frm041-aval th {
  background: #d9d9d9;
  font-size: 8.5px;
  font-weight: 700;
  text-transform: uppercase;
}
.rpt-frm041-badge { min-height: 30px; font-size: 11px; font-weight: 700; }
.rpt-frm041-badge .mark-aprov { color: #15803D; }
.rpt-frm041-badge .mark-reprov { color: #B91C1C; }
.rpt-frm041-date,
.rpt-frm041-sig { font-size: 9px; font-weight: 600; min-height: 30px; white-space: pre-line; line-height: 1.25; }

/* Rodapé fiel ao DOCX */
.rpt-frm041-footer {
  display: flex;
  justify-content: space-between;
  font-size: 8.5px;
  color: #333;
  border-top: 1px solid #999;
  margin-top: 10px;
  padding-top: 4px;
}

/* Impressão: tamanho A4, margens padrão do DOCX */
@media print {
  @page { size: A4; margin: 10mm 12mm; }
  .rpt-frm041 { font-size: 9px; padding: 0; }
  .rpt-frm041-title { border-color: #000; }
  .rpt-frm041 .rpt-section { page-break-inside: avoid; }
}

/* ═══════════════════════════════════════════════════════
   CLASSES FRM-041 (INDEPENDENTES DO FRM-047)
   Prefixo f041-* — evita qualquer colisão com rpt-*
   ═══════════════════════════════════════════════════════ */

/* Corpo em 2 colunas */
.rpt-frm041 .f041-columns {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.rpt-frm041 .f041-col {
  flex: 1;
  min-width: 0;
}

/* Seção (G0200, G0301, etc.) */
.rpt-frm041 .f041-section {
  margin-bottom: 6px;
  page-break-inside: avoid;
}
.rpt-frm041 .f041-section-title {
  background: #0F172A;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 3px 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-radius: 3px;
}

/* Sub-cabeçalho dentro de uma família (ex.: ENSAIO DO PINO REI no G1006-2).
   Mesmo visual da família, mas usado dentro de uma <tr><td colspan="3"> da
   f041-check-list — em report.js renderSection e no preview da Lista de Itens. */
.rpt-frm041 .f041-subsection-title {
  background: #1E293B;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 3px 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Sub-cabeçalho no wizard (preenchimento) — versão maior pra leitura na tela. */
.field-subsection-title {
  background: #1565C0;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 8px 14px;
  margin: 14px 0 6px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-radius: 4px;
}

/* Lista de check3 dentro da seção */
.rpt-frm041 .f041-check-list {
  width: 100%;
  border-collapse: collapse;
  font-size: 8.5px;
}
.rpt-frm041 .f041-check-list td {
  border: 1px solid #999;
  padding: 2px 4px;
  vertical-align: middle;
}
.rpt-frm041 .f041-check-box {
  width: 22px;
  text-align: center;
  font-weight: 700;
}
.rpt-frm041 .f041-code {
  width: 60px;
  font-family: ui-monospace, Consolas, monospace;
  font-size: 8px;
  font-weight: 700;
  background: #f0f0f0;
  text-align: center;
}
.rpt-frm041 .f041-label {
  font-size: 8.5px;
  line-height: 1.2;
}

/* Tabela de ensaio embutida no relatório (item check3 com tableSpec — ex: G0603_)
   Tamanhos alinhados ao padrão da .f041-check-list (label 8.5px, code 8px). */
.ensaio-report-wrap { margin: 4px 8px; }
.ensaio-report-table {
  width: 100%; max-width: 540px; border-collapse: collapse;
  background: #fff; border: 1px solid #E5E7EB;
  font-size: 8.5px; margin: 0 auto;
}
.ensaio-report-table th, .ensaio-report-table td {
  border: 1px solid #E5E7EB; padding: 2px 4px; text-align: center;
  line-height: 1.2;
}
.ensaio-report-table .ensaio-col-head {
  font-weight: 700; background: #F1F5F9; font-size: 8px; color: #0F172A;
  text-transform: uppercase; letter-spacing: 0.04em;
}
.ensaio-report-table .ensaio-row-label {
  font-weight: 700; padding: 2px 6px; text-align: left; background: #F8FAFC;
  font-size: 8.5px; color: #0F172A;
}
.ensaio-report-table .ensaio-limit-cell {
  background: #F1F5F9; color: #475569;
  font-family: ui-monospace, Consolas, monospace; font-weight: 700;
}
.ensaio-report-table .ensaio-limit-row-head { background: #EEF2F6; }
.ensaio-report-table .ensaio-limits-sep td {
  background: #E5E7EB; font-weight: 700; font-size: 7.5px;
  text-transform: uppercase; letter-spacing: .4px; color: #475569; padding: 1px 4px;
}
.ensaio-report-table .ensaio-footer {
  font-size: 8px; color: #444; font-style: italic; padding: 2px 6px;
}
.ensaio-equip-line {
  margin: 3px auto 0; max-width: 540px; font-size: 8.5px;
  display: flex; gap: 6px; align-items: center; flex-wrap: wrap;
  line-height: 1.2;
}
.ensaio-equip-line .ensaio-equip-lbl {
  font-weight: 700; text-transform: uppercase; letter-spacing: .3px; font-size: 8px;
}
.ensaio-equip-line .ensaio-cb {
  display: inline-flex; align-items: center; gap: 3px;
}

/* Pair-cell: célula que contém pares Esq/Dir lado a lado (ex: G0501_incl_esq + G0501_incl_dir).
   Usada quando dois ou mais fields compartilham o mesmo `row` no schema. */
.rpt-frm041 .f041-pair-cell {
  padding: 0 !important;
}
.rpt-frm041 .f041-pair-cell .pair-row {
  display: flex;
  border-bottom: 1px solid #999;
}
.rpt-frm041 .f041-pair-cell .pair-row:last-child {
  border-bottom: none;
}
.rpt-frm041 .f041-pair-cell .pair-half {
  flex: 1;
  padding: 2px 4px;
  font-size: 8.5px;
  line-height: 1.2;
}
.rpt-frm041 .f041-pair-cell .pair-half + .pair-half {
  border-left: 1px solid #999;
}

/* Tabelas inline FRM-041 (G0301, G0312, G0608, G0702, G0803, G0900, G1007, G1009) */
.rpt-frm041 .f041-table-data {
  width: 100%;
  border-collapse: collapse;
  font-size: 8.5px;
  margin: 2px 0 4px;
}
.rpt-frm041 .f041-table-data th,
.rpt-frm041 .f041-table-data td {
  border: 1px solid #666;
  padding: 2px 4px;
}
.rpt-frm041 .f041-table-data th {
  background: #e0e0e0;
  font-weight: 700;
  text-align: center;
  font-size: 8px;
  text-transform: uppercase;
}
.rpt-frm041 .f041-cell-readonly {
  background: #f5f5f5;
  font-size: 8px;
  font-style: italic;
  color: #555;
  text-align: center;
}

/* Ícones de status (Aprov/Reprov/N-A/Empty) — próprios do FRM-041 */
.rpt-frm041 .f041-aprov  { color: #1b5e20; font-size: 12px; font-weight: 900; }
.rpt-frm041 .f041-reprov { color: #b71c1c; font-weight: 900; }
.rpt-frm041 .f041-na     { color: #555; font-weight: 900; }
.rpt-frm041 .f041-empty  { color: #bbb; }

/* ═══════════════════════════════════════════════════════
   DROPDOWN MULTI-SELEÇÃO DE SERVIÇOS (Gerencial → Filtros)
   ═══════════════════════════════════════════════════════ */
.svc-dropdown {
  position: relative;
  width: 100%;
}
.svc-dd-trigger {
  width: 100%;
  background: #fff;
  border: 1px solid var(--border, #ccc);
  border-radius: 6px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-size: 13px;
  text-align: left;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.svc-dd-trigger:hover,
.svc-dropdown.open .svc-dd-trigger {
  border-color: var(--primary, #1976d2);
  box-shadow: 0 0 0 2px rgba(25,118,210,0.1);
}
.svc-dd-trigger-label {
  flex: 1;
  color: var(--text-pri, #333);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.svc-dd-arrow {
  color: var(--text-sec, #666);
  font-size: 11px;
  margin-left: 10px;
  transition: transform 0.2s;
}
.svc-dropdown.open .svc-dd-arrow { transform: rotate(180deg); }

.svc-dd-panel {
  /* Fica in-flow (empurra o conteúdo abaixo) para não ser cortado
     pelo overflow:hidden do .filter-panel. */
  margin-top: 6px;
  background: #fff;
  border: 1px solid var(--border, #ccc);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  max-height: 380px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.svc-dd-header {
  padding: 10px 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--border, #eee);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-sec, #666);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.svc-dd-clear {
  background: none;
  border: none;
  color: var(--primary, #1976d2);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
  text-transform: uppercase;
}
.svc-dd-clear:hover { text-decoration: underline; }

.svc-dd-list {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}
.svc-dd-option {
  display: grid;
  grid-template-columns: 24px 90px 1fr;
  gap: 10px;
  align-items: center;
  padding: 8px 14px;
  cursor: pointer;
  font-size: 13px;
  border-left: 3px solid transparent;
  transition: background 0.1s;
}
.svc-dd-option:hover { background: #f5faff; }
.svc-dd-option.selected {
  background: #e3f2fd;
  border-left-color: var(--primary, #1976d2);
}
.svc-dd-option input { margin: 0; }
.svc-dd-code {
  font-family: ui-monospace, Consolas, monospace;
  font-weight: 700;
  color: var(--primary, #1976d2);
  font-size: 12px;
}
.svc-dd-desc {
  color: var(--text-pri, #333);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.svc-dd-footer {
  padding: 8px 14px;
  border-top: 1px solid var(--border, #eee);
  display: flex;
  justify-content: flex-end;
}
.svc-dd-empty {
  padding: 16px;
  text-align: center;
  color: var(--text-sec, #888);
  font-style: italic;
  font-size: 12px;
}

/* Tags abaixo do dropdown com os serviços selecionados */
.svc-dd-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.svc-dd-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--primary, #1976d2);
  color: #fff;
  padding: 3px 4px 3px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  font-family: ui-monospace, Consolas, monospace;
}
.svc-dd-tag-x {
  background: rgba(255,255,255,0.2);
  border: none;
  color: #fff;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.svc-dd-tag-x:hover { background: rgba(255,255,255,0.35); }

body.theme-dark .svc-dd-trigger,
body.theme-dark .svc-dd-panel {
  background: #1e2430;
  color: #e0e0e0;
  border-color: #2a3140;
}
body.theme-dark .svc-dd-option:hover { background: #2a3140; }
body.theme-dark .svc-dd-option.selected { background: #1a2a3a; }
body.theme-dark .svc-dd-empty { color: #888; }

/* ═══════════════════════════════════════════════════════
   CHECKBOXES (tipo de campo 'checkboxes' — multi-seleção)
   ═══════════════════════════════════════════════════════ */
.cb-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cb-group.cb-inline {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 10px;
}
.cb-opt {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--border, #ccc);
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  background: #fff;
  user-select: none;
  transition: all 0.15s;
}
.cb-opt:hover { border-color: var(--primary, #1976d2); }
.cb-opt.checked {
  background: var(--primary-light, #e3f2fd);
  border-color: var(--primary, #1976d2);
}
.cb-opt input { display: none; }
.cb-box {
  width: 20px;
  height: 20px;
  border: 2px solid var(--primary, #1976d2);
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--primary, #1976d2);
  font-weight: 700;
  font-size: 14px;
  background: #fff;
}
.cb-opt.checked .cb-box {
  background: var(--primary, #1976d2);
  color: #fff;
}
.cb-label { font-weight: 600; font-size: 14px; }
body.theme-dark .cb-opt { background: #1e2430; color: #e0e0e0; }
body.theme-dark .cb-opt.checked { background: #1a2a3a; }
body.theme-dark .cb-box { background: #1e2430; }
body.theme-dark .cb-opt.checked .cb-box { background: var(--primary, #1976d2); }

/* Célula footnote nas tabelas (texto spans toda a linha, itálico cinza) */
.insp-table td.cell-footnote,
.rpt-frm041 .f041-cell-footnote {
  background: #fafafa;
  font-size: 11px;
  font-style: italic;
  color: #555;
  padding: 6px 10px;
  text-align: left;
}
body.theme-dark .insp-table td.cell-footnote { background: #232936; color: #aaa; }

/* Checkboxes no relatório FRM-041 */
.rpt-frm041 .f041-cb {
  font-family: inherit;
  font-size: 10px;
  font-weight: 600;
  color: #555;
  margin-right: 4px;
}
.rpt-frm041 .f041-cb.on { color: #000; font-weight: 700; }

/* ═══════════════════════════════════════════════════════
   TIPOS DE USUARIO (RBAC) - grid de permissoes
   ═══════════════════════════════════════════════════════ */
.perm-group {
  border: 1px solid var(--border, #ddd);
  border-radius: 8px;
  padding: 12px 16px;
  margin: 12px 0;
  background: var(--card, #fafafa);
}
.perm-group legend {
  font-weight: 700;
  font-size: 13px;
  color: var(--primary, #1976d2);
  padding: 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.perm-group-toggle {
  background: none;
  border: 1px solid var(--border, #ccc);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 10px;
  cursor: pointer;
  color: var(--text-sec, #666);
  margin-left: 4px;
}
.perm-group-toggle:hover { background: #eee; }
.perm-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 6px 16px;
  margin-top: 8px;
}
.perm-item {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 6px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.perm-item:hover { background: rgba(25,118,210,0.06); }
.perm-item input[type="checkbox"] { margin-top: 3px; }
.perm-item strong { font-weight: 600; font-size: 12px; display: block; }
.perm-code {
  font-family: ui-monospace, Consolas, monospace;
  font-size: 10px;
  color: #888;
  display: block;
  margin-top: 2px;
}

/* ═══════════════════════════════════════════════════════
   Sub-aba VALIDAÇÃO — linha compacta
   Fonte preta em ambas variantes; fundo azul claro quando validada.
   ═══════════════════════════════════════════════════════ */
.valid-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 12px;
}
.valid-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border: 1px solid #d6dce4;
  border-radius: 8px;
  background: #ffffff;
  color: #000;
  font-size: 13px;
  flex-wrap: wrap;
  cursor: pointer;
  transition: box-shadow .15s ease, transform .05s ease;
}
.valid-row:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,.10);
  border-color: #9aa3ae;
}
.valid-row:active { transform: translateY(1px); }
.valid-row.validated {
  background: #e3f2fd;
  border-color: #90caf9;
}
.valid-row.validated:hover {
  box-shadow: 0 2px 8px rgba(13,71,161,.18);
  border-color: #1976d2;
}
.valid-col { display: flex; align-items: center; gap: 4px; }
.valid-col-ident { flex: 1 1 420px; flex-wrap: wrap; gap: 6px; }
.valid-col-ident .sep { color: #888; margin: 0 2px; }
.valid-col-status   { flex: 0 0 auto; min-width: 140px; justify-content: center; }
.valid-col-valstatus{ flex: 0 0 auto; min-width: 120px; justify-content: center; }
.valid-col-valdata  { flex: 0 0 auto; min-width: 140px; justify-content: center; font-variant-numeric: tabular-nums; }
.valid-col-action   { flex: 0 0 auto; min-width: 90px; justify-content: flex-end; }
.valid-col-empty    { color: #aaa; }

.valid-badge-status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .3px;
  white-space: nowrap;
}
/* Métrica TO (Tempo de Ociosidade) — destaque conforme horas aguardando */
.to-metric        { font-variant-numeric: tabular-nums; }
.to-metric.to-live     { color: #1565c0; font-weight: 700; }              /* < 24h */
.to-metric.to-warn     { color: #e65100; font-weight: 700; }              /* 24–48h */
.to-metric.to-critical { color: #b71c1c; font-weight: 700;                /* ≥ 48h */
                         text-shadow: 0 0 1px rgba(183,28,28,.15); }

.valid-badge-aprov      { background: #c8e6c9; color: #1b5e20; }
.valid-badge-reprov     { background: #ffcdd2; color: #b71c1c; }
.valid-badge-reinsp     { background: #ffe0b2; color: #e65100; }
.valid-badge-incompleto { background: #ffa726; color: #000; border: 1px solid #ef6c00; font-weight: 700; }
.valid-badge-aguardando { background: #fff3cd; color: #856404; border: 1px solid #ffeeba; }
.valid-badge-validada   { background: #bbdefb; color: #0d47a1; border: 1px solid #64b5f6; }

.btn-sm { padding: 4px 10px; font-size: 12px; border-radius: 6px; }

/* (classe .validated-mark removida — o selo agora é a TAG "VALIDADA"
   reutilizando .valid-badge-status + .valid-badge-validada) */

/* ═══════════════════════════════════════════════════════
   Sub-aba PRODUTIVIDADE — dashboard + rankings
   ═══════════════════════════════════════════════════════ */
.stat-grid-prod {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}
.prod-ranking {
  margin-top: 20px;
}
.prod-ranking .list-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary-dark);
  margin: 0 0 8px;
}
.prod-table td,
.prod-table th {
  font-size: 12.5px;
}
.prod-table tbody tr:hover { background: #f5f8ff; }
.empty-state-inline {
  color: #888;
  font-size: 12px;
  font-style: italic;
}

/* ═══════════════════════════════════════════════════════
   Painel "Jornada do Processo" (Gerencial → Produtividade)
   3 colunas em tempo real com timer por etapa.
   ═══════════════════════════════════════════════════════ */
.jp-panel { margin: 8px 0 24px; }
.jp-panel-head {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin: 0 0 10px;
}
.jp-panel-title {
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}
.jp-legend {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 12px;
  color: var(--text-sec);
}
.jp-legend-item { display: inline-flex; align-items: center; gap: 6px; }
.jp-dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  display: inline-block;
  flex: 0 0 auto;
}
.jp-dot.dot-green  { background: #16a34a; }
.jp-dot.dot-yellow { background: #f59e0b; }
.jp-dot.dot-red    { background: #dc2626; }
.jp-dot.dot-blue   { background: #2563eb; }
.jp-dot.dot-amber  { background: #d97706; }

.jp-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 1100px) { .jp-cols { grid-template-columns: 1fr; } }

.jp-col {
  background: var(--card);
  border-radius: 12px;
  border: 1px solid var(--border);
  box-shadow: 0 1px 2px rgba(15,23,42,0.04), 0 1px 3px rgba(15,23,42,0.05);
  padding: 14px;
  display: flex;
  flex-direction: column;
  min-height: 200px;
}
.jp-col-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.3px;
  margin-bottom: 12px;
}

.jp-sum {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 14px;
  padding: 10px 14px 12px;
  border-radius: 10px;
  background: rgba(100,116,139,0.07);
  margin-bottom: 14px;
  transition: background .35s ease;
}
.jp-sum-l, .jp-sum-r { display: flex; flex-direction: column; gap: 2px; }
.jp-sum-r { align-items: flex-end; }
.jp-sum-cap {
  font-size: 10.5px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-sec);
}
.jp-sum-time {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  font-size: 22px;
  line-height: 1;
  color: var(--text);
}
.jp-sum-count {
  font-weight: 800;
  font-size: 22px;
  line-height: 1;
  color: var(--text);
}
.jp-sum[data-zone="green"]  { background: #ecfdf5; }
.jp-sum[data-zone="yellow"] { background: #fef3c7; }
.jp-sum[data-zone="red"]    { background: #fee2e2; }
.jp-sum[data-zone="empty"]  { background: rgba(100,116,139,0.07); }

.jp-cards { display: flex; flex-direction: column; gap: 8px; }

.jp-card {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .35s ease, border-color .35s ease;
}
.jp-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 6px rgba(15,23,42,0.07);
}
.jp-card-zone { width: 9px; height: 9px; border-radius: 50%; background: #94a3b8; }
.jp-card-plate {
  font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.4px;
  color: var(--text);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.jp-card-tag {
  display: inline-block;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 4px;
  background: rgba(220,38,38,0.10);
  color: #991b1b;
  font-family: -apple-system, BlinkMacSystemFont, 'Inter', system-ui, sans-serif;
}
.jp-card-time {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  font-size: 12.5px;
  color: var(--text-sec);
}

.jp-card[data-zone="green"]  { background: #f0fdf4; border-color: #bbf7d0; }
.jp-card[data-zone="yellow"] { background: #fffbeb; border-color: #fde68a; }
.jp-card[data-zone="red"]    { background: #fef2f2; border-color: #fecaca; }
.jp-card[data-zone="green"]  .jp-card-zone { background: #16a34a; }
.jp-card[data-zone="yellow"] .jp-card-zone { background: #f59e0b; }
.jp-card[data-zone="red"]    .jp-card-zone { background: #dc2626; }

.jp-more {
  margin-top: 4px;
  padding: 8px 12px;
  border-radius: 8px;
  color: var(--primary-dark);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: background .15s;
}
.jp-more:hover { background: rgba(37,99,235,0.08); }

.jp-empty {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-sec);
  font-size: 12px;
  font-style: italic;
  padding: 20px 0;
}

/* Tema escuro — ajustes mínimos */
body.theme-dark .jp-card                  { background: #1e293b; }
body.theme-dark .jp-card[data-zone="green"]  { background: #052e1a; border-color: #14532d; }
body.theme-dark .jp-card[data-zone="yellow"] { background: #2c1d04; border-color: #78350f; }
body.theme-dark .jp-card[data-zone="red"]    { background: #2c0a0a; border-color: #7f1d1d; }
body.theme-dark .jp-sum[data-zone="green"]   { background: #052e1a; }
body.theme-dark .jp-sum[data-zone="yellow"]  { background: #2c1d04; }
body.theme-dark .jp-sum[data-zone="red"]     { background: #2c0a0a; }

/* ═══════════════════════════════════════════════════════
   Editor de Regras de Avaliação Automática (form_field_rules)
   ═══════════════════════════════════════════════════════ */
.rules-step { margin: 20px 0 28px; }
.rules-step h3 {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary-dark);
  margin: 0 0 8px;
  padding: 6px 10px;
  background: #f0f4ff;
  border-left: 4px solid var(--primary);
  border-radius: 4px;
}
.rules-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.rules-table th,
.rules-table td {
  padding: 8px 10px;
  border-bottom: 1px solid #e5e7eb;
  text-align: left;
  vertical-align: middle;
}
.rules-table th {
  background: #f9fafb;
  font-weight: 600;
  color: #374151;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.rules-table tbody tr:hover { background: #f5f8ff; }
.rules-cell-desc { color: #1b5e20; font-weight: 500; }
.ref-chip {
  display: inline-block;
  background: #eef2ff;
  color: #3730a3;
  border: 1px solid #c7d2fe;
  border-radius: 4px;
  padding: 1px 6px;
  margin: 1px 2px 1px 0;
  font-size: 11px;
  font-family: ui-monospace, Consolas, monospace;
  white-space: nowrap;
}
.form-chip {
  display: inline-block;
  background: #fef3c7;
  color: #78350f;
  border: 1px solid #fde68a;
  border-radius: 10px;
  padding: 1px 8px;
  margin: 1px 2px 1px 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .02em;
}

.rules-refs {
  margin-top: 24px;
  padding: 10px 14px;
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
}
.rules-refs summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 13px;
  color: #475569;
}
.rules-refs-body { margin-top: 10px; }
.rules-refs-body h4 { margin: 8px 0 4px; font-size: 12px; color: #374151; }
.rules-refs-body ul { margin: 0; padding-left: 20px; font-size: 12px; }
.rules-refs-body li { margin: 2px 0; color: #475569; }
.rules-refs-body .tiny { color: #9ca3af; font-size: 11px; }

/* Modal genérico (usado pelo modal de regra) */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 90;
}
.modal-box {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 12px 40px rgba(0,0,0,.25);
  padding: 22px 26px;
  z-index: 91;
  max-width: 560px;
  width: calc(100% - 32px);
  max-height: 90vh;
  overflow-y: auto;
}
.rules-modal h3 {
  color: var(--primary-dark);
  border-bottom: 1px solid var(--border);
  padding-bottom: 10px;
  margin-bottom: 16px;
}

/* Lock visual em check3 com regra ativa */
.check3-group.check3-locked {
  opacity: .82;
  position: relative;
  filter: saturate(.7);
}
.check3-group.check3-locked .check3-btn {
  cursor: not-allowed;
}
.check3-group.check3-locked .check3-btn:not(.selected) {
  opacity: .55;
}
.check3-lock-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 8px;
  border-radius: 999px;
  background: #e3f2fd;
  color: #0d47a1;
  border: 1px solid #90caf9;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  vertical-align: middle;
  cursor: help;
}

/* V40+: badge "REGRA · Item Específico" — sinaliza que o item só está aparecendo
   porque uma regra_especifica autorizou (subcategoria CTB + cabine bateu). */
.regra-esp-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 1px 8px;
  border-radius: 999px;
  background: #f3e8ff;
  color: #6b21a8;
  border: 1px solid #c4b5fd;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  vertical-align: middle;
  cursor: help;
  white-space: nowrap;
}
body.theme-dark .regra-esp-badge {
  background: #4c1d95;
  color: #ede9fe;
  border-color: #7c3aed;
}
/* Variante compacta pra sub-itens — só o ícone 🔍, sem texto. */
.regra-esp-badge-mini {
  margin: 0 4px 0 4px;
  padding: 0 5px;
  font-size: 10px;
  letter-spacing: 0;
}

/* Editor de regra composta — blocos de condições */
.cond-editor {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin: 8px 0;
  background: #fafbfc;
}
.cond-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.cond-editor-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .05em;
  background: #dbeafe;
  color: #1e40af;
  padding: 2px 10px;
  border-radius: 999px;
  text-transform: uppercase;
}
.cond-and-sep {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  color: #64748b;
  margin: 4px 0;
  padding: 4px 0;
  text-transform: uppercase;
}
.rules-modal {
  max-width: 640px;
}

/* Modo VALIDAÇÃO no relatório — banner + rodapé fixo */
.val-banner {
  position: sticky;
  top: 0;
  z-index: 50;
  background: #0d47a1;
  color: #fff;
  text-align: center;
  padding: 8px 12px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .5px;
}
.val-footer {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: #fff;
  border-top: 2px solid #0d47a1;
  padding: 12px 16px;
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  box-shadow: 0 -4px 12px rgba(0,0,0,.08);
  z-index: 60;
}
.val-footer .btn-primary { background: #1b5e20; }
body:has(.val-footer) { padding-bottom: 80px; }

/* ══════════════════════════════════════════════════════════════════
   MODELO — Canvas interativo (drag, smart guides, resize)
   Usado em Configurações → Formulários → MODELO no painel direito.
   ══════════════════════════════════════════════════════════════════ */
.modelo-canvas-wrap {
  position: relative;
  width: 100%;
  height: 780px;
  min-height: 300px;
  max-height: 3000px;
  overflow: auto;
  background: #0f1115;
  border-top: 1px solid #2c3345;
  color: #e8eaf0;
  /* Borda inferior arrastável (native browser resizer). */
  resize: vertical;
}
.modelo-canvas {
  /* Largura de uma folha A4 retrato @96dpi; altura alta pra permitir scroll
     com muitas famílias. Fundo branco puro (sem grade) pra simular a folha. */
  position: relative;
  width: 794px;
  height: 2000px;
  margin: 0 auto 40px;
  background: #ffffff;
  box-shadow: 0 0 0 1px #c8ced6, 0 10px 40px rgba(0,0,0,.45);
  user-select: none;
}
/* Alça pra ajustar a altura do "papel" (delimitação do formulário).
   Fica colada na borda inferior do canvas branco. */
.modelo-canvas-height-grip {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -12px;
  height: 12px;
  cursor: ns-resize;
  z-index: 6;
  background:
    linear-gradient(to bottom, transparent 0, transparent 3px, #1565C0 3px, #1565C0 5px, transparent 5px),
    linear-gradient(to bottom, transparent 0, transparent 6px, rgba(21,101,192,.5) 6px, rgba(21,101,192,.5) 7px, transparent 7px);
}
.modelo-canvas-height-grip::after {
  content: '↕ altura';
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  font-size: 10px;
  color: #1565C0;
  font-weight: 700;
  background: #fff;
  padding: 1px 8px;
  border-radius: 3px;
  border: 1px solid #c8ced6;
}
.modelo-canvas-wrap { background: #2a2f3a; }

/* Cabeçalho e rodapé fixos no canvas — ajudam a ter noção do topo e fim
   da folha impressa. Read-only (não arrastáveis). */
.modelo-canvas-header,
.modelo-canvas-footer {
  position: absolute;
  left: 8px;
  right: 8px;
  pointer-events: none;
  z-index: 3;
}
.modelo-canvas-header { top: 8px; }
.modelo-canvas-footer { bottom: 16px; }
.modelo-canvas-header .mch-title {
  font-size: 11px;
  font-weight: 700;
  text-align: center;
  color: #1565C0;
  text-transform: uppercase;
  letter-spacing: .3px;
  margin-bottom: 2px;
}
.modelo-canvas-header .mch-subtitle {
  font-size: 9px;
  text-align: center;
  color: #546e7a;
  margin-bottom: 6px;
}
.modelo-canvas-header .mch-ids {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-bottom: 4px;
}
.modelo-canvas-header .mch-ids > div {
  border: 1px solid #d0d7de;
  border-radius: 3px;
  padding: 3px 5px;
  background: #fafcff;
}
.modelo-canvas-header .mch-ids label {
  display: block;
  font-size: 7px;
  font-weight: 700;
  color: #546e7a;
  text-transform: uppercase;
}
.modelo-canvas-header .mch-ids span {
  font-size: 9px;
  color: #000;
  letter-spacing: 1px;
}
.modelo-canvas-header .mch-legend {
  font-size: 8px;
  color: #546e7a;
  font-style: italic;
  text-align: center;
  border: 1px solid #d0d7de;
  padding: 2px 4px;
  border-radius: 3px;
  background: #fafcff;
}
.modelo-canvas-header .mch-box,
.modelo-canvas-footer .mcf-box {
  border: 2px solid #1565C0;
  border-radius: 4px;
  padding: 6px 8px;
  background: #fff;
}
.modelo-canvas-footer .mcf-title {
  background: #1565C0;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 2px 2px 0 0;
  margin: -6px -8px 4px;
  letter-spacing: .3px;
}
.modelo-canvas-footer .mcf-obs {
  border: 1px solid #e0e0e0;
  min-height: 28px;
  padding: 3px 5px;
  font-size: 8px;
  color: #94a3b8;
  font-style: italic;
  margin-bottom: 4px;
  background: #fafafa;
}
.modelo-canvas-footer .mcf-row3 {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 6px;
  align-items: center;
  font-size: 8px;
  margin-bottom: 6px;
}
.modelo-canvas-footer .mcf-badge {
  background: #fff5e6;
  color: #e07a00;
  border: 1px solid #e07a00;
  border-radius: 3px;
  padding: 2px 10px;
  font-weight: 700;
  font-size: 9px;
  letter-spacing: 1.5px;
}
.modelo-canvas-footer .mcf-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  font-size: 7px;
  color: #475569;
}
.modelo-canvas-center-line {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 397px;
  width: 0;
  border-left: 2px dashed rgba(240,180,41,.35);
  pointer-events: none;
  transition: border-color .2s, box-shadow .2s;
  z-index: 2;
}
.modelo-canvas-center-line.is-active {
  border-left-color: #f0b429;
  box-shadow: 0 0 12px rgba(240,180,41,.45);
}
.modelo-canvas-center-line::before {
  content: 'CENTRO';
  position: absolute;
  top: 4px;
  left: 6px;
  font-size: 9px;
  font-weight: 700;
  color: rgba(240,180,41,.7);
  letter-spacing: 2px;
}

.modelo-family {
  position: absolute;
  background: #1b2030;
  border: 1px solid #2c3345;
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: box-shadow .2s, border-color .2s;
  z-index: 5;
}
.modelo-family.is-dragging {
  z-index: 30;
  border-color: rgba(34,197,94,.65);
  box-shadow: 0 12px 36px rgba(0,0,0,.55), 0 0 0 2px rgba(34,197,94,.35);
  cursor: grabbing;
}
.modelo-family.is-resizing {
  z-index: 30;
  border-color: rgba(240,180,41,.7);
}
.modelo-family.is-overlap {
  border-color: #ef4444;
  box-shadow: 0 0 0 2px rgba(239,68,68,.35), inset 0 0 0 9999px rgba(239,68,68,.14);
  animation: modelo-pulse-red 1.2s ease-in-out infinite;
}
@keyframes modelo-pulse-red {
  0%,100% { box-shadow: 0 0 0 2px rgba(239,68,68,.35), inset 0 0 0 9999px rgba(239,68,68,.10); }
  50%     { box-shadow: 0 0 0 3px rgba(239,68,68,.55), inset 0 0 0 9999px rgba(239,68,68,.22); }
}

.modelo-family-title {
  background: #1565C0;
  color: #fff;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .3px;
  cursor: grab;
  display: flex;
  align-items: center;
  gap: 8px;
  user-select: none;
}
.modelo-family-title:active { cursor: grabbing; }
.modelo-family-title .drag-handle { opacity: .6; font-size: 14px; line-height: 1; }
.modelo-family-title .coords {
  margin-left: auto;
  font-family: ui-monospace, Consolas, monospace;
  font-size: 9px;
  font-weight: 500;
  opacity: .75;
}
.modelo-family-body {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
  background: #fff;
  color: #000;
  font-size: 11px;
}
.modelo-subitem {
  display: grid;
  grid-template-columns: 20px 60px 30px 1fr;
  gap: 4px;
  padding: 3px 8px;
  align-items: center;
  cursor: grab;
  border-bottom: 1px solid #f0f0f0;
}
.modelo-subitem:last-child { border-bottom: 0; }
.modelo-subitem .si-handle { color: #94a3b8; font-size: 10px; text-align: center; }
.modelo-subitem .si-code {
  font-family: ui-monospace, Consolas, monospace;
  font-size: 9px;
  color: #475569;
}
.modelo-subitem .si-check { color: #cbd5e1; font-weight: 900; text-align: center; font-size: 10px; }
.modelo-subitem.is-ghost { opacity: .4; }
.modelo-subitem.is-drop-blocked {
  background: rgba(239,68,68,.15);
  cursor: not-allowed;
}
.modelo-subitem-drop-line {
  height: 2px;
  margin: -1px 0;
  background: #22c55e;
  box-shadow: 0 0 4px rgba(34,197,94,.7);
}

.modelo-family-resize {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 20px;
  height: 20px;
  cursor: nwse-resize;
  z-index: 4;
  background:
    linear-gradient(135deg, transparent 45%, rgba(148,163,184,.6) 45% 55%, transparent 55%),
    linear-gradient(135deg, transparent 62%, rgba(148,163,184,.6) 62% 72%, transparent 72%),
    linear-gradient(135deg, transparent 79%, rgba(148,163,184,.6) 79% 89%, transparent 89%);
}

.modelo-drop-target {
  position: absolute;
  border: 2px dashed rgba(34,197,94,.8);
  background: rgba(34,197,94,.12);
  border-radius: 6px;
  pointer-events: none;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(34,197,94,.9);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  animation: modelo-breathe 1.6s ease-in-out infinite;
}
.modelo-drop-target.at-center {
  border-color: rgba(240,180,41,.9);
  background: rgba(240,180,41,.12);
  color: rgba(240,180,41,.95);
}
@keyframes modelo-breathe {
  0%,100% { opacity: .85; transform: scale(1); }
  50%     { opacity: 1;   transform: scale(1.01); }
}

.modelo-smart-guide {
  position: absolute;
  pointer-events: none;
  z-index: 25;
  background: transparent;
}
.modelo-smart-guide.axis-v {
  width: 0;
  border-left: 1px dashed #ff4fa3;
  box-shadow: 0 0 6px rgba(255,79,163,.6);
}
.modelo-smart-guide.axis-h {
  height: 0;
  border-top: 1px dashed #ff4fa3;
  box-shadow: 0 0 6px rgba(255,79,163,.6);
}
.modelo-smart-guide::before,
.modelo-smart-guide::after {
  content: '';
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #ff4fa3;
  box-shadow: 0 0 6px rgba(255,79,163,.8);
}
.modelo-smart-guide.axis-v::before { top: -3px;    left: -3px; }
.modelo-smart-guide.axis-v::after  { bottom: -3px; left: -3px; }
.modelo-smart-guide.axis-h::before { left: -3px;  top: -3px; }
.modelo-smart-guide.axis-h::after  { right: -3px; top: -3px; }

.modelo-resize-tip {
  position: absolute;
  background: #f0b429;
  color: #1b1f28;
  padding: 4px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  pointer-events: none;
  z-index: 35;
  font-family: ui-monospace, Consolas, monospace;
  white-space: nowrap;
  box-shadow: 0 2px 8px rgba(0,0,0,.4);
}

.modelo-canvas-toolbar {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  gap: 6px;
  z-index: 40;
}
.modelo-canvas-toolbar button {
  background: rgba(27,32,48,.92);
  border: 1px solid #2c3345;
  color: #e8eaf0;
  padding: 4px 10px;
  font-size: 11px;
  border-radius: 4px;
  cursor: pointer;
}
.modelo-canvas-toolbar button:hover { background: #2c3345; }

.modelo-status {
  position: absolute;
  bottom: 8px;
  right: 8px;
  background: rgba(27,32,48,.92);
  color: #e8eaf0;
  padding: 6px 10px;
  border: 1px solid #2c3345;
  border-radius: 4px;
  font-size: 11px;
  font-family: ui-monospace, Consolas, monospace;
  z-index: 40;
  pointer-events: none;
  max-width: 420px;
}

/* ═══════════════════════════════════════════════════════════════
   TIPOS DE USUÁRIO — Redesign V3 (3 macro-áreas)
   Namespace `.tu-*` para isolar do CSS antigo de permissões.
   ═══════════════════════════════════════════════════════════════ */
.tu-page {
  --op-color: #2563eb;
  --gr-color: #f59e0b;
  --fi-color: #16a34a;   /* V23+: módulo Financeiro (verde — dinheiro) */
  --cf-color: #dc2626;
}
/* Garante que toda a árvore .tu-* herda a fonte global do app
   (system-ui), sem fallbacks de browser. */
.tu-page,
.tu-page * { font-family: inherit; }

.tu-page-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; padding-bottom: 14px; margin-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.tu-page-header h2 {
  font-size: 26px; font-weight: 700; color: var(--text);
  letter-spacing: -0.015em; line-height: 1.1; margin: 0;
}
.tu-page-header .tu-subtitle {
  font-size: 11px; color: var(--text-sec); margin-top: 6px;
  text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600;
}
.tu-editing-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; border: 1px solid var(--border);
  padding: 7px 12px; border-radius: 999px; font-size: 13px;
  color: var(--text-sec); box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.tu-editing-pill .tu-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}
.tu-editing-pill strong { color: var(--text); margin-left: 4px; }
body.theme-dark .tu-editing-pill { background: var(--card); }

/* ── Identidade (nome + descrição + presets) ── */
.tu-identity {
  background: #fff; border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 18px;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 22px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
@media (max-width: 880px) { .tu-identity { grid-template-columns: 1fr; } }
body.theme-dark .tu-identity { background: var(--card); }
.tu-identity .tu-name { font-size: 17px; font-weight: 600; max-width: 100%; }
.tu-identity .tu-toggle {
  display: flex; gap: 8px; align-items: center; margin-top: 10px;
  font-size: 14px; color: var(--text-sec); cursor: pointer;
}
.tu-identity .tu-toggle input { width: 16px; height: 16px; }

.tu-preset-row {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px;
}
.tu-preset-chip {
  padding: 6px 14px; border-radius: 999px; font-size: 13px; font-weight: 600;
  background: #fff; border: 1px solid var(--border); color: var(--text-sec);
  cursor: pointer; transition: all 0.15s;
}
.tu-preset-chip:hover { border-color: var(--primary); color: var(--primary); }
.tu-preset-chip.active {
  background: var(--primary); color: #fff; border-color: var(--primary);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--primary) 30%, transparent);
}
body.theme-dark .tu-preset-chip { background: var(--card); }

/* ── 3 cards macro (resumo) ── */
.tu-macro-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 18px;
}
@media (max-width: 1100px) { .tu-macro-grid { grid-template-columns: 1fr; } }

.tu-macro {
  background: #fff; border: 1px solid var(--border); border-radius: 12px;
  overflow: hidden; transition: all 0.2s; cursor: pointer; position: relative;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.tu-macro::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--macro-color);
}
.tu-macro:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(15,23,42,0.08);
  border-color: color-mix(in srgb, var(--macro-color) 35%, var(--border));
}
.tu-macro.is-active {
  border-color: var(--macro-color);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--macro-color) 12%, transparent);
}
.tu-macro[data-area="operacional"] { --macro-color: var(--op-color); }
.tu-macro[data-area="gerencial"]   { --macro-color: var(--gr-color); }
.tu-macro[data-area="financeiro"]  { --macro-color: var(--fi-color); }
.tu-macro[data-area="config"]      { --macro-color: var(--cf-color); }
body.theme-dark .tu-macro { background: var(--card); }

.tu-macro-head { padding: 14px 16px 6px; }
.tu-macro-num {
  font-size: 11px; font-weight: 700; color: var(--text-sec);
  letter-spacing: 0.18em; text-transform: uppercase;
}
.tu-macro-name {
  font-size: 19px; font-weight: 700; color: var(--text);
  margin-top: 4px; line-height: 1.2; letter-spacing: -0.01em;
}
.tu-macro-name span { color: var(--macro-color); }
.tu-macro-desc {
  font-size: 12px; color: var(--text-sec); margin-top: 4px; line-height: 1.4;
}
.tu-macro-meter {
  margin: 12px 16px 0;
  display: flex; align-items: baseline; justify-content: space-between; gap: 8px;
}
.tu-macro-meter-num {
  font-size: 26px; font-weight: 800; line-height: 1;
  color: var(--macro-color); font-variant-numeric: tabular-nums;
}
.tu-macro-meter-num small {
  font-size: 13px; font-weight: 500; color: var(--text-sec); margin-left: 3px;
}
.tu-macro-meter-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--text-sec); font-weight: 700;
}
.tu-macro-bar {
  margin: 8px 16px 0; height: 4px; background: #f1f5f9;
  border-radius: 2px; overflow: hidden;
}
body.theme-dark .tu-macro-bar { background: #1e293b; }
.tu-macro-bar-fill {
  height: 100%; background: var(--macro-color); border-radius: 2px;
  transition: width 0.4s ease;
}
.tu-macro-actions { margin: 10px 16px 14px; display: flex; gap: 6px; }
.tu-macro-btn {
  flex: 1; font-size: 11px; padding: 6px 10px; border-radius: 6px;
  background: #fff; border: 1px solid var(--border); color: var(--text-sec);
  cursor: pointer; font-weight: 600; transition: all 0.15s;
}
.tu-macro-btn:hover {
  border-color: var(--macro-color); color: var(--macro-color);
  background: color-mix(in srgb, var(--macro-color) 6%, #fff);
}
body.theme-dark .tu-macro-btn { background: var(--card); }

/* ── Detalhe expandido ── */
.tu-detail {
  background: #fff; border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 20px; margin-bottom: 12px;
  border-top: 3px solid var(--macro-color);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
body.theme-dark .tu-detail { background: var(--card); }
.tu-detail[data-area="operacional"] { --macro-color: var(--op-color); }
.tu-detail[data-area="gerencial"]   { --macro-color: var(--gr-color); }
.tu-detail[data-area="financeiro"]  { --macro-color: var(--fi-color); }
.tu-detail[data-area="config"]      { --macro-color: var(--cf-color); }

.tu-detail-head { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.tu-detail-head h3 {
  font-size: 22px; font-weight: 700; color: var(--text);
  letter-spacing: -0.015em; line-height: 1.15; margin: 0;
}
.tu-detail-head h3 span { color: var(--macro-color); }
.tu-detail-head .tu-badge {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em;
  background: color-mix(in srgb, var(--macro-color) 12%, transparent);
  color: var(--macro-color); padding: 4px 10px; border-radius: 999px;
  font-weight: 700; border: 1px solid color-mix(in srgb, var(--macro-color) 25%, transparent);
}

.tu-subgroup { margin-top: 16px; }
.tu-subgroup:first-of-type { margin-top: 12px; }
.tu-subgroup-title {
  font-size: 13px; text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--text); font-weight: 700; margin-bottom: 10px;
  display: flex; align-items: center; gap: 12px;
}
.tu-subgroup-title::before {
  content: ''; width: 14px; height: 1px; background: var(--macro-color);
}
.tu-subgroup-title::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(to right, var(--border), transparent);
}

.tu-perm-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 4px;
}
.tu-perm-item {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 9px 12px; border-radius: 6px; cursor: pointer;
  transition: background 0.12s; border: 1px solid transparent;
}
.tu-perm-item:hover { background: #f8fafc; }
body.theme-dark .tu-perm-item:hover { background: #1a2230; }
.tu-perm-item.checked {
  background: color-mix(in srgb, var(--macro-color) 3%, transparent);
  border-color: color-mix(in srgb, var(--macro-color) 10%, transparent);
}
.tu-perm-check {
  appearance: none; width: 16px; height: 16px; border-radius: 4px;
  border: 1.5px solid #cbd5e1; cursor: pointer; flex-shrink: 0; margin-top: 2px;
  position: relative; transition: all 0.15s;
}
body.theme-dark .tu-perm-check { border-color: #475569; }
.tu-perm-check:hover { border-color: var(--macro-color); }
.tu-perm-check:checked {
  background: var(--macro-color); border-color: var(--macro-color);
}
.tu-perm-check:checked::after {
  content: '✓'; position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -55%); color: #fff; font-size: 11px; font-weight: 900;
}
.tu-perm-text strong {
  font-size: 13px; font-weight: 600; color: var(--text); display: block; line-height: 1.3;
}
.tu-perm-text code {
  font-size: 10px; color: var(--text-sec);
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  margin-top: 2px; display: inline-block;
  background: transparent; padding: 0;
}

/* ── Footer sticky ── */
.tu-footer {
  position: sticky; bottom: 16px; margin-top: 18px;
  display: flex; gap: 10px; justify-content: flex-end; align-items: center;
  background: rgba(255,255,255,0.95); backdrop-filter: blur(8px);
  padding: 12px 16px; border-radius: 12px;
  border: 1px solid var(--border);
  box-shadow: 0 4px 16px rgba(15,23,42,0.06);
  z-index: 5;
}
body.theme-dark .tu-footer { background: rgba(30,41,59,0.95); }
.tu-footer .tu-status {
  margin-right: auto; font-size: 12px; color: var(--text-sec); letter-spacing: 0.05em;
}
.tu-footer .tu-status .tu-num {
  color: var(--primary); font-weight: 700; font-size: 14px;
}

/* Animação fadeUp */
@keyframes tu-fadeUp { from { opacity:0; transform: translateY(8px); } to { opacity:1; transform: none; } }
.tu-macro, .tu-detail, .tu-identity { animation: tu-fadeUp 0.5s ease both; }
.tu-macro:nth-child(1) { animation-delay: 0.05s; }
.tu-macro:nth-child(2) { animation-delay: 0.12s; }
.tu-macro:nth-child(3) { animation-delay: 0.19s; }


/* ===================================================================
   WIZARD CONDENSADO (Opção A — Lista única scrollable com sticky headers)
   Aplicado quando localStorage['osm_wizard_layout'] !== 'classic'.
   Renderiza o passo 2 como uma lista contínua de famílias separadas por
   linha visual; o header de cada família vira sticky ao rolar dentro dela.
   =================================================================== */

.lista-progress-bar {
  display: flex; align-items: center; justify-content: space-between;
  background: #EFF6FF; border-left: 3px solid var(--primary);
  padding: 11px 14px; margin: 0 0 14px;
  border-radius: 0 8px 8px 0;
  font-size: 12.5px; line-height: 1.4;
}
.lista-progress-text strong { color: #1E40AF; font-weight: 700; }
.lista-progress-stats {
  color: #475569; font-size: 11.5px; font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.lista-scrollable {
  display: flex; flex-direction: column;
}

/* Separador visual entre famílias (V128 wizard-faithful) */
.lista-separator {
  height: 20px; position: relative;
  flex-shrink: 0;
}
.lista-separator::before {
  content: ''; position: absolute; top: 50%; left: 12px; right: 12px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #E5E7EB, transparent);
}

/* Container de cada família (V128 wizard-faithful: radius 12, elev-1, transition) */
.lista-familia {
  background: #fff;
  border: 1px solid #E5E7EB;
  border-radius: 12px;
  box-shadow: var(--elev-1);
  overflow: visible;     /* permite sticky funcionar */
  transition: var(--t-fast);
}
/* Família ativa — borda azul translúcida + elev-2 (V128) */
.lista-familia.is-active {
  border-color: rgba(37, 99, 235, 0.3);
  box-shadow: var(--elev-2);
}

/* Header da família — sticky ao rolar (V128 wizard-faithful: elev-sticky azul) */
.lista-familia-header {
  position: sticky;
  top: 0;
  z-index: 4;
  background: linear-gradient(135deg, var(--text) 0%, #1E293B 100%);
  color: #fff;
  padding: 11px 14px;
  border-radius: 12px 12px 0 0;
  display: flex; align-items: center; gap: 10px;
  box-shadow: 0 4px 14px rgba(30, 64, 175, 0.20);
  font-weight: 600;
  transition: var(--t-fast);
  overflow: hidden;
}

/* Famílias C (GNV) · mesma base preta + barra lateral azul accent + chip azul no código */
.lista-familia.is-c-family .lista-familia-header {
  background: linear-gradient(135deg, var(--text) 0%, #1E293B 100%);
}
.lista-familia.is-c-family .lista-familia-header::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--primary);
  border-radius: 12px 0 0 0;
}
.lista-familia.is-c-family .lista-familia-codigo {
  background: var(--primary);
  color: #fff;
}

/* Status dot dentro do header (V128: 9px, partial AZUL pulsante, done verde semantic) */
.lista-familia-status-dot {
  width: 9px; height: 9px; border-radius: 50%;
  flex-shrink: 0;
  background: rgba(255,255,255,0.4);
  transition: var(--t-fast);
}
.lista-familia.status-empty   .lista-familia-status-dot { background: rgba(255,255,255,0.35); }
.lista-familia.status-partial .lista-familia-status-dot {
  background: #93C5FD;
  box-shadow: 0 0 0 0 rgba(147, 197, 253, 0.7);
  animation: lista-pulse 2.2s infinite;
}
.lista-familia.status-done    .lista-familia-status-dot { background: #10B981; }
@keyframes lista-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(147, 197, 253, 0.55); }
  50%      { box-shadow: 0 0 0 6px rgba(147, 197, 253, 0); }
}

/* Código (G/C) e título (V128 wizard-faithful) */
.lista-familia-codigo {
  background: rgba(255,255,255,0.18);
  padding: 3px 8px;
  border-radius: 5px;
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, ui-monospace, monospace;
  font-size: 10.5px;
  color: #fff;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: 0.04em;
}
.lista-familia-titulo {
  flex: 1;
  font-size: 13.5px; font-weight: 700;
  color: #fff;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  letter-spacing: -0.01em;
}
.lista-familia-progress {
  background: rgba(255,255,255,0.20);
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 10.5px; font-weight: 700;
  color: #fff;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
  font-family: 'JetBrains Mono', 'SF Mono', Consolas, ui-monospace, monospace;
}

/* Body com fields da família (V128: padding 0, bg branco — item handles spacing) */
.lista-familia-body {
  padding: 0;
  background: #FFFFFF;
  border-radius: 0 0 12px 12px;
}

/* Tema escuro */
body.theme-dark .lista-familia {
  background: #1e293b;
  border-color: #334155;
}
body.theme-dark .lista-familia-header {
  background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
}
body.theme-dark .lista-familia.is-c-family .lista-familia-header {
  background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
}
body.theme-dark .lista-familia.is-active {
  border-color: rgba(96, 165, 250, 0.4);
}
body.theme-dark .lista-familia-body {
  background: #0f172a;
}
body.theme-dark .lista-separator::before {
  background: linear-gradient(90deg, transparent, #475569, transparent);
}
body.theme-dark .lista-progress-bar {
  background: rgba(30,58,138,.25);
  border-left-color: #93c5fd;
}
body.theme-dark .lista-progress-text strong { color: #93c5fd; }

/* Responsive — mobile (V128: body keeps padding 0, item handles spacing) */
@media (max-width: 600px) {
  .lista-familia-header { padding: 10px 12px; gap: 8px; }
  .lista-familia-titulo { font-size: 13px; }
  .lista-familia-codigo { font-size: 10px; padding: 2px 6px; }
  .lista-familia-progress { font-size: 10px; padding: 2px 7px; }
  .lista-familia-body { padding: 0; }
  .lista-progress-bar { padding: 9px 12px; font-size: 12px; }
  .lista-separator { height: 18px; }
}

/* === Índice por família (modo condensed) === */
.idx-step-progress {
  margin-left: auto;
  background: #f1f5f9;
  color: #475569;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  font-family: 'SF Mono', Consolas, monospace;
  white-space: nowrap;
}
.idx-step-row.idx-familia-row {
  padding-left: 14px;
}
.idx-step-row.idx-familia-row .idx-step-title em {
  background: #f1f5f9;
  color: #1e3a8a;
  padding: 1px 6px;
  border-radius: 3px;
  font-style: normal;
  font-family: 'SF Mono', Consolas, monospace;
  font-size: 11px;
  font-weight: 700;
}
/* Famílias C — destaque dourado/âmbar */
.idx-step-row.idx-familia-row .idx-step-title em:where([class*="C"]):empty,
.idx-step-row.idx-familia-row[onclick*="goToFamilia('C"] .idx-step-title em {
  background: #fef3c7;
  color: #ca8a04;
}
.idx-step-row.idx-row-reprov .idx-step-progress {
  background: #fee2e2;
  color: #dc2626;
}

/* Tema escuro */
body.theme-dark .idx-step-progress { background: #334155; color: #cbd5e1; }
body.theme-dark .idx-step-row.idx-familia-row .idx-step-title em { background: #334155; color: #93c5fd; }
body.theme-dark .idx-step-row.idx-familia-row[onclick*="goToFamilia('C"] .idx-step-title em { background: #422006; color: #fbbf24; }

/* === Separador entre famílias adjacentes no Índice === */
.idx-step-row.idx-familia-row + .idx-step-row.idx-familia-row {
  border-top: 1px solid #e2e8f0;
}
body.theme-dark .idx-step-row.idx-familia-row + .idx-step-row.idx-familia-row {
  border-top-color: #334155;
}

/* === Família ativa (estava visível ao abrir o índice) === */
.idx-step-row.idx-familia-row.idx-active {
  outline: 2px solid #2563eb;
  outline-offset: -2px;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, .15);
}
body.theme-dark .idx-step-row.idx-familia-row.idx-active {
  outline-color: #60a5fa;
  box-shadow: 0 0 0 2px rgba(96, 165, 250, .2);
}

/* === Estados de fundo da família no Índice === */
/* Empty (vazio) — branco, sem destaque */
.idx-step-row.idx-familia-row.idx-row-empty { background: #fff; }
.idx-step-row.idx-familia-row.idx-row-empty:hover { background: #f8fafc; }

/* Partial (parcial) — laranja claro */
.idx-step-row.idx-familia-row.idx-row-partial {
  background: #fff7ed;
  border-left: 3px solid #ea580c;
  padding-left: 11px;       /* compensa borda esquerda */
}
.idx-step-row.idx-familia-row.idx-row-partial:hover { background: #ffedd5; }

/* Done (aprovado) — verde claro */
.idx-step-row.idx-familia-row.idx-row-done {
  background: #f0fdf4;
  border-left: 3px solid #16a34a;
  padding-left: 11px;
}
.idx-step-row.idx-familia-row.idx-row-done:hover { background: #dcfce7; }

/* Reprov (algum item reprovado) — vermelho claro */
.idx-step-row.idx-familia-row.idx-row-reprov {
  background: #fef2f2;
  border-left: 3px solid #dc2626;
  padding-left: 11px;
}
.idx-step-row.idx-familia-row.idx-row-reprov:hover { background: #fee2e2; }

/* N/A — cinza claro (todos os check3 marcados X) */
.idx-step-row.idx-familia-row.idx-row-na {
  background: #f8fafc;
  border-left: 3px solid #94a3b8;
  padding-left: 11px;
}

/* Badge "⚠ G0501, G0502" — destaque na linha reprovada */
.idx-reprov-badge {
  display: inline-block;
  margin-left: 8px;
  background: #dc2626;
  color: #fff;
  padding: 1px 7px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  font-family: 'SF Mono', Consolas, monospace;
  letter-spacing: .02em;
  vertical-align: middle;
  white-space: nowrap;
}

/* Tema escuro — adapta as cores de fundo da família */
body.theme-dark .idx-step-row.idx-familia-row.idx-row-empty   { background: transparent; }
body.theme-dark .idx-step-row.idx-familia-row.idx-row-empty:hover { background: #1a2433; }
body.theme-dark .idx-step-row.idx-familia-row.idx-row-partial {
  background: rgba(234, 88, 12, .12);
  border-left-color: #fb923c;
}
body.theme-dark .idx-step-row.idx-familia-row.idx-row-done    {
  background: rgba(22, 163, 74, .12);
  border-left-color: #4ade80;
}
body.theme-dark .idx-step-row.idx-familia-row.idx-row-reprov  {
  background: rgba(220, 38, 38, .14);
  border-left-color: #f87171;
}
body.theme-dark .idx-step-row.idx-familia-row.idx-row-na      {
  background: rgba(148, 163, 184, .1);
  border-left-color: #94a3b8;
}
body.theme-dark .idx-reprov-badge { background: #b91c1c; }

/* === Badge de código do item (G0501, C0205-03) antes do label do check3 === */
.check3-codigo-badge {
  display: inline-block;
  background: #1e3a8a;
  color: #fff;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .03em;
  margin-right: 6px;
  vertical-align: middle;
  font-family: 'SF Mono', Consolas, monospace;
  white-space: nowrap;
}
/* Famílias C (GNV) — destaque dourado pra distinguir */
.check3-codigo-badge[data-family="c"],
.lista-familia.is-c-family .check3-codigo-badge {
  background: #ca8a04;
}
/* Tema escuro */
body.theme-dark .check3-codigo-badge { background: #2563eb; }
body.theme-dark .lista-familia.is-c-family .check3-codigo-badge { background: #b45309; }

/* =====================================================
   MOBILE REDESIGN (direção C — bottom-sheet + FAB + lista compacta)
   Aplica a celulares e tablets pequenos (≤768px).
   ===================================================== */

/* FAB de índice — só aparece no wizard mobile.
   Já existe sempre no DOM (renderizado por renderWizard); CSS controla visibilidade. */
.fab-mobile-index { display: none; }

@media (max-width: 768px) {

  /* Defesa contra overflow-x da página: se algum conteúdo do wizard estoura
     a viewport (tabela, label longo), o body cresce e o navegador mobile
     aplica zoom-out automático — o bottom-sheet do índice (position:fixed)
     aparece desproporcional / cortado. clip evita isso sem quebrar o
     position:sticky dos main-cards/family-headers (≠ hidden). */
  html, body { overflow-x: clip; }

  /* ── Wizard header compactação ── */
  .wizard-header { padding: 8px 10px; gap: 6px; }
  .vehicle-info { font-size: 13px; line-height: 1.3; }
  .step-counter { font-size: 11px; }
  .btn-back, .btn-home, .theme-toggle-btn {
    padding: 6px 10px; font-size: 17px;
  }
  /* Em mobile o índice abre via FAB, então esconde o botão do header */
  .btn-index { display: none; }
  /* O floating-index-btn lateral é desktop-only */
  .floating-index-btn { display: none; }

  /* ── Lista de famílias (densidade aumentada, mas tipografia legível) ── */
  .lista-familia-header {
    padding: 9px 12px; gap: 8px;
    min-height: 44px;
  }
  .lista-familia-titulo  { font-size: 13.5px; }
  .lista-familia-codigo  { font-size: 12px;  padding: 3px 8px; }
  .lista-familia-progress{ font-size: 12px;  padding: 3px 9px; }
  .lista-familia-body    { padding: 8px 10px; }
  .lista-progress-bar    { padding: 10px 12px; font-size: 13px; }
  .lista-separator       { height: 14px; }

  /* Card de item denso (mas com respiro entre eles) */
  .lista-familia-body .card {
    padding: 12px 12px 14px;
    margin-bottom: 10px;
    border-radius: 10px;
  }

  /* Label do field — sempre acima dos botões em mobile */
  .lista-familia-body .field-label {
    font-size: 13.5px;
    line-height: 1.35;
    margin-bottom: 10px;
  }

  /* Badge de código do item (G0501 / C0205-03) — leitura clara */
  .check3-codigo-badge {
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 4px;
  }

  /* ── Botões check3 (A/R/X) — main check3 grande, sub-itens permanecem compactos ── */
  /* Main check3 (não-compact): tap target 56px, 3 colunas full-width */
  .check3-group:not(.check3-compact) {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6px;
  }
  .check3-group:not(.check3-compact) .check3-btn {
    height: 56px;
    font-size: 18px;
    border-radius: 8px;
    border-width: 2px;
    transition: transform 0.08s ease, box-shadow 0.15s ease;
  }
  .check3-group:not(.check3-compact) .check3-btn:active { transform: scale(0.96); }

  /* Sub-itens compactos: mantém densidade, mas com tap target ≥40px e fonte legível */
  .check3-compact .check3-btn {
    height: 40px;
    font-size: 14px;
    font-weight: 700;
  }

  /* Cards de sub-itens — gap maior pra ficar respirado em mobile */
  .subitem-card { padding: 10px; }
  .subitem-grid { gap: 10px; }
  .subitem-item { padding: 10px; }
  .subitem-label { font-size: 12.5px; line-height: 1.35; }
  .subitem-num { font-size: 11px; padding: 2px 7px; }

  /* ── Main check3 da família sticky abaixo do header ──
     Decorado por _decorateMainCheck3Cards após render. Fica grudado
     logo abaixo do .lista-familia-header enquanto o usuário rola pelos
     sub-itens — sempre visível o veredito da família.
     top: 52px = ~44px do header + ~8px de clearance pra não cortar
     a borda do main card. */
  .lista-familia-body .card.is-main-card {
    position: sticky;
    top: 52px;
    z-index: 4;
    background: #fff;
    border-radius: 0;
    box-shadow: 0 2px 6px rgba(0,0,0,0.06);
    border-top: 1px solid transparent;
  }
  body.theme-dark .lista-familia-body .card.is-main-card {
    background: var(--card, #1e293b);
  }

  /* ── ÍNDICE COMO BOTTOM-SHEET ──
     Reaproveita .step-index-overlay/.step-index-panel já em DOM.
     No mobile: alinha ao bottom, panel ocupa width full, slide vertical. */
  .step-index-overlay {
    align-items: flex-end;
  }
  .step-index-panel {
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: 88vh;
    border-radius: 16px 16px 0 0;
    transform: translateY(100%);
    box-shadow: 0 -8px 32px rgba(0,0,0,0.25);
    padding-bottom: env(safe-area-inset-bottom);
  }
  .step-index-overlay.open .step-index-panel {
    transform: translateY(0);
  }

  /* Drag handle visual no topo do sheet */
  .step-index-panel::before {
    content: '';
    position: absolute;
    top: 8px; left: 50%;
    transform: translateX(-50%);
    width: 40px; height: 5px;
    background: #cbd5e1;
    border-radius: 3px;
    pointer-events: none;
  }
  body.theme-dark .step-index-panel::before { background: #475569; }

  /* Header do sheet ganha espaço pro drag handle */
  .step-index-header {
    padding: 22px 18px 14px;
    font-size: 16px;
  }

  /* Itens do índice — tap target maior em mobile */
  .idx-step-row {
    padding: 12px 18px;
    font-size: 14px;
    min-height: 56px;
  }
  .idx-step-row.idx-familia-row { padding-left: 16px; }
  .idx-step-progress { font-size: 12px; padding: 3px 9px; }
  .idx-step-row.idx-familia-row .idx-step-title em {
    font-size: 12px; padding: 2px 7px;
  }
  .idx-reprov-badge { font-size: 11px; padding: 2px 8px; }

  /* Título longo (família/passo) quebra dentro do painel em vez
     de empurrar a largura do bottom-sheet. */
  .idx-step-title { overflow-wrap: anywhere; word-break: break-word; }

  /* ── FAB (bottom-right, ACIMA da nav-bar Anterior/Próximo) ──
     .nav-bar é fixed bottom:0 z-index:98 com altura ~72px (12px padding × 2 + 48px botão).
     FAB precisa ficar acima dela tanto em z-index quanto em posição vertical. */
  .fab-mobile-index {
    display: flex;
    position: fixed;
    bottom: calc(88px + env(safe-area-inset-bottom));
    right: 16px;
    width: 60px; height: 60px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1e40af, #2563eb);
    color: #fff;
    border: none;
    box-shadow: 0 8px 24px rgba(37,99,235,0.45);
    font-size: 24px;
    cursor: pointer;
    z-index: 99;
    align-items: center;
    justify-content: center;
    transition: transform 0.1s ease, box-shadow 0.15s ease;
  }
  .fab-mobile-index:active {
    transform: scale(0.94);
    box-shadow: 0 4px 12px rgba(37,99,235,0.55);
  }
  body.theme-dark .fab-mobile-index {
    background: linear-gradient(135deg, #2563eb, #3b82f6);
  }

  /* Nav-bar mais compacta no mobile (libera espaço pro FAB e pro conteúdo) */
  .nav-bar { padding: 8px 12px calc(8px + env(safe-area-inset-bottom)); }
  .nav-bar .btn-secondary, .nav-bar .btn-primary {
    height: 44px; font-size: 14px;
  }

  /* Section header (FRMs sem code/title de família) — compacta */
  .section-header { padding: 10px 12px; }
  .section-code   { font-size: 13px; }
  .section-title  { font-size: 14px; line-height: 1.3; }

  /* Screen e wizard-screen — padding lateral menor */
  .screen.wizard-screen { padding: 8px 8px 16px; }
}

/* Smaller phones (<400px) — compactação extra mas mantém tap target */
@media (max-width: 400px) {
  .lista-familia-header { padding: 8px 10px; }
  .lista-familia-body   { padding: 6px 8px; }
  .lista-familia-body .card { padding: 10px 10px 12px; }
  .check3-btn { font-size: 16px; }
  /* FAB do índice — mantém ACIMA da nav-bar (não sobrepõe o botão "Próximo").
     nav-bar tem ~60px de altura + safe-area; FAB fica 12px acima dela. */
  .fab-mobile-index {
    width: 52px; height: 52px; font-size: 20px;
    bottom: calc(72px + env(safe-area-inset-bottom));
    right: 12px;
  }
  /* Nav-bar mais compacta + botões com largura mínima razoável pro texto */
  .nav-bar { padding: 6px 10px calc(6px + env(safe-area-inset-bottom)); gap: 8px; }
  .nav-bar .btn-secondary {
    flex: 1 1 0; max-width: 130px; font-size: 13px; padding: 8px 10px;
  }
  .nav-bar .btn-primary {
    flex: 2 1 0; min-width: 0; font-size: 13px; padding: 8px 12px;
    /* Garante que o texto não estoure mesmo se faltar espaço */
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
}

/* =====================================================
   OPEN-METEO — botão "Buscar Clima" + badges
   Aparece no step Cond. Ambientais (G0100). Click → geolocation
   → Open-Meteo → preenche G0101 (temp), G0102 (umidade), G0103 (pressão).
   ===================================================== */
.clima-wrap {
  margin: 0 0 12px 0;
}
.clima-btn {
  width: 100%;
  background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: transform 0.1s, box-shadow 0.15s;
  box-shadow: 0 2px 8px rgba(6, 182, 212, 0.25);
}
.clima-btn:hover { box-shadow: 0 4px 14px rgba(6, 182, 212, 0.4); }
.clima-btn:active { transform: scale(0.98); }
.clima-btn .clima-icon { font-size: 18px; line-height: 1; }
.clima-btn.loading {
  background: var(--c-g500, #707072);
  cursor: progress;
  box-shadow: none;
}
.clima-btn.loading .clima-icon { animation: clima-spin 1s linear infinite; }
@keyframes clima-spin { to { transform: rotate(360deg); } }

.clima-disclaimer {
  font-size: 11px;
  color: var(--text-sec, #64748b);
  text-align: center;
  margin-top: 6px;
  padding: 0 8px;
  line-height: 1.4;
}
.clima-disclaimer strong { color: var(--text, #0f172a); }

/* Badges Open-Meteo / Editado nos labels dos 3 fields */
.clima-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 8px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
}
.clima-badge-api    { background: #06b6d4; color: #fff; }
.clima-badge-edited { background: #ea580c; color: #fff; }

/* Cards de field destacados quando preenchidos via API */
.field-clima-api {
  border-left: 3px solid #06b6d4 !important;
  background: #f0fdff !important;
}
.field-clima-edited {
  border-left: 3px solid #ea580c !important;
  background: #fff7ed !important;
}
body.theme-dark .field-clima-api    { background: rgba(6, 182, 212, 0.08) !important; }
body.theme-dark .field-clima-edited { background: rgba(234, 88, 12, 0.08) !important; }

/* ════════════════════════════════════════════════════════════════════
   FINANCEIRO V1 — Linguagem visual unificada (Onda B+)
   Inspirado no padrão "Controlle". Reutilizado em modais de despesa,
   receita, transferência, pagamento, recebimento e lançamento manual.
   Prefixo `.fin-v1-` para evitar colisão com classes legadas.
   ════════════════════════════════════════════════════════════════════ */

/* Container e modal */
.fin-v1-modal {
  background: var(--card, #fff);
  color: var(--text);
  border-radius: 12px;
  max-width: 880px;
  width: 100%;
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  overflow: hidden;
  border-top: 5px solid var(--primary, #2563eb);   /* default: azul (genérico) */
}
/* Variantes por tipo de operação financeira (Onda B+):
   - Receita        → verde (#16a34a)
   - Despesa        → vermelho (#dc2626)
   - Transferência  → laranja (#f59e0b)
   - Pagamento/recebimento podem reusar receita/despesa */
.fin-v1-modal.tipo-receita       { border-top-color: #16a34a; }
.fin-v1-modal.tipo-despesa       { border-top-color: #dc2626; }
.fin-v1-modal.tipo-transferencia { border-top-color: #f59e0b; }
.fin-v1-modal.tipo-receita       .fin-v1-section-title { border-bottom-color: #16a34a; color: #16a34a; }
.fin-v1-modal.tipo-despesa       .fin-v1-section-title { border-bottom-color: #dc2626; color: #dc2626; }
.fin-v1-modal.tipo-transferencia .fin-v1-section-title { border-bottom-color: #f59e0b; color: #b45309; }
.fin-v1-header {
  padding: 16px 24px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.fin-v1-header h3 { margin: 0; font-size: 17px; font-weight: 700; }
.fin-v1-close {
  background: none; border: none; font-size: 22px;
  color: var(--text-sec); cursor: pointer; line-height: 1; padding: 0 4px;
}
.fin-v1-close:hover { color: var(--text); }
.fin-v1-body { padding: 18px 24px; overflow-y: auto; flex: 1; }
.fin-v1-footer {
  padding: 12px 24px;
  border-top: 1px solid var(--border);
  display: flex; justify-content: flex-end; gap: 8px;
  background: var(--card-head, #fafbfc);
}

/* Section title (com borda inferior em primary) */
.fin-v1-section-title {
  font-size: 14px; font-weight: 700;
  margin: 18px 0 10px;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--primary, #2563eb);
  color: var(--primary, #2563eb);
}
.fin-v1-section-title:first-child { margin-top: 0; }

/* Field e linhas */
.fin-v1-field { margin-bottom: 14px; }
.fin-v1-field label,
.fin-v1-label {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--text); margin-bottom: 4px;
}
.fin-v1-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.fin-v1-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.fin-v1-row-5 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr 1fr; gap: 10px; margin-bottom: 14px; }
.fin-v1-row > div, .fin-v1-row-3 > div, .fin-v1-row-5 > div { min-width: 0; }

/* Inputs com aparência V1 (sem mexer em .field-input legado) */
.fin-v1-input,
.fin-v1-modal input[type=text],
.fin-v1-modal input[type=date],
.fin-v1-modal input[type=number],
.fin-v1-modal select,
.fin-v1-modal textarea {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  background: var(--card, #fff);
  color: var(--text);
}
.fin-v1-input:focus,
.fin-v1-modal input:focus,
.fin-v1-modal select:focus,
.fin-v1-modal textarea:focus {
  outline: none;
  border-color: var(--primary, #2563eb);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.fin-v1-input[disabled] { background: #f8fafc; color: var(--text-sec); }

/* Prefix R$ / %
   !important necessário porque .fin-v1-modal input[type=text]
   (specificity 0,2,1) sobrescreveria padding-left sem isso. */
.fin-v1-prefix { position: relative; }
.fin-v1-prefix > span {
  position: absolute; left: 10px; top: 50%; transform: translateY(-50%);
  color: var(--text-sec); font-size: 13px; pointer-events: none; z-index: 1;
}
.fin-v1-prefix > input,
.fin-v1-modal .fin-v1-prefix > input { padding-left: 36px !important; }

/* Toggle V1 */
.fin-v1-toggle-row { display: flex; align-items: center; gap: 10px; padding: 8px 0 14px; }
.fin-v1-toggle { position: relative; display: inline-block; width: 40px; height: 22px; flex: 0 0 auto; }
.fin-v1-toggle input { opacity: 0; width: 0; height: 0; }
.fin-v1-toggle-slider {
  position: absolute; cursor: pointer; inset: 0;
  background: #cbd5e1; border-radius: 22px; transition: .2s;
}
.fin-v1-toggle-slider::before {
  content: ""; position: absolute; height: 16px; width: 16px;
  left: 3px; bottom: 3px; background: #fff; border-radius: 50%;
  transition: .2s; box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.fin-v1-toggle input:checked + .fin-v1-toggle-slider { background: var(--success, #16a34a); }
.fin-v1-toggle input:checked + .fin-v1-toggle-slider::before { transform: translateX(18px); }
.fin-v1-toggle-label { font-weight: 600; font-size: 13px; }
.fin-v1-badge-new {
  font-size: 10px; background: #dbeafe; color: #1e40af;
  padding: 2px 8px; border-radius: 10px; font-weight: 600;
}

/* Section box (rateio + pagto realizado) */
.fin-v1-section-box {
  background: #f1f5f9; border-radius: 10px; padding: 16px;
  margin: 8px 0 14px; border: 1px solid var(--border);
}
.fin-v1-section-box h4 { font-size: 13px; font-weight: 700; margin: 0 0 4px; }
.fin-v1-section-box .fin-v1-help {
  font-size: 12px; color: var(--text-sec); margin-bottom: 12px;
}

/* Rateio rows */
.fin-v1-rateio-add {
  width: 100%; padding: 9px;
  background: var(--card, #fff);
  border: 1px dashed #94a3b8; border-radius: 6px;
  cursor: pointer; font-size: 13px;
  color: var(--primary, #2563eb); font-weight: 600;
  font-family: inherit;
}
.fin-v1-rateio-add:hover { background: #eff6ff; border-color: var(--primary, #2563eb); }
.fin-v1-rateio-row {
  display: grid;
  grid-template-columns: 2fr 1fr 80px 32px;
  gap: 8px; align-items: center;
  padding: 8px;
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-bottom: 6px;
}
.fin-v1-rateio-row select,
.fin-v1-rateio-row input { padding: 6px 8px; font-size: 12px; }
.fin-v1-rateio-rm {
  background: none; border: none; cursor: pointer;
  color: var(--danger, #dc2626); font-size: 16px; padding: 4px;
  font-family: inherit;
}
.fin-v1-rateio-total {
  font-size: 12px; padding: 8px 10px;
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px; margin-top: 6px;
  display: flex; justify-content: space-between;
}
.fin-v1-rateio-total.ok  { background: #f0fdf4; border-color: #86efac; color: #166534; }
.fin-v1-rateio-total.err { background: #fef2f2; border-color: #fca5a5; color: #991b1b; }

/* Tabela de parcelas */
.fin-v1-parcelas-tbl { width: 100%; font-size: 12px; margin-top: 8px; border-collapse: collapse; }
.fin-v1-parcelas-tbl th,
.fin-v1-parcelas-tbl td { padding: 6px 8px; text-align: left; border-bottom: 1px solid var(--border); }
.fin-v1-parcelas-tbl th {
  font-weight: 700; color: var(--text-sec); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.fin-v1-parcelas-tbl input { padding: 4px 6px; font-size: 12px; }

/* "Mais opções" expansível */
.fin-v1-more-toggle {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 0; cursor: pointer; font-size: 13px;
  color: var(--primary, #2563eb); font-weight: 600;
  user-select: none;
}
.fin-v1-more-toggle:hover { color: var(--primary-dark, #1d4ed8); }
.fin-v1-more-content { padding: 8px 0; display: none; }
.fin-v1-more-content.open { display: block; }

/* Avatar (Responsável) */
.fin-v1-avatar-input {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; background: #f8fafc;
  border: 1px solid var(--border); border-radius: 6px;
  font-size: 13px;
}
.fin-v1-avatar {
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--primary, #2563eb); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}

/* Helpers */
.fin-v1-help { font-size: 12px; color: var(--text-sec); margin-bottom: 10px; }
.fin-v1-req  { color: var(--danger, #dc2626); }
.fin-v1-tag {
  display: inline-block; font-size: 10px;
  padding: 1px 6px; border-radius: 8px;
  background: #fef3c7; color: #92400e;
  font-weight: 700; margin-left: 6px;
}

/* Tema escuro — overrides */
body.theme-dark .fin-v1-section-box { background: rgba(255,255,255,0.04); }
body.theme-dark .fin-v1-input[disabled],
body.theme-dark .fin-v1-avatar-input { background: rgba(255,255,255,0.04); }
body.theme-dark .fin-v1-rateio-row,
body.theme-dark .fin-v1-rateio-total,
body.theme-dark .fin-v1-rateio-add { background: rgba(255,255,255,0.02); }

/* Trigger ▼ de dropdown de ações em linhas (Caixa, Receitas, Despesas).
   Borda transparente, fundo transparente, só o triângulo aparece. */
.fin-row-menu-trigger {
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 4px 8px;
  color: var(--text-sec);
  font-family: inherit;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.fin-row-menu-trigger:hover {
  background: #f1f5f9;
  color: var(--text);
}
body.theme-dark .fin-row-menu-trigger:hover { background: rgba(255,255,255,0.06); }

/* ── Centralização e largura máxima do conteúdo financeiro ──
   Em telas largas (>1500px), o conteúdo fica centralizado em vez de
   esticar até as bordas. Mantém legibilidade e foco. */
.fin-area {
  max-width: 1480px;
  margin: 0 auto;
}

/* Tabelas das listagens (Caixa, Receitas, Despesas, Cadastros): mais
   espaço entre as colunas pra que cada campo fique claramente delimitado. */
.fin-area table th,
.fin-area table td {
  padding: 10px 14px !important;
  vertical-align: top;
}
.fin-area table th {
  font-weight: 700;
  white-space: nowrap;
}
/* Pequenos botões (▼ menu, ícones de ação) não precisam do padding extra. */
.fin-area table td .fin-row-menu-trigger,
.fin-area table td button.btn-edit,
.fin-area table td button.btn-delete { padding: 4px 8px !important; }

/* Inputs dentro das células (ex: parcelas) ficam compactos */
.fin-area table td input[type=text],
.fin-area table td input[type=date],
.fin-area table td input[type=number],
.fin-area table td select {
  padding: 6px 8px !important;
  font-size: 12px;
}

/* ── Padronização de inputs em TODA a área financeira (Onda C+) ──
   Aplica a mesma fonte/visual dos modais V1 em todas as telas do menu
   Financeiro (Painel, Receitas, Despesas, Caixa, Conciliação, Cadastros,
   Relatórios). Sobrescreve `.field-input` legado dentro do escopo `.fin-area`. */
.fin-area input[type=text],
.fin-area input[type=date],
.fin-area input[type=number],
.fin-area input[type=email],
.fin-area input[type=tel],
.fin-area input[type=search],
.fin-area select,
.fin-area textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  background: var(--card, #fff);
  color: var(--text);
}
/* Selects: trunca options longas com ellipsis pra não esticar o widget. */
.fin-area select { text-overflow: ellipsis; }
.fin-area input[type=text]:focus,
.fin-area input[type=date]:focus,
.fin-area input[type=number]:focus,
.fin-area input[type=email]:focus,
.fin-area input[type=tel]:focus,
.fin-area input[type=search]:focus,
.fin-area select:focus,
.fin-area textarea:focus {
  outline: none;
  border-color: var(--primary, #2563eb);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}
.fin-area input[disabled],
.fin-area select[disabled],
.fin-area textarea[disabled] {
  background: #f8fafc;
  color: var(--text-sec);
  cursor: not-allowed;
}
.fin-area label,
.fin-area .field-label {
  font-size: 12px;
  font-weight: 600;
}
body.theme-dark .fin-area input[disabled],
body.theme-dark .fin-area select[disabled],
body.theme-dark .fin-area textarea[disabled] {
  background: rgba(255,255,255,0.04);
}

/* ============================================================
   FIN-V3 — Linguagem visual financeiro-minimalism-v1
   Aplica o estilo aprovado do mockup ao Painel + cromados das
   listagens (table, badges, chips, period segmented).
   Prefix `.fin-v3-*` para isolar do legado.
   ============================================================ */

/* Topbar / breadcrumb / period segmented */
.fin-v3-topbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 18px;
}
.fin-v3-breadcrumb {
  font-size: 13px; color: var(--text-sec); font-weight: 500;
  letter-spacing: -0.005em;
}
.fin-v3-breadcrumb b { color: var(--text); font-weight: 600; }
.fin-v3-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.fin-v3-period {
  display: inline-flex; align-items: center;
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 2px;
  font-size: 12px; font-weight: 500;
}
.fin-v3-period button {
  border: 0; background: transparent; padding: 6px 12px;
  color: var(--text-sec); cursor: pointer;
  font-family: inherit; font-size: 12px; font-weight: 500;
  border-radius: 4px;
  transition: background 150ms cubic-bezier(.4,0,.2,1), color 150ms cubic-bezier(.4,0,.2,1);
}
.fin-v3-period button.is-active {
  background: var(--gray-900, #18181B); color: #fff;
}
.fin-v3-period button:hover:not(.is-active) { color: var(--text); }

.fin-v3-btn {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid var(--border);
  background: var(--card, #fff);
  color: var(--text);
  padding: 7px 14px;
  border-radius: 6px;
  font-family: inherit; font-size: 13px; font-weight: 500;
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
}
.fin-v3-btn:hover { background: var(--bg, #f8fafc); border-color: var(--text-sec); }
.fin-v3-btn--primary {
  background: var(--gray-900, #18181B); color: #fff; border-color: var(--gray-900, #18181B);
}
.fin-v3-btn--primary:hover { background: var(--gray-800, #27272A); border-color: var(--gray-800, #27272A); }
.fin-v3-btn svg { width: 14px; height: 14px; }

/* Page head */
.fin-v3-page-head { margin-bottom: 22px; }
.fin-v3-page-head h1 {
  font-size: 26px; font-weight: 600; margin: 0 0 4px;
  letter-spacing: -0.02em; color: var(--text);
}
.fin-v3-page-head p { margin: 0; color: var(--text-sec); font-size: 14px; }

/* KPIs strip */
.fin-v3-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-bottom: 20px;
}
@media (max-width: 1100px) { .fin-v3-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .fin-v3-kpis { grid-template-columns: 1fr; } }

.fin-v3-kpi {
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 20px;
  transition: border-color 150ms;
  position: relative;
}
.fin-v3-kpi:hover { border-color: var(--text-sec); }
.fin-v3-kpi__label {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--text-sec); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.fin-v3-kpi__label svg { width: 13px; height: 13px; flex-shrink: 0; }
.fin-v3-kpi__value {
  font-size: 24px; font-weight: 600;
  letter-spacing: -0.02em; line-height: 1.1;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.fin-v3-kpi__value--positive { color: var(--success, #16a34a); }
.fin-v3-kpi__value--negative { color: var(--danger,  #dc2626); }
.fin-v3-kpi__currency {
  font-size: 13px; color: var(--text-sec); font-weight: 500; margin-right: 4px;
}
.fin-v3-kpi__cents {
  color: var(--text-sec); font-size: 16px;
}
.fin-v3-kpi__delta {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 9px; font-size: 11px; font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.fin-v3-kpi__delta--up      { color: var(--success, #16a34a); }
.fin-v3-kpi__delta--down    { color: var(--danger,  #dc2626); }
.fin-v3-kpi__delta--neutral { color: var(--text-sec); }
.fin-v3-kpi__delta svg { width: 12px; height: 12px; }
.fin-v3-kpi__sub {
  font-size: 11px; color: var(--text-sec); margin-top: 6px;
  font-variant-numeric: tabular-nums;
}

/* Cards genericos no estilo do mockup */
.fin-v3-grid-main {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 18px; margin-bottom: 18px;
}
.fin-v3-grid-sub {
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 18px;
}
@media (max-width: 1100px) {
  .fin-v3-grid-main, .fin-v3-grid-sub { grid-template-columns: 1fr; }
}

.fin-v3-card {
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.fin-v3-card__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.fin-v3-card__title {
  font-size: 14px; font-weight: 600; letter-spacing: -0.01em; color: var(--text);
}
.fin-v3-card__sub {
  font-size: 12px; color: var(--text-sec); margin-top: 2px;
}
.fin-v3-card__action {
  font-size: 12px; font-weight: 500;
  color: var(--primary, #2563eb);
  text-decoration: none; cursor: pointer;
  background: none; border: 0;
  font-family: inherit;
}
.fin-v3-card__action:hover { text-decoration: underline; }

/* Fluxo de caixa - barras agrupadas */
.fin-v3-chart-wrap { padding: 22px 20px 18px; }
.fin-v3-chart-legend {
  display: flex; gap: 16px; margin-bottom: 14px;
  font-size: 12px; color: var(--text-sec);
}
.fin-v3-legend-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; margin-right: 6px; vertical-align: middle;
}
.fin-v3-bars {
  display: flex; align-items: flex-end; gap: 10px;
  height: 200px; padding: 0 4px;
}
.fin-v3-bar-col {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  cursor: default;
}
.fin-v3-bar-stack {
  display: flex; align-items: flex-end; gap: 3px;
  width: 100%; height: 168px;
}
.fin-v3-bar-segment {
  flex: 1; border-radius: 3px 3px 0 0;
  transition: background 150ms;
  min-height: 2px;
}
.fin-v3-bar-in  { background: var(--gray-900, #18181B); }
.fin-v3-bar-out { background: var(--gray-300, #D4D4D8); }
.fin-v3-bar-col:hover .fin-v3-bar-in  { background: var(--primary, #2563eb); }
.fin-v3-bar-col:hover .fin-v3-bar-out { background: var(--gray-400, #A1A1AA); }
.fin-v3-bar-label {
  font-size: 11px; color: var(--text-sec);
  font-variant-numeric: tabular-nums;
}

/* Bank list */
.fin-v3-bank-list { padding: 8px 12px 12px; }
.fin-v3-bank {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 8px;
  border-radius: 6px;
  transition: background 150ms;
}
.fin-v3-bank:hover { background: var(--bg, #f8fafc); }
.fin-v3-bank__icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--bg, #f8fafc);
  display: grid; place-items: center;
  font-size: 12px; font-weight: 700; letter-spacing: -0.02em;
  color: var(--text);
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.fin-v3-bank__icon--itau     { background: #EC7000; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--bb       { background: #FAE100; color: #002D74; border-color: transparent; }
.fin-v3-bank__icon--bradesco { background: #00377B; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--santander{ background: #EC0000; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--caixa    { background: #005CA9; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--nubank   { background: #820AD1; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--inter    { background: #FF7A00; color: #fff; border-color: transparent; }
.fin-v3-bank__icon--neutro   { background: var(--gray-900, #18181B); color: #fff; border-color: transparent; }
.fin-v3-bank__info { flex: 1; min-width: 0; }
.fin-v3-bank__name {
  font-size: 13px; font-weight: 500; color: var(--text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fin-v3-bank__meta {
  font-size: 11px; color: var(--text-sec); margin-top: 2px;
}
.fin-v3-bank__balance {
  text-align: right; font-size: 14px; font-weight: 600;
  font-variant-numeric: tabular-nums; color: var(--text);
}
.fin-v3-bank__balance-sub {
  font-size: 11px; color: var(--text-sec); margin-top: 2px;
  font-weight: 400; font-variant-numeric: tabular-nums;
}
.fin-v3-bank-total {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  background: var(--bg, #f8fafc);
  font-size: 13px;
}
.fin-v3-bank-total__label { color: var(--text-sec); font-weight: 500; }
.fin-v3-bank-total__value {
  font-weight: 600; font-size: 15px;
  font-variant-numeric: tabular-nums; letter-spacing: -0.01em;
}

/* Filter chips */
.fin-v3-chip-row {
  display: flex; gap: 8px; padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.fin-v3-chip {
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card, #fff);
  font-size: 12px; font-weight: 500;
  color: var(--text-sec);
  cursor: pointer;
  font-family: inherit;
  transition: background 150ms, color 150ms, border-color 150ms;
}
.fin-v3-chip:hover { background: var(--bg, #f8fafc); }
.fin-v3-chip.is-active {
  background: var(--gray-900, #18181B);
  color: #fff;
  border-color: var(--gray-900, #18181B);
}

/* Table style do mockup */
.fin-v3-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.fin-v3-table th {
  text-align: left; font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec);
  padding: 10px 20px;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.fin-v3-table td {
  padding: 12px 20px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.fin-v3-table tr:last-child td { border-bottom: 0; }
.fin-v3-table tr:hover td { background: var(--bg, #f8fafc); }
.fin-v3-table .right { text-align: right; }
.fin-v3-table .num   { font-variant-numeric: tabular-nums; font-weight: 500; }
.fin-v3-num--in  { color: var(--success, #16a34a); }
.fin-v3-num--out { color: var(--text); }
.fin-v3-desc-title { font-weight: 500; }
.fin-v3-desc-sub   { font-size: 11px; color: var(--text-sec); margin-top: 2px; }

/* Badges status */
.fin-v3-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.fin-v3-badge__dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: currentColor;
}
.fin-v3-badge--paid       { background: rgba(22,163,74,.10);  color: #047857; }
.fin-v3-badge--pending    { background: var(--warn-bg, #FEF3C7); color: #92400E; }
.fin-v3-badge--overdue    { background: rgba(220,38,38,.08); color: #B91C1C; }
.fin-v3-badge--reconciled { background: rgba(37,99,235,.10); color: #1E40AF; }
.fin-v3-badge--neutral    { background: var(--bg, #f1f5f9);   color: var(--text-sec); }

/* Despesas por categoria - barras horizontais escala monocromatica */
.fin-v3-categ { padding: 16px 20px; }
.fin-v3-categ__row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 8px; align-items: center;
  padding: 8px 0;
}
.fin-v3-categ__row + .fin-v3-categ__row { border-top: 1px solid var(--border); }
.fin-v3-categ__name {
  font-size: 13px; font-weight: 500;
  display: flex; align-items: center; gap: 8px;
  color: var(--text);
}
.fin-v3-categ__dot {
  width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0;
}
.fin-v3-categ__amount {
  font-size: 13px; font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.fin-v3-categ__bar {
  grid-column: 1 / -1;
  height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
}
.fin-v3-categ__bar > div {
  height: 100%; border-radius: 2px;
  transition: width 200ms cubic-bezier(.4,0,.2,1);
}

/* Empty state minimal */
.fin-v3-empty {
  padding: 24px 20px; text-align: center;
  font-size: 13px; color: var(--text-sec);
}

/* Dark mode tweaks */
body.theme-dark .fin-v3-period button.is-active,
body.theme-dark .fin-v3-btn--primary,
body.theme-dark .fin-v3-chip.is-active {
  background: #f1f5f9; color: #0f172a; border-color: #f1f5f9;
}
body.theme-dark .fin-v3-btn--primary:hover { background: #e2e8f0; border-color: #e2e8f0; }
body.theme-dark .fin-v3-bar-in { background: #f1f5f9; }
body.theme-dark .fin-v3-bar-out { background: #334155; }
body.theme-dark .fin-v3-bank-total { background: rgba(255,255,255,0.03); }

/* ============================================================
   OP-V1 - Linguagem visual dashboard-minimalism-v1 (Operacional)
   Aplica o estilo aprovado do mockup ao topo da aba Cadastro:
   greeting + KPI strip + 2 cards (recentes + FRMs) + mini chart.
   Prefix `.op-v1-*` para isolar do legado.
   ============================================================ */

/* Greeting */
.op-v1-greeting { margin: 4px 0 22px; }
.op-v1-greeting h1 {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 6px; color: var(--text); line-height: 1.15;
}
.op-v1-greeting p {
  margin: 0; color: var(--text-sec); font-size: 14px; line-height: 1.5;
}

/* KPI strip */
.op-v1-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 28px;
}
@media (max-width: 1100px) { .op-v1-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .op-v1-kpis { grid-template-columns: 1fr; } }

.op-v1-kpi {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  padding: 20px 22px;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1);
}
.op-v1-kpi:hover { border-color: var(--text-sec); }
.op-v1-kpi__label {
  font-size: 12px; font-weight: 500; color: var(--gray-500, #71717A);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.op-v1-kpi__value {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  line-height: 1; font-variant-numeric: tabular-nums;
  color: var(--text);
}
.op-v1-kpi__delta {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 10px; font-size: 12px; font-weight: 500;
}
.op-v1-kpi__delta--up      { color: var(--success, #16a34a); }
.op-v1-kpi__delta--down    { color: var(--danger, #dc2626); }
.op-v1-kpi__delta--neutral { color: var(--gray-500, #71717A); }
.op-v1-kpi__delta svg { width: 12px; height: 12px; }

/* Cards row (2fr / 1fr) */
.op-v1-grid {
  display: grid; grid-template-columns: 2fr 1fr;
  gap: 20px; margin-bottom: 28px;
}
@media (max-width: 1100px) { .op-v1-grid { grid-template-columns: 1fr; } }

.op-v1-col {
  display: flex; flex-direction: column; gap: 20px;
}

.op-v1-card {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  overflow: hidden;
}
.op-v1-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
}
.op-v1-card__title {
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); line-height: 1.3;
}
.op-v1-card__sub {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.op-v1-card__action {
  font-size: 13px; font-weight: 500;
  color: var(--primary, #2563EB);
  text-decoration: none; cursor: pointer;
  background: transparent; border: 0; padding: 4px 8px;
  border-radius: 6px; font-family: inherit;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
}
.op-v1-card__action:hover { background: var(--bg, #F8FAFC); text-decoration: underline; }
.op-v1-card__body { padding: 4px 0; }

/* Recent inspections table */
.op-v1-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.op-v1-table th {
  text-align: left; font-weight: 500;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--gray-500, #71717A);
  padding: 10px 22px;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.op-v1-table td {
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.op-v1-table tr:last-child td { border-bottom: 0; }
.op-v1-table tr { cursor: pointer; transition: background 100ms cubic-bezier(.4,0,.2,1); }
.op-v1-table tr:hover td { background: var(--bg, #F8FAFC); }

.op-v1-plate {
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--text);
}
.op-v1-vehicle-meta {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.op-v1-time {
  font-variant-numeric: tabular-nums;
  color: var(--text-sec);
  font-size: 12px;
}

/* Badges (pills) */
.op-v1-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.op-v1-badge__dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.op-v1-badge--success { background: rgba(22, 163, 74, 0.10); color: #047857; }
.op-v1-badge--warn    { background: rgba(245, 158, 11, 0.12); color: #92400E; }
.op-v1-badge--accent  { background: rgba(37, 99, 235, 0.10); color: #1E40AF; }
.op-v1-badge--danger  { background: rgba(220, 38, 38, 0.10); color: #B91C1C; }
.op-v1-badge--draft   { background: var(--bg, #F1F5F9); color: var(--gray-600, #52525B); }
.op-v1-badge--frm     {
  background: var(--bg, #F4F4F5); color: var(--text-sec);
  border: 1px solid var(--gray-200, #E4E4E7);
  font-weight: 600; font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

/* FRMs ativos grid (2 cols x 3 rows) */
.op-v1-frm-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px; padding: 14px 18px 18px;
}
.op-v1-frm-tile {
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 6px;
  padding: 12px 14px;
  cursor: pointer;
  background: var(--card, #fff);
  transition: border-color 150ms cubic-bezier(.4,0,.2,1),
              transform 100ms cubic-bezier(.4,0,.2,1);
  text-align: left;
  font-family: inherit;
  display: block;
  width: 100%;
}
.op-v1-frm-tile:hover { border-color: var(--text); }
.op-v1-frm-tile:active { transform: scale(0.98); }
.op-v1-frm-tile__code {
  font-size: 12px; font-weight: 600;
  color: var(--primary, #2563EB);
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
}
.op-v1-frm-tile__name {
  font-size: 13px; font-weight: 500;
  margin-top: 4px; line-height: 1.35;
  color: var(--text);
}
.op-v1-frm-tile__meta {
  font-size: 11px; color: var(--gray-500, #71717A);
  margin-top: 4px;
}
.op-v1-frm-empty {
  grid-column: 1 / -1;
  padding: 18px 6px; text-align: center;
  font-size: 12px; color: var(--text-sec);
}

/* Mini chart */
.op-v1-chart { padding: 20px 22px 22px; }
.op-v1-chart__bars {
  display: flex; align-items: flex-end; gap: 6px;
  height: 120px; margin-bottom: 12px;
}
.op-v1-chart__bar {
  flex: 1;
  background: var(--gray-700, #3F3F46);
  border-radius: 2px 2px 0 0;
  min-height: 2px;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
  cursor: pointer;
}
.op-v1-chart__bar:hover { background: var(--primary, #2563EB); }
.op-v1-chart__bar--current { background: var(--primary, #2563EB); }
.op-v1-chart__legend {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--gray-500, #71717A);
  font-variant-numeric: tabular-nums;
}
.op-v1-chart__legend span { flex: 1; text-align: center; }

/* Empty state pill within cards */
.op-v1-empty {
  padding: 28px 22px; text-align: center;
  font-size: 13px; color: var(--text-sec);
}

/* Dark mode tweaks */
body.theme-dark .op-v1-kpi,
body.theme-dark .op-v1-card,
body.theme-dark .op-v1-frm-tile {
  background: var(--card);
  border-color: var(--border);
}
body.theme-dark .op-v1-kpi:hover,
body.theme-dark .op-v1-frm-tile:hover { border-color: #cbd5e1; }
body.theme-dark .op-v1-table tr:hover td { background: rgba(255,255,255,0.03); }
body.theme-dark .op-v1-chart__bar { background: #cbd5e1; }
body.theme-dark .op-v1-chart__bar--current,
body.theme-dark .op-v1-chart__bar:hover { background: #60a5fa; }
body.theme-dark .op-v1-badge--success { background: rgba(22,163,74,0.18); color: #4ade80; }
body.theme-dark .op-v1-badge--warn    { background: rgba(245,158,11,0.18); color: #fbbf24; }
body.theme-dark .op-v1-badge--accent  { background: rgba(37,99,235,0.20); color: #93c5fd; }
body.theme-dark .op-v1-badge--danger  { background: rgba(220,38,38,0.18); color: #f87171; }
body.theme-dark .op-v1-badge--draft   { background: rgba(255,255,255,0.06); color: var(--text-sec); }
body.theme-dark .op-v1-badge--frm     { background: rgba(255,255,255,0.04); color: var(--text-sec); }
body.theme-dark .op-v1-card__action:hover { background: rgba(255,255,255,0.04); }
body.theme-dark .op-v1-plate { color: var(--text); }

/* ============================================================
   GR-V1 - Linguagem visual dashboard-minimalism-v1 (Gerencial)
   Mesma família visual de .op-v1-* / .fin-v3-* aplicada ao Painel
   Gerencial: greeting + period segmented + KPI strip + cards
   (chart 30d, top inspetores, distribuição FRM, distribuição CTB).
   Prefix `.gr-v1-*` para isolar do legado.
   ============================================================ */

/* Greeting (mesmo cromado do op-v1) */
.gr-v1-greeting { margin: 4px 0 22px; }
.gr-v1-greeting h1 {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 6px; color: var(--text); line-height: 1.15;
}
.gr-v1-greeting p {
  margin: 0; color: var(--gray-500, #71717A); font-size: 14px; line-height: 1.5;
}

/* Period segmented (Hoje | 7d | Mês | Trim | Ano) */
.gr-v1-period-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 18px;
}
.gr-v1-period {
  display: inline-flex; align-items: center;
  background: var(--card, #fff);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 2px;
  font-size: 12px; font-weight: 500;
}
.gr-v1-period button {
  border: 0; background: transparent; padding: 6px 12px;
  color: var(--text-sec); cursor: pointer;
  font-family: inherit; font-size: 12px; font-weight: 500;
  border-radius: 4px;
  transition: background 150ms cubic-bezier(.4,0,.2,1), color 150ms cubic-bezier(.4,0,.2,1);
}
.gr-v1-period button.is-active {
  background: var(--gray-900, #18181B); color: #fff;
}
.gr-v1-period button:hover:not(.is-active) { color: var(--text); }
.gr-v1-period-meta {
  font-size: 12px; color: var(--text-sec);
  font-variant-numeric: tabular-nums;
}

/* KPI strip (4 cols) */
.gr-v1-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 24px;
}
@media (max-width: 1100px) { .gr-v1-kpis { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .gr-v1-kpis { grid-template-columns: 1fr; } }

.gr-v1-kpi {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  padding: 20px 22px;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1);
  position: relative;
}
.gr-v1-kpi:hover { border-color: var(--text-sec); }
.gr-v1-kpi__label {
  font-size: 12px; font-weight: 500; color: var(--gray-500, #71717A);
  text-transform: uppercase; letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.gr-v1-kpi__value {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  line-height: 1; font-variant-numeric: tabular-nums;
  color: var(--text);
}
.gr-v1-kpi__value--accent  { color: var(--primary, #2563EB); }
.gr-v1-kpi__value--success { color: var(--success, #16a34a); }
.gr-v1-kpi__value--danger  { color: var(--danger,  #dc2626); }
.gr-v1-kpi__delta {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 10px; font-size: 12px; font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.gr-v1-kpi__delta--up      { color: var(--success, #16a34a); }
.gr-v1-kpi__delta--down    { color: var(--danger, #dc2626); }
.gr-v1-kpi__delta--neutral { color: var(--gray-500, #71717A); }
.gr-v1-kpi__delta svg { width: 12px; height: 12px; }
.gr-v1-kpi__sub {
  font-size: 11px; color: var(--gray-500, #71717A);
  margin-top: 6px; font-variant-numeric: tabular-nums;
}

/* Card chrome (igual op-v1/fin-v3) */
.gr-v1-grid {
  display: grid; grid-template-columns: 2fr 1fr;
  gap: 20px; margin-bottom: 24px;
}
.gr-v1-grid-2 {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px; margin-bottom: 24px;
}
@media (max-width: 1100px) {
  .gr-v1-grid, .gr-v1-grid-2 { grid-template-columns: 1fr; }
}

.gr-v1-card {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  overflow: hidden;
}
.gr-v1-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
  gap: 12px;
}
.gr-v1-card__title {
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); line-height: 1.3;
}
.gr-v1-card__sub {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.gr-v1-card__action {
  font-size: 13px; font-weight: 500;
  color: var(--primary, #2563EB);
  text-decoration: none; cursor: pointer;
  background: transparent; border: 0; padding: 4px 8px;
  border-radius: 6px; font-family: inherit;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
}
.gr-v1-card__action:hover { background: var(--bg, #F8FAFC); text-decoration: underline; }
.gr-v1-card__body { padding: 4px 0; }

/* Bars chart 30d */
.gr-v1-chart { padding: 22px 22px 18px; }
.gr-v1-bars {
  display: flex; align-items: flex-end; gap: 4px;
  height: 160px; padding: 0 2px;
}
.gr-v1-bar {
  flex: 1;
  background: var(--gray-300, #D4D4D8);
  border-radius: 2px 2px 0 0;
  min-height: 2px;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
  cursor: pointer;
  position: relative;
}
.gr-v1-bar:hover { background: var(--primary, #2563EB); }
.gr-v1-bar--current { background: var(--primary, #2563EB); }
.gr-v1-bar--empty   { background: var(--gray-200, #E4E4E7); }
.gr-v1-bars-legend {
  display: flex; justify-content: space-between;
  margin-top: 12px;
  font-size: 11px; color: var(--gray-500, #71717A);
  font-variant-numeric: tabular-nums;
}

/* Table chrome (mesma do op-v1) */
.gr-v1-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.gr-v1-table th {
  text-align: left; font-weight: 500;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--gray-500, #71717A);
  padding: 10px 22px;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.gr-v1-table td {
  padding: 12px 22px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.gr-v1-table tr:last-child td { border-bottom: 0; }
.gr-v1-table tr:hover td { background: var(--bg, #F8FAFC); }
.gr-v1-table .right { text-align: right; }
.gr-v1-table .num   { font-variant-numeric: tabular-nums; font-weight: 500; }
.gr-v1-table__rank {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg, #F4F4F5); color: var(--text-sec);
  font-size: 11px; font-weight: 600;
  font-variant-numeric: tabular-nums;
  border: 1px solid var(--gray-200, #E4E4E7);
  margin-right: 8px;
}
.gr-v1-name {
  font-size: 13px; font-weight: 500; color: var(--text);
}

/* Distribuição CTB - lista compacta com barra horizontal */
.gr-v1-cat { padding: 16px 22px; }
.gr-v1-cat__row {
  display: grid; grid-template-columns: 30px 1fr auto;
  gap: 10px; align-items: center;
  padding: 8px 0;
}
.gr-v1-cat__row + .gr-v1-cat__row { border-top: 1px solid var(--border); }
.gr-v1-cat__code {
  font-size: 12px; font-weight: 700; letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  color: var(--primary, #2563EB);
  text-align: center;
}
.gr-v1-cat__name {
  font-size: 12px; color: var(--text-sec);
  display: flex; align-items: center; gap: 8px;
}
.gr-v1-cat__bar {
  flex: 1; height: 4px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden;
  min-width: 60px;
}
.gr-v1-cat__bar > div {
  height: 100%; background: var(--gray-900, #18181B);
  border-radius: 2px;
  transition: width 200ms cubic-bezier(.4,0,.2,1);
}
.gr-v1-cat__amount {
  font-size: 13px; font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text);
}
.gr-v1-cat__pct {
  font-size: 11px; color: var(--gray-500, #71717A);
  font-variant-numeric: tabular-nums;
  margin-left: 6px;
}

/* Badges (mesmo cromado do op-v1) */
.gr-v1-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.gr-v1-badge__dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.gr-v1-badge--success { background: rgba(22, 163, 74, 0.10); color: #047857; }
.gr-v1-badge--warn    { background: rgba(245, 158, 11, 0.12); color: #92400E; }
.gr-v1-badge--accent  { background: rgba(37, 99, 235, 0.10); color: #1E40AF; }
.gr-v1-badge--danger  { background: rgba(220, 38, 38, 0.10); color: #B91C1C; }
.gr-v1-badge--neutral { background: var(--bg, #F1F5F9); color: var(--gray-600, #52525B); }
.gr-v1-badge--frm     {
  background: var(--bg, #F4F4F5); color: var(--text-sec);
  border: 1px solid var(--gray-200, #E4E4E7);
  font-weight: 600; font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

/* Empty state */
.gr-v1-empty {
  padding: 28px 22px; text-align: center;
  font-size: 13px; color: var(--text-sec);
}

/* Dark mode tweaks */
body.theme-dark .gr-v1-kpi,
body.theme-dark .gr-v1-card {
  background: var(--card);
  border-color: var(--border);
}
body.theme-dark .gr-v1-kpi:hover { border-color: #cbd5e1; }
body.theme-dark .gr-v1-period button.is-active {
  background: #f1f5f9; color: #0f172a;
}
body.theme-dark .gr-v1-bar { background: #334155; }
body.theme-dark .gr-v1-bar--empty { background: rgba(255,255,255,0.06); }
body.theme-dark .gr-v1-bar--current,
body.theme-dark .gr-v1-bar:hover { background: #60a5fa; }
body.theme-dark .gr-v1-table tr:hover td { background: rgba(255,255,255,0.03); }
body.theme-dark .gr-v1-table__rank {
  background: rgba(255,255,255,0.04); border-color: var(--border);
}
body.theme-dark .gr-v1-cat__bar > div { background: #f1f5f9; }
body.theme-dark .gr-v1-card__action:hover { background: rgba(255,255,255,0.04); }
body.theme-dark .gr-v1-badge--success { background: rgba(22,163,74,0.18); color: #4ade80; }
body.theme-dark .gr-v1-badge--warn    { background: rgba(245,158,11,0.18); color: #fbbf24; }
body.theme-dark .gr-v1-badge--accent  { background: rgba(37,99,235,0.20); color: #93c5fd; }
body.theme-dark .gr-v1-badge--danger  { background: rgba(220,38,38,0.18); color: #f87171; }
body.theme-dark .gr-v1-badge--neutral { background: rgba(255,255,255,0.06); color: var(--text-sec); }
body.theme-dark .gr-v1-badge--frm     { background: rgba(255,255,255,0.04); color: var(--text-sec); }

/* ============================================================
   CFG-V1 - Linguagem visual dashboard-minimalism-v1 (Configurações)
   Mesma família visual de .op-v1-* / .fin-v3-* / .gr-v1-* aplicada
   à entrada do módulo Configurações: greeting + secondary nav
   (sub-abas) + overview grid (tiles) + cards + table chrome.
   Sub-páginas mantêm chrome legacy — só o entry point é polido.
   Prefix `.cfg-v1-*` para isolar do legado (.cad-tabs, .config-group).
   ============================================================ */

/* Greeting (mesmo cromado do op-v1 / gr-v1) */
.cfg-v1-greeting { margin: 4px 0 22px; }
.cfg-v1-greeting h1 {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 6px; color: var(--text); line-height: 1.15;
}
.cfg-v1-greeting p {
  margin: 0; color: var(--gray-500, #71717A); font-size: 14px; line-height: 1.5;
}

/* Secondary nav (sub-abas) — substitui visual das .cad-tabs no entry point.
   Horizontal pill row, ativa sublinhada com gray-900. Preserva handlers. */
.cfg-v1-nav {
  display: flex; align-items: center; gap: 2px;
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 8px;
  padding: 4px;
  margin-bottom: 22px;
  flex-wrap: wrap;
  overflow-x: auto;
}
.cfg-v1-nav button {
  border: 0; background: transparent; padding: 8px 14px;
  color: var(--text-sec); cursor: pointer;
  font-family: inherit; font-size: 13px; font-weight: 500;
  border-radius: 6px;
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
  transition: background 150ms cubic-bezier(.4,0,.2,1), color 150ms cubic-bezier(.4,0,.2,1);
}
.cfg-v1-nav button:hover:not(.is-active) {
  color: var(--text); background: var(--bg, #F8FAFC);
}
.cfg-v1-nav button.is-active {
  background: var(--gray-900, #18181B); color: #fff;
}
.cfg-v1-nav button .cfg-v1-nav__icon {
  font-size: 14px; line-height: 1; opacity: 0.9;
}

/* V66+: Sub-nav (linha 2 abaixo dos macros — sub-tabs da macro ativa) */
.cfg-v1-subnav {
  display: flex; align-items: center; gap: 4px;
  margin-top: -14px; margin-bottom: 22px;
  padding: 4px 6px 8px 8px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--gray-200, #E4E4E7);
}
.cfg-v1-subnav button {
  border: 0; background: transparent; padding: 7px 14px;
  color: var(--text-sec); cursor: pointer;
  font-family: inherit; font-size: 12.5px; font-weight: 500;
  border-radius: 6px;
  white-space: nowrap;
  transition: background 150ms cubic-bezier(.4,0,.2,1), color 150ms cubic-bezier(.4,0,.2,1);
}
.cfg-v1-subnav button:hover:not(.is-active) {
  color: var(--text); background: var(--bg, #F8FAFC);
}
.cfg-v1-subnav button.is-active {
  color: var(--text); background: transparent;
  border-bottom: 2px solid var(--gray-900, #18181B);
  border-radius: 4px 4px 0 0;
  font-weight: 600;
}

/* Overview grid (tiles para cada cadastro/área) */
.cfg-v1-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 24px;
}
@media (max-width: 1100px) { .cfg-v1-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .cfg-v1-grid { grid-template-columns: 1fr; } }

.cfg-v1-tile {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  padding: 18px 20px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  display: flex; flex-direction: column; gap: 8px;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1),
              transform 150ms cubic-bezier(.4,0,.2,1),
              box-shadow 150ms cubic-bezier(.4,0,.2,1);
  position: relative;
  min-height: 110px;
}
.cfg-v1-tile:hover {
  border-color: var(--text-sec);
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.cfg-v1-tile:active { transform: translateY(1px); }
.cfg-v1-tile:focus-visible {
  outline: 2px solid var(--primary, #2563EB);
  outline-offset: 2px;
}
.cfg-v1-tile__icon {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--bg, #F4F4F5);
  border: 1px solid var(--gray-200, #E4E4E7);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px; line-height: 1;
  color: var(--gray-700, #3F3F46);
  margin-bottom: 4px;
}
.cfg-v1-tile__title {
  font-size: 14px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); line-height: 1.3;
}
.cfg-v1-tile__sub {
  font-size: 12px; color: var(--gray-500, #71717A);
  line-height: 1.4;
}
.cfg-v1-tile.is-active {
  border-color: var(--gray-900, #18181B);
  background: var(--bg, #FAFAFA);
}

/* Card chrome (igual op-v1/fin-v3/gr-v1) */
.cfg-v1-card {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 20px;
}
.cfg-v1-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
  gap: 12px;
}
.cfg-v1-card__title {
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); line-height: 1.3;
}
.cfg-v1-card__sub {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.cfg-v1-card__action {
  font-size: 13px; font-weight: 500;
  color: var(--primary, #2563EB);
  text-decoration: none; cursor: pointer;
  background: transparent; border: 0; padding: 4px 8px;
  border-radius: 6px; font-family: inherit;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
}
.cfg-v1-card__action:hover { background: var(--bg, #F8FAFC); text-decoration: underline; }
.cfg-v1-card__body { padding: 16px 22px; }

/* Table chrome (mesma do op-v1/gr-v1) */
.cfg-v1-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.cfg-v1-table th {
  text-align: left; font-weight: 500;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--gray-500, #71717A);
  padding: 10px 22px;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.cfg-v1-table td {
  padding: 12px 22px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.cfg-v1-table tr:last-child td { border-bottom: 0; }
.cfg-v1-table tr:hover td { background: var(--bg, #F8FAFC); }
.cfg-v1-table .right { text-align: right; }
.cfg-v1-table .num   { font-variant-numeric: tabular-nums; font-weight: 500; }

/* Inline form row (label + control side by side dentro de card) */
.cfg-v1-form-row {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 16px; align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}
.cfg-v1-form-row:last-child { border-bottom: 0; }
.cfg-v1-form-row__label {
  font-size: 13px; font-weight: 500; color: var(--text);
}
.cfg-v1-form-row__hint {
  display: block; font-size: 11px; font-weight: 400;
  color: var(--gray-500, #71717A); margin-top: 2px;
}
.cfg-v1-form-row__control {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
@media (max-width: 700px) {
  .cfg-v1-form-row { grid-template-columns: 1fr; gap: 6px; }
}

/* Badges (mesmo cromado do gr-v1) */
.cfg-v1-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.cfg-v1-badge__dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.cfg-v1-badge--success { background: rgba(22, 163, 74, 0.10); color: #047857; }
.cfg-v1-badge--warn    { background: rgba(245, 158, 11, 0.12); color: #92400E; }
.cfg-v1-badge--accent  { background: rgba(37, 99, 235, 0.10); color: #1E40AF; }
.cfg-v1-badge--danger  { background: rgba(220, 38, 38, 0.10); color: #B91C1C; }
.cfg-v1-badge--neutral { background: var(--bg, #F1F5F9); color: var(--gray-600, #52525B); }

/* Section title sutil (entre tiles e tab content) */
.cfg-v1-section-title {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--gray-500, #71717A);
  margin: 4px 0 12px;
}

/* Empty state */
.cfg-v1-empty {
  padding: 28px 22px; text-align: center;
  font-size: 13px; color: var(--text-sec);
}

/* Dark mode tweaks */
body.theme-dark .cfg-v1-tile,
body.theme-dark .cfg-v1-card,
body.theme-dark .cfg-v1-nav {
  background: var(--card);
  border-color: var(--border);
}
body.theme-dark .cfg-v1-tile:hover { border-color: #cbd5e1; }
body.theme-dark .cfg-v1-tile.is-active {
  background: rgba(255,255,255,0.04);
  border-color: #f1f5f9;
}
body.theme-dark .cfg-v1-tile__icon {
  background: rgba(255,255,255,0.04);
  border-color: var(--border);
  color: var(--text);
}
body.theme-dark .cfg-v1-nav button:hover:not(.is-active) { background: rgba(255,255,255,0.04); }
body.theme-dark .cfg-v1-nav button.is-active {
  background: #f1f5f9; color: #0f172a;
}
body.theme-dark .cfg-v1-table tr:hover td { background: rgba(255,255,255,0.03); }
body.theme-dark .cfg-v1-card__action:hover { background: rgba(255,255,255,0.04); }
body.theme-dark .cfg-v1-badge--success { background: rgba(22,163,74,0.18); color: #4ade80; }
body.theme-dark .cfg-v1-badge--warn    { background: rgba(245,158,11,0.18); color: #fbbf24; }
body.theme-dark .cfg-v1-badge--accent  { background: rgba(37,99,235,0.20); color: #93c5fd; }
body.theme-dark .cfg-v1-badge--danger  { background: rgba(220,38,38,0.18); color: #f87171; }
body.theme-dark .cfg-v1-badge--neutral { background: rgba(255,255,255,0.06); color: var(--text-sec); }

/* ============================================================
   CAD-V1 - Linguagem visual dashboard-minimalism-v1 (Cadastro)
   Mesma família visual de .op-v1-* / .gr-v1-* / .cfg-v1-*
   aplicada às sub-abas REINSPEÇÕES, VALIDAÇÃO e PLACAS:
   greeting + summary strip + cards com tabela + filtros chips.
   Prefix `.cad-v1-*` para isolar do legado.
   ============================================================ */

/* Greeting */
.cad-v1-greeting { margin: 4px 0 22px; }
.cad-v1-greeting h1 {
  font-size: 28px; font-weight: 600; letter-spacing: -0.02em;
  margin: 0 0 6px; color: var(--text); line-height: 1.15;
}
.cad-v1-greeting p {
  margin: 0; color: var(--gray-500, #71717A); font-size: 14px; line-height: 1.5;
}

/* Summary strip (KPI-style) */
.cad-v1-summary {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 24px;
}
.cad-v1-summary--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1100px) { .cad-v1-summary, .cad-v1-summary--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .cad-v1-summary, .cad-v1-summary--3 { grid-template-columns: 1fr; } }

.cad-v1-kpi {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  padding: 18px 20px;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1);
}
.cad-v1-kpi:hover { border-color: var(--text-sec); }
.cad-v1-kpi__label {
  font-size: 11px; font-weight: 500; color: var(--gray-500, #71717A);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: 10px;
}
.cad-v1-kpi__value {
  font-size: 26px; font-weight: 600; letter-spacing: -0.02em;
  line-height: 1; font-variant-numeric: tabular-nums;
  color: var(--text);
}
.cad-v1-kpi__value--accent  { color: var(--primary, #2563EB); }
.cad-v1-kpi__value--success { color: var(--success, #16a34a); }
.cad-v1-kpi__value--warn    { color: #b45309; }
.cad-v1-kpi__value--danger  { color: var(--danger, #dc2626); }
.cad-v1-kpi__sub {
  margin-top: 8px; font-size: 12px; font-weight: 500;
  color: var(--gray-500, #71717A);
}

/* Card chrome (twin of op-v1-card) */
.cad-v1-card {
  background: var(--card, #fff);
  border: 1px solid var(--gray-200, #E4E4E7);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 20px;
}
.cad-v1-card__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px; border-bottom: 1px solid var(--border);
  gap: 12px; flex-wrap: wrap;
}
.cad-v1-card__title {
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text); line-height: 1.3;
}
.cad-v1-card__sub {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.cad-v1-card__action {
  font-size: 13px; font-weight: 500;
  color: var(--primary, #2563EB);
  text-decoration: none; cursor: pointer;
  background: transparent; border: 0; padding: 6px 12px;
  border-radius: 6px; font-family: inherit;
  transition: background 150ms cubic-bezier(.4,0,.2,1);
}
.cad-v1-card__action:hover { background: var(--bg, #F8FAFC); text-decoration: underline; }
.cad-v1-card__action--primary {
  background: var(--gray-900, #18181B); color: #fff;
  font-weight: 500;
}
.cad-v1-card__action--primary:hover { background: var(--text); text-decoration: none; opacity: 0.92; }
.cad-v1-card__body { padding: 4px 0; }
.cad-v1-card__body--padded { padding: 18px 22px; }

/* Filter row (chips bar) */
.cad-v1-filter-row {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 12px 22px; border-bottom: 1px solid var(--border);
  background: transparent;
}
.cad-v1-filter-row__label {
  font-size: 11px; font-weight: 500; color: var(--gray-500, #71717A);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-right: 4px;
}
.cad-v1-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 999px;
  font-size: 12px; font-weight: 500;
  background: var(--bg, #F4F4F5); color: var(--text-sec);
  border: 1px solid var(--gray-200, #E4E4E7);
  cursor: pointer; font-family: inherit;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1),
              background 150ms cubic-bezier(.4,0,.2,1),
              color 150ms cubic-bezier(.4,0,.2,1);
}
.cad-v1-chip:hover { border-color: var(--text-sec); color: var(--text); }
.cad-v1-chip.is-active {
  background: var(--gray-900, #18181B); color: #fff;
  border-color: var(--gray-900, #18181B);
}

/* Table chrome (twin of op-v1-table) */
.cad-v1-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
}
.cad-v1-table th {
  text-align: left; font-weight: 500;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--gray-500, #71717A);
  padding: 10px 22px;
  border-bottom: 1px solid var(--border);
  background: transparent;
}
.cad-v1-table td {
  padding: 14px 22px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.cad-v1-table tr:last-child td { border-bottom: 0; }
.cad-v1-table tbody tr { cursor: pointer; transition: background 100ms cubic-bezier(.4,0,.2,1); }
.cad-v1-table tbody tr:hover td { background: var(--bg, #F8FAFC); }
.cad-v1-table .num { font-variant-numeric: tabular-nums; font-weight: 500; }
.cad-v1-table .right { text-align: right; }
.cad-v1-table .center { text-align: center; }

.cad-v1-plate {
  font-family: 'SF Mono', Menlo, Consolas, monospace;
  font-weight: 600; font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--text);
}
.cad-v1-meta {
  font-size: 12px; color: var(--gray-500, #71717A);
  margin-top: 2px;
}
.cad-v1-time {
  font-variant-numeric: tabular-nums;
  color: var(--text-sec);
  font-size: 12px;
}

/* Badges (pills) */
.cad-v1-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; line-height: 1.4;
  white-space: nowrap;
}
.cad-v1-badge__dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.cad-v1-badge--success { background: rgba(22, 163, 74, 0.10); color: #047857; }
.cad-v1-badge--warn    { background: rgba(245, 158, 11, 0.12); color: #92400E; }
.cad-v1-badge--accent  { background: rgba(37, 99, 235, 0.10); color: #1E40AF; }
.cad-v1-badge--danger  { background: rgba(220, 38, 38, 0.10); color: #B91C1C; }
.cad-v1-badge--draft   { background: var(--bg, #F1F5F9); color: var(--gray-600, #52525B); }
.cad-v1-badge--frm     {
  background: var(--bg, #F4F4F5); color: var(--text-sec);
  border: 1px solid var(--gray-200, #E4E4E7);
  font-weight: 600; font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

/* Action mini buttons inside cells */
.cad-v1-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 6px;
  font-size: 12px; font-weight: 500;
  background: var(--gray-900, #18181B); color: #fff;
  border: 0; cursor: pointer; font-family: inherit;
  transition: opacity 150ms cubic-bezier(.4,0,.2,1);
}
.cad-v1-btn:hover { opacity: 0.92; }
.cad-v1-btn--ghost {
  background: transparent; color: var(--text-sec);
  border: 1px solid var(--gray-200, #E4E4E7);
}
.cad-v1-btn--ghost:hover { color: var(--text); border-color: var(--text-sec); opacity: 1; }
.cad-v1-btn--danger {
  background: transparent; color: var(--danger, #dc2626);
  border: 1px solid transparent;
}
.cad-v1-btn--danger:hover { background: rgba(220,38,38,0.08); border-color: rgba(220,38,38,0.2); opacity: 1; }

/* Empty state pill within cards */
.cad-v1-empty {
  padding: 36px 22px; text-align: center;
  font-size: 13px; color: var(--text-sec);
}
.cad-v1-empty strong { color: var(--text); font-weight: 600; display: block; margin-bottom: 4px; }

/* Grid for placas (2 col layout option) */
.cad-v1-grid {
  display: grid; grid-template-columns: 2fr 1fr;
  gap: 20px; margin-bottom: 20px;
}
@media (max-width: 1100px) { .cad-v1-grid { grid-template-columns: 1fr; } }

/* TO timer color cues (validacao) */
.cad-v1-to--live     { color: var(--primary, #2563EB); font-weight: 600; }
.cad-v1-to--warn     { color: #b45309; font-weight: 600; }
.cad-v1-to--critical { color: var(--danger, #dc2626); font-weight: 600; }

/* Dark mode tweaks */
body.theme-dark .cad-v1-kpi,
body.theme-dark .cad-v1-card {
  background: var(--card);
  border-color: var(--border);
}
body.theme-dark .cad-v1-kpi:hover { border-color: #cbd5e1; }
body.theme-dark .cad-v1-table tbody tr:hover td { background: rgba(255,255,255,0.03); }
body.theme-dark .cad-v1-card__action:hover { background: rgba(255,255,255,0.04); }
body.theme-dark .cad-v1-card__action--primary {
  background: #f1f5f9; color: #0f172a;
}
body.theme-dark .cad-v1-card__action--primary:hover { background: #e2e8f0; }
body.theme-dark .cad-v1-chip {
  background: rgba(255,255,255,0.04); color: var(--text-sec);
  border-color: var(--border);
}
body.theme-dark .cad-v1-chip:hover { color: var(--text); border-color: #cbd5e1; }
body.theme-dark .cad-v1-chip.is-active {
  background: #f1f5f9; color: #0f172a; border-color: #f1f5f9;
}
body.theme-dark .cad-v1-btn {
  background: #f1f5f9; color: #0f172a;
}
body.theme-dark .cad-v1-btn--ghost {
  background: transparent; color: var(--text-sec);
  border-color: var(--border);
}
body.theme-dark .cad-v1-btn--ghost:hover { color: var(--text); border-color: #cbd5e1; }
body.theme-dark .cad-v1-badge--success { background: rgba(22,163,74,0.18); color: #4ade80; }
body.theme-dark .cad-v1-badge--warn    { background: rgba(245,158,11,0.18); color: #fbbf24; }
body.theme-dark .cad-v1-badge--accent  { background: rgba(37,99,235,0.20); color: #93c5fd; }
body.theme-dark .cad-v1-badge--danger  { background: rgba(220,38,38,0.18); color: #f87171; }
body.theme-dark .cad-v1-badge--draft   { background: rgba(255,255,255,0.06); color: var(--text-sec); }
body.theme-dark .cad-v1-badge--frm     { background: rgba(255,255,255,0.04); color: var(--text-sec); }
body.theme-dark .cad-v1-plate { color: var(--text); }
body.theme-dark .cad-v1-kpi__value--warn { color: #fbbf24; }

/* ═══════════════ DASH V1 — Sidebar + Topbar (mockup dashboard-minimalism-v1) ═══════════════ */
.dash-v1-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
  background: var(--bg);
}
.dash-v1-sidebar {
  background: var(--card);
  border-right: 1px solid var(--border);
  padding: 24px 16px;
  position: sticky;
  top: 0;
  height: 100vh;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}
.dash-v1-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 8px 24px;
  border-bottom: 1px solid #eef2f6;
  margin-bottom: 16px;
}
.dash-v1-brand-mark {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--text);
  color: #fff;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: -0.02em;
  flex-shrink: 0;
}
.dash-v1-brand-text {
  font-weight: 600;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--text);
  line-height: 1.2;
}
.dash-v1-brand-sub {
  font-size: 11px;
  color: var(--gray-500);
  font-weight: 400;
  line-height: 1.3;
  margin-top: 2px;
}
.dash-v1-section-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--gray-500);
  padding: 16px 8px 6px;
  font-weight: 500;
}
.dash-v1-nav {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.dash-v1-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  color: var(--gray-600);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background 150ms cubic-bezier(.4,0,.2,1), color 150ms cubic-bezier(.4,0,.2,1);
  background: transparent;
  border: 0;
  text-align: left;
  width: 100%;
  font-family: inherit;
}
.dash-v1-nav-item:hover {
  background: var(--bg);
  color: var(--text);
}
.dash-v1-nav-item:hover svg { color: var(--text); }
.dash-v1-nav-item.is-active {
  background: var(--text);
  color: #fff;
}
.dash-v1-nav-item.is-active svg { color: #fff; }
.dash-v1-nav-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--gray-500);
  transition: color 150ms cubic-bezier(.4,0,.2,1);
}
.dash-v1-user {
  margin-top: auto;
  padding: 12px 8px;
  border-top: 1px solid #eef2f6;
  display: flex;
  align-items: center;
  gap: 10px;
}
.dash-v1-user-info {
  flex: 1;
  min-width: 0;
  cursor: pointer;
  background: transparent;
  border: 0;
  padding: 0;
  font-family: inherit;
  text-align: left;
}
.dash-v1-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--primary-soft);
  color: var(--primary);
  display: grid;
  place-items: center;
  font-weight: 600;
  font-size: 13px;
  flex-shrink: 0;
}
.dash-v1-user-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dash-v1-user-role {
  font-size: 11px;
  color: var(--gray-500);
}
.dash-v1-logout-btn {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 0;
  background: transparent;
  color: var(--gray-500);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background 150ms, color 150ms;
  flex-shrink: 0;
}
.dash-v1-logout-btn:hover { background: var(--bg); color: var(--text); }
.dash-v1-logout-btn svg { width: 16px; height: 16px; }

.dash-v1-main {
  padding: 32px 40px 64px;
  max-width: 1280px;
  width: 100%;
  box-sizing: border-box;
}
.dash-v1-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
  gap: 16px;
}
.dash-v1-topbar-title {
  font-size: 13px;
  color: var(--gray-500);
  font-weight: 500;
}
.dash-v1-topbar-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.dash-v1-search {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 7px 12px;
  width: 280px;
  transition: border-color 150ms cubic-bezier(.4,0,.2,1);
  box-sizing: border-box;
}
.dash-v1-search:focus-within { border-color: var(--text); }
.dash-v1-search svg {
  width: 14px;
  height: 14px;
  color: var(--gray-500);
  flex-shrink: 0;
}
.dash-v1-search input {
  border: 0;
  outline: 0;
  background: transparent;
  flex: 1;
  font-family: inherit;
  font-size: 13px;
  color: var(--text);
  min-width: 0;
}
.dash-v1-iconbtn {
  width: 34px;
  height: 34px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  border-radius: 6px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
  flex-shrink: 0;
}
.dash-v1-iconbtn:hover { background: var(--bg); border-color: var(--gray-500); }
.dash-v1-iconbtn svg { width: 14px; height: 14px; }

.dash-v1-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--text);
  background: var(--text);
  color: #fff;
  padding: 7px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
}
.dash-v1-cta:hover { background: #1E293B; border-color: #1E293B; }
.dash-v1-cta svg { width: 14px; height: 14px; }

.dash-v1-page-head { margin-bottom: 28px; }
.dash-v1-page-head h1 {
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 6px;
  letter-spacing: -0.02em;
  color: var(--text);
  line-height: 1.2;
}
.dash-v1-page-head p {
  margin: 0;
  color: var(--text-sec);
  font-size: 14px;
}

/* ── Dark theme overrides ── */
body.theme-dark .dash-v1-brand { border-bottom-color: rgba(255,255,255,0.06); }
body.theme-dark .dash-v1-user  { border-top-color: rgba(255,255,255,0.06); }
body.theme-dark .dash-v1-brand-mark { background: var(--text); color: #0f172a; }
body.theme-dark .dash-v1-nav-item.is-active { background: var(--text); color: #0f172a; }
body.theme-dark .dash-v1-nav-item.is-active svg { color: #0f172a; }
body.theme-dark .dash-v1-cta { background: var(--text); color: #0f172a; border-color: var(--text); }
body.theme-dark .dash-v1-cta:hover { background: #cbd5e1; border-color: #cbd5e1; }

/* ── Responsive ── */
/* Defaults (desktop): hamburger + overlay escondidos */
.dash-v1-menu-toggle { display: none; }
.dash-v1-sidebar-overlay { display: none; }

@media (max-width: 1100px) {
  .dash-v1-layout { grid-template-columns: 1fr; }
  .dash-v1-main { padding: 24px 20px 64px; }
  .dash-v1-search { width: 200px; }

  /* Sidebar vira drawer off-canvas (V83) */
  .dash-v1-sidebar {
    position: fixed;
    top: 0; left: 0;
    width: 280px; max-width: 85vw;
    height: 100dvh;
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 12px 32px rgba(0,0,0,.18);
    overflow-y: auto;
  }
  .dash-v1-sidebar.is-open { transform: translateX(0); }

  /* Overlay escuro atrás do drawer */
  .dash-v1-sidebar-overlay {
    display: block;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.4);
    z-index: 999;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s;
  }
  .dash-v1-sidebar-overlay.is-open {
    opacity: 1;
    pointer-events: auto;
  }

  /* Hamburger na topbar (só mobile) */
  .dash-v1-menu-toggle {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border: 0; border-radius: 8px;
    background: transparent;
    color: var(--text);
    cursor: pointer;
    flex-shrink: 0;
  }
  .dash-v1-menu-toggle:hover { background: var(--bg); }
  .dash-v1-menu-toggle svg { width: 22px; height: 22px; }
}
@media (max-width: 480px) {
  .dash-v1-search { display: none; }
  .dash-v1-topbar { flex-wrap: wrap; }
}

/* Esconde a greeting interna do op-v1 (já há um page-head global na dash-v1) */
.dash-v1-layout .op-v1-greeting { display: none; }

/* ═══════════════════════════════════════════════════════════════════════════
   CFG-SUB · Sub-pages de Configurações (V136)
   4 patterns prefixados — todos partilham este bloco shared:
     · cfg-sub-page-head    → título de seção + chips contadores + filtros
     · cfg-sub-card         → wrapper card branco com border + radius
     · cfg-sub-table        → padrão CRUD list (Pattern 1)
     · cfg-sub-row-actions  → ações SVG-only por linha com tooltip
     · cfg-sub-timeline     → padrão Auditoria (Pattern 2)
     · cfg-sub-toc          → padrão Settings com TOC (Pattern 3)
     · cfg-sub-editor       → padrão Editor Avançado split (Pattern 4)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Page head (título + count + filtros) */
.cfg-sub-page-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 16px; flex-wrap: wrap;
}
.cfg-sub-page-head__left { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.cfg-sub-page-head__title {
  font-size: 18px; font-weight: 600; letter-spacing: -0.01em; color: var(--text);
}
.cfg-sub-page-head__count {
  font-size: 11px; color: var(--text-sec);
  background: var(--bg); border: 1px solid var(--border);
  padding: 3px 9px; border-radius: 999px;
  font-variant-numeric: tabular-nums;
}
.cfg-sub-filters { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.cfg-sub-search {
  display: flex; align-items: center; gap: 8px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 6px; padding: 7px 12px; min-width: 240px;
  transition: 150ms;
}
.cfg-sub-search:focus-within { border-color: var(--text); }
.cfg-sub-search input {
  border: 0; outline: 0; background: transparent;
  flex: 1; font-family: inherit; font-size: 13px; color: var(--text);
}
.cfg-sub-search svg { width: 14px; height: 14px; color: var(--text-sec); flex-shrink: 0; }

.cfg-sub-select {
  appearance: none;
  background: var(--card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;
  border: 1px solid var(--border); border-radius: 6px;
  padding: 7px 32px 7px 12px;
  font-family: inherit; font-size: 13px; color: var(--text);
  cursor: pointer; transition: 150ms;
}
.cfg-sub-select:hover { border-color: var(--text-sec); }
.cfg-sub-select:focus { outline: 0; border-color: var(--text); box-shadow: 0 0 0 3px rgba(15,23,42,.06); }

.cfg-sub-btn {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid var(--border); background: var(--card);
  color: var(--text); font-family: inherit; font-size: 13px; font-weight: 500;
  padding: 7px 12px; border-radius: 6px;
  cursor: pointer; transition: 150ms; text-decoration: none;
}
.cfg-sub-btn:hover { border-color: var(--text-sec); background: var(--bg); }
.cfg-sub-btn svg { width: 14px; height: 14px; }
.cfg-sub-btn--primary { background: var(--text); color: #fff; border-color: var(--text); }
.cfg-sub-btn--primary:hover { background: #1E293B; border-color: #1E293B; }
.cfg-sub-btn--ghost { border-color: transparent; background: transparent; color: var(--text-sec); }
.cfg-sub-btn--ghost:hover { background: var(--bg); color: var(--text); }
.cfg-sub-btn--danger { color: var(--danger); border-color: rgba(220,38,38,.2); background: var(--card); }
.cfg-sub-btn--danger:hover { background: rgba(220,38,38,.08); border-color: rgba(220,38,38,.35); }

/* Segmented (Hoje / 7d / 30d) */
.cfg-sub-seg {
  display: inline-flex;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 6px; overflow: hidden;
}
.cfg-sub-seg__btn {
  border: 0; background: transparent; font-family: inherit;
  font-size: 12.5px; font-weight: 500; padding: 7px 14px;
  color: var(--text-sec); cursor: pointer; transition: 120ms;
}
.cfg-sub-seg__btn:hover { background: var(--bg); color: var(--text); }
.cfg-sub-seg__btn.is-active { background: var(--text); color: #fff; }
.cfg-sub-seg__btn + .cfg-sub-seg__btn { border-left: 1px solid var(--border); }

/* Card wrapper */
.cfg-sub-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04);
  /* V161+: NÃO usar overflow:hidden aqui — popovers de ações (Receitas,
     Caixa, Despesas) renderem position:absolute pra baixo e na ÚLTIMA linha
     da tabela são cortados pelo card. Sem isso, "Visualizar/Editar/Excluir"
     desaparece silenciosamente no último item — bug invisível.
     Os cantos arredondados continuam funcionando via border-radius. */
}

/* ─── PATTERN 1 · CRUD list ─── */
.cfg-sub-table { width: 100%; border-collapse: collapse; }
.cfg-sub-table th {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec); font-weight: 500; text-align: left;
  padding: 12px 16px; background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.cfg-sub-table td {
  padding: 14px 16px; border-bottom: 1px solid #EEF2F6;
  font-size: 14px; vertical-align: middle; color: var(--text);
}
.cfg-sub-table tr:last-child td { border-bottom: 0; }
.cfg-sub-table tbody tr { transition: 120ms; }
.cfg-sub-table tbody tr:hover { background: var(--bg); }

.cfg-sub-user-cell { display: flex; align-items: center; gap: 12px; }
.cfg-sub-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 600; font-size: 13px; flex-shrink: 0;
  background: rgba(37,99,235,.10); color: var(--primary);
}
.cfg-sub-avatar--master { background: #FEF3C7; color: #92400E; }
.cfg-sub-avatar--admin  { background: #E0E7FF; color: #3730A3; }
.cfg-sub-avatar--tech   { background: #DCFCE7; color: #166534; }
.cfg-sub-avatar--neutral{ background: var(--bg); color: var(--text-sec); border: 1px solid var(--border); }

.cfg-sub-user-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.cfg-sub-user-name { font-weight: 500; color: var(--text); }
.cfg-sub-user-login {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--text-sec);
}

.cfg-sub-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 9px; border-radius: 999px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.01em;
  white-space: nowrap;
}
.cfg-sub-badge--master  { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.cfg-sub-badge--admin   { background: #E0E7FF; color: #3730A3; border: 1px solid #C7D2FE; }
.cfg-sub-badge--tech    { background: #DCFCE7; color: #166534; border: 1px solid #BBF7D0; }
.cfg-sub-badge--neutral { background: var(--bg); color: var(--text-sec); border: 1px solid var(--border); }
.cfg-sub-badge--primary { background: rgba(37,99,235,.10); color: #1E40AF; border: 1px solid #BFDBFE; }
.cfg-sub-badge--success { background: #DCFCE7; color: #166534; border: 1px solid #BBF7D0; }
.cfg-sub-badge--warn    { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.cfg-sub-badge--danger  { background: #FEE2E2; color: #991B1B; border: 1px solid #FECACA; }

.cfg-sub-status-dot {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; color: var(--text-sec);
}
.cfg-sub-dot {
  width: 6px; height: 6px; border-radius: 50%;
  flex-shrink: 0;
}
.cfg-sub-dot--on   { background: #16A34A; box-shadow: 0 0 0 3px rgba(22,163,74,.15); }
.cfg-sub-dot--off  { background: var(--text-sec); }
.cfg-sub-dot--warn { background: #F59E0B; box-shadow: 0 0 0 3px rgba(245,158,11,.15); }

.cfg-sub-mono {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--text-sec);
  font-variant-numeric: tabular-nums;
}

/* Row actions SVG-only */
.cfg-sub-row-actions {
  display: flex; align-items: center; gap: 2px; justify-content: flex-end;
}
.cfg-sub-icon-btn {
  position: relative;
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border: 0; background: transparent;
  color: var(--text-sec); border-radius: 6px;
  cursor: pointer; transition: 120ms;
}
.cfg-sub-icon-btn:hover { background: var(--card); color: var(--text); box-shadow: 0 0 0 1px var(--border); }
.cfg-sub-icon-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.cfg-sub-icon-btn:disabled:hover { background: transparent; box-shadow: none; }
.cfg-sub-icon-btn svg { width: 15px; height: 15px; }
.cfg-sub-icon-btn--danger:hover { background: #FEE2E2; color: var(--danger); box-shadow: 0 0 0 1px #FECACA; }
.cfg-sub-icon-btn--primary:hover { background: rgba(37,99,235,.10); color: var(--primary); box-shadow: 0 0 0 1px #BFDBFE; }

.cfg-sub-icon-btn::after {
  content: attr(data-label);
  position: absolute; bottom: calc(100% + 4px); left: 50%;
  transform: translateX(-50%);
  background: var(--text); color: #fff;
  font-size: 10.5px; font-weight: 500;
  padding: 4px 8px; border-radius: 4px;
  white-space: nowrap; opacity: 0; pointer-events: none;
  transition: 120ms; letter-spacing: 0.01em; z-index: 10;
}
.cfg-sub-icon-btn:hover::after { opacity: 1; }

.cfg-sub-empty {
  padding: 48px 24px; text-align: center;
  color: var(--text-sec); font-size: 14px;
}
.cfg-sub-empty svg {
  width: 40px; height: 40px;
  color: var(--text-sec); opacity: 0.5;
  margin: 0 auto 12px; display: block;
}

/* KPI strip (compartilhado com Pattern 2) */
.cfg-sub-kpis {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 16px; margin-bottom: 24px;
}
.cfg-sub-kpi {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 18px;
  box-shadow: 0 1px 2px rgba(15,23,42,.04);
}
.cfg-sub-kpi__label {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec); font-weight: 500; margin-bottom: 8px;
}
.cfg-sub-kpi__value {
  font-size: 26px; font-weight: 600; letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  font-family: 'JetBrains Mono', monospace;
}
.cfg-sub-kpi__sub {
  font-size: 11px; color: var(--text-sec);
  margin-top: 4px; display: flex; align-items: center; gap: 5px;
}
.cfg-sub-delta-up   { color: #16A34A; font-weight: 500; }
.cfg-sub-delta-down { color: #DC2626; font-weight: 500; }

/* ─── PATTERN 2 · Timeline ─── */
.cfg-sub-timeline { padding: 8px 0; }
.cfg-sub-timeline__group {
  padding: 14px 24px 6px;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec); font-weight: 500;
  background: var(--bg);
  border-top: 1px solid #EEF2F6;
  border-bottom: 1px solid #EEF2F6;
}
.cfg-sub-timeline__group:first-child { border-top: 0; }

.cfg-sub-event {
  display: grid; grid-template-columns: 96px 28px 1fr auto;
  gap: 14px; align-items: start;
  padding: 14px 24px;
  border-bottom: 1px solid #EEF2F6;
  transition: 120ms;
}
.cfg-sub-event:last-child { border-bottom: 0; }
.cfg-sub-event:hover { background: var(--bg); }
.cfg-sub-event__time {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; color: var(--text-sec);
  font-variant-numeric: tabular-nums; padding-top: 4px;
}
.cfg-sub-event__icon {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center; flex-shrink: 0;
}
.cfg-sub-event__icon svg { width: 14px; height: 14px; }
.cfg-sub-event__icon--ok      { background: #DCFCE7; color: #166534; }
.cfg-sub-event__icon--warn    { background: #FEF3C7; color: #92400E; }
.cfg-sub-event__icon--danger  { background: #FEE2E2; color: #991B1B; }
.cfg-sub-event__icon--info    { background: #E0E7FF; color: #3730A3; }
.cfg-sub-event__icon--neutral { background: var(--bg); color: var(--text-sec); border: 1px solid var(--border); }

.cfg-sub-event__body { min-width: 0; }
.cfg-sub-event__title {
  font-size: 14px; font-weight: 500; color: var(--text); margin-bottom: 3px;
}
.cfg-sub-event__title strong { font-weight: 600; }
.cfg-sub-event__meta {
  font-size: 12px; color: var(--text-sec);
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.cfg-sub-event__chip {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 500;
  padding: 2px 7px; border-radius: 4px;
  background: var(--bg); color: var(--text-sec);
  border: 1px solid var(--border);
}
.cfg-sub-event__chip--user {
  background: rgba(37,99,235,.10); color: #1E40AF; border-color: #BFDBFE;
}
.cfg-sub-event__diff {
  margin-top: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  background: var(--bg);
  border-left: 3px solid var(--text-sec);
  border-radius: 0 4px 4px 0;
  padding: 8px 12px;
  color: var(--text-sec); line-height: 1.65;
}
.cfg-sub-event__diff .removed { color: var(--danger); text-decoration: line-through; }
.cfg-sub-event__diff .added   { color: #16A34A; }

/* ─── PATTERN 3 · Settings with TOC ─── */
.cfg-sub-settings-grid {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 32px; align-items: start;
}
.cfg-sub-toc {
  position: sticky; top: 24px;
  display: flex; flex-direction: column; gap: 2px;
}
.cfg-sub-toc__head {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec); font-weight: 500;
  padding: 6px 8px; margin-bottom: 4px;
}
.cfg-sub-toc__item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; border-radius: 6px;
  color: var(--text-sec); font-size: 13px;
  text-decoration: none;
  border-left: 2px solid transparent;
  cursor: pointer; transition: 120ms;
  background: transparent; border-top: 0; border-right: 0; border-bottom: 0;
  font-family: inherit; text-align: left;
}
.cfg-sub-toc__item:hover { background: var(--bg); color: var(--text); }
.cfg-sub-toc__item.is-active {
  background: var(--bg); color: var(--text);
  border-left-color: var(--text); font-weight: 500;
}
.cfg-sub-toc__item svg { width: 13px; height: 13px; color: var(--text-sec); flex-shrink: 0; }
.cfg-sub-toc__item.is-active svg { color: var(--text); }

.cfg-sub-settings-content { display: flex; flex-direction: column; gap: 20px; }

.cfg-sub-section {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04);
  overflow: hidden;
}
.cfg-sub-section__head {
  padding: 18px 24px 14px;
  border-bottom: 1px solid #EEF2F6;
  display: flex; align-items: flex-start; justify-content: space-between; gap: 16px;
}
.cfg-sub-section__head-left { display: flex; align-items: center; gap: 12px; }
.cfg-sub-section__icon {
  width: 36px; height: 36px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--border);
  display: grid; place-items: center;
  color: var(--text-sec); flex-shrink: 0;
}
.cfg-sub-section__icon svg { width: 16px; height: 16px; }
.cfg-sub-section__icon--danger {
  background: #FEE2E2; color: var(--danger); border-color: #FECACA;
}
.cfg-sub-section__title {
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  margin: 0 0 2px;
}
.cfg-sub-section__sub { font-size: 12px; color: var(--text-sec); }
.cfg-sub-section__body { padding: 8px 24px; }

.cfg-sub-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 16px; align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid #EEF2F6;
}
.cfg-sub-row:last-child { border-bottom: 0; }
.cfg-sub-row__label {
  font-size: 14px; font-weight: 500; color: var(--text); margin-bottom: 3px;
}
.cfg-sub-row__hint {
  font-size: 12px; color: var(--text-sec); line-height: 1.5;
}
.cfg-sub-row__hint code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; background: var(--bg);
  padding: 1px 6px; border-radius: 4px; border: 1px solid var(--border);
}

/* Toggle switch */
.cfg-sub-toggle {
  position: relative; display: inline-block;
  width: 40px; height: 22px; flex-shrink: 0;
}
.cfg-sub-toggle input { opacity: 0; width: 0; height: 0; }
.cfg-sub-toggle__slider {
  position: absolute; cursor: pointer; inset: 0;
  background: #CBD5E1; border-radius: 999px; transition: 200ms;
}
.cfg-sub-toggle__slider::before {
  content: ""; position: absolute;
  height: 18px; width: 18px; left: 2px; top: 2px;
  background: #fff; border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,.2); transition: 200ms;
}
.cfg-sub-toggle input:checked + .cfg-sub-toggle__slider { background: var(--text); }
.cfg-sub-toggle input:checked + .cfg-sub-toggle__slider::before { transform: translateX(18px); }

.cfg-sub-field { display: flex; align-items: center; gap: 10px; }
.cfg-sub-input,
.cfg-sub-select-inline {
  appearance: none;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 6px; padding: 7px 12px;
  font-family: inherit; font-size: 13px; color: var(--text);
  min-width: 140px; transition: 120ms;
}
.cfg-sub-input:focus,
.cfg-sub-select-inline:focus {
  outline: 0; border-color: var(--text);
  box-shadow: 0 0 0 3px rgba(15,23,42,.06);
}
.cfg-sub-select-inline {
  padding-right: 32px;
  background: var(--card) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>") no-repeat right 10px center;
  cursor: pointer;
}
.cfg-sub-input--mono { font-family: 'JetBrains Mono', monospace; font-size: 12.5px; }
.cfg-sub-unit { color: var(--text-sec); font-size: 13px; }

/* Sticky save bar */
.cfg-sub-savebar {
  position: sticky; bottom: 0; margin-top: 24px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(15,23,42,.08);
  padding: 14px 20px;
  display: flex; align-items: center; justify-content: space-between;
  backdrop-filter: blur(8px);
}
.cfg-sub-savebar__hint {
  font-size: 13px; color: var(--text-sec);
  display: flex; align-items: center; gap: 8px;
}
.cfg-sub-savebar__hint svg { width: 14px; height: 14px; color: #F59E0B; }
.cfg-sub-savebar__actions { display: flex; gap: 8px; }

/* ─── PATTERN 4 · Editor split (FRMs · Lista de Itens) ─── */
.cfg-sub-inner-tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
}
.cfg-sub-inner-tabs__item {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  color: var(--text-sec);
  font-size: 13px; font-weight: 500;
  cursor: pointer;
  background: transparent; border: 0;
  border-bottom: 2px solid transparent;
  font-family: inherit; transition: 120ms;
}
.cfg-sub-inner-tabs__item:hover { color: var(--text); }
.cfg-sub-inner-tabs__item.is-active {
  color: var(--text); border-bottom-color: var(--text); font-weight: 600;
}
.cfg-sub-inner-tabs__item svg { width: 14px; height: 14px; }

.cfg-sub-editor-grid {
  display: grid; grid-template-columns: 280px 1fr;
  gap: 20px; align-items: start;
}
.cfg-sub-frmlist {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04);
  overflow: hidden;
  position: sticky; top: 24px;
  max-height: calc(100vh - 48px);
  display: flex; flex-direction: column;
}
.cfg-sub-frmlist__head {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.cfg-sub-frmlist__title {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-sec); font-weight: 500;
}
.cfg-sub-frmlist__count {
  font-size: 11px; color: var(--text-sec);
  font-variant-numeric: tabular-nums;
  background: var(--bg); border: 1px solid var(--border);
  padding: 2px 8px; border-radius: 999px;
}
.cfg-sub-frmlist__items { overflow-y: auto; flex: 1; }
.cfg-sub-frmitem {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 10px; align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid #EEF2F6;
  cursor: pointer; transition: 120ms; font-size: 13px;
  border-left: 3px solid transparent;
  background: transparent;
}
.cfg-sub-frmitem:last-child { border-bottom: 0; }
.cfg-sub-frmitem:hover { background: var(--bg); }
.cfg-sub-frmitem.is-active {
  background: rgba(37,99,235,.06);
  border-left-color: var(--primary);
  padding-left: 13px;
}
.cfg-sub-frmitem.is-active .cfg-sub-frmitem__code { color: var(--primary); }
.cfg-sub-frmitem__code {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600; font-size: 13px; color: var(--text);
}
.cfg-sub-frmitem__name {
  color: var(--text-sec); font-size: 12.5px; line-height: 1.3;
  min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cfg-sub-frmitem__count {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--text-sec);
  font-variant-numeric: tabular-nums;
}

.cfg-sub-builder { display: flex; flex-direction: column; gap: 16px; }
.cfg-sub-builder__head {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04);
  padding: 18px 20px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  flex-wrap: wrap;
}
.cfg-sub-builder__head-left {
  display: flex; align-items: center; gap: 14px; min-width: 0;
}
.cfg-sub-frmbadge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--text); color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; font-weight: 600;
  padding: 5px 10px; border-radius: 6px;
  letter-spacing: 0.02em; flex-shrink: 0;
}
.cfg-sub-builder__title {
  font-size: 16px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--text);
}
.cfg-sub-builder__sub {
  font-size: 12px; color: var(--text-sec); margin-top: 2px;
}
.cfg-sub-builder__head-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* Step (família) */
.cfg-sub-step {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 1px 2px rgba(15,23,42,.04);
  overflow: hidden;
}
.cfg-sub-step__head {
  display: grid; grid-template-columns: auto 1fr auto auto;
  gap: 14px; align-items: center;
  padding: 14px 18px;
  background: var(--text); color: #fff;
  cursor: pointer;
}
.cfg-sub-step__head--c {
  background: linear-gradient(90deg, var(--text), #1E293B);
  position: relative;
}
.cfg-sub-step__head--c::before {
  content: ""; position: absolute;
  left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--primary);
}
.cfg-sub-step__chev {
  width: 18px; height: 18px;
  color: rgba(255,255,255,.7);
  transition: 200ms;
}
.cfg-sub-step.is-open .cfg-sub-step__chev { transform: rotate(90deg); }
.cfg-sub-step__code {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 600; font-size: 12px;
  background: rgba(255,255,255,.13);
  padding: 3px 8px; border-radius: 5px;
  letter-spacing: 0.02em;
}
.cfg-sub-step__head--c .cfg-sub-step__code {
  background: var(--primary); color: #fff;
}
.cfg-sub-step__name {
  font-size: 14px; font-weight: 600; letter-spacing: -0.01em;
}
.cfg-sub-step__meta {
  font-size: 11.5px; color: rgba(255,255,255,.65);
  font-family: 'JetBrains Mono', monospace;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.cfg-sub-step__actions { display: flex; align-items: center; gap: 4px; }
.cfg-sub-step__icon-btn {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 0; background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.85);
  border-radius: 5px; cursor: pointer; transition: 120ms;
}
.cfg-sub-step__icon-btn:hover { background: rgba(255,255,255,.18); color: #fff; }
.cfg-sub-step__icon-btn svg { width: 13px; height: 13px; }
.cfg-sub-step__body { padding: 6px 0; }

.cfg-sub-item {
  display: grid; grid-template-columns: auto auto 1fr auto auto auto auto;
  gap: 14px; align-items: center;
  padding: 12px 18px;
  border-bottom: 1px solid #EEF2F6;
  transition: 120ms;
}
.cfg-sub-item:last-child { border-bottom: 0; }
.cfg-sub-item:hover { background: var(--bg); }
.cfg-sub-item--res993 { background: #FFF7ED; }
.cfg-sub-item--res993:hover { background: #FFEDD5; }

.cfg-sub-item__handle {
  color: var(--text-sec); cursor: grab;
  width: 14px; height: 14px;
}
.cfg-sub-item__check {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px;
  border: 1.5px solid var(--text-sec);
  border-radius: 4px; cursor: pointer;
  background: var(--card); transition: 120ms;
}
.cfg-sub-item__check.is-on {
  background: var(--text); border-color: var(--text); color: #fff;
}
.cfg-sub-item__check.is-on svg { width: 12px; height: 12px; display: block; }
.cfg-sub-item__check svg { display: none; }

.cfg-sub-item__main { min-width: 0; display: flex; align-items: center; gap: 10px; }
.cfg-sub-item__code {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px; color: var(--text-sec);
  background: var(--bg);
  padding: 2px 6px; border-radius: 4px;
  border: 1px solid var(--border);
  font-variant-numeric: tabular-nums;
}
.cfg-sub-item__label { font-size: 13.5px; color: var(--text); }
.cfg-sub-item__type {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; color: var(--text-sec);
  background: var(--bg);
  padding: 2px 7px; border-radius: 4px;
  border: 1px solid var(--border);
  text-transform: uppercase; letter-spacing: 0.04em;
}

.cfg-sub-pill {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px;
  font-size: 11px; font-weight: 500;
  border-radius: 999px; letter-spacing: 0.01em;
  white-space: nowrap;
}
.cfg-sub-pill--obrig { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.cfg-sub-pill--res   { background: #FFEDD5; color: #C2410C; border: 1px solid #FDBA74; }
.cfg-sub-pill--rule  { background: rgba(37,99,235,.10); color: #1E40AF; border: 1px solid #BFDBFE; }
.cfg-sub-pill svg { width: 11px; height: 11px; }

.cfg-sub-step__add {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  color: var(--text-sec);
  font-size: 12.5px; cursor: pointer;
  border-top: 1px dashed #EEF2F6;
  transition: 120ms;
  background: transparent; border-left: 0; border-right: 0; border-bottom: 0;
  width: 100%; font-family: inherit; text-align: left;
}
.cfg-sub-step__add:hover { background: var(--bg); color: var(--text); }
.cfg-sub-step__add svg { width: 14px; height: 14px; }

/* Empresa/upload preview */
.cfg-sub-upload-row { display: flex; align-items: center; gap: 16px; }
.cfg-sub-logo-preview {
  width: 96px; height: 96px; border-radius: 6px;
  background: var(--bg); border: 1px dashed var(--border);
  display: grid; place-items: center;
  color: var(--text-sec); font-size: 11px;
  overflow: hidden;
}
.cfg-sub-logo-preview img {
  max-width: 100%; max-height: 100%; object-fit: contain;
}
.cfg-sub-upload-actions { display: flex; flex-direction: column; gap: 6px; }

/* Responsive */
@media (max-width: 1100px) {
  .cfg-sub-kpis { grid-template-columns: repeat(2, 1fr); }
  .cfg-sub-settings-grid { grid-template-columns: 1fr; }
  .cfg-sub-toc { position: static; flex-direction: row; flex-wrap: wrap; gap: 4px; margin-bottom: 12px; }
  .cfg-sub-toc__item { border-left: 0; border-bottom: 2px solid transparent; }
  .cfg-sub-toc__item.is-active { border-left: 0; border-bottom-color: var(--text); }
  .cfg-sub-editor-grid { grid-template-columns: 1fr; }
  .cfg-sub-frmlist { position: static; max-height: 360px; }
}
@media (max-width: 720px) {
  .cfg-sub-kpis { grid-template-columns: 1fr; }
  .cfg-sub-event { grid-template-columns: 28px 1fr; gap: 10px; padding: 12px 16px; }
  .cfg-sub-event__time { grid-column: 2; padding-top: 0; margin-bottom: 6px; }
  .cfg-sub-event__action { display: none; }
  .cfg-sub-table th, .cfg-sub-table td { padding: 10px 12px; font-size: 13px; }
  .cfg-sub-search { min-width: 140px; }
}

/* Dark theme overrides */
body.theme-dark .cfg-sub-card,
body.theme-dark .cfg-sub-section,
body.theme-dark .cfg-sub-step,
body.theme-dark .cfg-sub-frmlist,
body.theme-dark .cfg-sub-builder__head,
body.theme-dark .cfg-sub-kpi,
body.theme-dark .cfg-sub-savebar { background: #0f172a; border-color: rgba(255,255,255,0.08); }
body.theme-dark .cfg-sub-table th { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.06); color: rgba(255,255,255,0.55); }
body.theme-dark .cfg-sub-table td { color: #f1f5f9; border-color: rgba(255,255,255,0.06); }
body.theme-dark .cfg-sub-table tbody tr:hover { background: rgba(255,255,255,0.03); }
body.theme-dark .cfg-sub-search,
body.theme-dark .cfg-sub-select,
body.theme-dark .cfg-sub-btn,
body.theme-dark .cfg-sub-input,
body.theme-dark .cfg-sub-select-inline { background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.08); color: #f1f5f9; }
body.theme-dark .cfg-sub-icon-btn:hover { background: rgba(255,255,255,0.05); }
body.theme-dark .cfg-sub-step__head { background: #1e293b; }

/* ═══════════════════════════════════════════════════════════════════════════
   V161 — Mobile performance + layout overrides
   - backdrop-filter desligado em <=720px (GPU-heavy em Android low-end)
   - Animações infinitas do login param (poster gradient já cobre)
   - login-fx (Three.js + dot-matrix) é pulado em JS para <=720px
   - .dash-v1-main recebe min-width:0 pra não overflow horizontal
   - .cad-tabs vira scroll horizontal em telas pequenas (em vez de cortar)
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  /* Sem isso, grid item com filhos largos (KPI strip, tabs em 20px)
     empurra a coluna pra largura maior que viewport. min-width:0 deixa
     o grid item shrink. */
  .dash-v1-main { min-width: 0; }
  .dash-v1-layout { overflow-x: hidden; }
  /* Permite que QUALQUER célula de grid/flex shrink abaixo do min-content.
     Sem isso, .op-kpi__value em 24px monospace empurra a grid pra fora. */
  .op-strip > *, .op-jornada > *, .op-grid-2-13 > *, .op-grid-2 > *,
  .op-alerts-grid > *, .op-compl-grid > *,
  .ge-strip > *, .ge-funnel > *, .ge-ar > *, .ge-grid-2 > *,
  .op-v1-kpis > *, .gr-v1-kpis > *, .fin-v3-kpis > *,
  .op-v1-grid > *, .gr-v1-grid > *, .gr-v1-grid-2 > *,
  .cfg-v1-grid > *, .cad-v1-grid > *, .cad-v1-summary > *,
  .cfg-sub-kpis > *, .cfg-sub-settings-grid > *, .cfg-sub-editor-grid > * {
    min-width: 0;
  }
  /* Cards que contêm tabelas largas: scroll horizontal interno
     em vez de empurrar layout pra fora do viewport. */
  .op-card, .ge-card {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Tabelas: preserva colunas alinhadas no scroll mobile */
  .op-table, .ge-table {
    min-width: max-content;
  }
}
@media (max-width: 720px) {
  .login-eyebrow,
  .login-telemetry,
  .login-right,
  .tu-footer,
  .cfg-sub-savebar {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .login-eyebrow::before,
  .login-telemetry__val.is-live,
  .login-telemetry__val.is-live::before,
  .login-head__live,
  .login-head__live::before {
    animation: none !important;
  }
  /* Tabs (macro Gerencial, cad-tabs em geral) — antes em 20px (V68),
     no celular vira scroll horizontal com font menor.
     Touch target: 44px min altura (CRÍTICO via UI/UX Pro Max). */
  .cad-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cad-tabs::-webkit-scrollbar { display: none; }
  .cad-tab {
    font-size: 13px;
    padding: 12px 12px;
    min-height: 44px;
    flex-shrink: 0;
    white-space: nowrap;
    gap: 6px;
    touch-action: manipulation;
  }

  /* Touch optimization global (CRITICAL — UI/UX Pro Max rule "touch-target-size")
     Botões pequenos no Gerencial Operacional/Estatístico recebem altura mínima
     de 40px (próximo dos 44px ideais) sem ficar bizarro em desktop. */
  button, [role="button"], a, .btn, .cad-tab,
  .op-period button, .ge-period button, .gr-v1-period button,
  .fin-v3-period button, .op-alert__action {
    touch-action: manipulation;
  }
  .op-period button, .ge-period button, .gr-v1-period button,
  .fin-v3-period button {
    padding: 9px 12px !important;
    font-size: 12px !important;
    min-height: 38px;
  }
  .op-alert__action, .ge-alert__action {
    min-height: 36px;
    padding: 7px 12px !important;
  }

  /* Inline styles em Configurações sobrescrevem CSS — preciso de !important
     pra forçar 1 coluna em mobile mesmo com style="grid-template-columns:..." */
  .cfg-sub-kpis,
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns:repeat(5"],
  [style*="grid-template-columns:repeat(6"] {
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
}

@media (max-width: 480px) {
  /* Em telas muito estreitas (≤480px), todas as grids cfg-sub-kpis viram 1 coluna */
  .cfg-sub-kpis,
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns:repeat(5"],
  [style*="grid-template-columns:repeat(6"] {
    grid-template-columns: 1fr !important;
  }
  /* Topbar wrap em mobile pequeno */
  .dash-v1-topbar { flex-wrap: wrap; gap: 8px; }
  .dash-v1-page-head h1, .dash-v1-page-head h2 { font-size: 18px !important; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   V161 — Tables como cards empilhados em mobile (UI/UX Pro Max rule:
   "Tables can overflow on mobile" → "Use horizontal scroll OR card layout")
   Escolha: card layout, porque o usuário pediu "nada pode ser cortado".
   Cada <tr> vira um card vertical mostrando todas as células empilhadas.
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  .cfg-sub-table,
  .op-table,
  .ge-table,
  .gr-v1-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .cfg-sub-table thead,
  .op-table thead,
  .ge-table thead,
  .gr-v1-table thead {
    display: none !important;
  }
  .cfg-sub-table tbody,
  .op-table tbody,
  .ge-table tbody,
  .gr-v1-table tbody {
    display: block !important;
  }
  .cfg-sub-table tbody tr,
  .op-table tbody tr,
  .ge-table tbody tr,
  .gr-v1-table tbody tr {
    display: block !important;
    background: var(--card, #fff) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    margin: 0 0 10px 0 !important;
    padding: 10px 12px !important;
    box-shadow: 0 1px 2px rgba(15,23,42,0.04);
  }
  .cfg-sub-table tbody td,
  .op-table tbody td,
  .ge-table tbody td,
  .gr-v1-table tbody td {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 4px 0 !important;
    border: none !important;
    text-align: left !important;
    white-space: normal !important;
    word-break: break-word;
  }
  /* Linha empty/colspan (ex.: "Nenhuma receita encontrada") — centralizada */
  .cfg-sub-table tbody td[colspan],
  .op-table tbody td[colspan],
  .ge-table tbody td[colspan],
  .gr-v1-table tbody td[colspan] {
    text-align: center !important;
    padding: 14px 8px !important;
  }
  /* Ações (popover) em linha cards: alinhar à direita */
  .cfg-sub-table tbody td:last-child,
  .op-table tbody td:last-child {
    margin-top: 6px;
    text-align: right !important;
    border-top: 1px dashed var(--border-soft, #F1F5F9) !important;
    padding-top: 8px !important;
  }
  /* Tabela com `min-width: max-content` foi pra cancelar scroll horizontal
     dentro do card — agora não precisa mais do scroll, sempre stack. */
  .op-card, .ge-card {
    overflow-x: visible !important;
  }
  .op-table, .ge-table {
    min-width: 0 !important;
  }
  /* Cards de Configurações/Financeiro também não precisam mais de scroll horizontal */
  .cfg-sub-card {
    overflow-x: visible;
  }
}
