/* UpCredit — Design System */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green-dark:    #1a5c2e;
  --green-mid:     #226b38;
  --green-accent:  #2ecc71;
  --green-btn:     #28a745;
  --green-btn-h:   #1e7e34;
  --white:         #ffffff;
  --gray-50:       #f8f9fa;
  --gray-100:      #f1f3f4;
  --gray-200:      #e9ecef;
  --gray-400:      #ced4da;
  --gray-600:      #6c757d;
  --gray-800:      #343a40;
  --blue:          #0d6efd;
  --yellow:        #ffc107;
  --red:           #dc3545;
  --orange:        #fd7e14;

  --sidebar-w: 240px;
  --topbar-h:  0px;
  --radius:    8px;
  --shadow:    0 2px 8px rgba(0,0,0,.08);
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 14px;
  color: var(--gray-800);
  background: var(--gray-100);
  min-height: 100vh;
}

/* ── LOGIN ─────────────────────────────────────────────────── */
.login-page {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background: linear-gradient(135deg, #1a5c2e 0%, #0d3a1c 100%);
}

.login-card {
  background: var(--white);
  border-radius: 16px;
  padding: 48px 40px;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
}

.login-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 32px;
  justify-content: center;
}

.logo-mark {
  width: 48px;
  height: 48px;
  background: var(--green-dark);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.logo-mark svg { width: 24px; height: 24px; fill: var(--white); }
.logo-mark img { width: 30px; height: 30px; object-fit: contain; }

.logo-text { line-height: 1.1; }
.logo-text .name  { font-size: 20px; font-weight: 700; color: var(--green-dark); }
.logo-text .sub   { font-size: 11px; font-weight: 600; color: var(--gray-600); letter-spacing: 2px; text-transform: uppercase; }

.login-title { font-size: 22px; font-weight: 600; color: var(--gray-800); margin-bottom: 24px; text-align: center; }

.field { margin-bottom: 18px; }
.field label { display: block; font-size: 12px; font-weight: 600; color: var(--gray-600); margin-bottom: 6px; text-transform: uppercase; letter-spacing: .5px; }
.field-hint { font-size: 10px; font-weight: 400; color: var(--gray-400); text-transform: none; letter-spacing: 0; margin-left: 6px; }
.field-hint code { background: var(--gray-100); border-radius: 3px; padding: 0 3px; font-size: 10px; color: var(--green-dark); }
.field input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  font-size: 14px;
  transition: border-color .2s;
  background: var(--white);
}
.field input:focus { outline: none; border-color: var(--green-accent); }

/* ── Custom Select ──────────────────────────────────────────────── */
.cs-wrap { position: relative; width: 100%; }
.cs-trigger {
  width: 100%; padding: 10px 32px 10px 14px; border: 1.5px solid var(--gray-400);
  border-radius: var(--radius); font-size: 14px; background: var(--white);
  cursor: pointer; user-select: none; color: var(--gray-800);
  position: relative; box-sizing: border-box;
}
.cs-trigger::after {
  content: '▾'; position: absolute; right: 12px; top: 50%;
  transform: translateY(-50%); color: var(--gray-500); pointer-events: none;
}
.cs-wrap.open .cs-trigger { border-color: var(--green-accent); }
.cs-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--white); border: 1.5px solid var(--gray-300);
  border-radius: var(--radius); box-shadow: 0 6px 20px rgba(0,0,0,.12);
  max-height: 240px; overflow-y: auto; z-index: 9999; display: none;
}
.cs-wrap.open .cs-dropdown { display: block; }
.cs-group {
  padding: 6px 12px 4px; font-size: 10px; font-weight: 700;
  color: var(--gray-400); text-transform: uppercase; letter-spacing: .8px;
  background: var(--gray-50); border-bottom: 1px solid var(--gray-100);
}
.cs-item {
  padding: 9px 14px; font-size: 13px; color: var(--gray-800);
  cursor: pointer; transition: background .1s;
}
.cs-item:hover    { background: var(--gray-100); }
.cs-item.selected { background: #e6f4ea; color: var(--green-dark); font-weight: 600; }

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--green-btn);
  color: var(--white);
  border: none;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}
.btn-primary:hover  { background: var(--green-btn-h); }
.btn-primary:disabled { opacity: .6; cursor: not-allowed; }
.btn-full { width: 100%; }

.login-error {
  background: #fff5f5;
  border: 1px solid #fed7d7;
  color: #c53030;
  border-radius: var(--radius);
  padding: 10px 14px;
  font-size: 13px;
  margin-bottom: 16px;
  display: none;
}
.login-error.show { display: block; }

/* ── LAYOUT ─────────────────────────────────────────────────── */
.app-layout {
  display: flex;
  min-height: 100vh;
}

