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

body {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 10.5pt;
  color: #111;
  background: #fff;
  padding: 0;
}

:root { --brand-color: #16a34a; }

/* ── Cabeçalho ─────────────────────────────────────────────────────────── */

.print-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding-bottom: 10px;
  border-bottom: 3px solid var(--brand-color);
  margin-bottom: 14px;
  gap: 16px;
}

.print-brand-block {
  display: flex;
  align-items: center;
  gap: 12px;
}

.print-logo {
  max-height: 60px;
  max-width: 160px;
  object-fit: contain;
}

.print-logo-placeholder {
  font-size: 2rem;
  width: 48px;
  text-align: center;
}

.print-brand {
  font-size: 12pt;
  font-weight: bold;
  color: var(--brand-color);
  margin-bottom: 2px;
}

.print-tagline {
  font-size: 8.5pt;
  color: #666;
  margin-bottom: 2px;
}

.print-doc {
  font-size: 8pt;
  color: #999;
}

.print-header-right {
  text-align: right;
  flex-shrink: 0;
}

.print-title {
  font-size: 15pt;
  font-weight: bold;
  color: #111;
}

.print-date {
  font-size: 8.5pt;
  color: #555;
  text-align: right;
  line-height: 1.5;
}

/* ── Filtros aplicados ─────────────────────────────────────────────────── */

.print-filters {
  font-size: 8.5pt;
  color: #333;
  background: #f2f2f2;
  border: 1px solid #ccc;
  padding: 5px 10px;
  margin-bottom: 14px;
  border-radius: 3px;
}

/* ── KPIs resumo ───────────────────────────────────────────────────────── */

.print-summary {
  display: flex;
  gap: 0;
  margin-bottom: 16px;
  border: 1px solid #bbb;
}

.print-kpi {
  flex: 1;
  text-align: center;
  padding: 8px 6px;
  border-right: 1px solid #bbb;
}

.print-kpi:last-child { border-right: none; }

.print-kpi-label {
  font-size: 7.5pt;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #666;
  margin-bottom: 3px;
}

.print-kpi-value {
  font-size: 13pt;
  font-weight: bold;
  color: #111;
}

.print-kpi-value.green { color: #145214; }
.print-kpi-value.red   { color: #8b0000; }

/* ── Títulos de seção ──────────────────────────────────────────────────── */

.print-section-title {
  font-size: 11pt;
  font-weight: bold;
  margin: 16px 0 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid #aaa;
  color: #222;
}

/* ── Tabelas ───────────────────────────────────────────────────────────── */

table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 16px;
  font-size: 9.5pt;
}

th {
  background: #e2e2e2;
  border: 1px solid #999;
  padding: 5px 7px;
  text-align: left;
  font-weight: bold;
  font-size: 9pt;
}

td {
  border: 1px solid #ccc;
  padding: 4px 7px;
  vertical-align: middle;
}

tr:nth-child(even) td { background: #f7f7f7; }

tfoot td {
  background: #e2e2e2;
  font-weight: bold;
  border: 1px solid #999;
}

.text-right  { text-align: right; }
.text-center { text-align: center; }

/* ── Rodapé ────────────────────────────────────────────────────────────── */

.print-footer {
  margin-top: 20px;
  padding-top: 6px;
  border-top: 2px solid var(--brand-color);
  font-size: 8pt;
  color: #888;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
}

.print-footer-sep {
  color: #ccc;
  margin: 0 2px;
}

/* ── Pedido — tabela de metadados ──────────────────────────────────────── */

.print-order-meta {
  margin-bottom: 14px;
}

.print-meta-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 9.5pt;
  margin-bottom: 0;
}

.print-meta-table th {
  background: none;
  border: none;
  font-size: 8pt;
  text-transform: uppercase;
  color: #555;
  letter-spacing: 0.04em;
  padding: 3px 10px 2px 0;
  font-weight: bold;
  white-space: nowrap;
  width: 120px;
}

.print-meta-table td {
  border: none;
  padding: 3px 20px 2px 0;
  font-size: 10pt;
}

/* ── Pedido — partes (cliente / vendedor / fábrica) ────────────────────── */

.print-parties {
  display: flex;
  gap: 0;
  border: 1px solid #bbb;
  margin-bottom: 16px;
}

.print-party {
  flex: 1;
  padding: 8px 12px;
  border-right: 1px solid #bbb;
}

.print-party:last-child { border-right: none; }

.print-party-label {
  font-size: 7.5pt;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #666;
  margin-bottom: 3px;
}

.print-party-name {
  font-size: 11pt;
  font-weight: bold;
  color: #111;
}

/* ── Pedido — observações ──────────────────────────────────────────────── */

.print-notes {
  border: 1px solid #ccc;
  border-left: 3px solid #888;
  padding: 8px 12px;
  font-size: 9.5pt;
  color: #333;
  margin-bottom: 20px;
  background: #f9f9f9;
}

/* ── Pedido — assinaturas ──────────────────────────────────────────────── */

.print-signatures {
  display: flex;
  gap: 24px;
  margin-top: 32px;
}

.print-signature-block { flex: 1; }

.print-signature-line {
  border-bottom: 1px solid #555;
  margin-bottom: 6px;
  height: 32px;
}

.print-signature-label {
  font-size: 8.5pt;
  color: #555;
  text-align: center;
}

/* ── Duas vias ─────────────────────────────────────────────────────────── */

.print-via-block {
  padding-bottom: 4px;
}

/* Quando dentro de via, o header não tem margin-top */
.print-via-block .print-header {
  margin-top: 0;
}

.print-via-badge {
  display: inline-block;
  font-size: 7.5pt;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 2px 9px;
  border-radius: 3px;
  margin-bottom: 10px;
}

.print-via-empresa {
  background: #1e293b;
  color: #fff;
}

.print-via-cliente {
  background: var(--brand-color);
  color: #fff;
}

.print-via-meta {
  display: flex;
  gap: 0;
  border: 1px solid #bbb;
  margin-bottom: 12px;
}

.print-via-meta-cell {
  flex: 1;
  padding: 6px 10px;
  border-right: 1px solid #bbb;
}

.print-via-meta-cell:last-child { border-right: none; }
.print-via-meta-wide { flex: 2; }

.print-via-table {
  margin-bottom: 10px;
}

.print-via-saldo-apos { color: #145214; }
.print-via-saldo-apos.negativo { color: #b91c1c; }

.print-via-obs-label {
  font-size: 8pt;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #555;
  margin-bottom: 3px;
}

.print-via-obs {
  border: 1px solid #ccc;
  border-left: 3px solid #aaa;
  padding: 5px 10px;
  font-size: 9pt;
  color: #333;
  margin-bottom: 10px;
  background: #f9f9f9;
}

/* Linha de corte entre as vias */

.print-cut-line {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 22px 0 20px;
  color: #999;
}

.print-cut-line::before,
.print-cut-line::after {
  content: '';
  flex: 1;
  border-top: 2px dashed #c0c0c0;
}

.print-cut-scissors {
  font-size: 11pt;
  color: #aaa;
  transform: rotate(270deg);
  display: inline-block;
  flex-shrink: 0;
}

.print-cut-text {
  font-size: 7.5pt;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #bbb;
  flex-shrink: 0;
}

/* ── Paginação impressa ────────────────────────────────────────────────── */

@page {
  size: A4;
  margin: 1.5cm 1.5cm 2cm;
}

@media print {
  body { padding: 0; }
  table { page-break-inside: auto; }
  tr    { page-break-inside: avoid; page-break-after: auto; }
  thead { display: table-header-group; }
  .print-section { page-break-inside: avoid; }
  .page-break-before { page-break-before: always; }
}
/*


 */
/*
 * RepresentaAgro — Stylesheet
 */

/* Garante que o atributo HTML `hidden` sempre esconda o elemento,
   mesmo quando regras de classe definem display diferente (ex: flex, block). */
[hidden] { display: none !important; }

/* ── Variáveis ─────────────────────────────────────────────────────────── */

:root {
  --green-950: #052e16;
  --green-900: #14532d;
  --green-800: #166534;
  --green-700: #15803d;
  --green-600: #16a34a;
  --green-500: #22c55e;
  --green-200: #bbf7d0;
  --green-100: #dcfce7;
  --green-50:  #f0fdf4;

  --amber-700: #b45309;
  --amber-600: #d97706;
  --amber-500: #f59e0b;
  --amber-200: #fde68a;
  --amber-100: #fef3c7;
  --amber-50:  #fffbeb;

  --slate-900: #0f172a;
  --slate-800: #1e293b;
  --slate-700: #334155;
  --slate-600: #475569;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #f1f5f9;
  --slate-50:  #f8fafc;

  --red-700:   #b91c1c;
  --red-600:   #dc2626;
  --red-500:   #ef4444;
  --red-100:   #fee2e2;
  --red-50:    #fef2f2;

  --bg:        #f2f1ec;
  --surface:   #ffffff;
  --radius:    12px;
  --radius-sm: 8px;
  --shadow:    0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.10), 0 4px 8px rgba(0,0,0,0.05);
}

/* ── Reset / Base ───────────────────────────────────────────────────────── */

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

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', 'Roboto',
    'Helvetica Neue', sans-serif;
  line-height: 1.6;
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--slate-800);
  min-height: 100vh;
  font-size: 15px;
}

