:root {
  --cor-fundo: #F8F9FA;
  --cor-fundo-card: #FFFFFF;
  --cor-fundo-hover: #F3F4F6;
  --cor-texto: #1F2937;
  --cor-texto-secundario: #6B7280;
  --cor-texto-sec: #6B7280;
  --cor-cinza: #9CA3AF;
  --cor-borda: #E5E7EB;
  --cor-borda-forte: #D1D5DB;
  --cor-acento: #2563EB;
  --cor-acento-hover: #1D4ED8;
  --cor-acento-light: #DBEAFE;
  --cor-sucesso: #059669;
  --cor-sucesso-light: #D1FAE5;
  --cor-alerta: #D97706;
  --cor-alerta-light: #FFEDD5;
  --cor-erro: #DC2626;
  --cor-erro-light: #FEE2E2;
  --cor-info: #2563EB;
  --cor-info-light: #DBEAFE;
  --cor-sidebar: #111827;
  --cor-sidebar-texto: #D1D5DB;
  --cor-sidebar-ativo: #2563EB;
  --cor-sidebar-hover: #1F2937;
  --sidebar-width: 220px;
  --fonte: 'SF Pro Display', 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  --pad-pagina: 20px;
  --pad-secao: 12px;
  --pad-elemento: 8px;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: var(--fonte); background: var(--cor-fundo); color: var(--cor-texto); font-size: 13px; display: flex; flex-direction: column; height: 100vh; overflow: hidden; }