/* ── SIDEBAR ─────────────────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  background: linear-gradient(180deg, #1e6b35 0%, #144d24 100%);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 100;
  overflow-y: auto;
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.sidebar-logo .logo-mark {
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,.18);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sidebar-logo .logo-mark svg { width: 20px; height: 20px; fill: var(--white); }
.sidebar-logo .logo-mark img { width: 26px; height: 26px; object-fit: contain; }

.sidebar-logo .logo-text .name { font-size: 15px; font-weight: 700; color: var(--white); letter-spacing: -.2px; }
.sidebar-logo .logo-text .sub  { font-size: 9px; font-weight: 700; color: rgba(255,255,255,.5); letter-spacing: 3px; text-transform: uppercase; margin-top: 1px; }

.sidebar-nav { flex: 1; padding: 14px 10px; }

.nav-section-label {
  font-size: 10px;
  font-weight: 700;
  color: rgba(255,255,255,.35);
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: 8px 10px 4px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  color: rgba(255,255,255,.65);
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: background .18s, color .18s, box-shadow .18s;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  border-radius: 8px;
  margin-bottom: 2px;
}
.nav-item:hover  { background: rgba(255,255,255,.1); color: var(--white); }
.nav-item.active {
  background: rgba(255,255,255,.95);
  color: var(--green-dark);
  box-shadow: 0 2px 10px rgba(0,0,0,.18);
}

.nav-item .nav-icon { width: 17px; height: 17px; flex-shrink: 0; opacity: .8; }
.nav-item:hover  .nav-icon { opacity: 1; }
.nav-item.active .nav-icon { opacity: 1; color: var(--green-dark); }

.nav-badge {
  margin-left: auto;
  background: var(--red);
  color: var(--white);
  border-radius: 10px;
  min-width: 20px;
  height: 18px;
  padding: 0 5px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nav-item.active .nav-badge { background: var(--red); }
.nav-badge.hidden { display: none; }

/* ── SIDEBAR NAV GROUPS ──────────────────────────────────────────── */
.nav-group { margin-bottom: 2px; }

.nav-group-header {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 12px;
  background: none;
  border: none;
  color: rgba(255,255,255,.42);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 6px;
  transition: color .18s, background .18s;
  margin-bottom: 1px;
}
.nav-group-header:hover { color: rgba(255,255,255,.75); background: rgba(255,255,255,.07); }
.nav-group-header .nav-icon { width: 14px; height: 14px; flex-shrink: 0; opacity: .65; }
.nav-group-chevron {
  width: 13px; height: 13px;
  flex-shrink: 0;
  margin-left: auto;
  transition: transform .22s ease;
  opacity: .5;
}
.nav-group.expanded > .nav-group-header .nav-group-chevron { transform: rotate(90deg); }
.nav-group.expanded > .nav-group-header { color: rgba(255,255,255,.7); }

.nav-group-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height .25s ease;
}
.nav-group.expanded > .nav-group-items { max-height: 220px; }

.nav-item.nav-sub { padding-left: 24px; font-size: 12.5px; }

.sidebar-user {
  padding: 12px 10px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 2px;
}

.user-avatar {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(255,255,255,.18);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--white);
  font-weight: 700;
  font-size: 14px;
}

.user-info { flex: 1; overflow: hidden; }
.user-info .user-name { font-size: 13px; font-weight: 600; color: var(--white); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.user-info .user-role { font-size: 11px; color: rgba(255,255,255,.45); margin-top: 1px; }

.btn-logout {
  background: rgba(255,255,255,.08);
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,.5);
  padding: 7px;
  border-radius: 7px;
  transition: all .18s;
  display: flex;
  align-items: center;
}
.btn-logout:hover { background: rgba(255,255,255,.15); color: var(--white); }
.btn-logout svg { width: 16px; height: 16px; display: block; }

/* ── MAIN CONTENT ─────────────────────────────────────────────── */
.main-content {
  margin-left: var(--sidebar-w);
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow-y: auto;
}

.page { display: none; padding: 28px 32px; }
.page.active { display: block; }

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  flex-shrink: 0;
}

.page-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--gray-800);
}

.page-actions { display: flex; gap: 10px; align-items: center; }

/* ── CARDS (dashboard) ─────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 0;
  flex-shrink: 0;
}

.stat-card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 14px 16px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
}

.stat-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.stat-icon svg { width: 22px; height: 22px; }
.stat-card.yellow .stat-icon { background: #fff8e1; color: #c77c00; }
.stat-card.green  .stat-icon { background: #e6f4ea; color: var(--green-btn); }
.stat-card.red    .stat-icon { background: #fce8e6; color: var(--red); }
.stat-card.blue   .stat-icon { background: #e8f0fe; color: var(--blue); }
.stat-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }

.stat-card .label { font-size: 11px; font-weight: 600; color: var(--gray-600); text-transform: uppercase; letter-spacing: .5px; }
.stat-card .value { font-size: 22px; font-weight: 700; color: var(--gray-800); line-height: 1.1; }
.stat-card .sub   { font-size: 11px; color: var(--gray-600); }

.stat-card.green .value { color: var(--green-btn); }
.stat-card.red   .value { color: var(--red); }
.stat-card.blue  .value { color: var(--blue); }
.stat-card.yellow .value { color: #c77c00; }
.stat-card.clickable { cursor: pointer; transition: box-shadow .15s, transform .1s; }
.stat-card.clickable:hover { box-shadow: 0 4px 16px rgba(0,0,0,.12); transform: translateY(-1px); }

/* ── DASHBOARD CHARTS ─────────────────────────────────────────── */
#page-dashboard { display:none; flex-direction:column; height:100%; padding:20px 28px 16px; box-sizing:border-box; overflow:hidden; }
#page-dashboard.active { display:flex; }
.dash-charts { display:grid; grid-template-columns:1fr 2fr 1.2fr; gap:14px; margin-top:12px; flex:1; min-height:0; }
@media(max-width:1100px){ .dash-charts { grid-template-columns:1fr 2fr; } }
@media(max-width:900px){ .dash-charts { grid-template-columns:1fr; overflow-y:auto; } }