h1, h2, h3, h4 { color: var(--slate-900); margin-top: 0; line-height: 1.3; }
h1 { font-size: 2rem;   font-weight: 700; }
h2 { font-size: 1.15rem; font-weight: 600; }

a { color: var(--green-700); transition: color 0.2s; }
a:hover { color: var(--green-900); text-decoration: underline; }

/* ── Layout base ────────────────────────────────────────────────────────── */

body.with-sidebar {
  display: flex;
  min-height: 100vh;
}

body.with-sidebar main {
  flex: 1;
  min-width: 0;
  padding: 28px 32px 48px;
  overflow-y: auto;
}

body.no-sidebar main {
  padding: 28px 28px 48px;
  max-width: 1440px;
  margin: 0 auto;
}

main {
  padding: 28px 28px 48px;
  max-width: 1440px;
  margin: 0 auto;
}

.devise-body main { padding: 0; max-width: 100%; margin: 0; }

/* ── Sidebar ────────────────────────────────────────────────────────────── */

.sidebar {
  width: 224px;
  min-width: 224px;
  background: var(--green-950);
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: sticky;
  top: 0;
  overflow-y: auto;
  overflow-x: hidden;
}

.sidebar-brand {
  padding: 18px 16px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.sidebar-brand-link {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 1rem;
}

.sidebar-brand-link:hover { color: var(--green-200); text-decoration: none; }

.sidebar-brand-icon {
  width: 30px;
  height: 30px;
  background: var(--green-600);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  flex-shrink: 0;
}

.sidebar-nav {
  flex: 1;
  padding: 10px 0;
}

.sidebar-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Link simples */
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  color: rgba(255,255,255,0.75);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
  border-radius: 0;
}

.sidebar-link:hover,
.sidebar-link.active {
  background: rgba(255,255,255,0.10);
  color: #fff;
  text-decoration: none;
}

.sidebar-icon {
  font-size: 1rem;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

/* Grupo com submenu */
.sidebar-group-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 16px;
  background: none;
  border: none;
  color: rgba(255,255,255,0.75);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s, color 0.15s;
}

.sidebar-group-btn:hover {
  background: rgba(255,255,255,0.10);
  color: #fff;
}

.sidebar-caret {
  margin-left: auto;
  font-size: 0.8rem;
  opacity: 0.5;
  transition: transform 0.2s;
  display: inline-block;
}

.sidebar-group.open .sidebar-group-btn {
  background: rgba(255,255,255,0.10);
  color: #fff;
}

.sidebar-group.open .sidebar-caret {
  transform: rotate(90deg);
  opacity: 0.9;
}

/* Submenu */
.sidebar-submenu {
  display: none;
  list-style: none;
  margin: 0;
  padding: 2px 0 4px 0;
  background: rgba(0,0,0,0.20);
}

.sidebar-group.open .sidebar-submenu {
  display: block;
}

.sidebar-submenu a {
  display: block;
  padding: 8px 16px 8px 46px;
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-size: 0.84rem;
  transition: background 0.15s, color 0.15s;
}

.sidebar-submenu a:hover {
  background: rgba(255,255,255,0.08);
  color: #fff;
  text-decoration: none;
}

/* Footer do sidebar */
.sidebar-footer {
  padding: 12px 12px;
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  gap: 8px;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  flex: 1;
  min-width: 0;
}

.sidebar-user:hover { text-decoration: none; }

.sidebar-avatar {
  width: 30px;
  height: 30px;
  background: var(--green-700);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 0.8rem;
  font-weight: 700;
  flex-shrink: 0;
  object-fit: cover;
  overflow: hidden;
}

img.sidebar-avatar {
  display: block;
  background: none;
}

.sidebar-user-name {
  color: rgba(255,255,255,0.80);
  font-size: 0.82rem;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-logout-form { margin: 0; }

.sidebar-logout-btn {
  background: none;
  border: 1px solid rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.60);
  border-radius: 6px;
  padding: 5px 8px;
  font-size: 0.75rem;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}

.sidebar-logout-btn:hover {
  background: rgba(255,255,255,0.10);
  color: #fff;
  border-color: rgba(255,255,255,0.4);
}

/* ── Filter bar ─────────────────────────────────────────────────────────── */

.filter-bar {
  margin-bottom: 16px;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  box-shadow: var(--shadow);
}

.filter-form {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.filter-input {
  padding: 7px 10px;
  border: 1px solid var(--slate-200);
  border-radius: 6px;
  font-size: 0.85rem;
  background: var(--slate-50);
  color: var(--slate-900);
  transition: border-color 0.2s;
  height: 36px;
}

.filter-input:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12);
  background: #fff;
}

.filter-wide { min-width: 240px; }

.filter-check-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.875rem;
  color: var(--slate-600);
  cursor: pointer;
  white-space: nowrap;
}

.filter-check {
  accent-color: var(--green-600);
  width: 15px;
  height: 15px;
  cursor: pointer;
}

/* ── Role badges ────────────────────────────────────────────────────────── */

.role-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.role-admin   { background: #fef3c7; color: #92400e; border: 1px solid #fde68a; }
.role-seller  { background: var(--green-100); color: var(--green-800); border: 1px solid var(--green-200); }
.role-stock   { background: #e0f2fe; color: #0369a1; border: 1px solid #bae6fd; }
.role-manager { background: #f3e8ff; color: #6b21a8; border: 1px solid #e9d5ff; }

/* ── Search form (clientes) ─────────────────────────────────────────────── */

.search-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.search-input {
  padding: 7px 12px;
  border: 1px solid var(--slate-200);
  border-radius: 6px;
  font-size: 0.875rem;
  min-width: 280px;
  background: var(--slate-50);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.search-input:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12);
  background: #fff;
}

/* ── Flash ──────────────────────────────────────────────────────────────── */

.flash {
  padding: 12px 16px;
  margin-bottom: 20px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 500;
}

.flash-notice {
  background: var(--green-50);
  color: var(--green-800);
  border: 1px solid var(--green-200);
}

.flash-alert {
  background: var(--red-50);
  color: var(--red-700);
  border: 1px solid var(--red-100);
}

/* ── Dashboard ──────────────────────────────────────────────────────────── */

.dashboard-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--slate-200);
  flex-wrap: wrap;
}

.dashboard-header-content h1 {
  margin: 0 0 4px;
  font-size: 1.75rem;
  color: var(--slate-900);
}

.dashboard-subtitle {
  margin: 0;
  color: var(--slate-500);
  font-size: 0.9rem;
}

.dashboard-header-date { display: flex; align-items: center; }

/* Filtro de período */
.period-filter-form {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  box-shadow: var(--shadow);
}

.period-filter-group {
  display: flex;
  align-items: center;
  gap: 6px;
}

.period-filter-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--slate-500);
  white-space: nowrap;
}

.period-input {
  padding: 6px 10px;
  border: 1px solid var(--slate-200);
  border-radius: 6px;
  font-size: 0.85rem;
  background: var(--slate-50);
  color: var(--slate-900);
  transition: border-color 0.2s;
}

.period-input:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12);
  background: #fff;
}

/* Título de seção */
.dashboard-section-title {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--slate-500);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 36px 0 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.section-period-badge {
  font-size: 0.72rem;
  font-weight: 600;
  background: var(--green-100);
  color: var(--green-800);
  border-radius: 20px;
  padding: 2px 10px;
  text-transform: none;
  letter-spacing: 0;
  white-space: nowrap;
}