/* === LAYOUT === */
.app-container { display: flex; flex: 1; overflow: hidden; }
.sidebar { width: var(--sidebar-width); min-width: var(--sidebar-width); background: var(--cor-sidebar); color: var(--cor-sidebar-texto); display: flex; flex-direction: column; overflow-y: auto; }
.main-area { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.breadcrumb-bar { background: white; border-bottom: 1px solid var(--cor-borda); padding: 0 var(--pad-pagina); display: flex; align-items: center; gap: 0; font-size: 13px; color: var(--cor-texto-secundario); min-height: 44px; }
.breadcrumb-bar .bc-back { display: inline-flex; align-items: center; gap: 6px; color: var(--cor-acento); cursor: pointer; text-decoration: none; font-weight: 600; padding: 8px 14px 8px 0; border-right: 1px solid var(--cor-borda); margin-right: 14px; font-size: 13px; transition: color 0.15s; }
.breadcrumb-bar .bc-back:hover { color: var(--cor-acento-hover); }
.breadcrumb-bar .bc-back .bc-arrow { font-size: 16px; line-height: 1; }
.breadcrumb-bar .bc-sep { color: var(--cor-cinza); margin: 0 6px; }
.breadcrumb-bar .bc-link { color: var(--cor-texto-secundario); cursor: pointer; text-decoration: none; transition: color 0.15s; }
.breadcrumb-bar .bc-link:hover { color: var(--cor-acento); text-decoration: underline; }
.breadcrumb-bar .bc-current { color: var(--cor-texto); font-weight: 600; }
.content-area { flex: 1; overflow-y: auto; padding: var(--pad-pagina); background: var(--cor-fundo); }
.screen { display: none; }
.screen.active { display: block; }

/* === SIDEBAR === */
.sidebar-brand { padding: 16px 16px 12px; display: flex; align-items: center; }
.sidebar-logo { height: 32px; width: auto; filter: brightness(0) invert(1); }
.sidebar-sep { height: 1px; background: #374151; margin: 4px 12px; }
.sidebar-label { padding: 8px 16px 4px; font-size: 9px; text-transform: uppercase; color: #6B7280; letter-spacing: 1px; font-weight: 600; }
.sidebar-item { padding: 9px 16px; color: var(--cor-sidebar-texto); cursor: pointer; display: flex; align-items: center; gap: 10px; transition: background 0.15s; font-size: 13px; border-left: 3px solid transparent; }
.sidebar-item:hover { background: var(--cor-sidebar-hover); }
.sidebar-item.active { background: rgba(37,99,235,0.15); color: #fff; border-left-color: var(--cor-acento); }
.sidebar-item .icon { width: 18px; text-align: center; font-size: 14px; }
.sidebar-item.sub { padding-left: 44px; font-size: 12px; }
.sidebar-footer { margin-top: auto; padding: 12px 16px; font-size: 10px; color: #6B7280; border-top: 1px solid #374151; }

/* ── Sidebar notification badge ── */
.sidebar-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 18px; height: 18px; padding: 0 5px; border-radius: 9px; background: #DC2626; color: #fff; font-size: 10px; font-weight: 700; margin-left: auto; line-height: 1; }

/* === LOG PANEL === */
.log-panel { background: #1E1E1E; color: #0F0; font-family: 'SF Mono', 'Consolas', 'Courier New', monospace; font-size: 11px; padding: 6px 12px; border-top: 1px solid #333; line-height: 1.6; min-height: 60px; max-height: 60px; overflow: hidden; }
.log-panel .log-line { opacity: 0.85; }
.log-panel .log-time { color: #888; }
.log-panel .log-ok { color: #4ADE80; }
.log-panel .log-warn { color: #FBBF24; }
.log-panel .log-err { color: #F87171; }

/* === CARDS === */
.card { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 8px; padding: var(--pad-secao); }
.card-header { font-size: 13px; font-weight: 600; color: var(--cor-texto); margin-bottom: 12px; padding-bottom: 8px; border-bottom: 1px solid var(--cor-borda); }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 16px; }
.stat-card { text-align: center; padding: 16px var(--pad-secao); transition: box-shadow .15s, transform .15s; cursor: default; }
.stat-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); transform: translateY(-1px); }
.stat-card .number { font-size: 32px; font-weight: 700; line-height: 1; }
.stat-card .label { font-size: 11px; color: var(--cor-texto-secundario); margin-top: 4px; }

/* Period toggle (Acumulado / 30d) */
.period-toggle { display: inline-flex; background: var(--cor-borda, #E5E7EB); border-radius: 8px; padding: 3px; gap: 2px; }
.period-toggle .pill { padding: 6px 16px; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; color: var(--cor-texto-sec, #6B7280); transition: all .15s; border: none; background: transparent; }
.period-toggle .pill.active { background: var(--cor-fundo-card, #fff); color: var(--cor-texto, #1F2937); box-shadow: 0 1px 3px rgba(0,0,0,.1); }
.period-toggle .pill:hover:not(.active) { color: var(--cor-texto, #1F2937); }

/* Stat delta indicators */
.stat-delta { font-size: 12px; font-weight: 600; margin-top: 6px; }
.stat-delta.up { color: #059669; }
.stat-delta.down { color: #DC2626; }
.stat-delta.neutral { color: var(--cor-texto-sec, #6B7280); }

/* Movimentacao card (Meus processos) */
.mov-card { background: var(--cor-fundo-card, #fff); border-radius: var(--radius, 12px); padding: 16px var(--pad-secao); border: 1px solid var(--cor-borda, #E5E7EB); transition: box-shadow .15s, transform .15s; cursor: default; }
.mov-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); transform: translateY(-1px); }
.mov-card .mov-title { font-size: 12px; color: var(--cor-texto); margin-bottom: 14px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.mov-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 10px; }
.mov-row:last-child { margin-bottom: 0; }
.mov-row .mov-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; position: relative; top: -2px; }
.mov-row .mov-num { font-size: 22px; font-weight: 700; min-width: 32px; text-align: right; }
.mov-row .mov-text { font-size: 13px; color: var(--cor-texto-sec, #6B7280); line-height: 1.3; }

/* Row label with line */
.row-label { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--cor-texto-sec, #6B7280); margin-bottom: 8px; display: flex; align-items: center; gap: 10px; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.grid-4 { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 16px; }

/* === BUTTONS === */
.btn-primary { background: var(--cor-acento); color: white; border: none; padding: 8px 16px; border-radius: 6px; font-weight: 600; cursor: pointer; font-size: 13px; font-family: var(--fonte); }
.btn-primary:hover { background: var(--cor-acento-hover); }
.btn-secondary { background: white; color: var(--cor-texto); border: 1px solid var(--cor-borda); padding: 8px 16px; border-radius: 6px; cursor: pointer; font-size: 13px; font-family: var(--fonte); }
.btn-secondary:hover { background: var(--cor-fundo-hover); }
.btn-sm { padding: 4px 10px; font-size: 11px; }
.btn-success { background: var(--cor-sucesso); color: white; border: none; padding: 4px 12px; border-radius: 6px; cursor: pointer; font-size: 11px; font-family: var(--fonte); }
.btn-danger { background: var(--cor-erro); color: white; border: none; padding: 4px 12px; border-radius: 6px; cursor: pointer; font-size: 11px; font-family: var(--fonte); }

/* === TABLE === */
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th { background: #F9FAFB; color: var(--cor-texto-secundario); font-weight: 600; text-align: left; padding: 10px 12px; border-bottom: 2px solid var(--cor-borda); font-size: 11px; text-transform: uppercase; }
.data-table td { padding: 12px 12px; border-bottom: 1px solid #F3F4F6; }
.data-table tr:nth-child(even) td { background: #F9FAFB; }
.data-table tr:hover td { background: var(--cor-acento-light); }
.data-table tr.clickable { cursor: pointer; }

/* === BADGE === */
.badge { display: inline-block; padding: 2px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; white-space: nowrap; }
.badge-green { background: #D1FAE5; color: #059669; }
.badge-red { background: #FEE2E2; color: #DC2626; }
.badge-orange { background: #FFEDD5; color: #D97706; }
.badge-blue { background: #DBEAFE; color: #2563EB; }
.badge-gray { background: #F3F4F6; color: #6B7280; }
.badge-yellow { background: #FEF3C7; color: #92400E; }
.badge-purple { background: #EDE9FE; color: #7C3AED; }
.badge-teal { background: #CCFBF1; color: #0D9488; }
.badge-terceiro { background: #E0E7FF; color: #4338CA; border: 1px dashed #A5B4FC; }

/* === SEMAPHORE === */
.semaforo-dot { width: 12px; height: 12px; border-radius: 50%; display: inline-block; }
.sem-red { background: var(--cor-erro); }
.sem-orange { background: var(--cor-alerta); }
.sem-yellow { background: #EAB308; }
.sem-green { background: var(--cor-sucesso); }
.sem-gray { background: var(--cor-cinza); }

/* === TABS === */
.tab-bar { display: flex; border-bottom: 2px solid var(--cor-borda); margin-bottom: 16px; }
.tab { padding: 10px 20px; font-size: 13px; cursor: pointer; color: var(--cor-texto-secundario); font-weight: 500; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color 0.15s; }
.tab:hover { color: var(--cor-texto); }
.tab.active { color: var(--cor-acento); border-bottom-color: var(--cor-acento); }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* === FILTERS === */
.filter-bar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; padding: 12px; background: white; border: 1px solid var(--cor-borda); border-radius: 8px; }
.filter-bar select, .filter-bar input[type=text], .filter-bar input[type=number], .filter-bar input[type=date] { padding: 6px 10px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 13px; font-family: var(--fonte); background: white; }
.filter-bar label { font-size: 12px; color: var(--cor-texto-secundario); font-weight: 500; }
.filter-bar input[type=checkbox] { accent-color: var(--cor-acento); }

/* === PAGINATION === */
.pagination { display: flex; justify-content: space-between; align-items: center; padding: 12px 0; font-size: 13px; color: var(--cor-texto-secundario); flex-wrap: wrap; gap: 8px; }
.pagination button { background: white; border: 1px solid var(--cor-borda); padding: 6px 14px; border-radius: 6px; cursor: pointer; font-size: 12px; font-family: var(--fonte); }
.pagination button:hover:not(:disabled) { background: var(--cor-fundo-hover); }
.pagination button:disabled { opacity: 0.4; cursor: default; }
.pagination .pag-info { font-size: 12px; color: var(--cor-texto-secundario); white-space: nowrap; }
.pagination .pag-controls { display: flex; align-items: center; gap: 4px; }
.pagination .pag-controls button { padding: 4px 10px; min-width: 32px; }
.pagination .pag-controls button.active { background: var(--cor-acento); color: white; border-color: var(--cor-acento); font-weight: 600; }
.pagination .pag-controls .pag-ellipsis { padding: 4px 6px; color: var(--cor-texto-secundario); }
.pagination .pag-right { display: flex; align-items: center; gap: 8px; }
.pagination .pag-right select { padding: 4px 8px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 12px; font-family: var(--fonte); background: white; }
.pagination .pag-goto { display: flex; align-items: center; gap: 4px; }
.pagination .pag-goto input { width: 50px; padding: 4px 8px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 12px; text-align: center; font-family: var(--fonte); }
.pagination .pag-goto button { padding: 4px 8px; font-size: 11px; }

/* === SCREEN DESC === */
.screen-desc { font-size: 13px; color: var(--cor-texto-secundario); line-height: 1.5; margin-bottom: 16px; padding: 10px 14px; background: var(--cor-fundo); border-left: 3px solid var(--cor-acento); border-radius: 4px; }

/* === HEADER === */
.screen-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.screen-header h1 { font-size: 20px; font-weight: 700; color: var(--cor-texto); }
.screen-header .actions { display: flex; gap: 8px; }

/* === FORMS === */
.form-group { margin-bottom: 12px; }
.form-group label { display: block; font-size: 12px; font-weight: 500; color: var(--cor-texto-secundario); margin-bottom: 4px; }
.form-group input, .form-group select, .form-group textarea { width: 100%; padding: 8px 10px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 13px; font-family: var(--fonte); background: white; }
.form-group textarea { min-height: 80px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-row-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }

/* === BAR CHART (CSS only) === */
.bar-chart-row { display: flex; align-items: center; margin-bottom: 8px; gap: 8px; transition: background .12s; border-radius: 4px; padding: 2px 4px; margin-left: -4px; margin-right: -4px; }
.bar-clickable { cursor: pointer; }
.bar-clickable:hover { background: rgba(37, 99, 235, .06); }
.bar-chart-row .bar-label { width: 130px; font-size: 12px; color: var(--cor-texto-secundario); text-align: right; flex-shrink: 0; }
.bar-chart-row .bar-track { flex: 1; height: 20px; background: #F3F4F6; border-radius: 4px; overflow: hidden; }
.bar-chart-row .bar-fill { height: 100%; border-radius: 4px; display: flex; align-items: center; padding-left: 8px; font-size: 10px; color: white; font-weight: 600; min-width: 24px; }
.bar-chart-row .bar-val { width: 30px; font-size: 12px; font-weight: 600; }

/* === TIMELINE (legacy) === */
.timeline { display: flex; align-items: flex-start; gap: 0; margin: 16px 0; padding: 0 20px; }
.timeline-step { display: flex; flex-direction: column; align-items: center; position: relative; flex: 1; }
.timeline-step .dot, .timeline-step .step-dot { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; z-index: 1; background: #E5E7EB; color: #9CA3AF; }
.timeline-step .dot.done, .timeline-step.completed .step-dot { background: var(--cor-sucesso); color: white; }
.timeline-step .dot.pending { background: #E5E7EB; color: #9CA3AF; }
.timeline-step .dot.current, .timeline-step.active .step-dot { background: var(--cor-acento); color: white; }
.timeline-step .step-label { font-size: 10px; margin-top: 6px; color: var(--cor-texto-secundario); text-align: center; }
.timeline-step.completed .step-label { color: var(--cor-sucesso); font-weight: 600; }
.timeline-step.active .step-label { color: var(--cor-acento); font-weight: 600; }
.timeline-step .step-date { font-size: 9px; color: var(--cor-texto-secundario); margin-top: 2px; }
.timeline-line { flex: 1; height: 3px; background: #E5E7EB; }
.timeline-line.done { background: var(--cor-sucesso); }

/* === TIMELINE FLOW (dynamic despacho-based) === */
.timeline-flow { display: flex; align-items: center; padding: 20px 16px; overflow-x: auto; gap: 0; min-height: 100px; }
.tl-step { display: flex; flex-direction: column; align-items: center; min-width: 80px; max-width: 120px; flex-shrink: 0; }
.tl-date { font-size: 10px; color: var(--cor-texto-sec); margin-bottom: 6px; white-space: nowrap; height: 14px; }
.tl-dot { width: 20px; height: 20px; border-radius: 50%; background: #E5E7EB; border: 3px solid #D1D5DB; flex-shrink: 0; }
.tl-step.completed .tl-dot { background: var(--cor-sucesso); border-color: var(--cor-sucesso); }
.tl-step.completed .tl-dot.dep { background: var(--cor-acento); border-color: var(--cor-acento); }
.tl-step.projected .tl-dot { background: transparent; border: 3px dashed #D1D5DB; }
.tl-label { font-size: 10px; margin-top: 6px; text-align: center; line-height: 1.2; color: var(--cor-texto-sec); max-width: 110px; word-wrap: break-word; }
.tl-step.completed .tl-label { color: var(--cor-texto); font-weight: 600; }
.tl-step.projected .tl-label { color: #9CA3AF; font-style: italic; }
.tl-comp { font-size: 9px; color: var(--cor-texto-sec); margin-top: 3px; text-align: center; max-width: 110px; line-height: 1.2; opacity: 0.7; word-wrap: break-word; }
.tl-connector { display: flex; align-items: center; flex-direction: column; justify-content: center; min-width: 32px; position: relative; }
.tl-line { width: 100%; height: 2px; min-width: 24px; }
.tl-line.done { background: var(--cor-sucesso); }
.tl-line.projected { background: transparent; border-top: 2px dashed #D1D5DB; }
.tl-days { font-size: 9px; color: var(--cor-texto-sec); margin-top: 2px; white-space: nowrap; font-weight: 500; }
.tl-days.projected { color: #9CA3AF; font-style: italic; }

/* Hybrid lifecycle timeline — fixed stages with status indicators */
.timeline-lifecycle { display: flex; align-items: flex-start; gap: 0; padding: 20px 16px 16px; overflow-x: auto; min-height: 100px; }
.tl-stage { display: flex; flex-direction: column; align-items: center; min-width: 90px; flex: 1; position: relative; }
.tl-stage-date { font-size: 11px; color: var(--cor-texto-sec); margin-bottom: 6px; min-height: 16px; text-align: center; }
.tl-stage-dot { width: 14px; height: 14px; border-radius: 50%; background: var(--cor-borda); border: 2px solid var(--cor-borda); position: relative; z-index: 2; transition: all 0.3s; }
.tl-stage.completed .tl-stage-dot { background: var(--cor-acento); border-color: var(--cor-acento); }
.tl-stage.active .tl-stage-dot { background: var(--cor-acento); border-color: var(--cor-acento); box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.15); animation: pulse-current 2.5s ease-in-out infinite; }
.tl-stage.current .tl-stage-dot { background: white; border-color: var(--cor-acento); border-width: 3px; }
@keyframes pulse-current {
  0%, 100% { box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.15); }
  50% { box-shadow: 0 0 0 8px rgba(37, 99, 235, 0.08); }
}
.tl-stage.terminal .tl-stage-dot { background: #EF4444; border-color: #EF4444; }
.tl-stage-name { font-size: 11px; font-weight: 600; color: var(--cor-texto-sec); margin-top: 6px; text-align: center; line-height: 1.3; max-width: 100px; }
.tl-stage.completed .tl-stage-name { color: var(--cor-texto); }
.tl-stage.active .tl-stage-name { color: var(--cor-acento); font-weight: 700; }
.tl-stage.current .tl-stage-name { color: var(--cor-acento); font-weight: 700; }
.tl-stage.terminal .tl-stage-name { color: #EF4444; }
.tl-stage-days { font-size: 10px; color: var(--cor-texto-sec); margin-top: 2px; }
.tl-stage-days.estimated { color: var(--cor-acento); font-style: italic; opacity: 0.7; }

/* Progress bar inside connector line (current stage transition) */
.tl-stage-connector.progress { flex-direction: column; justify-content: center; gap: 4px; padding-top: 18px; }
.tl-conn-progress { height: 4px; width: 100%; background: #E5E7EB; border-radius: 2px; overflow: hidden; }
.tl-conn-fill { height: 100%; background: var(--cor-acento); border-radius: 2px; transition: width 0.5s ease; }
.tl-conn-info { font-size: 9px; color: var(--cor-acento); white-space: nowrap; text-align: center; font-style: italic; }
.tl-stage-connector { flex: 1; display: flex; align-items: center; min-width: 20px; padding-top: 22px; }
.tl-stage-line { height: 2px; width: 100%; background: var(--cor-borda); }
.tl-stage-connector.done .tl-stage-line { background: var(--cor-acento); }
.tl-stage-connector.optional .tl-stage-line { background: repeating-linear-gradient(90deg, var(--cor-borda) 0, var(--cor-borda) 5px, transparent 5px, transparent 10px); }
.tl-stage.deadline .tl-stage-dot { background: white; border-color: #F59E0B; box-shadow: 0 0 0 4px rgba(245,158,11,0.15); animation: pulse-deadline 2.5s ease-in-out infinite; }
@keyframes pulse-deadline {
  0%, 100% { box-shadow: 0 0 0 4px rgba(245, 158, 11, 0.15); }
  50% { box-shadow: 0 0 0 8px rgba(245, 158, 11, 0.08); }
}
.tl-stage.deadline .tl-stage-name { color: #F59E0B; font-weight: 700; }
.tl-stage.expired .tl-stage-dot { background: #9CA3AF; border-color: #9CA3AF; }
.tl-stage.expired .tl-stage-name { color: #9CA3AF; }
.tl-stage-deadline { font-size: 10px; color: #F59E0B; margin-top: 3px; font-weight: 600; text-align: center; }
.tl-stage-deadline.expired { color: #9CA3AF; font-weight: 400; }

/* === UPLOAD AREA === */
.upload-area { border: 2px dashed var(--cor-borda-forte); border-radius: 8px; padding: 40px; text-align: center; color: var(--cor-texto-secundario); cursor: pointer; transition: border-color 0.2s; }
.upload-area:hover { border-color: var(--cor-acento); }

/* === TOGGLE === */
.toggle-group { display: inline-flex; border: 1px solid var(--cor-borda); border-radius: 6px; overflow: hidden; }
.toggle-group .toggle-btn { padding: 8px 20px; font-size: 13px; cursor: pointer; background: white; border: none; font-family: var(--fonte); font-weight: 500; color: var(--cor-texto-secundario); }
.toggle-group .toggle-btn.active { background: var(--cor-acento); color: white; }

/* === PROGRESS BAR === */
.progress-bar { height: 8px; background: #E5E7EB; border-radius: 4px; overflow: hidden; margin: 8px 0; }
.progress-bar .progress-fill { height: 100%; background: var(--cor-acento); border-radius: 4px; transition: width 0.3s; }

/* === INFO GRID === */
.info-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; margin-bottom: 16px; }
.info-item { }
.info-item .info-label { font-size: 11px; color: var(--cor-texto-secundario); text-transform: uppercase; font-weight: 600; margin-bottom: 2px; }
.info-item .info-value { font-size: 14px; font-weight: 500; }

/* === CLIENTE DETALHE — 2 colunas === */
.cli-info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.card:has(.cli-info-grid) { padding: 0; }
.cli-info-col { padding: 20px 24px; }
.cli-info-col:first-child { border-right: 1px solid var(--cor-borda); }
.cli-section-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--cor-texto-secundario); font-weight: 600; margin-bottom: 14px; padding-bottom: 6px; border-bottom: 1px solid var(--cor-borda); }
.cli-field { margin-bottom: 12px; }
.cli-field:last-child { margin-bottom: 0; }
.cli-field-label { font-size: 11px; color: var(--cor-texto-secundario); text-transform: uppercase; font-weight: 600; margin-bottom: 2px; letter-spacing: 0.3px; }
.cli-field-value { font-size: 14px; font-weight: 500; color: var(--cor-texto); word-break: break-word; line-height: 1.4; }
.cli-field-value.muted { color: var(--cor-texto-secundario); font-style: italic; }
.cli-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cli-action-bar { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.tab-count { font-size: 11px; background: var(--cor-borda); color: var(--cor-texto-secundario); padding: 1px 6px; border-radius: 10px; margin-left: 4px; font-weight: 500; }

/* === HEALTH CHECK === */
.health-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: 13px; }
.health-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; background: #9CA3AF; }
.health-dot.green { background: #10B981; }
.health-dot.yellow { background: #F59E0B; }
.health-dot.red { background: #EF4444; }
.health-label { flex: 1; color: var(--cor-texto); }
.health-val { font-weight: 600; min-width: 30px; text-align: right; }

/* === MAINTENANCE ACTION BUTTONS === */
.btn-manut {
    display: flex; align-items: center; gap: 12px;
    width: 100%; padding: 12px 14px;
    background: var(--cor-fundo); border: 1px solid var(--cor-borda);
    border-radius: 10px; cursor: pointer;
    text-align: left; transition: all .15s;
}
.btn-manut:hover { background: #EFF6FF; border-color: #BFDBFE; }
.btn-manut:active { transform: scale(0.99); }
.btn-manut:disabled { opacity: 0.6; cursor: not-allowed; }
.btn-manut-icon {
    width: 36px; height: 36px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; background: var(--cor-fundo-card); color: var(--cor-acento);
    border: 1px solid var(--cor-borda); flex-shrink: 0;
}
.btn-manut:hover .btn-manut-icon { background: #DBEAFE; border-color: #93C5FD; }
.btn-manut-text { flex: 1; min-width: 0; }
.btn-manut-title { font-size: 13px; font-weight: 600; color: var(--cor-texto); }
.btn-manut-desc { font-size: 11px; color: var(--cor-texto-sec); margin-top: 2px; }

/* === MISC === */
.mb-16 { margin-bottom: 16px; }
.mb-8 { margin-bottom: 8px; }
.mt-16 { margin-top: 16px; }
.link-processo, .link-proc { color: var(--cor-acento); text-decoration: none; font-weight: 600; cursor: pointer; }
.link-processo:hover, .link-proc:hover { text-decoration: underline; }
.ncl-entry { padding: 8px 12px; background: #F9FAFB; border-radius: 6px; margin-bottom: 6px; }
.ncl-entry .ncl-classe { font-weight: 700; color: var(--cor-acento); }
.ncl-entry .ncl-espec { font-size: 12px; color: var(--cor-texto-secundario); margin-top: 2px; }
.text-sm { font-size: 12px; }
.text-muted { color: var(--cor-texto-secundario); }
.text-center { text-align: center; }
.preview-box { background: #F9FAFB; border: 1px solid var(--cor-borda); border-radius: 8px; padding: 20px; min-height: 200px; font-size: 12px; line-height: 1.6; white-space: pre-wrap; color: var(--cor-texto-secundario); }
.info-banner { background: var(--cor-info-light); color: var(--cor-info); padding: 10px 14px; border-radius: 6px; font-size: 12px; font-weight: 500; margin-bottom: 16px; }

/* === TOAST NOTIFICATIONS === */
.toast-container { position: fixed; top: 20px; right: 20px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }
.toast { padding: 12px 20px; border-radius: 8px; font-size: 13px; font-weight: 500; color: white; animation: slideIn 0.3s ease; box-shadow: 0 4px 12px rgba(0,0,0,0.15); max-width: 400px; }
.toast-success { background: var(--cor-sucesso); }
.toast-error { background: var(--cor-erro); }
.toast-warning { background: var(--cor-alerta); }
.toast-info { background: var(--cor-acento); }
@keyframes slideIn { from { transform: translateX(100%); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } }

/* === MODAL === */
.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.5); z-index: 9998; display: flex; align-items: center; justify-content: center; }
.modal { background: white; border-radius: 12px; padding: 24px; max-width: 600px; width: 90%; max-height: 80vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.modal-header { font-size: 18px; font-weight: 700; margin-bottom: 16px; padding-bottom: 12px; border-bottom: 1px solid var(--cor-borda); }
.modal-footer { margin-top: 20px; display: flex; justify-content: flex-end; gap: 8px; }

/* === LOADING SPINNER === */
.loading { display: flex; align-items: center; justify-content: center; padding: 40px; color: var(--cor-texto-secundario); }
.spinner { width: 24px; height: 24px; border: 3px solid var(--cor-borda); border-top-color: var(--cor-acento); border-radius: 50%; animation: spin 0.8s linear infinite; margin-right: 10px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* === EMPTY STATE === */
.empty-state { text-align: center; padding: 60px 20px; color: var(--cor-texto-secundario); }
.empty-state .icon { font-size: 48px; margin-bottom: 12px; opacity: 0.5; }
.empty-state .message { font-size: 14px; font-weight: 500; }
.empty-state .hint { font-size: 12px; margin-top: 4px; }

/* === STATUS BANNER === */
.status-banner { padding: 8px 16px; font-size: 12px; font-weight: 500; display: flex; align-items: center; gap: 8px; }
.status-banner.offline { background: var(--cor-erro-light); color: var(--cor-erro); }
.status-banner.online { background: var(--cor-sucesso-light); color: var(--cor-sucesso); }

/* === LOGIN PAGE === */
.login-fullpage { display: flex; align-items: center; justify-content: center; height: 100vh; background: linear-gradient(135deg, #111827 0%, #1E3A5F 50%, #2563EB 100%); }
.login-card { background: white; border-radius: 12px; padding: 40px 36px 32px; width: 360px; max-width: 90vw; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.login-brand { text-align: center; margin-bottom: 4px; }
.login-logo { height: 48px; width: auto; }
.login-subtitle { text-align: center; color: var(--cor-texto-secundario); font-size: 13px; margin-bottom: 24px; }
.login-error { color: var(--cor-erro); font-size: 12px; min-height: 18px; text-align: center; margin-top: 4px; }

/* === ACCESSIBILITY — Focus States === */
:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: 2px;
}
button:focus-visible, .btn-primary:focus-visible, .btn-secondary:focus-visible,
.btn-success:focus-visible, .btn-danger:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px var(--cor-acento-light);
}
.sidebar-item:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: -2px;
  background: var(--cor-sidebar-hover);
}
.tab:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: -2px;
}
.toggle-btn:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: -2px;
}
input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: none;
  border-color: var(--cor-acento);
  box-shadow: 0 0 0 3px var(--cor-acento-light);
}
.bc-link:focus-visible {
  outline: 2px solid var(--cor-acento);
  outline-offset: 2px;
  border-radius: 2px;
}
.data-table tr.clickable:focus-visible td {
  background: var(--cor-acento-light);
  outline: none;
}
/* Skip to content link (hidden until focused) */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--cor-acento);
  color: white;
  padding: 8px 16px;
  z-index: 10000;
  font-size: 13px;
  font-weight: 600;
  border-radius: 0 0 6px 0;
  transition: top 0.2s;
}
.skip-link:focus { top: 0; }
/* Screen reader only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* === PESQUISA DE MARCAS === */
.pesquisa-hero { background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 60%, #1E40AF 100%); border-radius: 12px; padding: 24px 28px; color: white; display: flex; align-items: center; gap: 20px; margin-bottom: 16px; position: relative; overflow: hidden; }
.pesquisa-hero::before { content: ''; position: absolute; top: -40px; right: -20px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%); border-radius: 50%; }
.pesquisa-hero-icon { font-size: 40px; width: 64px; height: 64px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.15); border-radius: 14px; flex-shrink: 0; backdrop-filter: blur(4px); }
.pesquisa-hero-content { flex: 1; position: relative; z-index: 1; }
.pesquisa-hero-title { font-size: 18px; font-weight: 700; margin-bottom: 3px; }
.pesquisa-hero-subtitle { font-size: 13px; opacity: 0.85; }
.pesquisa-hero-badges { display: flex; gap: 8px; margin-top: 8px; }
.pesquisa-hero-badge { padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; background: rgba(255,255,255,0.2); display: flex; align-items: center; gap: 5px; }
.pesquisa-hero-dot { width: 6px; height: 6px; border-radius: 50%; background: #4ADE80; display: inline-block; }
.pesquisa-hero-stats { display: flex; gap: 24px; position: relative; z-index: 1; }
.pesquisa-hero-stat { text-align: center; }
.pesquisa-hero-stat-num { font-size: 20px; font-weight: 700; line-height: 1; }
.pesquisa-hero-stat-label { font-size: 10px; opacity: 0.7; text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; }
/* --- Processo Detalhe Hero --- */
.proc-hero { background: linear-gradient(135deg, #1E3A5F 0%, #2563EB 50%, #1D4ED8 100%); border-radius: 12px; padding: 24px 28px; color: white; display: flex; align-items: center; gap: 20px; margin-bottom: 16px; position: relative; overflow: hidden; }
.proc-hero::before { content: ''; position: absolute; top: -40px; right: -20px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%); border-radius: 50%; }
.proc-hero-icon { font-size: 40px; width: 64px; height: 64px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.15); border-radius: 14px; flex-shrink: 0; backdrop-filter: blur(4px); }
.proc-hero-content { flex: 1; position: relative; z-index: 1; }
.proc-hero-title { font-size: 20px; font-weight: 700; margin-bottom: 2px; line-height: 1.2; }
.proc-hero-numero { font-size: 13px; opacity: 0.8; font-family: 'SF Mono', 'Fira Code', monospace; letter-spacing: 0.5px; margin-bottom: 8px; }
.proc-hero-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.proc-hero-badge { padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; background: rgba(255,255,255,0.2); backdrop-filter: blur(4px); }
.proc-hero-right { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; position: relative; z-index: 1; flex-shrink: 0; }
.proc-hero-situacao .badge { font-size: 12px; padding: 4px 12px; }
.proc-hero-actions { display: flex; gap: 6px; }
.proc-hero-action.btn-secondary { background: rgba(255,255,255,0.15); color: white; border-color: rgba(255,255,255,0.3); font-size: 11px; padding: 4px 10px; backdrop-filter: blur(4px); }
.proc-hero-action.btn-secondary:hover { background: rgba(255,255,255,0.25); }
/* Logo da marca (Mista/Figurativa) no hero */
.proc-hero-logo { position: relative; z-index: 1; flex-shrink: 0; }
.proc-hero-logo img { max-width: 110px; max-height: 90px; object-fit: contain; border-radius: 10px; border: 2px solid rgba(255,255,255,0.25); background: rgba(255,255,255,0.95); padding: 6px; box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.proc-hero-logo-placeholder { cursor: pointer; }
.proc-hero-logo-placeholder .upload-zone { width: 90px; height: 72px; border: 2px dashed rgba(255,255,255,0.35); border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; background: rgba(255,255,255,0.08); backdrop-filter: blur(4px); transition: all 0.2s; }
.proc-hero-logo-placeholder .upload-zone:hover { border-color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.15); }
.proc-hero-logo-placeholder .upload-icon { font-size: 22px; opacity: 0.7; }
.proc-hero-logo-placeholder .upload-text { font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; opacity: 0.6; font-weight: 600; }
/* --- Processo Info Highlight Cards --- */
.proc-info-highlights { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 16px; }
.proc-info-card { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-radius: 10px; border: 1px solid rgba(0,0,0,0.04); }
.proc-info-card-icon { font-size: 22px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,0.7); border-radius: 10px; flex-shrink: 0; }
.proc-info-card-body { flex: 1; min-width: 0; }
.proc-info-card-label { font-size: 10px; text-transform: uppercase; font-weight: 600; letter-spacing: 0.5px; color: var(--cor-texto-secundario); margin-bottom: 2px; }
.proc-info-card-value { font-size: 14px; font-weight: 600; color: var(--cor-texto); }
.proc-info-card-value a { color: inherit; text-decoration: none; border-bottom: 1px dashed var(--cor-borda); }
.proc-info-card-value a:hover { color: var(--cor-acento); border-color: var(--cor-acento); }
.proc-info-card[data-action] { transition: transform 0.15s, box-shadow 0.15s; }
.proc-info-card[data-action]:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.08); }

/* --- Histórico Timeline (processo-historico) --- */
.hist-summary { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px; padding: 0 4px; }
.hist-summary-pill { display: inline-flex; align-items: center; gap: 4px; padding: 6px 12px; border-radius: 20px; font-size: 12px; font-weight: 500; }
.hist-summary-pill strong { font-weight: 700; margin-left: 2px; }

.hist-timeline { position: relative; padding-left: 28px; }
.hist-timeline::before { content: ''; position: absolute; left: 11px; top: 0; bottom: 0; width: 2px; background: #E5E7EB; border-radius: 1px; }

.hist-month-sep { position: relative; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--cor-texto-sec); padding: 20px 0 12px 12px; }
.hist-month-sep::before { content: ''; position: absolute; left: -21px; top: 50%; width: 10px; height: 10px; background: var(--cor-fundo-card); border: 2px solid #D1D5DB; border-radius: 50%; transform: translateY(-50%); z-index: 1; }

.hist-event { display: flex; gap: 16px; position: relative; margin-bottom: 4px; }

.hist-dot-col { width: 0; flex-shrink: 0; position: relative; display: flex; justify-content: center; padding-top: 18px; }
.hist-dot { width: 10px; height: 10px; border-radius: 50%; position: absolute; left: -22px; top: 20px; z-index: 1; }

.hist-event-content { flex: 1; background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-left: 3px solid; border-radius: 10px; padding: 14px 18px; margin-bottom: 8px; transition: box-shadow 0.15s; }
.hist-event-content:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.05); }

.hist-event-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.hist-event-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 12px; font-size: 11px; font-weight: 600; }
.hist-event-date { font-size: 12px; color: var(--cor-texto-sec); margin-left: auto; }
.hist-event-code { font-size: 10px; font-family: 'SF Mono', monospace; background: #F3F4F6; color: #6B7280; padding: 2px 8px; border-radius: 4px; font-weight: 600; }

.hist-event-title { font-size: 14px; font-weight: 600; color: var(--cor-texto); line-height: 1.4; }
.hist-event-desc { font-size: 13px; color: var(--cor-texto-sec); margin-top: 4px; line-height: 1.5; }
.hist-event-meta { font-size: 11px; color: var(--cor-texto-sec); margin-top: 6px; font-style: italic; }

@media (max-width: 768px) {
    .hist-timeline { padding-left: 20px; }
    .hist-timeline::before { left: 7px; }
    .hist-dot { left: -16px; }
    .hist-month-sep::before { left: -17px; }
    .hist-event-content { padding: 12px 14px; }
    .hist-event-date { margin-left: 0; }
}

/* --- Movimentações mini-timeline (processo-detalhe) --- */
.mov-timeline { padding: 8px 16px 8px 24px; position: relative; }
.mov-timeline::before { content: ''; position: absolute; left: 30px; top: 8px; bottom: 8px; width: 2px; background: #E5E7EB; }
.mov-item { display: flex; gap: 14px; position: relative; margin-bottom: 2px; }
.mov-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 16px; position: relative; z-index: 1; }
.mov-content { flex: 1; padding: 10px 14px; border-radius: 8px; transition: background 0.15s; }
.mov-content:hover { background: #F9FAFB; }
.mov-header { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 3px; }
.mov-badge { font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 10px; }
.mov-code { font-size: 10px; font-family: 'SF Mono', monospace; background: #F3F4F6; color: #6B7280; padding: 1px 6px; border-radius: 3px; }
.mov-date { font-size: 11px; color: var(--cor-texto-sec); margin-left: auto; }
.mov-title { font-size: 13px; font-weight: 600; color: var(--cor-texto); line-height: 1.4; }
.mov-desc { font-size: 12px; color: var(--cor-texto-sec); margin-top: 3px; line-height: 1.4; }
.mov-meta { font-size: 11px; color: var(--cor-texto-sec); margin-top: 4px; font-style: italic; }

/* --- Documentos (processo-detalhe) --- */
.doc-file-list { padding: 4px 0; }
.doc-row { display: flex; align-items: center; gap: 12px; padding: 10px 16px; border-bottom: 1px solid #F3F4F6; transition: background 0.1s; }
.doc-row:last-child { border-bottom: none; }
.doc-row:hover { background: #F9FAFB; }
.doc-row-icon { font-size: 20px; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: #F3F4F6; border-radius: 8px; flex-shrink: 0; }
.doc-row-info { flex: 1; min-width: 0; }
.doc-row-name { font-size: 13px; font-weight: 600; color: var(--cor-texto); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.doc-row-detail { font-size: 11px; color: var(--cor-texto-sec); margin-top: 1px; }
.doc-row-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.doc-row-date { font-size: 11px; color: var(--cor-texto-sec); }
.doc-row-btn { width: 28px; height: 28px; border: 1px solid #E5E7EB; border-radius: 6px; background: white; cursor: pointer; font-size: 12px; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.doc-row-btn:hover { background: #EFF6FF; border-color: var(--cor-acento); color: var(--cor-acento); }
.doc-row-btn-del:hover { background: #FEF2F2; border-color: #EF4444; color: #EF4444; }

.doc-dropzone { margin: 8px 16px 16px; padding: 24px 16px; border: 2px dashed #D1D5DB; border-radius: 10px; text-align: center; cursor: pointer; transition: all 0.2s; }
.doc-dropzone:hover, .doc-dropzone.dragover { border-color: var(--cor-acento); background: #EFF6FF; }
.doc-dropzone-icon { font-size: 24px; color: #9CA3AF; margin-bottom: 6px; }
.doc-dropzone:hover .doc-dropzone-icon, .doc-dropzone.dragover .doc-dropzone-icon { color: var(--cor-acento); }
.doc-dropzone-text { font-size: 13px; font-weight: 600; color: var(--cor-texto-sec); }
.doc-dropzone-sub { font-size: 11px; color: #9CA3AF; margin-top: 4px; }

/* --- Carteira Pipeline (6 etapas fixas do depósito) --- */
.carteira-pipeline { display: flex; align-items: flex-start; justify-content: space-between; padding: 20px 8px; position: relative; }
.carteira-pipe-step { display: flex; flex-direction: column; align-items: center; flex: 1; position: relative; min-width: 0; }
.carteira-pipe-connector { position: absolute; top: 18px; right: 50%; width: 100%; height: 3px; background: var(--cor-borda); z-index: 0; }
.carteira-pipe-connector.done { background: #16A34A; }
.carteira-pipe-circle { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; position: relative; z-index: 1; transition: all .2s; }
.carteira-pipe-step.done .carteira-pipe-circle { background: #16A34A; color: white; border: 3px solid #16A34A; }
.carteira-pipe-step.current .carteira-pipe-circle { background: white; color: #2563EB; border: 3px solid #2563EB; box-shadow: 0 0 0 4px rgba(37,99,235,0.15); animation: pulse-pipe 2s infinite; }
.carteira-pipe-step.pending .carteira-pipe-circle { background: #F3F4F6; color: #9CA3AF; border: 2px solid #D1D5DB; }
.carteira-pipe-label { font-size: 11px; font-weight: 600; text-align: center; margin-top: 8px; color: var(--cor-texto-sec, #6B7280); line-height: 1.3; max-width: 90px; }
.carteira-pipe-step.done .carteira-pipe-label { color: #16A34A; }
.carteira-pipe-step.current .carteira-pipe-label { color: #2563EB; font-weight: 700; }
.carteira-pipe-date { font-size: 10px; color: var(--cor-texto-sec, #6B7280); margin-top: 2px; }
@keyframes pulse-pipe { 0%, 100% { box-shadow: 0 0 0 4px rgba(37,99,235,0.15); } 50% { box-shadow: 0 0 0 8px rgba(37,99,235,0.08); } }

/* Carteira Anexos Grid */
.carteira-anexos-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; padding: 12px 0; }
.carteira-anexo-card { border: 1px solid var(--cor-borda); border-radius: 10px; padding: 12px; position: relative; display: flex; flex-direction: column; gap: 8px; }
.carteira-anexo-card img { width: 100%; height: 120px; object-fit: cover; border-radius: 6px; }
.carteira-anexo-nome { font-size: 13px; font-weight: 500; word-break: break-all; }
.carteira-anexo-tipo { font-size: 11px; color: var(--cor-texto-sec, #6B7280); text-transform: uppercase; }
.carteira-anexo-delete { position: absolute; top: 8px; right: 8px; background: rgba(0,0,0,0.5); color: white; border: none; border-radius: 50%; width: 24px; height: 24px; cursor: pointer; font-size: 14px; display: flex; align-items: center; justify-content: center; }
.carteira-anexo-delete:hover { background: #DC2626; }

/* Carteira Anotação */
.carteira-anotacao-form { display: flex; gap: 8px; padding: 12px 0; }
.carteira-anotacao-form textarea { flex: 1; min-height: 60px; padding: 10px; border: 1px solid var(--cor-borda); border-radius: 8px; font-family: inherit; font-size: 13px; resize: vertical; }

.pesquisa-form-grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.pesquisa-action-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.pesquisa-pill-sep { width: 1px; height: 24px; background: var(--cor-borda); margin: 0 2px; }
.pesquisa-mode-pills { display: flex; gap: 3px; background: var(--cor-fundo); border-radius: 8px; padding: 3px; border: 1px solid var(--cor-borda); }
.pesquisa-mode-pill { padding: 5px 11px; border-radius: 6px; border: none; background: transparent; cursor: pointer; font-size: 12px; font-family: var(--fonte); color: var(--cor-texto-secundario); font-weight: 500; transition: all 0.15s; white-space: nowrap; }
.pesquisa-mode-pill:hover { color: var(--cor-texto); }
.pesquisa-mode-pill.active { background: white; color: var(--cor-texto); box-shadow: 0 1px 3px rgba(0,0,0,0.08); font-weight: 600; }
.pesquisa-mode-premium { border-left: 2px solid #7C3AED !important; }
.pesquisa-coin-badge { display: inline-block; font-size: 9px; font-weight: 700; color: #7C3AED; background: #EDE9FE; padding: 1px 5px; border-radius: 8px; margin-left: 3px; vertical-align: middle; }
.pesquisa-nexxus-toggle { display: inline-flex; align-items: center; gap: 7px; padding: 5px 14px; border-radius: 8px; cursor: pointer; font-size: 12px; font-weight: 600; border: 1px solid var(--cor-borda); background: white; color: var(--cor-texto-secundario); transition: all 0.2s; margin-left: auto; user-select: none; }
.pesquisa-nexxus-toggle.active { background: linear-gradient(135deg, #7C3AED, #2563EB); color: white; border-color: transparent; box-shadow: 0 2px 8px rgba(124, 58, 237, 0.3); }
.pesquisa-toggle-track { width: 28px; height: 16px; border-radius: 8px; background: #D1D5DB; position: relative; transition: background 0.2s; }
.pesquisa-nexxus-toggle.active .pesquisa-toggle-track { background: rgba(255,255,255,0.4); }
.pesquisa-toggle-thumb { width: 12px; height: 12px; border-radius: 50%; background: white; position: absolute; top: 2px; left: 2px; transition: transform 0.2s; }
.pesquisa-nexxus-toggle.active .pesquisa-toggle-thumb { transform: translateX(12px); }
.pesquisa-nexxus-bar { display: flex; align-items: center; gap: 10px; padding: 8px 14px; background: linear-gradient(135deg, rgba(124,58,237,0.06), rgba(37,99,235,0.06)); border: 1px solid rgba(124,58,237,0.15); border-radius: 8px; margin-bottom: 12px; font-size: 12px; color: #7C3AED; font-weight: 500; }
.pesquisa-nexxus-status { font-size: 11px; color: var(--cor-texto-secundario); }
.pesquisa-results-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--cor-borda); }
.pesquisa-results-title { font-size: 13px; font-weight: 600; color: var(--cor-texto); display: flex; align-items: center; gap: 8px; }
.pesquisa-results-count { background: var(--cor-acento-light); color: var(--cor-acento); padding: 2px 10px; border-radius: 12px; font-size: 11px; font-weight: 700; }
.pesquisa-empty-state { text-align: center; padding: 48px 20px; color: var(--cor-texto-secundario); }
.pesquisa-empty-icon { font-size: 44px; margin-bottom: 10px; opacity: 0.35; }
.pesquisa-empty-title { font-size: 14px; font-weight: 600; color: var(--cor-texto); margin-bottom: 4px; }
.pesquisa-empty-desc { font-size: 12px; max-width: 360px; margin: 0 auto; line-height: 1.5; }
.pesquisa-tipo-badge { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 6px; font-size: 11px; font-weight: 700; background: var(--cor-fundo); border: 1px solid var(--cor-borda); color: var(--cor-texto-secundario); }
.pesquisa-tipo-N { background: #DBEAFE; color: #2563EB; border-color: #BFDBFE; }
.pesquisa-tipo-M { background: #EDE9FE; color: #7C3AED; border-color: #DDD6FE; }
.pesquisa-tipo-F { background: #D1FAE5; color: #059669; border-color: #A7F3D0; }
.pesquisa-tipo-T { background: #FFEDD5; color: #D97706; border-color: #FED7AA; }
.pesquisa-ncl-badge { display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; background: #F3F4F6; color: var(--cor-texto); font-family: 'SF Mono', 'Consolas', monospace; cursor: help; }

/* --- Vigilância --- */
.vig-desc-cards { display: flex; gap: 12px; margin-top: 12px; }
.vig-desc-card { display: flex; align-items: center; gap: 10px; padding: 10px 16px; background: white; border-radius: 8px; border: 1px solid var(--cor-borda); flex: 1; font-size: 12px; }
.vig-desc-card-icon { width: 34px; height: 34px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.vig-desc-card strong { font-size: 13px; }
.vig-filter-bar { display: flex; align-items: flex-end; gap: 20px; flex-wrap: wrap; }
.vig-filter-group { display: flex; flex-direction: column; gap: 6px; }
.vig-filter-label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px; color: var(--cor-texto-secundario); }
.vig-scope-pills { display: flex; gap: 3px; background: var(--cor-fundo); border-radius: 8px; padding: 3px; border: 1px solid var(--cor-borda); }
.vig-scope-pill { padding: 5px 12px; border-radius: 6px; border: none; background: transparent; cursor: pointer; font-size: 12px; font-family: var(--fonte); color: var(--cor-texto-secundario); font-weight: 500; transition: all 0.15s; white-space: nowrap; }
.vig-scope-pill:hover { color: var(--cor-texto); }
.vig-scope-pill.active { background: white; color: var(--cor-texto); box-shadow: 0 1px 3px rgba(0,0,0,0.08); font-weight: 600; }
.vig-rpi-input { padding: 5px 10px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 12px; width: 90px; font-family: var(--fonte); }
.vig-nivel-wrap { display: flex; align-items: center; gap: 8px; }
.vig-nivel-slider { width: 120px; accent-color: var(--cor-acento); cursor: pointer; }
.vig-nivel-value { font-size: 13px; font-weight: 700; color: var(--cor-acento); min-width: 32px; }
.vig-nexxus-card { display: flex; align-items: center; gap: 14px; padding: 14px 18px; background: linear-gradient(135deg, rgba(124,58,237,0.04), rgba(37,99,235,0.04)); border: 1px solid rgba(124,58,237,0.15); border-radius: 10px; margin-bottom: 16px; }
.vig-nexxus-card-icon { font-size: 24px; width: 42px; height: 42px; background: linear-gradient(135deg, #EDE9FE, #DBEAFE); border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.vig-nexxus-card-content { flex: 1; min-width: 0; }
.vig-nexxus-card-title { font-size: 13px; font-weight: 700; color: #7C3AED; margin-bottom: 2px; }
.vig-nexxus-card-desc { font-size: 12px; color: var(--cor-texto-secundario); line-height: 1.5; }
.vig-nexxus-card-btn { padding: 6px 16px; border-radius: 8px; border: 1px solid rgba(124,58,237,0.25); background: white; color: #7C3AED; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: all 0.15s; font-family: var(--fonte); }
.vig-nexxus-card-btn:hover { background: #7C3AED; color: white; border-color: #7C3AED; }
.vig-results-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--cor-borda); }
.vig-results-title { font-size: 13px; font-weight: 600; color: var(--cor-texto); display: flex; align-items: center; gap: 8px; }
.vig-results-count { background: var(--cor-acento-light); color: var(--cor-acento); padding: 2px 10px; border-radius: 12px; font-size: 11px; font-weight: 700; }
.vig-results-summary { font-size: 12px; color: var(--cor-texto-secundario); }
.vig-empty-state { text-align: center; padding: 48px 20px; color: var(--cor-texto-secundario); }
.vig-empty-icon { font-size: 44px; margin-bottom: 10px; opacity: 0.35; }
.vig-empty-title { font-size: 14px; font-weight: 600; color: var(--cor-texto); margin-bottom: 4px; }
.vig-empty-desc { font-size: 12px; max-width: 400px; margin: 0 auto; line-height: 1.5; }
.vig-nexxus-upsell { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: linear-gradient(135deg, rgba(124,58,237,0.04), rgba(37,99,235,0.04)); border: 1px dashed rgba(124,58,237,0.25); border-radius: 8px; margin-top: 12px; font-size: 12px; color: var(--cor-texto-secundario); }
.vig-nexxus-upsell-icon { font-size: 18px; opacity: 0.6; }
.vig-nexxus-upsell-content { flex: 1; }
.vig-nexxus-upsell-content strong { color: var(--cor-texto); font-size: 12px; }
.vig-nexxus-upsell-desc { margin-top: 2px; line-height: 1.4; }
.vig-help-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.45); backdrop-filter: blur(4px); z-index: 99999; display: flex; align-items: center; justify-content: center; animation: pesqHelpFadeIn 0.2s ease; }
.vig-ici-lock { display: inline-flex; align-items: center; gap: 4px; color: #9CA3AF; font-size: 11px; cursor: pointer; padding: 2px 8px; border-radius: 12px; background: #F9FAFB; border: 1px solid #E5E7EB; transition: all 0.15s; }
.vig-ici-lock:hover { border-color: #7C3AED; color: #7C3AED; background: #FAF5FF; }

/* --- Help Button & Popup --- */
.pesquisa-help-btn { width: 26px; height: 26px; border-radius: 50%; border: 1.5px solid var(--cor-borda); background: white; color: var(--cor-texto-secundario); font-size: 13px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; font-family: var(--fonte); flex-shrink: 0; }
.pesquisa-help-btn:hover { border-color: var(--cor-acento); color: var(--cor-acento); background: #EFF6FF; transform: scale(1.08); }
.pesquisa-help-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.45); backdrop-filter: blur(4px); z-index: 99999; display: flex; align-items: center; justify-content: center; animation: pesqHelpFadeIn 0.2s ease; }
@keyframes pesqHelpFadeIn { from { opacity: 0; } to { opacity: 1; } }
.pesquisa-help-popup { background: white; border-radius: 14px; width: 540px; max-width: 92vw; max-height: 85vh; overflow: hidden; box-shadow: 0 25px 60px rgba(0,0,0,0.25), 0 0 0 1px rgba(0,0,0,0.05); animation: pesqHelpSlideUp 0.25s ease; display: flex; flex-direction: column; }
@keyframes pesqHelpSlideUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.pesquisa-help-header { background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%); padding: 20px 24px; display: flex; align-items: center; gap: 14px; color: white; position: relative; }
.pesquisa-help-header::before { content: ''; position: absolute; inset: 0; background: radial-gradient(circle at 85% 20%, rgba(255,255,255,0.12) 0%, transparent 60%); pointer-events: none; }
.pesquisa-help-header-icon { font-size: 28px; width: 48px; height: 48px; background: rgba(255,255,255,0.18); border-radius: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pesquisa-help-header-title { font-size: 17px; font-weight: 700; }
.pesquisa-help-header-sub { font-size: 12px; opacity: 0.8; margin-top: 2px; }
.pesquisa-help-close { position: absolute; top: 14px; right: 14px; width: 28px; height: 28px; border-radius: 8px; border: none; background: rgba(255,255,255,0.15); color: white; font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
.pesquisa-help-close:hover { background: rgba(255,255,255,0.3); }
.pesquisa-help-body { padding: 16px 20px 20px; overflow-y: auto; }
.pesquisa-help-item { display: flex; gap: 12px; padding: 10px 4px; border-bottom: 1px solid #F3F4F6; }
.pesquisa-help-item:last-child { border-bottom: none; }
.pesquisa-help-item-icon { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 800; flex-shrink: 0; font-family: var(--fonte); }
.pesquisa-help-item-content { flex: 1; min-width: 0; }
.pesquisa-help-item-title { font-size: 13px; font-weight: 700; color: var(--cor-texto); margin-bottom: 3px; display: flex; align-items: center; }
.pesquisa-help-item-desc { font-size: 12px; color: var(--cor-texto-secundario); line-height: 1.55; }
.pesquisa-help-sep { height: 1px; background: linear-gradient(90deg, transparent, var(--cor-borda), transparent); margin: 8px 0; }
.pesquisa-help-section-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.8px; color: #7C3AED; padding: 4px 4px 8px; }

/* === RESPONSIVE === */

/* --- Tablet (≤1024px): sidebar narrower, grids adjust --- */
@media (max-width: 1024px) {
  :root { --sidebar-width: 180px; --pad-pagina: 16px; }
  .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .form-row-3 { grid-template-columns: 1fr 1fr; }
  .info-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .bar-chart-row .bar-label { width: 100px; }
  .stat-card .number { font-size: 26px; }

  /* Tab bar: scroll if too many tabs */
  .tab-bar { overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .tab-bar::-webkit-scrollbar { display: none; }
  .tab { white-space: nowrap; flex-shrink: 0; padding: 10px 14px; }

  /* Timeline: scrollable */
  .timeline { overflow-x: auto; padding-bottom: 8px; }
  .timeline-step { min-width: 80px; }
  .timeline-flow { padding: 16px 8px; }
  .tl-step { min-width: 64px; }
  .timeline-lifecycle { padding: 12px 8px; }
  .tl-stage { min-width: 70px; }
  .tl-stage-name { font-size: 10px; max-width: 70px; }
}

/* --- Mobile (≤768px): sidebar icons-only, tables scroll, stacking --- */
@media (max-width: 768px) {
  :root { --sidebar-width: 56px; --pad-pagina: 12px; --pad-secao: 10px; }

  /* Sidebar: icons only */
  .sidebar { width: var(--sidebar-width); min-width: var(--sidebar-width); }
  .sidebar-brand, .sidebar-label, .sidebar-footer { display: none; }
  .sidebar-item span:not(.icon) { display: none; }
  .sidebar-item { padding: 12px 0; justify-content: center; border-left-width: 2px; }
  .sidebar-item .icon { width: auto; font-size: 18px; }
  .sidebar-item.sub { padding-left: 0; }
  .sidebar-sep { margin: 4px 8px; }

  /* Sidebar user area: just icon */
  .sidebar-user #sidebar-user-info { display: none; }
  .sidebar-user > div > div { justify-content: center; padding: 8px 0 !important; }

  /* Screen header: stack title + actions */
  .screen-header { flex-direction: column; align-items: flex-start; gap: 10px; }
  .screen-header .actions { width: 100%; flex-wrap: wrap; }
  .screen-header .actions button,
  .screen-header .actions select { flex: 1; min-width: 120px; }

  /* Grids: collapse */
  .grid-4 { grid-template-columns: 1fr 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-2 { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .form-row-3 { grid-template-columns: 1fr; }
  .cli-info-grid { grid-template-columns: 1fr; }
  .cli-info-col:first-child { border-right: none; border-bottom: 1px solid var(--cor-borda); }
  .cli-field-row { grid-template-columns: 1fr; }
  .info-grid { grid-template-columns: 1fr 1fr; }

  /* Tables: horizontal scroll (card wraps, or use .table-scroll) */
  .card:has(.data-table) { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table { min-width: 600px; }
  .data-table th, .data-table td { padding: 8px 10px; font-size: 12px; }

  /* Filter bar: stack items */
  .filter-bar { gap: 8px; padding: 10px; }
  .filter-bar select, .filter-bar input[type=text],
  .filter-bar input[type=number], .filter-bar input[type=date] {
    min-width: 0; flex: 1 1 140px;
  }
  .filter-bar label { flex-basis: 100%; font-size: 11px; }

  /* Pagination: compact */
  .pagination { font-size: 12px; gap: 6px; }
  .pagination .pag-goto { display: none; }
  .pagination .pag-right select { display: none; }

  /* Breadcrumb: smaller */
  .breadcrumb-bar { padding: 0 var(--pad-pagina); font-size: 11px; min-height: 36px; }
  .breadcrumb-bar .bc-back { padding: 6px 10px 6px 0; margin-right: 10px; font-size: 11px; }
  .breadcrumb-bar .bc-back .bc-arrow { font-size: 13px; }

  /* Toast: full width */
  .toast-container { left: 12px; right: 12px; top: 12px; }
  .toast { max-width: 100%; }

  /* Modal: nearly full screen */
  .modal { width: 95%; max-width: none; padding: 20px 16px; max-height: 85vh; }
  .modal-header { font-size: 16px; }

  /* Bar chart: smaller labels */
  .bar-chart-row .bar-label { width: 80px; font-size: 11px; }

  /* Stat cards: smaller */
  .stat-card { padding: 12px 8px; }
  .stat-card .number { font-size: 22px; }
  .stat-card .label { font-size: 10px; }

  /* Upload area: less padding */
  .upload-area { padding: 24px 16px; font-size: 12px; }

  /* Toggle group: full width */
  .toggle-group { display: flex; width: 100%; }
  .toggle-group .toggle-btn { flex: 1; padding: 8px 12px; font-size: 12px; }

  /* Log panel: thinner */
  .log-panel { min-height: 40px; max-height: 40px; font-size: 10px; padding: 4px 10px; }

  /* Login: already mostly responsive, minor tweak */
  .login-card { padding: 32px 24px 24px; width: 100%; max-width: 360px; }

  /* Hero cards: compact on mobile */
  .pesquisa-hero-subtitle { display: none; }
  .prospect-hero-subtitle { display: none; }
  .pesquisa-hero { padding: 16px 20px; gap: 12px; }
  .prospect-hero { padding: 16px 20px; gap: 12px; }
  .pesquisa-hero-icon { width: 48px; height: 48px; font-size: 28px; }
  .prospect-hero-icon { width: 48px; height: 48px; font-size: 28px; }
  .pesquisa-hero-title { font-size: 16px; }
  .prospect-hero-title { font-size: 16px; }
  .pesquisa-hero-stat-num { font-size: 16px; }
  .prospect-hero-stat-num { font-size: 20px; }
  .pesquisa-hero-badges { display: none; }
  .proc-hero { padding: 16px 20px; gap: 12px; flex-wrap: wrap; }
  .proc-hero-icon { width: 48px; height: 48px; font-size: 28px; }
  .proc-hero-title { font-size: 16px; }
  .proc-hero-badges { display: none; }
  .proc-hero-right { align-items: flex-start; }
  .proc-info-highlights { grid-template-columns: 1fr 1fr; }
}

/* --- Small phone (≤480px): further simplification --- */
@media (max-width: 480px) {
  :root { --pad-pagina: 10px; }

  /* Sidebar: hide completely, use top bar approach */
  .sidebar { width: 48px; min-width: 48px; }
  .sidebar-item { padding: 10px 0; }
  .sidebar-item .icon { font-size: 16px; }

  /* Grids: single column */
  .grid-4, .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .info-grid { grid-template-columns: 1fr; }

  /* Screen header */
  .screen-header h1 { font-size: 17px; }
  .screen-header .actions button,
  .screen-header .actions select { font-size: 12px; padding: 6px 12px; }

  /* Buttons: smaller */
  .btn-primary, .btn-secondary { padding: 7px 14px; font-size: 12px; }

  /* Pagination: minimal */
  .pagination .pag-controls button { padding: 4px 8px; min-width: 28px; font-size: 11px; }

  /* Tables: narrower min-width */
  .data-table { min-width: 500px; }

  /* Filter bar: fully stacked */
  .filter-bar { flex-direction: column; }
  .filter-bar select, .filter-bar input[type=text],
  .filter-bar input[type=number], .filter-bar input[type=date] {
    width: 100%; flex: none;
  }
  .filter-bar .btn-primary, .filter-bar .btn-secondary { width: 100%; }

  /* Login */
  .login-card { padding: 24px 20px 20px; border-radius: 0; max-width: 100%; }
  .login-brand { font-size: 24px; }

  /* Modal */
  .modal { width: 100%; border-radius: 8px 8px 0 0; margin-top: auto; max-height: 90vh; }
  .modal-overlay { align-items: flex-end; }

  /* Cards */
  .card { border-radius: 6px; padding: 10px; }
}

/* ═══════════════════════════════════════════════════════════════
   PLANOS & T3P COINS — Responsive overrides
   ═══════════════════════════════════════════════════════════════ */
/* Screen-desc badge grids: collapse on tablet */
@media (max-width: 1024px) {
  .screen-desc > div[style*="grid-template-columns: repeat(4"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
/* Screen-desc badge grids: single column on mobile */
@media (max-width: 768px) {
  .screen-desc > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
  #header-coin-saldo { font-size: 10px !important; }
}

/* Planos comparison cards: collapse on smaller screens */
@media (max-width: 1024px) {
  #planos-comparacao > div:first-child {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 768px) {
  #planos-comparacao > div:first-child {
    grid-template-columns: 1fr !important;
  }
  /* Meu Plano cards: stack */
  #plano-atual-info > div:first-child {
    grid-template-columns: 1fr !important;
  }
  /* Limites: smaller grid */
  #plano-limites .card > div[style*="repeat(5"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  #plano-limites .card > div[style*="repeat(3"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  /* Conquistas: smaller grid */
  #plano-conquistas .card > div[style*="repeat(5"] {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  /* Coin packages: stack */
  #coins-pacotes > div[style*="grid-template-columns"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  #coins-pacotes > div[style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }
  #plano-limites .card > div[style*="repeat(5"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  #plano-conquistas .card > div[style*="repeat(5"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PROSPECT CRM — Pipeline stages
   ═══════════════════════════════════════════════════════════════ */
.prospect-stage-pills { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 12px; }
.prospect-stage-pill { padding: 6px 14px; border-radius: 20px; font-size: 12px; font-weight: 600; cursor: pointer; border: 2px solid var(--cor-borda); background: var(--cor-fundo-card); color: var(--cor-texto-secundario); transition: all .15s; display: flex; align-items: center; gap: 6px; }
.prospect-stage-pill:hover { border-color: var(--cor-acento); color: var(--cor-texto); }
.prospect-stage-pill.active { border-color: currentColor; background: currentColor; }
.prospect-stage-pill.active span { color: #fff; }
.prospect-stage-pill .pill-count { font-size: 10px; background: rgba(0,0,0,.08); padding: 1px 6px; border-radius: 10px; }
.prospect-stage-pill.active .pill-count { background: rgba(255,255,255,.25); color: #fff; }

/* Prospect advance button */
.btn-advance-stage { display: inline-flex; align-items: center; gap: 6px; padding: 6px 16px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; border: 1px solid var(--cor-borda); background: var(--cor-fundo-card); color: var(--cor-texto); transition: all .15s; }
.btn-advance-stage:hover { border-color: var(--cor-acento); color: var(--cor-acento); background: #EFF6FF; }
.btn-advance-stage .arrow { font-size: 14px; }

/* Prospect interaction timeline */
.prospect-timeline { position: relative; padding-left: 24px; }
.prospect-timeline::before { content: ''; position: absolute; left: 8px; top: 0; bottom: 0; width: 2px; background: var(--cor-borda); }
.prospect-tl-item { position: relative; padding: 8px 0 16px; }
.prospect-tl-item::before { content: ''; position: absolute; left: -20px; top: 12px; width: 10px; height: 10px; border-radius: 50%; background: var(--cor-acento); border: 2px solid var(--cor-fundo-card); }
.prospect-tl-item.tl-contatado::before { background: #F59E0B; }
.prospect-tl-item.tl-negociando::before { background: #EAB308; }
.prospect-tl-item.tl-convertido::before { background: #059669; }
.prospect-tl-item.tl-perdido::before { background: #6B7280; }
.prospect-tl-date { font-size: 11px; color: var(--cor-texto-secundario); }
.prospect-tl-content { font-size: 13px; margin-top: 2px; }

/* Pipeline metrics row */
.pipeline-metrics { display: flex; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
.pipeline-metric { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--cor-texto-secundario); }
.pipeline-metric strong { color: var(--cor-texto); font-size: 15px; }

/* ═══════════════════════════════════════════════════════════════
   BASE DE CONHECIMENTO
   ═══════════════════════════════════════════════════════════════ */
.bdc-lista { display: flex; flex-direction: column; gap: 2px; }
.bdc-item {
    padding: 14px 16px;
    border-bottom: 1px solid var(--cor-borda);
    cursor: pointer;
    transition: background 0.15s;
    border-radius: 4px;
}
.bdc-item:hover { background: #F0F4FF; }
.bdc-item:last-child { border-bottom: none; }
.bdc-item-header {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 4px;
}
.bdc-codigo {
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-weight: 700;
    font-size: 14px;
    color: var(--cor-acento);
    background: #EEF2FF;
    padding: 2px 8px;
    border-radius: 4px;
    min-width: 38px;
    text-align: center;
}
.bdc-nome { font-weight: 600; font-size: 14px; color: var(--cor-texto); flex: 1; }
.bdc-tags { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.bdc-prazo {
    font-size: 11px;
    font-weight: 600;
    color: #B45309;
    background: #FEF3C7;
    padding: 2px 6px;
    border-radius: 4px;
}
.bdc-item-desc {
    font-size: 13px;
    color: var(--cor-texto-secundario);
    line-height: 1.4;
    padding-left: 0;
}

/* Detalhe expandido */
.bdc-detalhe-card {
    background: #FAFBFF;
    border: 2px solid var(--cor-acento);
    border-radius: 10px;
    padding: 20px 24px;
}
.bdc-detalhe-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
}
.bdc-detalhe-codigo {
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-weight: 700;
    font-size: 20px;
    color: var(--cor-acento);
    background: #EEF2FF;
    padding: 4px 12px;
    border-radius: 6px;
    display: inline-block;
    margin-bottom: 4px;
}
.bdc-detalhe-nome { font-size: 18px; font-weight: 600; color: var(--cor-texto); margin: 4px 0 0; }
.bdc-detalhe-body {}
.bdc-detalhe-section { margin-bottom: 14px; }
.bdc-detalhe-section label {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--cor-texto-secundario);
    font-weight: 600;
    margin-bottom: 4px;
}
.bdc-detalhe-section p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--cor-texto); }
.bdc-detalhe-acao {
    background: #FEF3C7;
    border-left: 3px solid #F59E0B;
    padding: 10px 14px;
    border-radius: 0 6px 6px 0;
}
.bdc-detalhe-acao label { color: #92400E; }
.bdc-detalhe-acao p { color: #78350F; }
.bdc-detalhe-meta {
    display: flex;
    gap: 24px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--cor-borda);
}
.bdc-detalhe-meta label {
    display: block;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--cor-texto-secundario);
    font-weight: 600;
    margin-bottom: 4px;
}

/* Tab bar */
.bdc-tab-bar {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--cor-borda);
    margin-bottom: 16px;
}
.bdc-tab {
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    color: var(--cor-texto-secundario);
    background: none;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}
.bdc-tab:hover { color: var(--cor-texto); }
.bdc-tab.active {
    color: var(--cor-acento);
    border-bottom-color: var(--cor-acento);
}

/* Manual de Marcas — resultados */
.bdc-manual-lista { display: flex; flex-direction: column; gap: 2px; }
.bdc-manual-item {
    padding: 14px 16px;
    border-bottom: 1px solid var(--cor-borda);
    cursor: pointer;
    transition: background 0.15s;
    border-radius: 4px;
}
.bdc-manual-item:hover { background: #F0F4FF; }
.bdc-manual-item:last-child { border-bottom: none; }
.bdc-manual-item-header {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.bdc-manual-titulo {
    font-weight: 600;
    font-size: 14px;
    color: var(--cor-texto);
    flex: 1;
}
.bdc-manual-path {
    font-size: 11px;
    color: var(--cor-texto-secundario);
    background: var(--cor-fundo);
    padding: 2px 8px;
    border-radius: 4px;
    white-space: nowrap;
}
.bdc-manual-snippet {
    font-size: 13px;
    color: var(--cor-texto-secundario);
    line-height: 1.5;
}
.bdc-manual-snippet mark {
    background: #FEF08A;
    color: var(--cor-texto);
    padding: 0 2px;
    border-radius: 2px;
}

/* Manual de Marcas — painel de leitura */
.bdc-manual-leitura-card {
    background: #FAFBFF;
    border: 2px solid var(--cor-acento);
    border-radius: 10px;
    padding: 20px 24px;
}
.bdc-manual-leitura-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 16px;
    gap: 12px;
}
.bdc-manual-leitura-titulo {
    font-size: 18px;
    font-weight: 600;
    color: var(--cor-texto);
    margin: 0;
}
.bdc-manual-leitura-path {
    font-size: 12px;
    color: var(--cor-texto-secundario);
    margin-bottom: 6px;
}
.bdc-manual-leitura-body {
    font-size: 14px;
    line-height: 1.7;
    color: var(--cor-texto);
}
.bdc-manual-leitura-body h1,
.bdc-manual-leitura-body h2,
.bdc-manual-leitura-body h3,
.bdc-manual-leitura-body h4 {
    margin: 18px 0 8px;
    font-weight: 600;
    color: var(--cor-texto);
}
.bdc-manual-leitura-body h1 { font-size: 20px; }
.bdc-manual-leitura-body h2 { font-size: 17px; }
.bdc-manual-leitura-body h3 { font-size: 15px; }
.bdc-manual-leitura-body h4 { font-size: 14px; }
.bdc-manual-leitura-body p { margin: 0 0 10px; }
.bdc-manual-leitura-body ul,
.bdc-manual-leitura-body ol {
    margin: 6px 0 10px 20px;
    padding: 0;
}
.bdc-manual-leitura-body li { margin-bottom: 4px; }
.bdc-manual-leitura-body blockquote {
    margin: 10px 0;
    padding: 8px 14px;
    border-left: 3px solid var(--cor-acento);
    background: var(--cor-acento-light);
    border-radius: 0 6px 6px 0;
    color: var(--cor-texto);
}
.bdc-manual-leitura-body hr {
    border: none;
    border-top: 1px solid var(--cor-borda);
    margin: 16px 0;
}
.bdc-manual-leitura-body strong { font-weight: 600; }

@media (max-width: 768px) {
    .bdc-item-header { flex-direction: column; align-items: flex-start; gap: 4px; }
    .bdc-detalhe-meta { flex-direction: column; gap: 10px; }
    .bdc-detalhe-header { flex-direction: column; gap: 8px; }
    .bdc-tab { padding: 8px 14px; font-size: 13px; }
    .bdc-manual-leitura-header { flex-direction: column; }
}

/* ------------------------------------------------------------------ */
/*  WP3 — Novos componentes UI/UX                                    */
/* ------------------------------------------------------------------ */

/* Filtro de período (pills) */
.date-filter-bar { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; align-items: center; }
.date-filter-bar .label { font-size: 12px; color: var(--cor-texto-sec); margin-right: 4px; }
.date-pill {
    padding: 4px 12px;
    border-radius: 12px;
    border: 1px solid var(--cor-borda);
    background: var(--cor-fundo-card);
    cursor: pointer;
    font-size: 12px;
    color: var(--cor-texto-sec);
    transition: all .15s;
}
.date-pill:hover { border-color: var(--cor-acento); color: var(--cor-acento); }
.date-pill.active { background: var(--cor-acento); color: #fff; border-color: var(--cor-acento); }

/* Autocomplete input */
.autocomplete-wrap { position: relative; }
.autocomplete-wrap input { width: 100%; }
.autocomplete-list {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid var(--cor-borda);
    border-radius: 6px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 100;
    box-shadow: 0 4px 12px rgba(0,0,0,.1);
    display: none;
}
.autocomplete-list.open { display: block; }
.autocomplete-item { padding: 8px 12px; cursor: pointer; font-size: 13px; }
.autocomplete-item:hover, .autocomplete-item.selected { background: var(--cor-fundo); }
.autocomplete-item .tipo { font-size: 11px; color: var(--cor-texto-sec); margin-left: 8px; }
.autocomplete-empty { padding: 8px 12px; font-size: 12px; color: var(--cor-texto-sec); font-style: italic; }

/* Stat cards menores (prospects funil) */
.stat-card-sm {
    padding: 12px 16px;
    text-align: center;
    background: var(--cor-fundo-card);
    border: 1px solid var(--cor-borda);
    border-radius: 8px;
}
.stat-card-sm .stat-number { font-size: 20px; font-weight: 700; color: var(--cor-texto); }
.stat-card-sm .stat-label { font-size: 11px; color: var(--cor-texto-sec); margin-top: 2px; }
.stat-grid-sm { display: grid; grid-template-columns: repeat(auto-fit, minmax(100px, 1fr)); gap: 10px; margin-bottom: 16px; }

/* ── Oportunidades ── */
.oport-rpi-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 16px; }
.oport-rpi-card { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 12px; padding: 20px; transition: box-shadow .15s, border-color .15s; }
.oport-rpi-card:hover { border-color: var(--cor-acento); box-shadow: 0 4px 12px rgba(37,99,235,.10); }
.oport-rpi-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.oport-rpi-num { font-weight: 700; font-size: 15px; color: var(--cor-texto); }
.oport-rpi-date { font-size: 12px; color: var(--cor-texto-sec); }
.oport-rpi-body { text-align: center; margin-bottom: 14px; }
.oport-rpi-big { font-size: 36px; font-weight: 800; color: var(--cor-acento); line-height: 1; }
.oport-rpi-label { font-size: 12px; color: var(--cor-texto-sec); margin-top: 2px; }
.oport-rpi-meta { display: flex; justify-content: center; gap: 12px; margin-top: 8px; font-size: 12px; color: var(--cor-texto-sec); }
.oport-rpi-bar { display: flex; height: 6px; border-radius: 3px; overflow: hidden; background: var(--cor-fundo); margin-bottom: 14px; }
.oport-bar-seg { height: 100%; transition: width .3s; }
.oport-bar-pend { background: #F59E0B; }
.oport-bar-aceita { background: #059669; }
.oport-bar-ign { background: #D1D5DB; }
.oport-rpi-footer { display: flex; align-items: baseline; gap: 6px; }
.oport-receita { font-size: 18px; font-weight: 700; color: var(--cor-texto); }
.oport-receita-label { font-size: 12px; color: var(--cor-texto-sec); }
.oport-filter-bar { display: flex; gap: 6px; margin-bottom: 16px; flex-wrap: wrap; }
.oport-pill { padding: 5px 14px; border-radius: 20px; border: 1px solid var(--cor-borda); background: var(--cor-fundo-card); cursor: pointer; font-size: 12px; font-family: var(--fonte); color: var(--cor-texto-sec); transition: all .15s; }
.oport-pill:hover { border-color: var(--cor-acento); color: var(--cor-acento); }
.oport-pill.active { background: var(--cor-acento); color: #fff; border-color: var(--cor-acento); }
.oport-pill-pend.active { background: #F59E0B; border-color: #F59E0B; }
.oport-pill-aceita.active { background: #059669; border-color: #059669; }
.oport-pill-ign.active { background: #6B7280; border-color: #6B7280; }

/* ── Prospect Hero ── */
.prospect-hero { background: linear-gradient(135deg, #2563EB 0%, #1D4ED8 100%); border-radius: 12px; padding: 28px 32px; color: #fff; display: flex; align-items: center; gap: 24px; margin-bottom: 20px; position: relative; overflow: hidden; }
.prospect-hero::before { content: ''; position: absolute; top: -40px; right: -40px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 70%); border-radius: 50%; }
.prospect-hero-icon { font-size: 48px; width: 72px; height: 72px; display: flex; align-items: center; justify-content: center; background: rgba(255,255,255,.15); border-radius: 16px; flex-shrink: 0; }
.prospect-hero-content { flex: 1; }
.prospect-hero-title { font-size: 22px; font-weight: 700; margin-bottom: 4px; }
.prospect-hero-subtitle { font-size: 14px; opacity: .85; line-height: 1.5; max-width: 560px; }
.prospect-hero-stats { display: flex; gap: 32px; flex-shrink: 0; }
.prospect-hero-stat { text-align: center; }
.prospect-hero-stat-num { font-size: 28px; font-weight: 700; line-height: 1; }
.prospect-hero-stat-label { font-size: 11px; opacity: .7; margin-top: 4px; text-transform: uppercase; letter-spacing: .5px; }

/* ── Funil Pipeline ── */
.funil-pipeline { display: flex; align-items: stretch; gap: 0; margin-bottom: 20px; background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 12px; overflow: hidden; }
.funil-stage { flex: 1; text-align: center; padding: 20px 12px; position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; transition: background .15s; cursor: default; }
.funil-stage:hover { background: rgba(0,0,0,.015); }
.funil-stage:not(:last-child) { border-right: 1px solid var(--cor-borda); }
.funil-stage:not(:last-child)::after { content: ''; position: absolute; right: -1px; top: 50%; transform: translateY(-50%); width: 0; height: 0; border-top: 20px solid transparent; border-bottom: 20px solid transparent; border-left: 12px solid var(--cor-borda); z-index: 1; }
.funil-stage:not(:last-child)::before { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); width: 0; height: 0; border-top: 20px solid transparent; border-bottom: 20px solid transparent; border-left: 12px solid var(--cor-fundo-card); z-index: 2; }
.funil-dot { width: 10px; height: 10px; border-radius: 50%; margin-bottom: 8px; }
.funil-num { font-size: 28px; font-weight: 700; line-height: 1; }
.funil-label { font-size: 11px; color: var(--cor-texto-sec); margin-top: 4px; text-transform: uppercase; letter-spacing: .5px; font-weight: 600; }
.funil-bar { height: 3px; border-radius: 2px; margin-top: 8px; opacity: .3; }

/* ── Filter bar card ── */
.filter-bar-card { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 10px; padding: 14px 20px; margin-bottom: 16px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.filter-bar-card select, .filter-bar-card input[type="text"] { padding: 8px 12px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 13px; background: var(--cor-fundo); outline: none; transition: border-color .15s; font-family: inherit; }
.filter-bar-card select { min-width: 140px; }
.filter-bar-card input[type="text"] { flex: 1; min-width: 200px; }
.filter-bar-card input:focus, .filter-bar-card select:focus { border-color: var(--cor-acento); box-shadow: 0 0 0 3px rgba(37,99,235,.08); }

/* Logo dropzone */
.logo-dropzone {
    border: 2px dashed var(--cor-borda);
    border-radius: 8px;
    padding: 24px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s;
    max-width: 300px;
}
.logo-dropzone:hover, .logo-dropzone.dragover { border-color: var(--cor-acento); }
.logo-dropzone img { max-height: 80px; margin-bottom: 8px; display: block; margin-left: auto; margin-right: auto; }
.logo-dropzone .drop-label { font-size: 12px; color: var(--cor-texto-sec); }
.logo-dropzone .drop-hint { font-size: 11px; color: var(--cor-texto-sec); opacity: .7; margin-top: 4px; }

/* Modal Cadastro Processo */
.modal-cadastro { max-width: 520px; }
.modal-cadastro .modal-body { padding: 0; }
.modal-dropzone {
    border: 2px dashed var(--cor-borda);
    border-radius: 10px;
    padding: 40px 24px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    margin: 20px;
}
.modal-dropzone:hover, .modal-dropzone.dragover {
    border-color: var(--cor-acento);
    background: rgba(37,99,235,.03);
}
.modal-dropzone-icon { font-size: 36px; margin-bottom: 8px; color: var(--cor-texto-sec); }
.modal-dropzone-text { font-size: 14px; color: var(--cor-texto); font-weight: 500; }
.modal-dropzone-hint { font-size: 12px; color: var(--cor-texto-sec); margin-top: 4px; }
.modal-cadastro-content { padding: 0 20px 20px; }
.modal-pdf-file {
    display: flex; align-items: center; gap: 10px;
    background: var(--cor-fundo); border: 1px solid var(--cor-borda);
    border-radius: 8px; padding: 10px 14px; margin-bottom: 16px;
}
.modal-pdf-file .pdf-icon { font-size: 20px; flex-shrink: 0; }
.modal-pdf-file .pdf-name { flex: 1; font-size: 13px; font-weight: 500; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.modal-pdf-file .pdf-status { width: 10px; height: 10px; border-radius: 50%; background: #10B981; flex-shrink: 0; }
.modal-pdf-file .pdf-remove { cursor: pointer; font-size: 16px; color: var(--cor-texto-sec); flex-shrink: 0; }
.modal-pdf-file .pdf-remove:hover { color: #DC2626; }
.modal-preview-row { display: flex; gap: 8px; margin-bottom: 8px; font-size: 13px; }
.modal-preview-row .lbl { color: var(--cor-texto-sec); min-width: 90px; flex-shrink: 0; }
.modal-preview-row .val { font-weight: 500; color: var(--cor-texto); }
.modal-divider { border: none; border-top: 1px solid var(--cor-borda); margin: 16px 0; }
.modal-success-icon { font-size: 48px; text-align: center; margin-bottom: 12px; color: #10B981; }
.modal-success-text { font-size: 15px; font-weight: 600; text-align: center; margin-bottom: 20px; }
.modal-suggestion {
    border: 1px solid var(--cor-borda); border-radius: 10px; padding: 16px;
    margin-bottom: 12px; display: flex; align-items: center; gap: 14px;
}
.modal-suggestion-icon { font-size: 24px; flex-shrink: 0; }
.modal-suggestion-body { flex: 1; }
.modal-suggestion-title { font-size: 13px; font-weight: 600; margin-bottom: 2px; }
.modal-suggestion-desc { font-size: 12px; color: var(--cor-texto-sec); }
.modal-suggestion .btn-sm { padding: 6px 14px; font-size: 12px; border-radius: 6px; }
.modal-actions { display: flex; gap: 8px; margin-top: 16px; }
.modal-actions .btn-primary, .modal-actions .btn-secondary { flex: 1; }
.modal-link { display: block; text-align: center; margin-top: 12px; font-size: 12px; color: var(--cor-texto-sec); cursor: pointer; }
.modal-link:hover { color: var(--cor-acento); }
.modal-loading { text-align: center; padding: 40px 20px; }
.modal-loading-spinner { width: 40px; height: 40px; border: 3px solid var(--cor-borda); border-top-color: var(--cor-acento); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto 16px; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Nexxus Stress Test */
.nexxus-card { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 10px; padding: 20px; }
.nexxus-card .nexxus-title { font-size: 15px; font-weight: 700; color: var(--cor-texto); margin-bottom: 4px; }
.nexxus-card .nexxus-subtitle { font-size: 12px; color: var(--cor-texto-secundario); margin-bottom: 16px; }
.nexxus-summary { display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.nexxus-stat { padding: 10px 16px; border-radius: 8px; text-align: center; min-width: 110px; }
.nexxus-stat .ns-num { font-size: 22px; font-weight: 700; }
.nexxus-stat .ns-label { font-size: 11px; margin-top: 2px; }
.nexxus-stat-critico { background: var(--cor-erro-light); color: var(--cor-erro); }
.nexxus-stat-atencao { background: var(--cor-alerta-light); color: var(--cor-alerta); }
.nexxus-stat-livre { background: var(--cor-sucesso-light); color: var(--cor-sucesso); }
.nexxus-marca-group { border: 1px solid var(--cor-borda); border-radius: 8px; margin-bottom: 10px; overflow: hidden; }
.nexxus-marca-header { background: var(--cor-fundo); padding: 10px 14px; font-weight: 600; font-size: 13px; border-bottom: 1px solid var(--cor-borda); display: flex; align-items: center; gap: 8px; }
.nexxus-ameaca { padding: 10px 14px; border-bottom: 1px solid var(--cor-borda); display: flex; align-items: center; gap: 12px; font-size: 12px; }
.nexxus-ameaca:last-child { border-bottom: none; }
.nexxus-ameaca .na-marca { font-weight: 600; min-width: 120px; }
.nexxus-ameaca .na-ici { font-weight: 700; min-width: 60px; }
.nexxus-ameaca .na-dias { min-width: 90px; text-align: right; margin-left: auto; }
.nexxus-pulse { animation: nexxusPulse 1.2s ease-in-out infinite; }
@keyframes nexxusPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ------------------------------------------------------------------ */
/*  WP8 — Responsividade novos componentes                           */
/* ------------------------------------------------------------------ */
@media (max-width: 768px) {
    .date-filter-bar { gap: 4px; }
    .date-pill { padding: 3px 8px; font-size: 11px; }
    .stat-grid-sm { grid-template-columns: repeat(2, 1fr); }
    .screen-desc { padding: 8px 12px; font-size: 12px; }
    .logo-dropzone { padding: 16px; }
    .screen-header { flex-direction: column; align-items: flex-start; gap: 8px; }
    .screen-header .actions { flex-wrap: wrap; }
}

@media (max-width: 480px) {
    .stat-grid-sm { grid-template-columns: 1fr; }
    .autocomplete-list { max-height: 160px; }
    .screen-header .actions { width: 100%; }
    .screen-header .actions button { flex: 1; font-size: 12px; }
}

/* ------------------------------------------------------------------ */
/*  Sprint 11 — Evolução Tela de Processos                            */
/* ------------------------------------------------------------------ */

/* Bulk action bar */
.bulk-bar { display: flex; align-items: center; gap: 8px; padding: 10px 16px; background: var(--cor-acento); color: #fff; border-radius: 8px; margin-bottom: 12px; animation: slideDown 0.2s ease; }
.bulk-bar .bulk-info { font-size: 13px; margin-right: auto; font-weight: 500; }
.bulk-bar button { background: rgba(255,255,255,0.15); color: #fff; border: 1px solid rgba(255,255,255,0.3); padding: 5px 12px; border-radius: 5px; font-size: 12px; cursor: pointer; white-space: nowrap; }
.bulk-bar button:hover { background: rgba(255,255,255,0.25); }
.bulk-bar .btn-bulk-danger { background: #DC2626; border-color: #DC2626; }
.bulk-bar .btn-bulk-danger:hover { background: #B91C1C; }
.bulk-bar .btn-bulk-ghost { background: transparent; border-color: rgba(255,255,255,0.4); }
@keyframes slideDown { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

/* Advanced filters panel */
.advanced-filters { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 8px; padding: 20px; margin-bottom: 12px; display: none; }
.advanced-filters.open { display: block; }
.filters-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.filter-group label { display: block; font-size: 12px; font-weight: 600; color: var(--cor-texto-sec); margin-bottom: 4px; text-transform: uppercase; letter-spacing: 0.5px; }
.filter-group select, .filter-group input[type="text"] { width: 100%; padding: 8px 12px; border: 1px solid var(--cor-borda); border-radius: 6px; font-size: 13px; background: var(--cor-fundo); }
.btn-filtros-toggle { background: var(--cor-acento); color: #fff; border: none; padding: 10px 20px; border-radius: 8px; font-size: 13px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: background 0.15s; }
.btn-filtros-toggle:hover { background: var(--cor-acento-hover); }

/* Pill toggle (Ativos / Todos) */
.btn-pill-toggle { background: #F0FDF4; color: #16A34A; border: 1px solid #BBF7D0; padding: 8px 16px; border-radius: 20px; font-size: 12px; font-weight: 600; cursor: pointer; white-space: nowrap; transition: all 0.2s; letter-spacing: 0.3px; }
.btn-pill-toggle:hover { background: #DCFCE7; }
.btn-pill-toggle.showing-all { background: #FEF3C7; color: #B45309; border-color: #FDE68A; }
.btn-pill-toggle.showing-all:hover { background: #FDE68A; }
.btn-pill-toggle.pill-off { background: #F3F4F6; color: #6B7280; border-color: #D1D5DB; }
.btn-pill-toggle.pill-off:hover { background: #E5E7EB; }

/* Presentation badges */
.badge-apresentacao { width: 34px; height: 34px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; color: #fff; cursor: default; }
.badge-apresentacao.nom { background: #475569; }
.badge-apresentacao.mix { background: #6366F1; }
.badge-apresentacao.fig { background: #E11D48; }
.badge-apresentacao.tri { background: #059669; }

/* Row action icons */
.row-actions { display: flex; gap: 4px; align-items: center; opacity: 0.45; transition: opacity 0.15s; }
.data-table tbody tr:hover .row-actions { opacity: 1; }
.row-action { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border-radius: 6px; cursor: pointer; color: var(--cor-texto-sec); font-size: 14px; transition: all 0.15s; border: none; background: none; }
.row-action:hover { background: #F3F4F6; color: var(--cor-acento); }

/* Zebra striping */
.data-table tbody tr:nth-child(even) { background: rgba(0, 0, 0, 0.015); }

/* Row hover — blue left border + smooth transition */
.data-table tbody tr { transition: all 0.15s ease; border-left: 3px solid transparent; }
.data-table tbody tr:hover { background: #EFF6FF !important; border-left-color: var(--cor-acento); }

/* Numero fica azul ao hover */
.data-table tbody tr:hover .proc-numero { color: var(--cor-acento); }

/* Hover arrow indicator */
.hover-arrow { opacity: 0; transition: opacity 0.15s; color: var(--cor-texto-sec); font-size: 16px; }
.data-table tbody tr:hover .hover-arrow { opacity: 1; }

/* Checkbox azul */
.data-table input[type="checkbox"] { accent-color: var(--cor-acento); width: 15px; height: 15px; cursor: pointer; }

/* Selected row */
.data-table tbody tr.selected { background: #EFF6FF !important; }

/* Proc numero styling */
.proc-numero { font-weight: 600; font-family: 'SF Mono', 'Fira Code', 'Cascadia Code', monospace; font-size: 14px; transition: color 0.15s; }

/* NCL chip */
.ncl-chip { display: inline-flex; align-items: center; gap: 4px; background: #F3F4F6; border: 1px solid #E5E7EB; border-radius: 6px; padding: 3px 10px; font-size: 12px; font-weight: 600; color: #374151; cursor: help; transition: all 0.15s; }
.ncl-chip:hover { background: #E5E7EB; border-color: #D1D5DB; }
.ncl-chip .ncl-num { color: var(--cor-acento); font-weight: 700; }

/* NCL tooltip in table (legacy) */
.ncl-tooltip { cursor: help; border-bottom: 1px dotted var(--cor-texto-sec); }

/* Header counter badge */
.header-count { font-size: 14px; font-weight: 500; color: var(--cor-texto-sec); background: #F3F4F6; padding: 2px 10px; border-radius: 12px; }

/* ── Search Container (barra unificada) ── */
.search-container { background: var(--cor-fundo-card); border: 1px solid var(--cor-borda); border-radius: 12px; padding: 16px 20px; margin-bottom: 20px; box-shadow: 0 1px 3px rgba(0,0,0,0.04); }
.search-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.search-input-wrap { flex: 1; position: relative; min-width: 200px; }
.search-input-wrap .search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: #9CA3AF; font-size: 16px; pointer-events: none; }
.search-input { width: 100%; padding: 10px 14px 10px 40px; border: 1px solid var(--cor-borda); border-radius: 8px; font-size: 14px; outline: none; transition: border-color .15s; background: var(--cor-fundo); }
.search-input:focus { border-color: var(--cor-acento); box-shadow: 0 0 0 3px rgba(37,99,235,0.1); }
.search-input::placeholder { color: #9CA3AF; }

/* ── Type Pills ── */
.type-pills { display: flex; gap: 4px; background: var(--cor-fundo); border-radius: 8px; padding: 3px; border: 1px solid var(--cor-borda); }
.type-pill { padding: 7px 14px; border-radius: 6px; font-size: 13px; font-weight: 500; cursor: pointer; transition: all .15s; border: none; background: transparent; color: var(--cor-texto-sec); white-space: nowrap; font-family: inherit; }
.type-pill:hover { background: rgba(37,99,235,0.06); color: var(--cor-texto); }
.type-pill.active { background: var(--cor-acento); color: white; box-shadow: 0 1px 3px rgba(37,99,235,0.3); }

/* ── Stat Chips ── */
.stats-row { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.stat-chip { display: flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 6px; font-size: 12px; font-weight: 500; color: var(--cor-texto-sec); }
.stat-chip .stat-num { font-weight: 700; }
.stat-chip.chip-total { background: #F3F4F6; }
.stat-chip.chip-total .stat-num { color: var(--cor-texto); }
.stat-chip.chip-pf { background: #DBEAFE; }
.stat-chip.chip-pf .stat-num { color: #2563EB; }
.stat-chip.chip-pj { background: #F3E8FF; }
.stat-chip.chip-pj .stat-num { color: #7C3AED; }
.stat-chip.chip-est { background: #FEF3C7; }
.stat-chip.chip-est .stat-num { color: #D97706; }

/* ── Badge Amber (Estrangeiro) ── */
.badge-amber { background: #FEF3C7; color: #D97706; }

/* ── T3P Nexxus IP ── */
.nexxus-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 8px; cursor: pointer;
  font-size: 13px; font-weight: 500; color: var(--cor-texto);
  background: var(--cor-fundo); border: 1px solid var(--cor-borda);
  transition: all 0.2s;
}
.nexxus-toggle:hover { border-color: var(--cor-acento); }
.nexxus-toggle input:checked + span { color: var(--cor-acento); font-weight: 600; }

.nexxus-section {
  margin-top: 20px; padding: 16px; border-radius: 10px;
  background: var(--cor-fundo-card); border: 1px solid var(--cor-borda);
}
.nexxus-section h3 { margin: 0 0 12px 0; font-size: 15px; color: var(--cor-texto); }

.nexxus-score-big {
  font-size: 42px; font-weight: 800; line-height: 1;
}
.nexxus-score-big.score-critico { color: #DC2626; }
.nexxus-score-big.score-atencao { color: #D97706; }
.nexxus-score-big.score-livre { color: #059669; }

.nexxus-faixa {
  display: inline-block; padding: 4px 12px; border-radius: 6px;
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
}
.nexxus-faixa.faixa-critico { background: #FEE2E2; color: #DC2626; }
.nexxus-faixa.faixa-atencao { background: #FFEDD5; color: #D97706; }
.nexxus-faixa.faixa-livre { background: #D1FAE5; color: #059669; }

.nexxus-radar-container {
  display: flex; flex-wrap: wrap; gap: 24px; align-items: flex-start;
}
.nexxus-radar-svg { flex-shrink: 0; }
.nexxus-radar-details { flex: 1; min-width: 200px; }
.nexxus-radar-details .detail-row {
  display: flex; justify-content: space-between; padding: 6px 0;
  border-bottom: 1px solid var(--cor-borda); font-size: 13px;
}
.nexxus-radar-details .detail-row:last-child { border-bottom: none; }
.nexxus-radar-details .detail-label { color: var(--cor-texto-secundario); }
.nexxus-radar-details .detail-value { font-weight: 600; color: var(--cor-texto); }

.nexxus-countdown {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 700;
}
.nexxus-countdown.urgente {
  background: #FEE2E2; color: #DC2626;
  animation: nexxus-pulse 1.5s ease-in-out infinite;
}
.nexxus-countdown.normal { background: #FFEDD5; color: #D97706; }
.nexxus-countdown.expirado { background: #F3F4F6; color: #9CA3AF; }

@keyframes nexxus-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.05); }
}

.nexxus-vuln-card {
  padding: 12px; margin-bottom: 8px; border-radius: 8px;
  border: 1px solid var(--cor-borda); background: var(--cor-fundo);
}
.nexxus-vuln-card .vuln-header {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px;
}
.nexxus-vuln-card .vuln-marca { font-weight: 600; font-size: 14px; }
.nexxus-vuln-card .vuln-ameacas { font-size: 12px; color: var(--cor-texto-secundario); }

.btn-nexxus {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 8px; border: none; cursor: pointer;
  font-size: 13px; font-weight: 600; color: #fff;
  background: linear-gradient(135deg, #7C3AED, #2563EB);
  transition: all 0.2s;
}
.btn-nexxus:hover { opacity: 0.9; transform: translateY(-1px); box-shadow: 0 4px 12px rgba(37,99,235,0.3); }
.btn-nexxus:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }

.nexxus-summary-stats {
  display: flex; gap: 12px; margin: 12px 0; flex-wrap: wrap;
}
.nexxus-stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 8px 16px; border-radius: 8px; min-width: 80px;
}
.nexxus-stat.stat-critico { background: #FEE2E2; }
.nexxus-stat.stat-atencao { background: #FFEDD5; }
.nexxus-stat.stat-livre { background: #D1FAE5; }
.nexxus-stat .stat-count { font-size: 24px; font-weight: 800; }
.nexxus-stat.stat-critico .stat-count { color: #DC2626; }
.nexxus-stat.stat-atencao .stat-count { color: #D97706; }
.nexxus-stat.stat-livre .stat-count { color: #059669; }
.nexxus-stat .stat-desc { font-size: 11px; color: var(--cor-texto-secundario); text-transform: uppercase; letter-spacing: 0.5px; }

/* ============================================================
   Anti-Cópia (Nível 2) — Pesquisa Paga Cliente
   ============================================================ */
.anti-copy {
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    position: relative;
}
.anti-copy::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 5;
    pointer-events: none;
}
body.page-blurred .anti-copy {
    filter: blur(20px);
    transition: filter 0.3s ease;
}
body.page-blurred .anti-copy::after {
    pointer-events: all;
    background: rgba(255,255,255,0.1);
}

/* ============================================================
   Registro (Auto-cadastro)
   ============================================================ */
.registro-container {
    max-width: 440px;
    margin: 60px auto;
    padding: 32px;
    background: var(--cor-fundo-card);
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.registro-container h2 {
    text-align: center;
    margin-bottom: 24px;
    font-size: 22px;
}
.registro-tipo-pills {
    display: flex;
    gap: 8px;
    margin-bottom: 20px;
}
.registro-tipo-pill {
    flex: 1;
    padding: 12px;
    text-align: center;
    border: 2px solid var(--cor-borda);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    transition: all 0.2s;
}
.registro-tipo-pill:hover {
    border-color: var(--cor-acento);
    color: var(--cor-acento);
}
.registro-tipo-pill.active {
    border-color: var(--cor-acento);
    background: var(--cor-acento);
    color: white;
}
.registro-footer {
    text-align: center;
    margin-top: 16px;
    font-size: 13px;
    color: var(--cor-texto-sec);
}

/* ============================================================
   GM Screens
   ============================================================ */
.gm-hero {
    background: linear-gradient(135deg, #1E3A5F 0%, #7C3AED 50%, #6D28D9 100%);
    border-radius: 12px;
    padding: 24px 28px;
    color: white;
    margin-bottom: 20px;
}
.gm-hero h2 {
    margin: 0 0 4px 0;
    font-size: 20px;
    font-weight: 700;
}
.gm-hero p {
    margin: 0;
    font-size: 13px;
    opacity: 0.8;
}

/* ============================================================
   Cliente Screens
   ============================================================ */
.cliente-hero {
    background: linear-gradient(135deg, #0F766E 0%, #0D9488 50%, #14B8A6 100%);
    border-radius: 12px;
    padding: 24px 28px;
    color: white;
    margin-bottom: 20px;
}
.cliente-hero h2 {
    margin: 0 0 4px 0;
    font-size: 20px;
    font-weight: 700;
}
.cliente-hero p {
    margin: 0;
    font-size: 13px;
    opacity: 0.8;
}

/* Pesquisa paga — level picker */
.nivel-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin: 20px 0;
}
.nivel-card {
    padding: 20px;
    border: 2px solid var(--cor-borda);
    border-radius: 12px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
}
.nivel-card:hover {
    border-color: var(--cor-acento);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.nivel-card.selected {
    border-color: var(--cor-acento);
    background: #EFF6FF;
}
.nivel-card h4 {
    margin: 0 0 8px 0;
    font-size: 15px;
}
.nivel-card .nivel-preco {
    font-size: 24px;
    font-weight: 800;
    color: var(--cor-acento);
    margin: 8px 0;
}
.nivel-card .nivel-desc {
    font-size: 12px;
    color: var(--cor-texto-sec);
}

/* Coin balance big */
.coin-balance-big {
    text-align: center;
    padding: 32px;
    background: linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);
    border-radius: 12px;
    margin-bottom: 20px;
}
.coin-balance-big .coin-icon {
    font-size: 48px;
}
.coin-balance-big .coin-value {
    font-size: 48px;
    font-weight: 800;
    color: #92400E;
    margin: 8px 0;
}
.coin-balance-big .coin-label {
    font-size: 14px;
    color: #92400E;
    opacity: 0.7;
}

/* === BTN-OUTLINE === */
.btn-outline {
    background: transparent;
    border: 1px solid var(--cor-acento);
    color: var(--cor-acento);
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s;
}
.btn-outline:hover {
    background: var(--cor-acento);
    color: white;
}

/* === GLOBAL SEARCH (Cmd+K / Ctrl+K) === */
.search-overlay {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.45);
    z-index: 1000;
    display: flex; align-items: flex-start; justify-content: center;
    padding-top: 15vh;
    animation: searchFadeIn 0.15s ease;
}
@keyframes searchFadeIn { from { opacity: 0; } to { opacity: 1; } }
.search-modal {
    background: var(--cor-fundo-card);
    border-radius: 12px;
    width: 560px; max-width: calc(100vw - 32px);
    max-height: 60vh;
    overflow: hidden;
    box-shadow: 0 25px 50px rgba(0,0,0,0.25);
    animation: searchSlideIn 0.15s ease;
}
@keyframes searchSlideIn { from { transform: translateY(-12px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.search-input-wrap {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 20px;
    border-bottom: 1px solid var(--cor-borda);
}
.search-input-wrap .search-icon { color: var(--cor-cinza); font-size: 18px; flex-shrink: 0; }
.search-input {
    flex: 1; border: none; font-size: 16px; outline: none;
    background: transparent; color: var(--cor-texto);
    font-family: var(--fonte);
}
.search-input::placeholder { color: var(--cor-cinza); }
.search-input-wrap .search-kbd {
    font-size: 11px; color: var(--cor-cinza);
    background: var(--cor-fundo); border: 1px solid var(--cor-borda);
    border-radius: 4px; padding: 2px 6px; flex-shrink: 0;
}
.search-results { overflow-y: auto; max-height: calc(60vh - 56px); }
.search-group-label {
    padding: 8px 20px 4px; font-size: 11px; font-weight: 700;
    color: var(--cor-cinza); text-transform: uppercase; letter-spacing: 0.5px;
}
.search-result {
    padding: 10px 20px; cursor: pointer;
    display: flex; align-items: center; gap: 12px;
    transition: background 0.1s;
}
.search-result:hover, .search-result.active { background: var(--cor-fundo-hover); }
.search-result-icon {
    width: 32px; height: 32px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 15px; flex-shrink: 0;
}
.search-result-icon.processo { background: #EFF6FF; color: #2563EB; }
.search-result-icon.cliente { background: #F0FDF4; color: #16A34A; }
.search-result-icon.prospect { background: #FFF7ED; color: #EA580C; }
.search-result-icon.ipas { background: #F5F3FF; color: #7C3AED; }
.search-result-text { flex: 1; min-width: 0; }
.search-result-title { font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-result-sub { font-size: 12px; color: var(--cor-texto-sec); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.search-hint {
    padding: 24px 20px; text-align: center;
    color: var(--cor-cinza); font-size: 13px;
}
.search-hint-keys { margin-top: 8px; font-size: 11px; color: var(--cor-cinza); }
.search-hint-keys kbd {
    background: var(--cor-fundo); border: 1px solid var(--cor-borda);
    border-radius: 3px; padding: 1px 5px; font-size: 11px;
    font-family: var(--fonte);
}
/* Sidebar shortcut hint */
.sidebar-search-hint {
    padding: 8px 16px; margin: 4px 12px 12px;
    background: rgba(255,255,255,0.06);
    border-radius: 8px; cursor: pointer;
    display: flex; align-items: center; gap: 8px;
    font-size: 12px; color: var(--cor-sidebar-texto);
    transition: background 0.15s;
}
.sidebar-search-hint:hover { background: rgba(255,255,255,0.12); }
.sidebar-search-hint kbd {
    margin-left: auto; font-size: 10px;
    background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15);
    border-radius: 3px; padding: 1px 5px;
    font-family: var(--fonte); color: var(--cor-sidebar-texto);
}

/* ------------------------------------------------------------------ */
/*  Onboarding Wizard                                                  */
/* ------------------------------------------------------------------ */
.onboarding-wizard {
    max-width: 640px;
    margin: 0 auto;
    padding: 32px 0;
}
.onboarding-header {
    text-align: center;
    margin-bottom: 32px;
}
.onboarding-logo {
    display: inline-block;
    font-size: 28px;
    font-weight: 800;
    color: var(--cor-acento);
    background: linear-gradient(135deg, #2563EB, #7C3AED);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 8px;
}
.onboarding-welcome {
    font-size: 24px;
    font-weight: 700;
    color: var(--cor-texto);
    margin: 0 0 4px;
}
.onboarding-subtitle {
    font-size: 14px;
    color: var(--cor-texto-sec, #6B7280);
    margin: 0;
}

/* Progress */
.onboarding-progress {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    margin-bottom: 28px;
}
.onboarding-progress-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 80px;
}
.onboarding-dot {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    border: 2px solid var(--cor-borda);
    color: var(--cor-texto-sec, #6B7280);
    background: var(--cor-fundo-card);
    transition: all 0.2s;
}
.onboarding-progress-step.active .onboarding-dot {
    border-color: var(--cor-acento);
    color: #fff;
    background: var(--cor-acento);
}
.onboarding-progress-step.done .onboarding-dot {
    border-color: #059669;
    color: #fff;
    background: #059669;
}
.onboarding-step-label {
    font-size: 11px;
    color: var(--cor-texto-sec, #6B7280);
    text-align: center;
    white-space: nowrap;
}
.onboarding-progress-step.active .onboarding-step-label {
    color: var(--cor-acento);
    font-weight: 600;
}
.onboarding-line {
    flex: 1;
    height: 2px;
    background: var(--cor-borda);
    min-width: 40px;
    margin: 0 4px;
    margin-bottom: 22px; /* align with dot center */
    transition: background 0.2s;
}
.onboarding-line.done {
    background: #059669;
}

/* Step title/desc */
.onboarding-step-title {
    font-size: 18px;
    font-weight: 700;
    color: var(--cor-texto);
    margin: 0 0 4px;
}
.onboarding-step-desc {
    font-size: 13px;
    color: var(--cor-texto-sec, #6B7280);
    margin: 0 0 20px;
}

/* Body */
.onboarding-body {
    margin-bottom: 24px;
}
.onboarding-form .form-group {
    margin-bottom: 14px;
}
.onboarding-form .form-group label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--cor-texto);
    margin-bottom: 4px;
}

/* Import cards */
.onboarding-import-options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}
.onboarding-import-card {
    border: 1px solid var(--cor-borda);
    border-radius: 10px;
    padding: 20px 16px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s;
    background: var(--cor-fundo-card);
}
.onboarding-import-card:hover {
    border-color: var(--cor-acento);
    box-shadow: 0 2px 8px rgba(37,99,235,0.08);
}
.onboarding-import-card.active {
    border-color: var(--cor-acento);
    background: #EFF6FF;
    box-shadow: 0 0 0 2px rgba(37,99,235,0.15);
}
.onboarding-import-icon {
    font-size: 28px;
    margin-bottom: 8px;
}
.onboarding-import-title {
    font-size: 14px;
    font-weight: 700;
    color: var(--cor-texto);
    margin-bottom: 6px;
}
.onboarding-import-desc {
    font-size: 12px;
    color: var(--cor-texto-sec, #6B7280);
    line-height: 1.4;
}

/* Footer */
.onboarding-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 16px;
    border-top: 1px solid var(--cor-borda);
}

/* Responsive */
@media (max-width: 600px) {
    .onboarding-wizard { padding: 16px 0; }
    .onboarding-import-options { grid-template-columns: 1fr; }
    .onboarding-progress-step { min-width: 60px; }
    .onboarding-step-label { font-size: 10px; }
    .onboarding-line { min-width: 20px; }
}

/* ------------------------------------------------------------------ */
/*  Dashboard Insights                                                 */
/* ------------------------------------------------------------------ */
.insights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 10px;
}
.insight-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 8px;
    cursor: pointer;
    transition: box-shadow 0.15s, transform 0.15s;
}
.insight-card:hover {
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transform: translateY(-1px);
}
.insight-icon {
    font-size: 18px;
    flex-shrink: 0;
}
.insight-text {
    flex: 1;
    font-size: 13px;
    color: var(--cor-texto);
    font-weight: 500;
}
.insight-arrow {
    font-size: 14px;
    color: var(--cor-texto-sec, #6B7280);
    flex-shrink: 0;
}

/* Link de navegação inline (tabelas, cards) */
.nav-link {
    color: var(--cor-texto);
    cursor: pointer;
    font-weight: 500;
    transition: color 0.15s;
}
.nav-link:hover {
    color: var(--cor-acento);
}