/* ── ATIVIDADE RECENTE ────────────────────────────────────────── */
.ativ-feed { display:flex; flex-direction:column; flex:1; min-height:0; overflow-y:auto; }
.ativ-empty { font-size:12px; color:var(--gray-600); text-align:center; padding:24px 0; }
.ativ-item { display:flex; align-items:center; gap:8px; padding:7px 0; border-bottom:1px solid var(--gray-200); flex-shrink:0; }
.ativ-item:last-child { border-bottom:none; }
.ativ-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.ativ-dot.aprovado  { background:var(--green-btn); }
.ativ-dot.reprovado { background:var(--red); }
.ativ-dot.concluido { background:var(--green-dark); }
.ativ-dot.pendente  { background:var(--gray-400); }
.ativ-info { flex:1; min-width:0; }
.ativ-nome   { font-size:12px; font-weight:600; color:var(--gray-800); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ativ-status { font-size:11px; color:var(--gray-600); margin-top:1px; }
.ativ-tempo  { font-size:11px; color:var(--gray-400); flex-shrink:0; }
.chart-card { background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow); padding:16px; display:flex; flex-direction:column; min-height:0; overflow:hidden; }
.chart-card-title { font-size:12px; font-weight:600; color:var(--gray-600); text-transform:uppercase; letter-spacing:.5px; margin-bottom:8px; flex-shrink:0; }
.chart-wrap { position:relative; flex:1; min-height:0; }