/* ── Cards KPI ──────────────────────────────────────────────────────────── */

.dashboard-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 12px;
}

.dashboard-card {
  background: var(--surface);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
  border-top: 3px solid transparent;
  transition: box-shadow 0.2s, transform 0.2s;
}

.dashboard-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.card-icon {
  width: 46px;
  height: 46px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
}

.card-content { flex: 1; min-width: 0; }

.card-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate-500);
  margin-bottom: 4px;
  overflow-wrap: break-word;
  word-break: break-word;
  line-height: 1.3;
}

.dashboard-count {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  color: var(--slate-900);
}

/* Cores por card */
.card-customers  { border-top-color: var(--green-600); }
.card-customers  .card-icon { background: var(--green-50); }

.card-orders     { border-top-color: var(--amber-600); }
.card-orders     .card-icon { background: var(--amber-50); }

.card-herds      { border-top-color: #0891b2; }
.card-herds      .card-icon { background: #ecfeff; }

.card-products   { border-top-color: #7c3aed; }
.card-products   .card-icon { background: #f5f3ff; }

.card-balances   { border-top-color: #2563eb; }
.card-balances   .card-icon { background: #eff6ff; }

.card-movements  { border-top-color: #db2777; }
.card-movements  .card-icon { background: #fdf2f8; }

.card-goals      { border-top-color: #ea580c; }
.card-goals      .card-icon { background: #fff7ed; }

/* ── Chart cards ────────────────────────────────────────────────────────── */

.dashboard-charts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.dashboard-chart-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 22px;
  box-shadow: var(--shadow);
  border: 1px solid var(--slate-100);
}

.dashboard-chart-card h2 {
  margin: 0 0 16px;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--slate-700);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--slate-100);
}

/* Alert card */
.alert-card { border-left: 4px solid var(--red-500); }
.alert-card h2 { color: var(--red-700); }

.alert-list { display: flex; flex-direction: column; gap: 10px; }

.alert-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: var(--red-50);
  border-radius: 8px;
  border-left: 3px solid var(--red-500);
}

.alert-badge {
  width: 28px;
  height: 28px;
  background: var(--red-500);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.85rem;
  flex-shrink: 0;
}

.alert-info { flex: 1; min-width: 0; }
.alert-customer { font-weight: 600; color: var(--red-700); font-size: 0.9rem; }
.alert-details  { font-size: 0.82rem; color: var(--red-700); opacity: 0.8; margin-top: 1px; }

.alert-empty {
  padding: 14px 16px;
  background: var(--green-50);
  border-left: 3px solid var(--green-500);
  border-radius: 8px;
  color: var(--green-800);
  font-weight: 500;
  font-size: 0.9rem;
}

.negative-value { color: var(--red-700); font-weight: 700; }

/* ── Clientes recentes ──────────────────────────────────────────────────── */

.dashboard-recent { margin-bottom: 16px; }

.recent-list { display: flex; flex-direction: column; }

.recent-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--slate-100);
}

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

.recent-avatar {
  width: 38px;
  height: 38px;
  background: linear-gradient(135deg, var(--green-700), var(--green-500));
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.recent-content { flex: 1; min-width: 0; }

.recent-name { font-weight: 600; color: var(--slate-900); margin-bottom: 1px; font-size: 0.9rem; }
.recent-name a { text-decoration: none; color: var(--slate-900); }
.recent-name a:hover { color: var(--green-700); text-decoration: none; }

.recent-meta { font-size: 0.8rem; color: var(--slate-500); }

.recent-status { flex-shrink: 0; }

.recent-footer {
  padding: 14px 0 0;
  border-top: 1px solid var(--slate-100);
  text-align: right;
  margin-top: 4px;
}

.link-action {
  color: var(--green-700);
  text-decoration: none;
  font-weight: 600;
  font-size: 0.875rem;
  transition: color 0.2s;
}

.link-action:hover { color: var(--green-900); text-decoration: none; }

.empty-state {
  padding: 24px;
  text-align: center;
  color: var(--slate-500);
  background: var(--slate-50);
  border-radius: 8px;
  margin: 0;
  font-size: 0.9rem;
}

/* Status badges */
.status-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
}

.status-active   { background: var(--green-100); color: var(--green-800); }
.status-inactive { background: var(--red-100);   color: var(--red-700);   }

/* ── Status de pedido ───────────────────────────────────────────────────── */

.order-status {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}

.order-status-quote              { background: #f1f5f9; color: var(--slate-600); }
.order-status-created            { background: #eff6ff; color: #1d4ed8; }
.order-status-sent_to_factory    { background: #fdf4ff; color: #7e22ce; }
.order-status-in_production      { background: var(--amber-100); color: var(--amber-700); }
.order-status-invoiced           { background: #fff7ed; color: #c2410c; }
.order-status-in_transit         { background: #ecfeff; color: #0e7490; }
.order-status-delivered_customer { background: var(--green-100); color: var(--green-800); }
.order-status-delivered_warehouse{ background: var(--green-100); color: var(--green-800); }
.order-status-finalized          { background: #d1fae5; color: #065f46; font-weight: 700; }
.order-status-canceled           { background: var(--red-100);  color: var(--red-700); }

/* ── Tabelas ────────────────────────────────────────────────────────────── */

table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 24px;
  box-shadow: var(--shadow);
}

table th, table td { padding: 12px 16px; text-align: left; }

table th {
  background: var(--slate-50);
  color: var(--slate-600);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--slate-200);
}

table td { border-bottom: 1px solid var(--slate-100); font-size: 0.9rem; }

table tr:last-child td { border-bottom: none; }

table tr:hover td { background: var(--slate-50); }

.dashboard-chart-card table { margin: 0; }

tr.row-critical    { background: #fff7ed; }
tr.row-critical:hover { background: #ffedd5; }

.critical-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 7px;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--red-50);
  color: var(--red-700);
  border: 1px solid #fca5a5;
  vertical-align: middle;
  white-space: nowrap;
}

/* ── Botões ─────────────────────────────────────────────────────────────── */

button,
input[type="submit"],
input[type="button"],
.button {
  border: none;
  border-radius: var(--radius-sm);
  background: var(--green-700);
  color: #fff;
  padding: 9px 18px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.875rem;
  transition: background 0.2s, box-shadow 0.2s, transform 0.15s;
  line-height: 1;
}

button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
.button:hover {
  background: var(--green-800);
  box-shadow: 0 4px 10px rgba(22,100,60,0.22);
  transform: translateY(-1px);
  text-decoration: none;
}

.button-secondary {
  background: var(--surface);
  color: var(--slate-700);
  border: 1px solid var(--slate-300);
  box-shadow: var(--shadow);
}

.button-secondary:hover {
  background: var(--slate-50);
  box-shadow: var(--shadow);
  transform: none;
}

.button-danger {
  background: var(--red-600);
}

.button-danger:hover {
  background: var(--red-700);
  box-shadow: 0 4px 10px rgba(220,38,38,0.22);
}

.button-small { padding: 5px 12px; font-size: 0.8rem; }

/* ── Page header (páginas CRUD) ─────────────────────────────────────────── */

/* ── Breadcrumb ────────────────────────────────────────────────────────────── */

.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px 4px;
  font-size: 12px;
  margin-bottom: 10px;
  line-height: 1.4;
}

.breadcrumb-link {
  color: var(--slate-500);
  text-decoration: none;
  transition: color 0.15s;
}

.breadcrumb-link:hover {
  color: var(--green-600);
  text-decoration: underline;
}

.breadcrumb-current {
  color: var(--slate-700);
  font-weight: 500;
}

.breadcrumb-sep {
  color: var(--slate-300);
  user-select: none;
  font-size: 13px;
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.page-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.search-form  { display: flex; gap: 8px; }

.search-input {
  padding: 8px 14px;
  border: 1px solid var(--slate-300);
  border-radius: var(--radius-sm);
  min-width: 240px;
  background: var(--surface);
  font-size: 0.875rem;
  transition: border-color 0.2s;
}

.search-input:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12);
}

/* ── Show page layout ───────────────────────────────────────────────────── */

.show-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.profile-avatar-wrap {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--slate-100);
}

.profile-avatar-img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--slate-200);
  flex-shrink: 0;
}

.profile-avatar-placeholder {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--green-600);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  flex-shrink: 0;
}

.profile-avatar-info { flex: 1; }

.profile-avatar-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--slate-600);
  margin-bottom: 6px;
}