/* ── PC TABS ──────────────────────────────────────────────────── */
.pc-tabs { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }
.pc-tab  { background:var(--white); border:1.5px solid var(--gray-300); padding:5px 16px; border-radius:20px; font-size:13px; font-weight:600; color:var(--gray-600); cursor:pointer; transition:all .15s; }
.pc-tab:hover { background:var(--gray-100); color:var(--gray-800); border-color:var(--gray-400); }
.pc-tab[data-sit="pendentes"].active  { border-color:var(--yellow); background:#fff8e1; color:#856404; }
.pc-tab[data-sit="aprovados"].active  { border-color:var(--green-btn); background:#e6f4ea; color:#1a7f37; }
.pc-tab[data-sit="reprovados"].active { border-color:var(--red); background:#fce8e6; color:#c62828; }

/* ── FILTER CHIPS ─────────────────────────────────────────────── */
.filter-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 16px;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid transparent;
  background: var(--white);
  transition: all .15s;
}
.chip:hover { opacity: .85; }
.chip.active { opacity: 1; }

.chip.pendente  { border-color: var(--yellow); color: #856404; }
.chip.analisando { border-color: var(--blue);  color: var(--blue); }
.chip.aprovado  { border-color: var(--green-btn); color: var(--green-btn); }
.chip.reprovado { border-color: var(--red);    color: var(--red); }
.chip.erro      { border-color: var(--gray-600); color: var(--gray-600); }
.chip.todos     { border-color: var(--gray-400); color: var(--gray-600); }

.chip.active.pendente   { background: #fff8e1; }
.chip.active.analisando { background: #e8f0fe; }
.chip.active.aprovado   { background: #e6f4ea; }
.chip.active.reprovado  { background: #fce8e6; }
.chip.active.erro       { background: var(--gray-100); }
.chip.active.todos      { background: var(--gray-100); }

/* ── SEARCH BAR ─────────────────────────────────────────────── */
.search-bar {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.search-input-wrap {
  position: relative;
  flex: 1;
  min-width: 180px;
  max-width: 360px;
}

.search-input-wrap svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  color: var(--gray-600);
  pointer-events: none;
}

.search-input-wrap input {
  width: 100%;
  padding: 9px 12px 9px 34px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--gray-800);
  background: var(--white);
  transition: border-color .2s;
}
.search-input-wrap input:focus { outline: none; border-color: var(--green-accent); }

.select-filter {
  padding: 9px 12px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  font-size: 13px;
  color: var(--gray-800);
  background: var(--white);
  cursor: pointer;
  flex-shrink: 0;
}

.btn-refresh {
  background: var(--white);
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  padding: 8px 10px;
  cursor: pointer;
  display: flex;
  align-items: center;
  color: var(--gray-600);
  transition: all .15s;
}
.btn-refresh:hover { border-color: var(--green-btn); color: var(--green-btn); }
.btn-refresh svg { width: 16px; height: 16px; }

/* ── TABLE ─────────────────────────────────────────────────── */
.table-wrap {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow-x: auto;
  overflow-y: hidden;
}

table {
  width: 100%;
  border-collapse: collapse;
}

thead th {
  background: var(--gray-50);
  padding: 10px 16px;
  text-align: left;
  font-size: 12px;
  font-weight: 700;
  color: var(--gray-600);
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
  border-bottom: 1px solid var(--gray-200);
}

thead th .sort-icon { margin-left: 4px; opacity: .4; }

tbody tr { border-bottom: 1px solid var(--gray-200); transition: background .1s; }
tbody tr:last-child { border-bottom: none; }
tbody tr:hover { background: var(--gray-50); }

tbody td { padding: 8px 16px; vertical-align: middle; }

.td-name { font-weight: 600; color: var(--gray-800); }
.td-doc  { font-size: 12px; color: var(--gray-600); font-family: monospace; }

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
}
.status-badge::before {
  content: '';
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-pendente   { background: #f8f9fa; color: #6c757d; }
.status-pendente::before   { background: #6c757d; }
.status-analisando { background: #e8f0fe; color: #0d6efd; }
.status-analisando::before { background: #0d6efd; }
.status-aprovado   { background: #e6f4ea; color: #1a7f37; }
.status-aprovado::before   { background: #28a745; }
.status-reprovado  { background: #fce8e6; color: #c62828; }
.status-reprovado::before  { background: #dc3545; }
.status-erro       { background: #fff3e0; color: #e65100; }
.status-erro::before       { background: #fd7e14; }

.td-actions { display: flex; gap: 6px; align-items: center; }

.btn-icon {
  border: none;
  border-radius: 6px;
  padding: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}
.btn-icon svg { width: 15px; height: 15px; }

.btn-icon.view   { background: #e6f4ea; color: var(--green-btn); }
.btn-icon.view:hover   { background: var(--green-btn); color: var(--white); }
.btn-icon.quick  { background: #e8f0fe; color: var(--blue); }
.btn-icon.quick:hover  { background: var(--blue); color: var(--white); }
.btn-icon.edit   { background: var(--gray-100); color: var(--gray-600); }
.btn-icon.edit:hover   { background: var(--gray-200); color: var(--gray-800); }
.btn-icon.delete { background: #fce8e6; color: var(--red); }
.btn-icon.delete:hover { background: var(--red); color: var(--white); }

.td-em { color: var(--gray-400); }

/* ── PAGINATION ─────────────────────────────────────────────── */
.pagination-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  border-top: 1px solid var(--gray-200);
  background: var(--white);
}

.pagination-info { font-size: 13px; color: var(--gray-600); }

.pagination-btns { display: flex; gap: 6px; align-items: center; }

.btn-page {
  min-width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--gray-400);
  border-radius: 6px;
  background: var(--white);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  transition: all .15s;
  padding: 0 8px;
}
.btn-page:hover    { border-color: var(--green-btn); color: var(--green-btn); }
.btn-page.active   { background: var(--green-btn); border-color: var(--green-btn); color: var(--white); }
.btn-page:disabled { opacity: .4; cursor: not-allowed; }
.btn-page svg { width: 14px; height: 14px; }

/* ── MODAL ─────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }

.modal {
  background: var(--white);
  border-radius: 12px;
  width: 100%;
  max-width: 520px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  transform: translateY(16px);
  transition: transform .2s;
}
.modal-overlay.open .modal { transform: translateY(0); }

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--gray-200);
}

.modal-title { font-size: 16px; font-weight: 700; color: var(--gray-800); }

.btn-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--gray-600);
  padding: 4px;
  border-radius: 4px;
  transition: color .15s;
}
.btn-close:hover { color: var(--gray-800); }
.btn-close svg { width: 20px; height: 20px; display: block; }

.modal-body { padding: 24px; overflow-y: auto; flex: 1; }
.modal-footer {
  padding: 16px 24px;
  border-top: 1px solid var(--gray-200);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.btn-secondary {
  padding: 9px 18px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  background: var(--white);
  color: var(--gray-600);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
}
.btn-secondary:hover { border-color: var(--gray-600); color: var(--gray-800); }

textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  font-size: 14px;
  font-family: inherit;
  resize: vertical;
  min-height: 80px;
  transition: border-color .2s;
}
textarea:focus { outline: none; border-color: var(--green-accent); }

select {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--gray-400);
  border-radius: var(--radius);
  font-size: 14px;
  background: var(--white);
}

/* ── QUICK STATUS DROPDOWN ─────────────────────────────────────── */
.quick-status-overlay {
  position: fixed;
  inset: 0;
  z-index: 400;
  display: none;
}
.quick-status-overlay.open { display: block; }

.quick-status-menu {
  position: fixed;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: 0 8px 24px rgba(0,0,0,.15);
  padding: 6px;
  z-index: 401;
  min-width: 160px;
  display: none;
}
.quick-status-menu.open { display: block; }

.status-opt {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  transition: background .1s;
}
.status-opt:hover { background: var(--gray-100); }
.status-opt::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.status-opt.pendente::before   { background: #6c757d; }
.status-opt.analisando::before { background: #0d6efd; }
.status-opt.aprovado::before   { background: #28a745; }
.status-opt.reprovado::before  { background: #dc3545; }
.status-opt.erro::before       { background: #fd7e14; }

/* ── TOAST ─────────────────────────────────────────────────── */
.toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 999;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.toast {
  background: var(--gray-800);
  color: var(--white);
  padding: 12px 18px;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 500;
  box-shadow: var(--shadow);
  animation: slideIn .2s ease;
}
.toast.success { background: var(--green-btn); }
.toast.error   { background: var(--red); }

@keyframes slideIn {
  from { transform: translateX(100%); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

/* ── LOADING ─────────────────────────────────────────────────── */
.loading-row td {
  text-align: center;
  padding: 40px;
  color: var(--gray-600);
}

.spinner {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--gray-200);
  border-top-color: var(--green-btn);
  border-radius: 50%;
  animation: spin .6s linear infinite;
  vertical-align: middle;
  margin-right: 8px;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ── RESPONSIVE ─────────────────────────────────────────────── */

/* Notebook / small desktop (≤1440px) */
@media (max-width: 1440px) {
  :root { --sidebar-w: 210px; }
  .page { padding: 20px 24px; }
  #page-dashboard { padding: 20px 24px; }
  .stats-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
  .stat-card .value { font-size: 22px; }
}

/* Notebook apertado (≤1280px) */
@media (max-width: 1280px) {
  :root { --sidebar-w: 196px; }
  .page { padding: 18px 20px; }
  #page-dashboard { padding: 18px 20px; }
  .stats-grid { grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 0; }
  .stat-card { padding: 14px; gap: 10px; }
  .stat-icon { width: 40px; height: 40px; }
  .fluxo-builder { grid-template-columns: 1fr; }
  .fluxo-legend { position: static; }
  .sidebar-logo .logo-text .name { font-size: 13px; }
  .nav-item { font-size: 12px; padding: 8px 10px; }
}

/* Tela pequena / tablet paisagem (≤1024px) */
@media (max-width: 1024px) {
  :root { --sidebar-w: 180px; }
  .page { padding: 16px; }
  #page-dashboard { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .dash-charts { grid-template-columns: 1fr; }
  .page-title { font-size: 17px; }
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); transition: transform .25s; }
  .sidebar.open { transform: translateX(0); }
  .main-content { margin-left: 0; }
  .page { padding: 16px; }
  #page-dashboard { padding: 16px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── PRÉ-CADASTROS ─────────────────────────────────────────────── */
.modal-wide { max-width: 700px; }
.modal-sm   { max-width: 400px; }

.confirm-icon { font-size: 28px; margin-right: 10px; line-height: 1; }
.confirm-msg  { font-size: 14px; color: var(--gray-800); margin: 0 0 6px; line-height: 1.5; }
.confirm-sub  { font-size: 12px; color: var(--gray-500); margin: 0; line-height: 1.4; }

.btn-danger {
  background: var(--red);
  color: var(--white);
  border: none;
  padding: 8px 18px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}
.btn-danger:hover { background: #b02a37; }

.modal-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 2px solid var(--gray-200);
  margin-bottom: 20px;
}

.tab-btn {
  padding: 8px 14px;
  border: none;
  background: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-600);
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: color .15s, border-color .15s;
}
.tab-btn:hover  { color: var(--gray-800); }
.tab-btn.active { color: var(--green-btn); border-bottom-color: var(--green-btn); }

.tab-pane        { display: none; }
.tab-pane.active { display: block; }

.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 16px;
}

.pc-info-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
  background: var(--gray-50);
  border-radius: var(--radius);
  padding: 8px 12px;
  margin-bottom: 16px;
  font-size: 12px;
  color: var(--gray-600);
}
.pc-info-bar:empty { display: none; }

.badge-sync {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
}
.sync-ok   { background: #e6f4ea; color: #1a7f37; }
.sync-pend { background: #fff3e0; color: #e65100; }

/* ── FLUXO DE CRÉDITO ─────────────────────────────────────────── */
.fluxo-builder {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 24px;
  align-items: start;
}

.fluxo-steps { display: flex; flex-direction: column; align-items: center; }

.loading-flow { padding: 40px; color: var(--gray-600); }

.flow-empty {
  padding: 48px 32px;
  text-align: center;
  color: var(--gray-600);
  background: var(--white);
  border-radius: var(--radius);
  border: 2px dashed var(--gray-200);
  width: 100%;
  line-height: 1.8;
}

.flow-start {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--green-btn);
  color: var(--white);
  padding: 9px 22px;
  border-radius: 24px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .5px;
}

.flow-connector {
  color: var(--gray-400);
  font-size: 18px;
  line-height: 1;
  padding: 4px 0;
}

.flow-step {
  width: 100%;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  border: 1.5px solid var(--gray-200);
  overflow: hidden;
  transition: opacity .2s;
}

.flow-step.step-inactive { opacity: .55; }

.step-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
}

.step-num {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--gray-100);
  color: var(--gray-600);
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.step-icon-wrap {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.step-icon-wrap.tipo-externo    { background: #e8f0fe; color: var(--blue); }
.step-icon-wrap.tipo-interno    { background: #e6f4ea; color: var(--green-btn); }

.step-info { flex: 1; min-width: 0; }
.step-name { font-size: 14px; font-weight: 600; color: var(--gray-800); }
.step-meta { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: 3px; }

.tipo-chip {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .3px;
}
.tipo-chip.tipo-externo    { background: #e8f0fe; color: var(--blue); }
.tipo-chip.tipo-interno    { background: #e6f4ea; color: #1a7f37; }
.tipo-chip.tipo-skip       { background: var(--gray-100); color: var(--gray-600); }

.step-subtipo-lbl { font-size: 12px; color: var(--gray-600); }
.pf-dot { font-size: 11px; color: var(--blue); font-weight: 600; }
.pj-dot { font-size: 11px; color: var(--green-btn); font-weight: 600; }

.step-controls {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.btn-step-ctrl {
  border: none;
  background: var(--gray-100);
  color: var(--gray-600);
  border-radius: 5px;
  padding: 5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}
.btn-step-ctrl:hover:not(:disabled) { background: var(--gray-200); color: var(--gray-800); }
.btn-step-ctrl:disabled { opacity: .3; cursor: not-allowed; }
.btn-step-ctrl.edit:hover:not(:disabled) { background: #e8f0fe; color: var(--blue); }
.btn-step-ctrl.delete:hover { background: #fce8e6; color: var(--red); }

/* CSS toggle switch */
.toggle-wrap  { position: relative; display: inline-block; width: 36px; height: 20px; cursor: pointer; flex-shrink: 0; }
.toggle-input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-slider { position: absolute; inset: 0; background: var(--gray-400); border-radius: 10px; transition: .2s; }
.toggle-slider::before { content: ''; position: absolute; width: 14px; height: 14px; left: 3px; bottom: 3px; background: white; border-radius: 50%; transition: .2s; }
.toggle-input:checked + .toggle-slider { background: var(--green-btn); }
.toggle-input:checked + .toggle-slider::before { transform: translateX(16px); }

.step-actions-bar {
  display: flex;
  gap: 20px;
  padding: 8px 16px 10px 64px;
  background: var(--gray-50);
  border-top: 1px solid var(--gray-200);
  font-size: 12px;
}
.step-action { color: var(--gray-600); }
.step-action.sucesso { color: #1a7f37; }
.step-action.falha   { color: var(--red); }
.step-action strong  { font-weight: 600; }

/* Legend */
.fluxo-legend {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
  font-size: 12px;
  position: sticky;
  top: 20px;
}
.legend-title   { font-size: 13px; font-weight: 700; color: var(--gray-800); margin-bottom: 12px; }
.legend-section { font-size: 10px; font-weight: 700; color: var(--gray-600); letter-spacing: .8px; text-transform: uppercase; margin-bottom: 8px; }
.legend-row { display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.leg-ic { width: 20px; height: 20px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; flex-shrink: 0; }
.leg-ic.continuar { background: #e8f0fe; color: var(--blue); }
.leg-ic.aprovar   { background: #e6f4ea; color: #1a7f37; }
.leg-ic.reprovar  { background: #fce8e6; color: var(--red); }
.leg-lbl  { font-weight: 600; color: var(--gray-800); flex: 1; }
.leg-desc { color: var(--gray-600); }
.leg-tipo-lbl { display: inline-block; padding: 2px 7px; border-radius: 4px; font-size: 10px; font-weight: 700; letter-spacing: .3px; margin-bottom: 5px; }
.leg-tipo-lbl.externo    { background: #e8f0fe; color: var(--blue); }
.leg-tipo-lbl.interno    { background: #e6f4ea; color: #1a7f37; }
.leg-tipo-lbl.hub        { background: #f0f4ff; color: #4338ca; }
.leg-tipo-lbl.atribuicao { background: #fff7ed; color: #c2410c; }
.leg-tipo-item { color: var(--gray-600); padding: 2px 0 2px 8px; font-size: 12px; display: flex; justify-content: space-between; }
.leg-price { color: var(--gray-400); font-size: 11px; font-weight: 500; padding-right: 4px; }

/* Field hint */
.field-hint { color: #64748b; font-size: 11px; margin-top: 5px; line-height: 1.5; display: block; }

/* Tour */
.tour-box {
  position: fixed;
  background: #fff;
  border-radius: 14px;
  padding: 20px 22px 18px;
  box-shadow: 0 20px 60px rgba(0,0,0,.22), 0 0 0 1px rgba(0,0,0,.06);
  pointer-events: all;
  z-index: 9999;
  transition: top .25s, left .25s;
}
.tour-progress  { font-size: 11px; color: #94a3b8; font-weight: 600; letter-spacing: .4px; text-transform: uppercase; }
.tour-title     { font-size: 15px; font-weight: 700; color: #1e293b; margin: 6px 0 10px; }
.tour-desc      { font-size: 13px; color: #475569; line-height: 1.65; margin: 0; white-space: pre-line; }
.tour-close-btn { background: none; border: none; color: #94a3b8; cursor: pointer; font-size: 16px; padding: 0 2px; line-height: 1; }
.tour-close-btn:hover { color: #475569; }

/* "Como funciona?" button */
.btn-tour {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius);
  border: 1.5px solid var(--green-btn);
  background: transparent;
  color: var(--green-btn);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.btn-tour:hover { background: var(--green-btn); color: #fff; }

/* Result modal */
.result-loading { padding: 24px; text-align: center; color: var(--gray-600); }
.result-error   { padding: 16px; background: #fce8e6; color: var(--red); border-radius: var(--radius); }
.result-banner-ok  { padding: 14px 18px; background: #e6f4ea; color: #1a7f37; border-radius: var(--radius); font-size: 16px; font-weight: 700; margin-bottom: 16px; }
.result-banner-nok { padding: 14px 18px; background: #fce8e6; color: var(--red); border-radius: var(--radius); font-size: 16px; font-weight: 700; margin-bottom: 16px; }

.result-steps { display: flex; flex-direction: column; gap: 8px; }
.result-step { display: flex; align-items: center; gap: 10px; padding: 10px 14px; border-radius: var(--radius); background: var(--gray-50); border: 1px solid var(--gray-200); }
.result-step.ok   { border-color: #c3e6cb; background: #f0faf3; }
.result-step.fail { border-color: #f5c6cb; background: #fff5f5; }
.result-step.skipped { opacity: .6; }
.rs-icon { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; background: var(--gray-200); color: var(--gray-600); }
.result-step.ok   .rs-icon { background: #c3e6cb; color: #1a7f37; }
.result-step.fail .rs-icon { background: #f5c6cb; color: var(--red); }
.rs-info { flex: 1; min-width: 0; }
.rs-nome { display: block; font-size: 13px; font-weight: 600; color: var(--gray-800); }
.rs-msg  { display: block; font-size: 12px; color: var(--gray-600); }
.rs-trace { margin-top: 8px; padding: 8px 10px; background: var(--gray-50); border-radius: 6px; border: 1px solid var(--gray-200); font-size: 11px; }
.rs-trace-url { color: var(--gray-500); margin-bottom: 6px; word-break: break-all; }
.rs-trace-row { display: flex; align-items: baseline; gap: 6px; padding: 2px 0; }
.rs-trace-icon { font-size: 10px; font-weight: 700; width: 12px; flex-shrink: 0; }
.rs-trace-row.ok   .rs-trace-icon { color: #1a7f37; }
.rs-trace-row.fail .rs-trace-icon { color: var(--red); }
.rs-trace-campo { font-weight: 600; color: var(--gray-700); min-width: 80px; }
.rs-trace-val { color: var(--gray-600); }
.rs-trace-resp { margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--gray-200); display: flex; flex-wrap: wrap; gap: 4px 12px; }
.rs-trace-kv { color: var(--gray-600); white-space: nowrap; }

/* Vincular button */
.btn-vincular {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  background: var(--green-btn);
  color: var(--white);
  border: none;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s;
}
.btn-vincular:hover { background: var(--green-btn-h); }

.btn-motivo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fce8e6;
  color: var(--red);
  border: 1.5px solid #f5c6cb;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  vertical-align: middle;
  margin-left: 4px;
  flex-shrink: 0;
}
.btn-vincular.hidden { display: none; }

.btn-icon.btn-lock { color: var(--gray-400); }
.btn-icon.btn-lock:hover { background: var(--gray-100); color: var(--gray-600); }
.badge-integrado {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 20px;
  background: #e8f5e9; color: var(--green-dark);
  font-size: 11px; font-weight: 600; white-space: nowrap;
  border: 1px solid #a5d6a7;
}

/* Vincular/Reprovar decision modal */
.vincular-opcoes { display: flex; flex-direction: column; gap: 10px; }
.btn-opcao-aprovar, .btn-opcao-reprovar {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 13px 16px;
  border-radius: var(--radius); font-size: 14px; font-weight: 600;
  cursor: pointer; transition: background .15s, border-color .15s;
  text-align: left;
}
.btn-opcao-aprovar, .btn-opcao-reprovar {
  background: var(--white); border: 2px solid var(--gray-300); color: var(--gray-700);
}
.btn-opcao-aprovar:hover { background: #f6fdf8; border-color: var(--green-btn); color: var(--green-dark); }
.btn-opcao-aprovar.selected { background: #d4edda; border-color: var(--green-btn); color: var(--green-dark); }
.btn-opcao-reprovar:hover { background: #fff5f5; border-color: var(--red); color: var(--red); }
.btn-opcao-reprovar.selected { background: #fcdede; border-color: var(--red); color: var(--red); }

/* ── CONFIGURAÇÕES ────────────────────────────────────────── */
.config-card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-bottom: 20px;
  overflow: hidden;
}

.config-card-hdr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--gray-200);
}

.config-card-hdr-left {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.config-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.config-card-icon svg { width: 18px; height: 18px; }
.config-card-icon.icon-blue   { background: #e8f0fe; color: var(--blue); }
.config-card-icon.icon-green  { background: #e6f4ea; color: var(--green-btn); }
.config-card-icon.icon-orange { background: #fff3e0; color: var(--orange); }
.config-card-icon.icon-gray   { background: var(--gray-100); color: var(--gray-600); }

.config-card-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--gray-800);
  margin-bottom: 2px;
}

.config-card-desc {
  font-size: 12px;
  color: var(--gray-600);
  line-height: 1.4;
}

/* table inside config card — card provides the shadow */
.config-card > .table-wrap {
  box-shadow: none;
  border-radius: 0;
}

/* padded area for non-table content */
.config-card-body {
  padding: 16px 20px;
}

/* job widget */
.config-job-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.config-job-row label {
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-700);
  white-space: nowrap;
}

.config-job-row input[type="number"] {
  width: 80px;
  padding: 7px 10px;
  border: 1.5px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 13px;
  background: var(--white);
}

.config-job-status {
  font-size: 12px;
  color: var(--gray-600);
  padding: 5px 10px;
  background: var(--gray-50);
  border-radius: 6px;
  border: 1px solid var(--gray-200);
}

.btn-sm {
  padding: 6px 14px;
  font-size: 13px;
}

.td-loading {
  text-align: center;
  color: var(--gray-600);
  padding: 24px !important;
}

/* ── INTEGRATION ENGINE BADGES ────────────────────────────── */
.api-badge {
  display: block;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 4px;
  margin-top: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.api-fill    { background: #e8f5e9; color: #2e7d32; border: 1px solid #c8e6c9; }
.api-match   { background: #e8f5e9; color: #2e7d32; border: 1px solid #c8e6c9; }
.api-diff    { background: #fff3e0; color: #e65100; border: 1px solid #ffe0b2; }
.api-valid   { background: #e8f5e9; color: #2e7d32; border: 1px solid #c8e6c9; }
.api-invalid { background: #fce4ec; color: #c62828; border: 1px solid #f48fb1; }

/* ── BULK COLUMN HIDE ─────────────────────────────────────── */
#pcTable.hide-cb th:first-child,
#pcTable.hide-cb td:first-child { display: none; }
#pcTable.hide-actions th:last-child,
#pcTable.hide-actions td:last-child { display: none; }

/* ── BULK ACTION BAR ──────────────────────────────────────── */
.bulk-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  background: #e8f0fe;
  border: 1px solid #c5d3f0;
  border-radius: var(--radius);
  margin-bottom: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--gray-800);
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  background: transparent;
  color: var(--gray-600);
  border: 1.5px solid var(--gray-300);
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.btn-outline:hover { background: var(--gray-100); border-color: var(--gray-400); }

/* ── LOTE RESULT MODAL ────────────────────────────────────── */
.lote-summary {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.lote-stat {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 700;
}
.lote-stat.lote-ok   { background: #e6f4ea; color: #1a7f37; }
.lote-stat.lote-nok  { background: #fce8e6; color: var(--red); }
.lote-stat.lote-skip { background: var(--gray-100); color: var(--gray-600); }
.lote-stat.lote-err  { background: #fff3e0; color: #c77c00; }

.lote-list { display: flex; flex-direction: column; gap: 6px; max-height: 360px; overflow-y: auto; }
.lote-row  {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: var(--radius);
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
}
.lote-row.ok      { border-color: #c3e6cb; background: #f0faf3; }
.lote-row.fail    { border-color: #f5c6cb; background: #fff5f5; }
.lote-row.skipped { opacity: .65; }

/* ── BUSCAR CLIENTE (REANÁLISE) ───────────────────────────── */
.buscar-cliente-list { display: flex; flex-direction: column; gap: 4px; max-height: 340px; overflow-y: auto; }
.buscar-cliente-item {
  padding: 10px 14px; border-radius: var(--radius); border: 1.5px solid var(--gray-200);
  cursor: pointer; transition: background .12s, border-color .12s;
}
.buscar-cliente-item:hover { background: #e6f4ea; border-color: var(--green-btn); }
.buscar-cliente-nome { font-size: 13px; font-weight: 600; color: var(--gray-800); }
.buscar-cliente-doc  { font-size: 11px; color: var(--gray-600); margin-top: 2px; }

/* ── AVALIAR CARTEIRA — viewport-fit grid ───────────────────────── */
#page-reanalise.active {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

#page-reanalise .page-header,
#page-reanalise #reanaliseBulkBar {
  flex-shrink: 0;
}

#page-reanalise .search-bar {
  flex-wrap: nowrap;
  flex-shrink: 0;
  margin-bottom: 12px;
  gap: 8px;
}

#page-reanalise .search-input-wrap {
  min-width: 140px;
  max-width: 220px;
}

#reanaliseAtivo  { width: 100px; }
#reanaliseTipo   { width: 126px; }
#reanaliseRisco  { width: 158px; }

#page-reanalise .table-wrap {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#page-reanalise .table-body-wrap {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: auto;
}

#page-reanalise .pagination-bar {
  flex-shrink: 0;
}