.profile-avatar-hint {
  display: block;
  font-size: 11px;
  color: var(--slate-400);
  margin-top: 4px;
}

.profile-avatar-remove {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--red-600);
  cursor: pointer;
  margin-top: 6px;
  accent-color: var(--red-600);
}

.info-list { display: flex; flex-direction: column; gap: 2px; margin: 0; }

.info-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 6px 0;
  border-bottom: 1px solid var(--slate-100);
  font-size: 0.9rem;
}

.info-row:last-child { border-bottom: none; }

.info-row dt {
  flex-shrink: 0;
  width: 130px;
  color: var(--slate-500);
  font-weight: 600;
  font-size: 0.8rem;
}

.info-row dd { margin: 0; color: var(--slate-800); }

/* ── Previsão de recompra ───────────────────────────────────────────────── */

.restock-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
  margin-bottom: 32px;
}

.restock-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  border-left: 4px solid var(--slate-300);
}

.restock-ok       { border-left-color: var(--green-500); }
.restock-warning  { border-left-color: var(--amber-500); }
.restock-critical { border-left-color: var(--red-500); background: #fff8f8; }
.restock-overdue  { border-left-color: var(--red-700); background: #fff0f0; }
.restock-unknown  { border-left-color: var(--slate-300); }

.restock-product {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--slate-900);
  margin-bottom: 8px;
}

.restock-balance {
  font-size: 0.85rem;
  color: var(--slate-600);
  margin-bottom: 10px;
}

.restock-days {
  font-size: 0.85rem;
  color: var(--slate-700);
  margin-bottom: 4px;
}

.restock-days-unknown { color: var(--slate-400); font-style: italic; }
.restock-days-overdue { color: var(--red-700); font-weight: 600; }

.restock-number {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--slate-900);
  line-height: 1;
  display: inline-block;
  margin-right: 2px;
}

.restock-critical .restock-number { color: var(--red-600); }
.restock-warning  .restock-number { color: var(--amber-600); }

.restock-date {
  font-size: 0.8rem;
  color: var(--slate-600);
  margin-bottom: 6px;
}

.restock-consumption {
  font-size: 0.78rem;
  color: var(--slate-400);
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--slate-100);
}

/* ── Página de previsão de recompra (lista/tabela) ──────────────────────── */

.urgency-summary {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.urgency-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--surface);
  border-radius: var(--radius);
  padding: 14px 20px;
  box-shadow: var(--shadow);
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  min-width: 90px;
}

.urgency-card:hover  { box-shadow: var(--shadow-md); }
.urgency-card.active { border-color: var(--primary-500); }

.urgency-count {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  color: var(--slate-800);
}

.urgency-label {
  font-size: 0.75rem;
  color: var(--slate-500);
  margin-top: 4px;
  white-space: nowrap;
}

.urgency-overdue  .urgency-count { color: var(--red-700); }
.urgency-critical .urgency-count { color: var(--red-600); }
.urgency-warning  .urgency-count { color: var(--amber-600); }
.urgency-ok       .urgency-count { color: var(--green-600); }
.urgency-unknown  .urgency-count { color: var(--slate-400); }

.urgency-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.urgency-badge-overdue  { background: #fee2e2; color: var(--red-700); }
.urgency-badge-critical { background: #fef3c7; color: #b45309; }
.urgency-badge-warning  { background: #fef9c3; color: #854d0e; }
.urgency-badge-ok       { background: #dcfce7; color: var(--green-700); }
.urgency-badge-unknown  { background: var(--slate-100); color: var(--slate-500); }

.empty-state-box {
  text-align: center;
  padding: 60px 20px;
  color: var(--slate-400);
}

.empty-state-box .empty-icon { font-size: 3rem; margin-bottom: 12px; }

/* ── Formulários ────────────────────────────────────────────────────────── */

.form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
  margin-bottom: 20px;
}

/* Ocupa toda a largura da linha no grid */
.form-group--full { grid-column: 1 / -1; }

/* Par de campos lado a lado dentro do grid — ocupa linha inteira e divide em 2 */
.form-group-pair {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 520px) {
  .form-group-pair { grid-template-columns: 1fr; }
}

/* Linha com N campos — ocupa linha inteira e distribui igualmente */
.form-group-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(var(--cols, 5), 1fr);
  gap: 16px;
}
@media (max-width: 900px) {
  .form-group-row { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .form-group-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 400px) {
  .form-group-row { grid-template-columns: 1fr; }
}

.form-group { display: flex; flex-direction: column; }

.form-group label {
  margin-bottom: 6px;
  font-weight: 600;
  color: var(--slate-700);
  font-size: 0.875rem;
}

.form-group input,
.form-group select,
.form-group textarea {
  border: 1px solid var(--slate-300);
  background: var(--surface);
  border-radius: var(--radius-sm);
  padding: 9px 12px;
  color: var(--slate-900);
  font-size: 0.9rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.12);
}

.form-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.form-errors {
  margin-bottom: 20px;
  padding: 16px;
  background: var(--red-50);
  border: 1px solid #fecaca;
  border-radius: var(--radius);
}

.form-errors h2 { margin: 0 0 10px; color: var(--red-700); font-size: 0.95rem; }

/* ── Login ──────────────────────────────────────────────────────────────── */

.devise-body { background: #fff; margin: 0; padding: 0; min-height: 100vh; }

.login-container {
  display: grid;
  grid-template-columns: 60% 40%;
  min-height: 100vh;
}

.login-visual {
  background: linear-gradient(135deg, #2d5016 0%, #1a3a0a 100%);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  background-image: url(/assets/rebanho.jpg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-color: #254114;
}

.login-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(72,187,120,0.15) 0%, transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(34,197,94,0.10) 0%, transparent 50%);
  z-index: 1;
}

.visual-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.22);
  z-index: 1;
}

.visual-content {
  position: relative;
  z-index: 2;
  color: #fff;
  padding: 40px 60px;
  max-width: 640px;
}

.visual-text h1 {
  margin: 0 0 12px;
  font-size: 2.8rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.visual-text > p {
  margin: 0 0 32px;
  font-size: 1.05rem;
  color: rgba(255,255,255,0.9);
}

.visual-features { display: flex; flex-direction: column; gap: 12px; margin-top: 36px; }

.feature {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(255,255,255,0.10);
  border-radius: 10px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.18);
  transition: background 0.2s;
}

.feature:hover { background: rgba(255,255,255,0.16); }
.feature-icon  { font-size: 1.3rem; }
.feature span:last-child { color: rgba(255,255,255,0.95); font-weight: 500; font-size: 0.9rem; }

.login-form-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f8f7f2;
  padding: 40px;
}

.login-form-container { width: 100%; max-width: 380px; }

.login-header { text-align: center; margin-bottom: 32px; }
.login-header h2 { margin: 0 0 8px; font-size: 1.7rem; color: var(--slate-900); }
.login-header p  { margin: 0; color: var(--slate-500); font-size: 0.9rem; }

.login-errors {
  background: var(--red-50);
  border: 1px solid #fecaca;
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 20px;
}

.login-errors ul { margin: 0; padding: 0; list-style: none; }
.login-errors li { color: var(--red-700); font-size: 0.875rem; padding: 3px 0; font-weight: 500; }

.login-field { margin-bottom: 18px; }

.login-label {
  display: block;
  margin-bottom: 7px;
  font-weight: 600;
  color: var(--slate-700);
  font-size: 0.875rem;
}

.login-input {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--slate-300);
  border-radius: 8px;
  font-size: 0.925rem;
  background: #fff;
  color: var(--slate-900);
  transition: border-color 0.2s, box-shadow 0.2s;
  box-sizing: border-box;
}

.login-input:focus {
  outline: none;
  border-color: var(--green-600);
  box-shadow: 0 0 0 3px rgba(22,163,74,0.12);
}

.login-input::placeholder { color: var(--slate-400); }

.login-checkbox { display: flex; align-items: center; gap: 8px; margin-bottom: 22px; }
.checkbox-input  { width: 16px; height: 16px; cursor: pointer; accent-color: var(--green-700); }
.checkbox-label  { font-size: 0.875rem; color: var(--slate-600); cursor: pointer; margin: 0; }

.login-actions { margin-bottom: 20px; }

.login-button {
  width: 100%;
  padding: 12px;
  background: linear-gradient(135deg, var(--green-700) 0%, var(--green-900) 100%);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 700;
  font-size: 0.95rem;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
  box-shadow: 0 4px 12px rgba(22,100,60,0.25);
}

.login-button:hover {
  opacity: 0.92;
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(22,100,60,0.30);
}

.login-footer { border-top: 1px solid var(--slate-200); padding-top: 18px; }

.login-links { display: flex; flex-direction: column; gap: 10px; text-align: center; }

.link-footer {
  color: var(--green-800);
  text-decoration: none;
  font-size: 0.875rem;
}

.link-footer:hover { color: var(--green-900); text-decoration: underline; }

/* ── Status update form inline ─────────────────────────────────────────── */

.status-update-form {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── Order item form ────────────────────────────────────────────────────── */

.order-item-form-wrap {
  background: var(--green-50);
  border: 1px solid var(--green-200);
  border-radius: var(--radius);
  padding: 18px 20px;
  margin-bottom: 20px;
}

.order-item-form-wrap h2 {
  margin: 0 0 14px;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--green-900);
}

/* ── Progress bar ───────────────────────────────────────────────────────── */

.progress-bar-track {
  height: 11px;
  background: var(--slate-200);
  border-radius: 99px;
  overflow: hidden;
  margin: 5px 0;
}

.progress-bar-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.5s ease;
  min-width: 2px;
}

.progress-low      { background: var(--red-500); }
.progress-good     { background: var(--amber-500); }
.progress-complete { background: var(--green-600); }

.goal-progress-section { margin-bottom: 16px; }
.goal-progress-section:last-child { margin-bottom: 0; }

.goal-progress-label {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  color: var(--slate-600);
  margin-bottom: 3px;
}

.progress-pct {
  font-size: 0.75rem;
  color: var(--slate-400);
  text-align: right;
  margin-top: 2px;
}

/* ── Seller goal rows ───────────────────────────────────────────────────── */

.seller-goal-row {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 12px 0;
}

.seller-goal-info { min-width: 0; }

.seller-goal-info strong {
  display: block;
  font-size: 0.9rem;
  color: var(--slate-800);
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.seller-goal-sub {
  font-size: 0.78rem;
  color: var(--slate-500);
}

.seller-goal-progress { flex: 1; min-width: 0; }

.seller-goal-actions { flex-shrink: 0; }

.divider-light { border: none; border-top: 1px solid var(--slate-100); margin: 0; }

/* ── Dashboard do Vendedor ──────────────────────────────────────────────── */

.card-commissions      { border-top-color: #7c3aed; }
.card-commissions      .card-icon { background: #f5f3ff; }

.card-sub {
  display: block;
  font-size: 0.75rem;
  color: var(--slate-500);
  margin-top: 2px;
}

.goals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
  margin-bottom: 32px;
}

.goal-progress-card {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow);
  border-left: 4px solid var(--primary-500);
}

.goal-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 14px;
}

.goal-period-badge {
  flex-shrink: 0;
  font-size: 0.72rem;
  background: var(--slate-100);
  color: var(--slate-600);
  padding: 2px 8px;
  border-radius: 999px;
  white-space: nowrap;
}

.goal-progress-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  color: var(--slate-600);
  margin-bottom: 5px;
}

.goal-progress-label { font-weight: 500; }
.goal-progress-value { color: var(--slate-800); }

.goal-progress-bar-wrap {
  background: var(--slate-100);
  border-radius: 999px;
  height: 8px;
  overflow: hidden;
}

.goal-progress-bar {
  height: 100%;
  border-radius: 999px;
  transition: width 0.4s ease;
  background: var(--slate-400);
}

.bar-full { background: var(--green-600); }
.bar-good { background: var(--amber-500); }
.bar-low  { background: var(--red-500); }

.goal-progress-pct {
  font-size: 0.75rem;
  color: var(--slate-500);
  text-align: right;
  margin-top: 3px;
}

/* ── Card border colors (genérico) ──────────────────────────────────────── */

.card-border-green { border-top-color: var(--green-600); }
.card-border-amber { border-top-color: var(--amber-600); }
.card-border-red   { border-top-color: var(--red-600); }
.card-border-blue  { border-top-color: #2563eb; }

/* ── Paginação (kaminari) ───────────────────────────────────────────────── */

.pagination-wrap {
  display: flex;
  justify-content: center;
  margin: 20px 0 8px;
}

nav.pagination {
  display: flex;
  gap: 4px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
}

nav.pagination a,
nav.pagination span,
nav.pagination em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  padding: 0 8px;
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  font-weight: 500;
  text-decoration: none;
  border: 1px solid var(--slate-200);
  color: var(--slate-700);
  background: var(--surface);
  transition: background 0.15s, border-color 0.15s;
}

nav.pagination a:hover {
  background: var(--green-50);
  border-color: var(--green-200);
  color: var(--green-800);
}

nav.pagination .current,
nav.pagination em.current {
  background: var(--green-700);
  border-color: var(--green-700);
  color: #fff;
  font-style: normal;
  font-weight: 700;
}

nav.pagination .disabled,
nav.pagination span.disabled {
  color: var(--slate-300);
  background: var(--slate-50);
  border-color: var(--slate-100);
  cursor: not-allowed;
}

/* ── Responsivo ─────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
  .login-container { grid-template-columns: 1fr; }
  .login-visual { min-height: 220px; order: -1; }
  .visual-text h1 { font-size: 1.9rem; }
  .visual-features { gap: 8px; }
  .feature { padding: 8px 10px; font-size: 0.875rem; }
}

@media (max-width: 768px) {
  main { padding: 20px 16px 40px; }
.dashboard-header { flex-direction: column; align-items: flex-start; }
  .dashboard-cards { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 480px) {
  .login-form-wrapper { padding: 20px 16px; }
  .login-form-container { max-width: 100%; }
  .dashboard-cards { grid-template-columns: 1fr 1fr; }
  .dashboard-charts { grid-template-columns: 1fr; }
}

/* ── Badge de tipo de movimentação ─────────────────────────────────────── */
.movement-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
}
.movement-entry      { background: var(--green-100); color: var(--green-800); }
.movement-withdrawal { background: var(--red-100);   color: var(--red-700);   }
.movement-adjustment { background: var(--amber-100); color: var(--amber-700); }

/* ── Formulário de itens de movimentação ───────────────────────────────── */

.movement-items-section {
  border: 1px solid var(--slate-200);
  border-radius: var(--radius-sm);
  padding: 12px;
  background: var(--slate-50);
  margin-bottom: 16px;
}

.movement-items-header {
  display: flex;
  gap: 8px;
  padding: 0 0 6px;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate-500);
  border-bottom: 1px solid var(--slate-200);
  margin-bottom: 8px;
}

.movement-item-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 6px;
}

.movement-item-row .login-input { margin: 0; }

.movement-item-row .login-input:first-of-type { flex: 1; }

.qty-input { width: 110px !important; flex: none !important; }

.movement-add-btn { margin-top: 6px; }

/* ── Utilitários de tabela ──────────────────────────────────────────────── */
.text-nowrap { white-space: nowrap; }

.col-actions {
  white-space: nowrap;
  width: 1%;
  text-align: right;
}

.col-actions .button + .button {
  margin-left: 4px;
}

/* button_to gera <form> block; manter inline em containers de ação */
.col-actions form,
.page-actions form,
.commission-actions form {
  display: inline-block;
}

.col-actions form + .button,
.col-actions .button + form .button,
.col-actions form + form .button {
  margin-left: 4px;
}

/* ── Commission status badges ───────────────────────────────────────────── */

.commission-status-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.commission-status-pending  { background: #fef3c7; color: #b45309; }
.commission-status-approved { background: #dcfce7; color: var(--green-700); }
.commission-status-paid     { background: #dbeafe; color: #1d4ed8; }
.commission-status-rejected { background: #fee2e2; color: var(--red-700); }

/* ── Commission approval flow ───────────────────────────────────────────── */

.commission-flow {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

.flow-step {
  padding: 4px 14px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 500;
  background: var(--slate-100);
  color: var(--slate-500);
  border: 1px solid var(--slate-200);
}

.flow-step-done     { background: var(--green-50); color: var(--green-700); border-color: var(--green-300); }
.flow-step-rejected { background: #fee2e2; color: var(--red-700); border-color: #fca5a5; }

.flow-arrow {
  color: var(--slate-300);
  font-size: 1.1rem;
  line-height: 1;
}

.flow-arrow-done { color: var(--green-400); }

.commission-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.commission-action-info {
  width: 100%;
  font-size: 0.88rem;
  color: var(--slate-600);
  margin-bottom: 8px;
}

/* ── Faixas de comissão (commission tiers) ──────────────────────────────── */

.tiers-section {
  margin-top: 28px;
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  padding: 20px;
  background: var(--slate-50);
}

.tiers-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 6px;
}

.tiers-header h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--slate-700);
  margin: 0;
}

.tiers-hint {
  font-size: 0.8rem;
  color: var(--slate-400);
  margin-bottom: 14px;
}

.tier-row { margin-bottom: 8px; }

.tier-row-fields {
  display: flex;
  gap: 10px;
  align-items: flex-end;
}

.tier-row-fields .form-group {
  flex: 1;
  margin-bottom: 0;
}

.tier-remove-btn {
  flex-shrink: 0;
  align-self: flex-end;
  margin-bottom: 0;
}

/* ── Permissões — grade de checkboxes ───────────────────────────────────── */

.perm-group {
  margin-bottom: 16px;
  border: 1px solid var(--slate-100);
  border-radius: var(--radius-sm);
  overflow: hidden;
}

.perm-group-header {
  padding: 6px 12px;
  background: var(--slate-50);
  border-bottom: 1px solid var(--slate-100);
}

.perm-group-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--slate-600);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.perm-keys {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 2px;
  padding: 8px;
}

.perm-key-label {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.8rem;
  transition: background 0.1s;
}

.perm-key-label:hover { background: var(--slate-50); }
.perm-key-label input { accent-color: var(--green-600); cursor: pointer; }

.perm-key-name {
  font-weight: 500;
  color: var(--slate-700);
}

.perm-key-full {
  font-size: 0.72rem;
  color: var(--slate-400);
  font-family: monospace;
}

/* ── Permissões individuais (override) ──────────────────────────────────── */

.perm-keys-override {
  grid-template-columns: 1fr;
  gap: 1px;
  padding: 4px 8px;
}

.perm-override-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 0;
  border-bottom: 1px solid var(--slate-50);
}

.perm-override-row .perm-key-full {
  flex: 1;
  font-size: 0.78rem;
  color: var(--slate-600);
}

.perm-base-badge {
  font-size: 0.68rem;
  padding: 1px 6px;
  border-radius: 10px;
  font-weight: 600;
  white-space: nowrap;
}

.perm-base-yes { background: var(--green-50);  color: var(--green-700); }
.perm-base-no  { background: var(--slate-100); color: var(--slate-400); }

.perm-override-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 4px;
  border: 1px solid var(--slate-200);
  background: var(--slate-50);
  cursor: pointer;
  font-size: 0.8rem;
  color: var(--slate-400);
  transition: all 0.15s;
  user-select: none;
}

.perm-override-btn:hover { border-color: var(--slate-400); }

.perm-grant.active  { background: var(--green-100); color: var(--green-700); border-color: var(--green-400); }
.perm-revoke.active { background: #fee2e2;           color: var(--red-700);   border-color: #fca5a5; }

/* ── Manual do Sistema ─────────────────────────────────────────────────────── */

.manual-search-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  padding: 10px 14px;
}

.manual-search-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
}

.manual-search-icon { font-size: 15px; flex-shrink: 0; }

.manual-search-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 0.9rem;
  background: transparent;
  color: var(--slate-800);
}

.manual-search-clear {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--slate-400);
  font-size: 13px;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background 0.15s;
}
.manual-search-clear:hover { background: var(--slate-100); color: var(--slate-700); }

.manual-search-counter {
  font-size: 12px;
  color: var(--slate-400);
  white-space: nowrap;
  flex-shrink: 0;
}

.manual-no-results {
  text-align: center;
  padding: 40px;
  color: var(--slate-400);
  background: var(--surface);
  border: 1px dashed var(--slate-200);
  border-radius: var(--radius);
  margin-bottom: 16px;
}

.manual-layout {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

/* ── Índice lateral sticky ── */
.manual-toc {
  position: sticky;
  top: 0;
  flex-shrink: 0;
  width: 220px;
  max-height: calc(100vh - 84px);
  overflow-y: auto;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  padding: 16px;
  font-size: 13px;
  z-index: 1;
  scrollbar-width: thin;
  scrollbar-color: var(--slate-200) transparent;
}

.manual-toc-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--slate-400);
  margin-bottom: 10px;
}

.manual-toc ul { list-style: none; margin: 0; padding: 0; }
.manual-toc > ul > li { margin-bottom: 6px; }
.manual-toc > ul > li > ul { padding-left: 12px; margin-top: 4px; }
.manual-toc > ul > li > ul > li { margin-bottom: 3px; }

.manual-toc a {
  color: var(--slate-600);
  text-decoration: none;
  display: block;
  padding: 2px 4px;
  border-radius: 4px;
  transition: background 0.1s, color 0.1s;
}
.manual-toc a:hover { background: var(--green-50); color: var(--green-700); }
.manual-toc a.toc-active {
  background: var(--green-100);
  color: var(--green-800);
  font-weight: 600;
  border-left: 3px solid var(--green-600);
  padding-left: 5px;
}

.manual-toc-group {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--slate-400);
  display: block;
  margin-bottom: 2px;
}

/* ── Seções ── */
.manual-sections { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 16px; }

.manual-section {
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  padding: 24px 28px;
  scroll-margin-top: 28px;
}

.manual-section[hidden] { display: none; }

.manual-section-title {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--slate-800);
  margin-bottom: 8px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--green-100);
}

.manual-section-desc {
  font-size: 0.88rem;
  color: var(--slate-500);
  margin-bottom: 20px;
  line-height: 1.6;
}

.manual-section h3 {
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--slate-500);
  margin: 20px 0 10px;
}
.manual-section h3:first-of-type { margin-top: 0; }

.manual-section p { font-size: 0.88rem; color: var(--slate-600); line-height: 1.6; margin-bottom: 10px; }

/* ── Campos ── */
.manual-fields { display: flex; flex-direction: column; gap: 8px; }

.manual-field {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 8px 16px;
  padding: 8px 10px;
  border-radius: 6px;
  background: var(--slate-50);
  font-size: 0.85rem;
  align-items: baseline;
}

.manual-field dt {
  font-weight: 600;
  color: var(--slate-700);
}

.manual-field dd {
  color: var(--slate-600);
  line-height: 1.55;
  margin: 0;
}

.manual-required {
  font-size: 10px;
  font-weight: 600;
  background: var(--green-100);
  color: var(--green-700);
  border-radius: 10px;
  padding: 1px 6px;
  margin-left: 4px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  vertical-align: middle;
}

.manual-tip {
  margin-top: 16px;
  padding: 10px 14px;
  background: #fffbeb;
  border-left: 3px solid var(--amber-500);
  border-radius: 0 6px 6px 0;
  font-size: 0.84rem;
  color: var(--slate-700);
  line-height: 1.5;
}

.manual-list {
  font-size: 0.88rem;
  color: var(--slate-600);
  padding-left: 20px;
  line-height: 1.8;
}

.manual-section code {
  background: var(--slate-100);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 0.8rem;
  color: var(--slate-700);
}

/* ── Destaque de busca ── */
mark.manual-highlight {
  background: #fef08a;
  color: inherit;
  border-radius: 2px;
  padding: 0 1px;
}

@media (max-width: 900px) {
  .manual-layout { flex-direction: column; }
  .manual-toc { position: static; width: auto; max-height: none; overflow-y: visible; margin-bottom: 16px; }
  .manual-field { grid-template-columns: 1fr; }
}

@media print {
  .manual-search-bar, .manual-toc { display: none; }
  .manual-layout { display: block; }
  .manual-section { break-inside: avoid; border: none; padding: 16px 0; border-bottom: 1px solid #ddd; }
  .manual-section[hidden] { display: block !important; }
}

/* ── PDF Import ─────────────────────────────────────────────────────────── */
.pdf-import-bar {
  display: flex;
  align-items: center;
  gap: 18px;
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-left: 4px solid var(--green-600);
  border-radius: var(--radius-sm);
  padding: 18px 22px;
  margin-bottom: 24px;
  box-shadow: var(--shadow);
}
.pdf-import-icon-wrap {
  width: 46px;
  height: 46px;
  background: var(--green-50);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--green-700);
}
.pdf-import-info { flex: 1; }
.pdf-import-info strong { font-size: 0.95rem; color: var(--slate-800); display: block; }
.pdf-import-info p { margin: 2px 0 0; font-size: 0.82rem; color: var(--slate-500); }

.pdf-import-status {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 16px;
  border: 1px solid transparent;
}
.pdf-import-loading { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.pdf-import-success { background: var(--green-50); color: var(--green-700); border-color: var(--green-200); }
.pdf-import-error   { background: var(--red-50);  color: var(--red-700);   border-color: var(--red-100);  }

/* Preview card */
.pdf-import-preview {
  background: var(--surface);
  border: 1px solid var(--slate-200);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-bottom: 24px;
  overflow: hidden;
}
.pdf-preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  background: var(--slate-50);
  border-bottom: 1px solid var(--slate-200);
}
.pdf-preview-title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--slate-400);
  margin: 0;
}
.pdf-preview-order-num {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--slate-600);
  background: var(--slate-100);
  padding: 2px 12px;
  border-radius: 20px;
  border: 1px solid var(--slate-200);
}
.pdf-preview-body { padding: 20px; }

/* Info grid */
.pdf-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}
.pdf-preview-block {
  background: var(--slate-50);
  border: 1px solid var(--slate-100);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.pdf-preview-label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--slate-400);
}
.pdf-preview-value {
  font-size: 0.88rem;
  color: var(--slate-700);
  font-weight: 500;
}

/* Match indicators */
.pdf-match-found   { font-size: 0.88rem; color: var(--green-700); font-weight: 500; }
.pdf-match-missing { font-size: 0.85rem; color: var(--amber-700); font-weight: 500; }

.pdf-section-title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--slate-400);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--slate-100);
}

/* Items table */
.pdf-items-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.pdf-items-table thead th {
  text-align: left;
  padding: 8px 12px;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--slate-500);
  background: var(--slate-50);
  border-bottom: 2px solid var(--slate-200);
  white-space: nowrap;
}
.pdf-items-table tbody tr { transition: background 0.12s; }
.pdf-items-table tbody tr:hover { background: var(--slate-50); }
.pdf-items-table tbody tr:not(:last-child) td { border-bottom: 1px solid var(--slate-100); }
.pdf-items-table td {
  padding: 10px 12px;
  color: var(--slate-700);
  vertical-align: middle;
}
.pdf-items-table .td-product { font-weight: 500; color: var(--slate-800); }
.pdf-items-table .td-num {
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--slate-600);
  white-space: nowrap;
}
.pdf-items-table .td-status { width: 230px; }

/* Badges */
.pdf-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}
.pdf-badge-ok   { background: var(--green-100); color: var(--green-800); }
.pdf-badge-warn { background: var(--amber-100); color: var(--amber-700); border: 1px solid var(--amber-200); }

/* Unmatched product actions */
.pdf-product-actions { display: flex; flex-direction: column; gap: 6px; }
.pdf-product-select {
  font-size: 0.8rem !important;
  padding: 4px 8px !important;
  height: auto !important;
  border-radius: 6px !important;
}
.pdf-product-register {
  font-size: 0.78rem !important;
  padding: 3px 10px !important;
  text-align: center;
  background: transparent !important;
  color: var(--green-700) !important;
  border: 1px solid var(--green-600) !important;
  box-shadow: none !important;
}
.pdf-product-register:hover { background: var(--green-50) !important; }

/* Missing items hint */
.pdf-missing-hint {
  margin-top: 14px;
  padding: 10px 14px;
  background: var(--amber-50);
  border: 1px solid var(--amber-200);
  border-radius: var(--radius-sm);
  font-size: 0.83rem;
  color: var(--amber-700);
  line-height: 1.5;
}

.factory-order-tag {
  font-size: 0.7rem;
  font-weight: 500;
  background: var(--slate-100);
  color: var(--slate-500);
  border: 1px solid var(--slate-200);
  border-radius: 6px;
  padding: 3px 10px;
  vertical-align: middle;
  margin-left: 8px;
  letter-spacing: 0.02em;
}

/* ── Extrato de Estoque ─────────────────────────────────────────────────── */
.extrato-table { width: 100%; border-collapse: collapse; }
.extrato-table th {
  padding: 10px 14px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--slate-500);
  border-bottom: 2px solid var(--slate-200);
  background: var(--slate-50);
}
.extrato-table td { padding: 10px 14px; border-bottom: 1px solid var(--slate-100); font-size: 0.88rem; }

.extrato-opening td { background: var(--slate-50); font-weight: 600; }
.extrato-closing td { background: var(--slate-50); font-weight: 700; border-top: 2px solid var(--slate-300); }

.extrato-row-entry     { background: #fff; }
.extrato-row-withdrawal { background: #fffbfb; }

.extrato-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
}
.extrato-badge-entry      { background: #dcfce7; color: #15803d; }
.extrato-badge-withdrawal { background: #fee2e2; color: #b91c1c; }
.extrato-badge-adjustment { background: #eff6ff; color: #1d4ed8; }
.extrato-badge-loan       { background: #fef9c3; color: #854d0e; }

.extrato-balance {
  text-align: right;
  font-weight: 700;
  font-size: 0.92rem;
  white-space: nowrap;
}
.extrato-balance-positive { color: var(--green-700); }
.extrato-balance-negative { color: var(--red-700); }
.extrato-balance-neutral  { color: var(--slate-600); }

/* ── Card Dias Úteis ────────────────────────────────────────────────── */
.biz-days-card {
  background: #fff;
  border: 1px solid var(--slate-200);
  border-radius: 12px;
  padding: 18px 22px;
  margin-bottom: 24px;
}
.biz-days-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
}
.biz-days-title {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--slate-700);
}
.biz-days-range {
  display: block;
  font-size: 0.78rem;
  color: var(--slate-400);
  margin-top: 2px;
}
.biz-days-numbers {
  display: flex;
  align-items: center;
  gap: 10px;
}
.biz-day-num { text-align: center; }
.biz-day-val {
  display: block;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--slate-700);
  line-height: 1;
}
.biz-day-val.biz-elapsed   { color: var(--green-700); }
.biz-day-val.biz-remaining { color: #1d4ed8; }
.biz-day-lbl { font-size: 0.7rem; color: var(--slate-400); text-transform: uppercase; letter-spacing: 0.04em; }
.biz-day-sep { font-size: 1.4rem; color: var(--slate-300); font-weight: 300; }

.biz-progress-wrap {
  position: relative;
  height: 10px;
  background: var(--slate-100);
  border-radius: 99px;
  overflow: visible;
  margin-bottom: 6px;
}
.biz-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--green-500), var(--green-400));
  border-radius: 99px;
  transition: width 0.4s ease;
  min-width: 4px;
}
.biz-holiday-marker {
  position: absolute;
  top: -3px;
  width: 3px;
  height: 16px;
  background: #f59e0b;
  border-radius: 2px;
  transform: translateX(-50%);
  cursor: help;
}
.biz-holiday-marker::after {
  content: '';
  position: absolute;
  top: -4px;
  left: 50%;
  transform: translateX(-50%);
  width: 7px;
  height: 7px;
  background: #f59e0b;
  border-radius: 50%;
}
.biz-progress-labels {
  display: flex;
  justify-content: space-between;
  font-size: 0.72rem;
  color: var(--slate-400);
  margin-bottom: 12px;
}
.biz-pct-label {
  font-weight: 600;
  color: var(--slate-500);
}
.biz-days-footer {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  padding-top: 10px;
  border-top: 1px solid var(--slate-100);
  font-size: 0.83rem;
  color: var(--slate-500);
}
.biz-holiday-info strong { color: #b45309; }
.biz-pace-info           { color: var(--slate-600); }
.biz-pace-info strong    { color: var(--slate-800); }

/* ── Quick-create modal ──────────────────────────────────────────────────── */
.select-with-add {
  display: flex;
  gap: 6px;
  align-items: center;
}
.select-with-add .login-input,
.select-with-add select {
  flex: 1;
  min-width: 0;
}
.btn-add-inline {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border: 1px solid var(--slate-300);
  border-radius: 6px;
  background: var(--slate-50);
  color: var(--slate-600);
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.btn-add-inline:hover {
  background: var(--green-50);
  border-color: var(--green-400);
  color: var(--green-700);
}
.qc-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.qc-modal {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.18);
  padding: 28px;
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
}
.qc-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.qc-modal-header h3 {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--slate-800);
}
.qc-close {
  background: none;
  border: none;
  font-size: 1.1rem;
  color: var(--slate-400);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
}
.qc-close:hover { background: var(--slate-100); color: var(--slate-700); }
.qc-modal-footer {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 20px;
  flex-wrap: wrap;
}
.qc-full-link {
  font-size: 0.82rem;
  color: var(--slate-400);
  margin-left: auto;
  text-decoration: underline;
}
.qc-full-link:hover { color: var(--slate-600); }
.qc-error {
  background: var(--red-50);
  border: 1px solid var(--red-200);
  color: var(--red-700);
  border-radius: 6px;
  padding: 8px 12px;
  font-size: 0.85rem;
  margin-bottom: 14px;
}

/* ── Painel de saldo de cliente (movimentações) ──────────────────────────── */
.balance-preview-panel {
  margin-top: 10px;
  border: 1px solid var(--slate-200);
  border-radius: 8px;
  overflow: hidden;
  font-size: 0.85rem;
}

.balance-preview-header {
  background: var(--slate-50);
  border-bottom: 1px solid var(--slate-200);
  padding: 6px 12px;
  font-weight: 600;
  font-size: 0.78rem;
  color: var(--slate-500);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.balance-preview-empty {
  padding: 10px 14px;
  color: var(--slate-400);
  font-style: italic;
  font-size: 0.85rem;
}

.balance-preview-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}
.balance-preview-table thead tr { background: transparent; }
.balance-preview-table th {
  padding: 5px 10px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--slate-500);
  text-align: left;
  border-bottom: 1px solid var(--slate-100);
}
.balance-preview-table td {
  padding: 6px 10px;
  border-bottom: 1px solid var(--slate-50);
  vertical-align: middle;
}
.balance-preview-table tbody tr:last-child td { border-bottom: none; }
.balance-preview-table tbody tr:hover { background: var(--slate-50); }

.bp-product { color: var(--slate-700); }
.bp-qty     { font-variant-numeric: tabular-nums; }
.bp-min     { color: var(--slate-400); font-size: 0.8rem; }

.balance-preview-ok   { color: var(--green-700); }
.balance-preview-crit { color: var(--amber-600); }
.balance-preview-neg  { color: var(--red-600); }

/* Alerta inline de violação de saldo em saída */
.balance-warn {
  margin-top: 6px;
  padding: 6px 10px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 6px;
  color: #9a3412;
  font-size: 0.8rem;
  font-weight: 500;
  grid-column: 1 / -1;
}
.balance-submit-banner {
  margin: 12px 0;
  padding: 10px 14px;
  background: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 8px;
  color: #991b1b;
  font-size: 0.85rem;
}
.balance-submit-banner ul {
  margin: 4px 0 0 16px;
  padding: 0;
}
.balance-submit-banner li {
  margin: 2px 0;
}

.last-movement-summary {
  max-width: 680px;
  margin-bottom: 24px;
  border: 1px solid #86efac;
  border-radius: 10px;
  background: #f0fdf4;
  overflow: hidden;
}
.last-movement-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid #bbf7d0;
}
.lm-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: #16a34a;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  flex-shrink: 0;
}
.last-movement-title {
  display: flex;
  align-items: center;
  gap: 14px;
}
.last-movement-meta {
  color: var(--slate-500);
  font-size: 0.82rem;
  margin-top: 2px;
}
.last-movement-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.last-movement-table th {
  padding: 6px 18px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--slate-500);
  text-align: left;
  border-bottom: 1px solid #bbf7d0;
  background: #dcfce7;
}
.last-movement-table td {
  padding: 8px 18px;
  border-bottom: 1px solid #d1fae5;
  color: var(--slate-700);
}
.last-movement-table tr:last-child td {
  border-bottom: none;
}
.last-movement-notes {
  padding: 8px 18px;
  font-size: 0.8rem;
  color: var(--slate-500);
  border-top: 1px solid #bbf7d0;
  font-style: italic;
}
.last-movement-cta {
  display: flex;
  gap: 0;
  border-top: 1px solid #bbf7d0;
}
.lm-cta-btn {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 8px;
  text-decoration: none;
  color: #15803d;
  font-size: 0.82rem;
  font-weight: 600;
  background: transparent;
  border-right: 1px solid #bbf7d0;
  transition: background 0.15s;
}
.lm-cta-btn:last-child { border-right: none; }
.lm-cta-btn:hover { background: #dcfce7; }
.lm-cta-primary { background: #16a34a; color: #fff; }
.lm-cta-primary:hover { background: #15803d; }
.lm-cta-icon { font-size: 1.2rem; line-height: 1; }
.lm-cta-label { letter-spacing: 0.01em; }

.registered-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 18px;
  border-radius: 8px;
  margin-bottom: 16px;
  font-size: 0.9rem;
  font-weight: 500;
}
.registered-cta-withdrawal {
  background: #f0fdf4;
  border: 1px solid #86efac;
  color: #15803d;
}
.registered-cta-entry {
  background: #eff6ff;
  border: 1px solid #93c5fd;
  color: #1d4ed8;
}

/* ── PDF Attachment ─────────────────────────────────────────────────────── */
.pdf-attachment-card {
  border: 1px solid var(--slate-200);
  border-radius: 10px;
  margin-bottom: 24px;
  overflow: hidden;
  background: var(--slate-50);
}
.pdf-attachment-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-bottom: 1px solid var(--slate-200);
  background: #fff;
  flex-wrap: wrap;
  gap: 8px;
}
.pdf-attachment-title {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--slate-700);
}
.pdf-attachment-info {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
}
.pdf-attachment-name {
  font-size: 0.875rem;
  color: var(--slate-700);
  font-weight: 500;
}
.pdf-attachment-size {
  font-size: 0.78rem;
  color: var(--slate-400);
}
.pdf-upload-form {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  flex-wrap: wrap;
}
.pdf-upload-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  flex: 1;
  min-width: 0;
}
.pdf-upload-input {
  display: none;
}
.pdf-upload-filename {
  font-size: 0.82rem;
  color: var(--slate-500);
  padding: 6px 10px;
  border: 1px dashed var(--slate-300);
  border-radius: 6px;
  background: #fff;
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
  transition: border-color 0.15s;
}
.pdf-upload-filename:hover { border-color: var(--green-600); }

.storage-fee-subtotal td {
  background: var(--slate-50);
  border-top: 1px solid var(--slate-200);
  font-size: 0.85rem;
}

/* ── Badges genéricos ──────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
}
.badge-warning { background: var(--amber-100); color: var(--amber-700); }
.badge-success { background: var(--green-100); color: var(--green-800); }
.badge-danger  { background: var(--red-100);   color: var(--red-700); }
.badge-info    { background: #eff6ff;           color: #1d4ed8; }

/* ── Log de Auditoria ──────────────────────────────────────────────────── */
.audit-row td { vertical-align: middle; }

.audit-expand-btn {
  background: none;
  border: 1px solid var(--slate-200);
  border-radius: 4px;
  cursor: pointer;
  padding: 1px 6px;
  font-size: 0.9rem;
  color: var(--slate-500);
  line-height: 1.4;
}
.audit-expand-btn:hover { background: var(--slate-100); }

.audit-changes-row { background: var(--slate-50); }
.audit-changes-row.hidden { display: none; }

.audit-changes-table {
  width: 100%;
  font-size: 0.82rem;
  border-collapse: collapse;
  margin-top: 4px;
}
.audit-changes-table th {
  text-align: left;
  padding: 4px 8px;
  background: var(--slate-100);
  font-weight: 600;
  color: var(--slate-600);
}
.audit-changes-table td {
  padding: 4px 8px;
  border-bottom: 1px solid var(--slate-100);
  vertical-align: top;
  font-family: monospace;
}
.audit-before { color: var(--red-700); background: #fef2f2; }
.audit-after  { color: var(--green-800); background: #f0fdf4; }
