:root {
  --bg: #f7f6f3;
  --bg2: #efeee9;
  --white: #ffffff;
  --border: #e4e2dc;
  --border2: #d4d2cb;
  --ink: #1a1915;
  --ink2: #5a5850;
  --ink3: #9a9890;
  --emerald: #1a6b4a;
  --emerald-light: #e8f5ee;
  --emerald-mid: #b8deca;
  --red: #c0392b;
  --red-light: #fdf0ee;
  --amber: #b7690a;
  --amber-light: #fef7ea;
  --blue: #1a5a9a;
  --blue-light: #eaf2fc;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 4px 16px rgba(0,0,0,0.07), 0 1px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.06);
  --radius: 12px;
  --font: 'Geist', sans-serif;
  --font-display: 'Fraunces', serif;
  --font-mono: 'Geist Mono', monospace;
}
* { margin:0; padding:0; box-sizing:border-box; }
body { background:var(--bg); color:var(--ink); font-family:var(--font); font-size:14px; line-height:1.5; min-height:100vh; display:flex; }

/* SIDEBAR */
.sidebar { width:232px; background:var(--white); border-right:1px solid var(--border); display:flex; flex-direction:column; position:fixed; height:100vh; z-index:100; overflow-y:auto; overflow-x:hidden; }
.logo { padding:24px 20px 20px; border-bottom:1px solid var(--border); position:sticky; top:0; z-index:1; background:var(--white); }
.logo-mark { display:flex; align-items:center; gap:10px; }
.logo-icon { width:34px; height:34px; border-radius:9px; object-fit:cover; display:block; box-shadow:var(--shadow-sm); }
.logo-text { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--ink); letter-spacing:-0.01em; }
.logo-sub { font-size:10.5px; color:var(--ink3); margin-top:6px; margin-left:42px; }
.nav-group-label { padding:18px 20px 6px; font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--ink3); }
.nav-item { display:flex; align-items:center; gap:9px; padding:8px 12px; margin:1px 8px; border-radius:8px; cursor:pointer; font-size:13.5px; color:var(--ink2); transition:all 0.12s; user-select:none; }
.nav-item:hover { background:var(--bg); color:var(--ink); }
.nav-item.active { background:var(--ink); color:white; }
.nav-group-parent { display:flex; align-items:center; gap:9px; padding:8px 12px; margin:1px 8px; border-radius:8px; cursor:pointer; font-size:13.5px; font-weight:600; color:var(--ink2); transition:all 0.12s; user-select:none; }
.nav-group-parent:hover { background:var(--bg); color:var(--ink); }
.nav-group-parent.has-active { color:var(--ink); }
.nav-arrow { margin-left:auto; font-size:9px; color:var(--ink3); transition:transform 0.18s; flex-shrink:0; }
.nav-group-parent.open .nav-arrow { transform:rotate(90deg); }
.nav-sub-list { display:none; }
.nav-sub-list.open { display:block; }
.nav-sub-item { padding-left:28px !important; font-size:13px !important; }
.nav-wa-badge { margin-left:auto; background:#25d366; color:#fff; border-radius:999px; font-size:10px; padding:1px 6px; font-weight:700; }
.nav-group-parent { display:flex; align-items:center; gap:9px; padding:8px 12px; margin:1px 8px; border-radius:8px; cursor:pointer; font-size:13.5px; color:var(--ink2); transition:all 0.12s; user-select:none; font-weight:500; }
.nav-group-parent:hover { background:var(--bg); color:var(--ink); }
.nav-group-parent.has-active { color:var(--ink); background:var(--bg); }
.nav-arrow { margin-left:auto; font-size:9px; color:var(--ink3); transition:transform 0.18s; flex-shrink:0; display:inline-block; }
.nav-group-parent.open .nav-arrow { transform:rotate(90deg); }
.nav-sub-list { display:none; }
.nav-sub-list.open { display:block; }
.nav-sub-item { padding-left:28px !important; font-size:13px !important; }
.nav-wa-badge { margin-left:auto; background:#25d366; color:#fff; border-radius:999px; font-size:10px; padding:1px 6px; font-weight:700; }
.nav-icon { width:18px; text-align:center; font-size:14px; }
.sidebar-footer { margin-top:auto; padding:16px 20px; border-top:1px solid var(--border); }
.regime-badge { display:inline-flex; align-items:center; gap:6px; background:var(--bg2); border:1px solid var(--border); border-radius:20px; padding:4px 12px; font-size:11px; color:var(--ink2); }

/* MAIN */
.main { margin-left:232px; flex:1; display:flex; flex-direction:column; }
.topbar { background:var(--white); border-bottom:1px solid var(--border); padding:14px 28px; display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:50; }
.page-title { font-family:var(--font-display); font-size:19px; font-weight:600; color:var(--ink); letter-spacing:-0.02em; }
.topbar-right { display:flex; align-items:center; gap:10px; }

/* BUTTONS */
.btn { padding:7px 16px; border-radius:8px; font-family:var(--font); font-size:13px; font-weight:500; cursor:pointer; border:none; transition:all 0.12s; display:inline-flex; align-items:center; gap:6px; }
.btn-primary { background:var(--ink); color:white; }
.btn-primary:hover { background:#2d2c28; }
.btn-outline { background:transparent; border:1px solid var(--border2); color:var(--ink2); }
.btn-outline:hover { border-color:var(--ink2); color:var(--ink); }
.btn-sm { padding:5px 12px; font-size:12px; }
.btn-ghost { background:transparent; color:var(--ink2); }
.btn-ghost:hover { background:var(--bg); }

/* CONTENT */
.content { padding:24px 28px; flex:1; }
.page { display:none; }
.page.active { display:block; animation:fadeIn 0.2s ease; }
@keyframes fadeIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }

/* GRIDS */
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:20px; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin-bottom:20px; }

/* CARDS */
.card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow-sm); }
.card-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--ink3); margin-bottom:10px; }
.card-value { font-family:var(--font-mono); font-size:24px; font-weight:500; letter-spacing:-0.02em; color:var(--ink); }
.card-value.green { color:var(--emerald); }
.card-value.red { color:var(--red); }
.card-value.amber { color:var(--amber); }
.card-value.blue { color:var(--blue); }
.card-sub { font-size:11.5px; color:var(--ink3); margin-top:6px; }
.card-icon-row { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:6px; }
.card-badge { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:15px; }
.badge-green { background:var(--emerald-light); }
.badge-red { background:var(--red-light); }
.badge-amber { background:var(--amber-light); }
.badge-blue { background:var(--blue-light); }
.progress { height:3px; background:var(--bg2); border-radius:2px; margin-top:12px; overflow:hidden; }
.progress-fill { height:100%; border-radius:2px; }

/* ALERTS */
.alert { border-radius:var(--radius); padding:16px 20px; margin-bottom:20px; display:flex; gap:14px; align-items:flex-start; }
.alert-amber { background:var(--amber-light); border:1px solid #f5d48c; }
.alert-green { background:var(--emerald-light); border:1px solid var(--emerald-mid); }
.alert-icon { font-size:18px; flex-shrink:0; margin-top:1px; }
.alert-title { font-size:13px; font-weight:600; color:var(--ink); margin-bottom:3px; }
.alert-text { font-size:12.5px; color:var(--ink2); line-height:1.6; }

/* TABLE */
.table-wrap { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-sm); overflow:hidden; margin-bottom:20px; }
.table-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.table-title { font-size:13.5px; font-weight:600; color:var(--ink); }
table { width:100%; border-collapse:collapse; }
th { text-align:left; padding:10px 20px; font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.08em; color:var(--ink3); background:var(--bg); border-bottom:1px solid var(--border); }
td { padding:13px 20px; border-bottom:1px solid var(--border); color:var(--ink2); font-size:13px; vertical-align:middle; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--bg); }
.mono { font-family:var(--font-mono); font-size:13px; }

/* PILLS */
.pill { display:inline-flex; align-items:center; padding:2px 9px; border-radius:20px; font-size:11px; font-weight:500; white-space:nowrap; }
.pill-green { background:var(--emerald-light); color:var(--emerald); }
.pill-red { background:var(--red-light); color:var(--red); }
.pill-amber { background:var(--amber-light); color:var(--amber); }
.pill-blue { background:var(--blue-light); color:var(--blue); }
.pill-gray { background:var(--bg2); color:var(--ink3); }

/* SECTION */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.section-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--ink); letter-spacing:-0.01em; }

/* SAFE BOX */
.safe-box { background:var(--white); border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow); padding:36px; text-align:center; margin-bottom:20px; }
.safe-label { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; color:var(--ink3); margin-bottom:10px; }
.safe-amount { font-family:var(--font-display); font-size:56px; font-weight:600; color:var(--emerald); letter-spacing:-0.03em; line-height:1; margin-bottom:10px; }
.safe-desc { font-size:13px; color:var(--ink3); }

/* SETTINGS */
.settings-block { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-sm); margin-bottom:16px; overflow:hidden; }
.settings-head { padding:14px 20px; border-bottom:1px solid var(--border); font-size:13.5px; font-weight:600; color:var(--ink); display:flex; align-items:center; justify-content:space-between; background:var(--bg); }
.settings-body { padding:20px; }
.config-tabs { display:flex; gap:6px; flex-wrap:wrap; margin:14px 0 18px; padding:6px; background:var(--bg2); border:1px solid var(--border); border-radius:10px; }
.config-tab { border:1px solid transparent; background:transparent; color:var(--ink2); border-radius:8px; padding:8px 12px; font-size:12.5px; font-weight:650; cursor:pointer; }
.config-tab.active { background:var(--white); color:var(--ink); border-color:var(--border); box-shadow:var(--shadow-sm); }
/* Marketing tabs — pastel colors */
.mkt-tabs { background:#f5f3ff; border-color:#e2dcff; }
.mkt-tab-rel { color:#6d28d9; }
.mkt-tab-rel.active { background:#ede9fe; border-color:#c4b5fd; color:#5b21b6; }
.mkt-tab-leads { color:#065f46; }
.mkt-tab-leads.active { background:#d1fae5; border-color:#6ee7b7; color:#047857; }
.mkt-panel { border-radius:0 12px 12px 12px; padding:20px; margin-top:-1px; }
.mkt-panel-rel  { background:#f9f7ff; border:1px solid #e2dcff; }
.mkt-panel-leads { background:#f0fdf8; border:1px solid #a7f3d0; }
/* Conciliação menu tabs */
.concmenu-tabs { display:flex; gap:4px; flex-wrap:wrap; padding:6px; background:var(--bg2); border:1px solid var(--border); border-radius:10px; margin-bottom:0; }
.concmenu-tab  { border:1px solid transparent; background:transparent; color:var(--ink2); border-radius:7px; padding:7px 11px; font-size:12px; font-weight:600; cursor:pointer; white-space:nowrap; }
.concmenu-panel { padding:20px; border:1px solid var(--border); border-top:none; border-radius:0 0 12px 12px; }
.cm-tab-cu.active       { background:#dcfce7; border-color:#86efac; color:#166534; }
.cm-tab-banco.active    { background:#dbeafe; border-color:#93c5fd; color:#1e40af; }
.cm-tab-rede.active     { background:#ffedd5; border-color:#fdba74; color:#9a3412; }
.cm-tab-proj.active     { background:#e0e7ff; border-color:#a5b4fc; color:#3730a3; }
.cm-tab-fluxo.active    { background:#cffafe; border-color:#67e8f9; color:#155e75; }
.cm-tab-dre.active      { background:#f1f5f9; border-color:#cbd5e1; color:#334155; }
.cm-tab-impostos.active { background:#ffe4e6; border-color:#fda4af; color:#9f1239; }
.cm-tab-cartoes2.active { background:#fef9c3; border-color:#fcd34d; color:#854d0e; }
.cm-panel-cu       { background:#f0fdf4; border-color:#86efac; }
.cm-panel-banco    { background:#eff6ff; border-color:#93c5fd; }
.cm-panel-rede     { background:#fff7ed; border-color:#fdba74; }
.cm-panel-proj     { background:#eef2ff; border-color:#a5b4fc; }
.cm-panel-fluxo    { background:#ecfeff; border-color:#67e8f9; }
.cm-panel-dre      { background:#f8fafc; border-color:#cbd5e1; }
.cm-panel-impostos { background:#fff1f2; border-color:#fda4af; }
.cm-panel-cartoes2 { background:#fffbeb; border-color:#fcd34d; }
.agent-conciliacao-banner {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(133, 243, 170, .75);
  border-radius: 14px;
  padding: 12px 14px;
  margin-top: 14px;
}
.agent-conciliacao-banner .agent-icon {
  width: 92px;
  height: 92px;
  flex-shrink: 0;
  display: block;
  object-fit: contain;
}
.agent-conciliacao-banner-body {
  flex: 1;
  min-width: 0;
}
.agent-conciliacao-title {
  font-weight: 800;
  color: var(--ink);
  font-size: 14px;
  line-height: 1.25;
}
.agent-conciliacao-sub {
  font-size: 12px;
  color: var(--ink3);
  line-height: 1.5;
  margin-top: 3px;
}
.agent-conciliacao-pill {
  flex-shrink: 0;
  align-self: center;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--emerald-light);
  color: var(--emerald);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}
.agent-conciliacao-banner + .concmenu-panel {
  margin-top: 14px;
}
.agent-conciliacao-banner + .concmenu-panel.cm-panel-cu {
  margin-top: 14px;
}
.agent-conciliacao-banner + .concmenu-panel .cu-kpis {
  margin-top: 0;
}
.agent-conciliacao-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: rgba(255,255,255,.82);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px;
}
.agent-conciliacao-card .agent-icon {
  width: 92px;
  height: 92px;
  flex-shrink: 0;
  display: block;
  object-fit: contain;
}
.ai-config-row { display:grid; grid-template-columns:1.2fr 160px 1fr; gap:10px; align-items:end; padding:12px 0; border-bottom:1px solid var(--border); }
.ai-config-row:last-child { border-bottom:none; }
.ai-task-title { font-size:13px; font-weight:650; color:var(--ink); }
.ai-task-desc { font-size:11.5px; color:var(--ink3); margin-top:3px; line-height:1.45; }
.fields-row { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.taxa-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:1px; background:var(--border); }
.taxa-cell { background:var(--white); padding:12px 16px; display:flex; align-items:center; justify-content:space-between; }
.taxa-label { font-size:12.5px; color:var(--ink2); }
.taxa-input { width:74px; background:var(--bg); border:1px solid var(--border2); border-radius:6px; padding:4px 8px; color:var(--emerald); font-family:var(--font-mono); font-size:12.5px; text-align:right; transition:border-color 0.12s; }
.taxa-input:focus { outline:none; border-color:var(--ink); }

/* FORM */
.form-group { margin-bottom:14px; }
.form-label { display:block; font-size:11.5px; font-weight:600; color:var(--ink2); margin-bottom:5px; text-transform:uppercase; letter-spacing:0.05em; }
.form-control { width:100%; background:var(--bg); border:1px solid var(--border2); border-radius:8px; padding:9px 12px; color:var(--ink); font-family:var(--font); font-size:13.5px; transition:all 0.12s; }
.form-control:focus { outline:none; border-color:var(--ink); background:var(--white); box-shadow:0 0 0 3px rgba(26,25,21,0.06); }
.form-control option { background:white; }
.form-control[readonly] { color:var(--ink2); cursor:default; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }

/* UPLOAD ZONE */
.upload-zone { border:1.5px dashed var(--border2); border-radius:10px; padding:20px 16px; text-align:center; cursor:pointer; transition:all 0.15s; background:var(--bg); position:relative; min-height:110px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.upload-zone:hover { border-color:var(--ink2); background:var(--bg2); }
.upload-zone.has-file { border-style:solid; border-color:var(--emerald); background:var(--emerald-light); }
.upload-zone input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; z-index:2; }
.upload-icon { font-size:24px; margin-bottom:6px; }
.upload-text { font-size:12px; color:var(--ink2); line-height:1.5; }
.upload-text strong { color:var(--ink); display:block; font-size:12.5px; margin-bottom:2px; }
.upload-preview { width:100%; max-height:100px; object-fit:contain; border-radius:6px; margin-top:8px; display:none; z-index:1; }
.upload-filename { font-size:11.5px; color:var(--emerald); font-weight:500; margin-top:6px; display:none; z-index:1; }
.upload-clear { position:absolute; top:8px; right:8px; background:var(--white); border:1px solid var(--border2); border-radius:6px; padding:2px 7px; font-size:11px; color:var(--ink2); cursor:pointer; z-index:3; display:none; }
.upload-zone.has-file .upload-clear { display:block; }

/* MODAL */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(26,25,21,0.45); backdrop-filter:blur(4px); z-index:1000; align-items:center; justify-content:center; padding:20px; }
.modal-overlay.open { display:flex; }
.modal { background:var(--white); border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow-lg); width:580px; max-width:100%; max-height:90vh; overflow-y:auto; }
.modal-head { padding:22px 24px 16px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--white); z-index:1; }
.modal-title { font-family:var(--font-display); font-size:20px; font-weight:600; letter-spacing:-0.02em; color:var(--ink); }
.modal-subtitle { font-size:12.5px; color:var(--ink3); margin-top:2px; }
.modal-body { padding:20px 24px; }
.modal-section { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--ink3); padding:14px 0 10px; border-top:1px solid var(--border); margin-top:6px; }
.modal-section:first-child { border-top:none; padding-top:0; margin-top:0; }
.modal-footer { padding:16px 24px; border-top:1px solid var(--border); display:flex; justify-content:flex-end; gap:10px; background:var(--bg); border-radius:0 0 16px 16px; position:sticky; bottom:0; }

/* BAR CHART */
.bar-chart { display:flex; align-items:flex-end; gap:10px; height:90px; }
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:5px; height:100%; justify-content:flex-end; }
.bar-fill { width:100%; border-radius:4px 4px 0 0; }
.bar-lbl { font-size:10px; color:var(--ink3); }

/* DRE */
.dre-row-highlight td { background:var(--bg); font-weight:600; color:var(--ink); }
.dre-row-total td { background:var(--emerald-light); font-weight:700; color:var(--emerald); border-top:2px solid var(--emerald-mid) !important; }
.dre-row-sub td { color:var(--ink3); font-size:12.5px; }
.dre-row-sub td:first-child { padding-left:36px; }

/* TOAST */
#toast { position:fixed; bottom:24px; right:24px; background:var(--ink); color:white; padding:12px 18px; border-radius:10px; font-size:13px; font-weight:500; display:none; z-index:9999; box-shadow:var(--shadow-lg); }

::-webkit-scrollbar { width:5px; }
.sidebar::-webkit-scrollbar { width:4px; }
.sidebar::-webkit-scrollbar-track { background:transparent; }
.sidebar::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }
.empty-state { text-align:center; padding:36px; color:var(--ink3); font-size:13px; }

/* CONTAS */
.conta-item { display:flex; align-items:center; gap:12px; padding:14px 16px; border-bottom:1px solid var(--border); transition:background 0.1s; }
.conta-item:last-child { border-bottom:none; }
.conta-item:hover { background:var(--bg); }
.conta-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }
.conta-info { flex:1; min-width:0; }
.conta-nome { font-size:13.5px; font-weight:500; color:var(--ink); }
.conta-detalhe { font-size:12px; color:var(--ink3); margin-top:1px; }
.conta-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.conta-padrao-badge { display:inline-flex; align-items:center; gap:4px; padding:2px 8px; border-radius:20px; font-size:11px; font-weight:600; background:var(--emerald-light); color:var(--emerald); border:1px solid var(--emerald-mid); }
.btn-icon { width:28px; height:28px; border-radius:6px; border:1px solid var(--border2); background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:13px; color:var(--ink2); transition:all 0.12s; }
.btn-icon:hover { border-color:var(--red); color:var(--red); background:var(--red-light); }
.btn-icon.edit:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-light); }
.row-actions { display:flex; align-items:center; justify-content:flex-end; gap:6px; white-space:nowrap; }
.action-icon { width:28px; height:28px; border-radius:7px; border:1px solid var(--border2); background:var(--white); color:var(--ink2); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; font-size:14px; line-height:1; transition:all .12s; padding:0; }
.action-icon:hover { transform:translateY(-1px); box-shadow:var(--shadow-sm); }
.action-icon.edit:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-light); }
.action-icon.delete:hover { border-color:#f5c6c0; color:var(--red); background:var(--red-light); }
.action-icon.expand { background:var(--bg); color:var(--ink3); }
.action-icon.expand:hover { border-color:var(--ink2); color:var(--ink); background:var(--white); }
.conta-option { display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius:8px; border:1.5px solid var(--border2); cursor:pointer; transition:all 0.12s; background:var(--bg); margin-bottom:6px; }
.conta-option:hover { border-color:var(--ink2); background:var(--white); }
.conta-option.selected { border-color:var(--emerald); background:var(--emerald-light); }
.conta-option input[type=radio] { accent-color:var(--emerald); width:15px; height:15px; flex-shrink:0; }
.conta-option-info { flex:1; }
.conta-option-nome { font-size:13px; font-weight:500; color:var(--ink); display:flex; align-items:center; gap:6px; }
.conta-option-detalhe { font-size:11.5px; color:var(--ink3); margin-top:1px; }
.pj-tag { background:var(--blue-light); color:var(--blue); font-size:10px; padding:1px 6px; border-radius:4px; font-weight:600; }
.pf-tag { background:var(--amber-light); color:var(--amber); font-size:10px; padding:1px 6px; border-radius:4px; font-weight:600; }

/* ── CONCILIAÇÃO ── */
.concil-upload { border:2px dashed var(--border2); border-radius:14px; padding:40px 24px; text-align:center; cursor:pointer; transition:all 0.18s; background:var(--white); position:relative; }
.concil-upload:hover { border-color:var(--ink2); background:var(--bg); }
.concil-upload.active { border-color:var(--emerald); border-style:solid; background:var(--emerald-light); }
.concil-upload input[type=file] { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }
.concil-upload-icon { font-size:36px; margin-bottom:10px; }
.concil-upload-title { font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--ink);margin-bottom:6px; }
.concil-upload-sub { font-size:13px;color:var(--ink2);line-height:1.6; }

/* Status geral */
.concil-status-bar { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.cstat { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:16px 18px; }
.cstat-label { font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:6px; }
.cstat-val { font-family:var(--font-mono); font-size:22px; font-weight:500; }

/* Linha de conciliação */
.concil-row { display:grid; grid-template-columns:120px 1fr 110px 90px 32px; gap:0; align-items:stretch; border-bottom:1px solid var(--border); transition:background .1s; }
.concil-row:last-child { border-bottom:none; }
.concil-row:hover { background:var(--bg); }
.concil-cell { padding:11px 14px; font-size:13px; color:var(--ink2); display:flex; align-items:center; border-right:1px solid var(--border); }
.concil-cell:last-child { border-right:none; justify-content:center; }
.concil-cell.date { font-family:var(--font-mono); font-size:12px; color:var(--ink3); }
.concil-cell.valor { font-family:var(--font-mono); font-size:13px; }
.concil-cell.status { justify-content:center; }

/* Status badges */
.badge-concil { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:20px; font-size:11px; font-weight:600; white-space:nowrap; }
.badge-ok       { background:#e8f5ee; color:#1a6b4a; }
.badge-sem-lanc { background:#fef7ea; color:#b7690a; }
.badge-sem-ext  { background:#fdf0ee; color:#c0392b; }
.badge-diverge  { background:#eaf2fc; color:#1a5a9a; }

/* Painel lado a lado */
.concil-pair { display:grid; grid-template-columns:1fr 24px 1fr; gap:0; border-bottom:1px solid var(--border); align-items:stretch; }
.concil-pair:last-child { border-bottom:none; }
.concil-pair:hover .concil-side { background:var(--bg); }
.concil-side { padding:12px 16px; font-size:13px; }
.concil-divider-col { display:flex; align-items:center; justify-content:center; background:var(--bg2); font-size:14px; color:var(--ink3); border-left:1px solid var(--border); border-right:1px solid var(--border); }
.concil-side.ok     { background:rgba(26,107,74,.03); }
.concil-side.warn   { background:rgba(183,105,10,.04); }
.concil-side.error  { background:rgba(192,57,43,.04); }
.concil-side-label  { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:4px; }
.concil-side-desc   { color:var(--ink); font-weight:500; margin-bottom:2px; }
.concil-side-meta   { font-size:11.5px; color:var(--ink3); }
.concil-side-valor  { font-family:var(--font-mono); font-size:13px; margin-top:4px; }

/* Tabs conciliação */
.concil-tabs { display:flex; gap:2px; background:var(--bg2); border-radius:8px; padding:3px; margin-bottom:16px; }
.concil-tab { flex:1; padding:7px 12px; border-radius:6px; font-size:13px; font-weight:500; border:none; cursor:pointer; background:transparent; color:var(--ink2); transition:all .12s; text-align:center; }
.concil-tab.active { background:var(--white); color:var(--ink); box-shadow:var(--shadow-sm); }

/* Loading spinner conciliação */
.concil-loading { text-align:center; padding:48px 24px; }
.concil-spinner { width:36px; height:36px; border:3px solid var(--border2); border-top-color:var(--emerald); border-radius:50%; animation:spin 0.8s linear infinite; margin:0 auto 14px; }
@keyframes spin { to { transform:rotate(360deg); } }

/* Filtro chip */
.filter-chips { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.chip { padding:4px 12px; border-radius:20px; font-size:12px; font-weight:500; cursor:pointer; border:1.5px solid var(--border2); background:var(--white); color:var(--ink2); transition:all .12s; }
.chip:hover { border-color:var(--ink2); }
.chip.active { background:var(--ink); color:white; border-color:var(--ink); }
.chip.chip-amber.active { background:var(--amber); border-color:var(--amber); }
.chip.chip-red.active   { background:var(--red);   border-color:var(--red);   }
.chip.chip-blue.active  { background:var(--blue);  border-color:var(--blue);  }
.chip.chip-green.active { background:var(--emerald);border-color:var(--emerald);}


/* ═══ REDE CONCILIAÇÃO ═══ */
.rede-hero { background:linear-gradient(135deg,#1a1915 0%,#2d2c28 100%); border-radius:14px; padding:28px 28px 24px; margin-bottom:20px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.rede-hero-left h2 { font-family:var(--font-display); font-size:22px; font-weight:600; color:white; margin-bottom:4px; }
.rede-hero-left p  { font-size:13px; color:rgba(255,255,255,.55); }
.rede-badge { background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); border-radius:8px; padding:8px 16px; font-size:12px; color:rgba(255,255,255,.7); display:flex; align-items:center; gap:8px; }
.rede-badge strong { color:white; }

/* Upload REDE */
.rede-upload-zone { border:2px dashed #d4d2cb; border-radius:14px; padding:44px 28px; text-align:center; cursor:pointer; transition:all .18s; background:#fff; position:relative; }
.rede-upload-zone:hover  { border-color:#5a5850; background:#f7f6f3; }
.rede-upload-zone.active { border-color:#1a6b4a; border-style:solid; background:#e8f5ee; }
.rede-upload-zone input  { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }

/* Tabs REDE */
.rede-tabs { display:flex; gap:2px; background:#efeee9; border-radius:8px; padding:3px; margin-bottom:16px; }
.rede-tab  { flex:1; padding:7px 10px; border-radius:6px; font-size:12.5px; font-weight:500; border:none; cursor:pointer; background:transparent; color:#5a5850; transition:all .12s; text-align:center; }
.rede-tab.active { background:#fff; color:#1a1915; box-shadow:0 1px 3px rgba(0,0,0,.06); }

/* Resumo diário */
.rede-day { border-bottom:1px solid var(--border); }
.rede-day:last-child { border-bottom:none; }
.rede-day-header { display:grid; grid-template-columns:110px 1fr repeat(4,100px) 90px; gap:0; align-items:center; padding:0; cursor:pointer; transition:background .1s; }
.rede-day-header:hover { background:var(--bg); }
.rede-day-cell { padding:12px 14px; font-size:13px; color:var(--ink2); border-right:1px solid var(--border); }
.rede-day-cell:last-child { border-right:none; text-align:center; }
.rede-day-cell.date { font-family:var(--font-mono); font-size:12px; color:var(--ink3); font-weight:500; }
.rede-day-cell.mono { font-family:var(--font-mono); }
.rede-day-body { display:none; border-top:1px solid var(--border); background:var(--bg); }
.rede-day-body.open { display:block; }
.rede-txn { display:grid; grid-template-columns:110px 1fr 120px 100px 100px 100px 90px; gap:0; border-bottom:1px solid var(--border); }
.rede-txn:last-child { border-bottom:none; }
.rede-txn-cell { padding:9px 14px; font-size:12.5px; color:var(--ink2); border-right:1px solid var(--border); }
.rede-txn-cell:last-child { border-right:none; text-align:center; }
.rede-txn-cell.mono { font-family:var(--font-mono); font-size:12px; }

/* Status REDE */
.rs-ok      { background:#e8f5ee; color:#1a6b4a; }
.rs-warn    { background:#fef7ea; color:#b7690a; }
.rs-err     { background:#fdf0ee; color:#c0392b; }
.rs-div     { background:#eaf2fc; color:#1a5a9a; }
.rs-pend    { background:#efeee9; color:#5a5850; }

/* Kpis REDE */
.rede-kpis { display:grid; grid-template-columns:repeat(5,1fr); gap:12px; margin-bottom:20px; }
.rede-kpi  { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:14px 16px; }
.rede-kpi-label { font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:6px; }
.rede-kpi-val   { font-family:var(--font-mono); font-size:19px; font-weight:500; }

/* Timeline de depósitos */
.dep-row { display:grid; grid-template-columns:100px 1fr 110px 110px 110px 90px; gap:0; border-bottom:1px solid var(--border); }
.dep-row:last-child { border-bottom:none; }
.dep-row:hover > div { background:var(--bg); }
.dep-cell { padding:11px 14px; font-size:13px; color:var(--ink2); border-right:1px solid var(--border); display:flex; align-items:center; }
.dep-cell:last-child { border-right:none; justify-content:center; }
.dep-cell.mono { font-family:var(--font-mono); font-size:12.5px; }

/* Divergência detalhe */
.div-detail { background:var(--amber-light); border:1px solid #f5d48c; border-radius:8px; padding:12px 16px; font-size:12.5px; color:var(--amber); margin:2px 14px 10px; }
.div-detail strong { color:var(--ink); }

/* Toggle chevron */
.chevron { transition:transform .2s; display:inline-block; }
.chevron.open { transform:rotate(180deg); }

/* Spinner REDE */
.rede-spinner { width:32px; height:32px; border:3px solid var(--border2); border-top-color:var(--ink); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto 12px; }


/* ═══ TAXAS CONTRATUAIS REDE ═══ */
.rede-contract-table { width:100%; border-collapse:collapse; font-size:13px; }
.rede-contract-table th { background:var(--bg2); padding:9px 14px; text-align:left; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); border-bottom:1px solid var(--border); white-space:nowrap; }
.rede-contract-table td { padding:0; border-bottom:1px solid var(--border); vertical-align:middle; }
.rede-contract-table tr:last-child td { border-bottom:none; }
.rede-contract-table tr:hover td { background:var(--bg); }
.rede-contract-table .td-inner { padding:10px 14px; display:flex; align-items:center; }
.rede-contract-table .td-right { text-align:right; }
.ctr-input { width:70px; background:var(--bg); border:1px solid var(--border2); border-radius:6px; padding:5px 8px; color:var(--emerald); font-family:var(--font-mono); font-size:12.5px; text-align:right; transition:border-color .12s; }
.ctr-input:focus { outline:none; border-color:var(--ink); background:var(--white); }
.ctr-prazo { width:130px; background:var(--bg); border:1px solid var(--border2); border-radius:6px; padding:5px 8px; color:var(--ink2); font-family:var(--font); font-size:12.5px; transition:border-color .12s; }
.ctr-prazo:focus { outline:none; border-color:var(--ink); background:var(--white); }
.group-header td { background:var(--ink); padding:0; }
.group-header .td-inner { color:white; font-weight:600; font-size:12px; padding:8px 14px; }
.prazo-badge { display:inline-flex; align-items:center; padding:2px 8px; border-radius:20px; font-size:11px; font-weight:500; background:var(--blue-light); color:var(--blue); white-space:nowrap; }
.rede-contract-table .add-row-btn { display:flex; align-items:center; gap:6px; padding:9px 14px; cursor:pointer; color:var(--ink3); font-size:12.5px; transition:color .12s; border-top:1px dashed var(--border2); }
.rede-contract-table .add-row-btn:hover { color:var(--emerald); }


/* ═══ AGENDA DE RECEBÍVEIS ═══ */
.recv-venda-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:12px; margin-bottom:12px; overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.recv-venda-header {
  display:grid; grid-template-columns:100px 1fr 90px 90px 90px 100px 90px 36px;
  background:var(--bg); border-bottom:1px solid var(--border);
  cursor:pointer; transition:background .1s;
}
.recv-venda-header:hover { background:var(--bg2); }
.recv-venda-cell {
  padding:12px 14px; font-size:13px; color:var(--ink2);
  border-right:1px solid var(--border); display:flex; align-items:center;
}
.recv-venda-cell:last-child { border-right:none; justify-content:center; }
.recv-venda-cell.mono { font-family:var(--font-mono); font-size:12.5px; }

.recv-parcelas-body { display:none; }
.recv-parcelas-body.open { display:block; }

.recv-parc-row {
  display:grid; grid-template-columns:100px 1fr 90px 90px 90px 100px 90px 36px;
  border-top:1px solid var(--border); transition:background .1s;
}
.recv-parc-row:hover { background:var(--bg); }
.recv-parc-cell {
  padding:10px 14px; font-size:12.5px; color:var(--ink2);
  border-right:1px solid var(--border); display:flex; align-items:center;
}
.recv-parc-cell:last-child { border-right:none; justify-content:center; }
.recv-parc-cell.mono { font-family:var(--font-mono); font-size:12px; }
.recv-parc-cell.num  { color:var(--ink3); font-family:var(--font-mono); font-size:12px; }

/* Status parcela */
.sp-pend   { background:var(--bg2);        color:var(--ink3);    }
.sp-prox   { background:var(--amber-light); color:var(--amber);   }
.sp-rec    { background:var(--emerald-light);color:var(--emerald);}
.sp-atraso { background:var(--red-light);   color:var(--red);     }

/* Timeline gráfica */
.recv-timeline {
  display:flex; gap:0; align-items:stretch;
  border:1px solid var(--border); border-radius:10px; overflow:hidden;
  margin-bottom:20px; background:var(--white);
}
.recv-tl-item {
  flex:1; padding:12px 10px; text-align:center; border-right:1px solid var(--border);
  position:relative; transition:background .1s;
}
.recv-tl-item:last-child { border-right:none; }
.recv-tl-item.tl-pend    { background:var(--white); }
.recv-tl-item.tl-prox    { background:var(--amber-light); }
.recv-tl-item.tl-rec     { background:var(--emerald-light); }
.recv-tl-item.tl-atraso  { background:var(--red-light); }
.recv-tl-mes  { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--ink3); margin-bottom:4px; }
.recv-tl-val  { font-family:var(--font-mono); font-size:12.5px; font-weight:500; }
.recv-tl-cnt  { font-size:10px; color:var(--ink3); margin-top:2px; }

/* KPIs recebíveis */
.recv-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }
.recv-kpi  { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:16px 18px; }
.recv-kpi-label { font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:6px; }
.recv-kpi-val   { font-family:var(--font-mono); font-size:22px; font-weight:500; }

/* Filtros */
.recv-filters { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; align-items:center; }
.recv-filter-chip { padding:5px 14px; border-radius:20px; font-size:12px; font-weight:500; cursor:pointer; border:1.5px solid var(--border2); background:var(--white); color:var(--ink2); transition:all .12s; }
.recv-filter-chip:hover { border-color:var(--ink2); }
.recv-filter-chip.active { background:var(--ink); color:white; border-color:var(--ink); }
.recv-filter-chip.chip-green.active  { background:var(--emerald); border-color:var(--emerald); }
.recv-filter-chip.chip-amber.active  { background:var(--amber);   border-color:var(--amber); }
.recv-filter-chip.chip-red.active    { background:var(--red);     border-color:var(--red); }

/* Botão marcar recebido */
.btn-recv { padding:3px 10px; border-radius:6px; font-size:11px; font-weight:600; cursor:pointer; border:1.5px solid var(--emerald-mid); background:var(--emerald-light); color:var(--emerald); transition:all .12s; }
.btn-recv:hover { background:var(--emerald); color:white; border-color:var(--emerald); }
.btn-recv.recebido { background:var(--bg2); color:var(--ink3); border-color:var(--border2); cursor:default; }


/* ═══ PROJEÇÃO DE CAIXA 90 DIAS ═══ */
.proj-hero {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  margin-bottom: 20px;
  box-shadow: var(--shadow-sm);
}
.proj-hero-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 20px;
}
.proj-hero-left h2 {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 4px;
}
.proj-hero-left p { font-size: 12.5px; color: var(--ink3); }

/* Chart container */
.proj-chart-wrap {
  position: relative;
  width: 100%;
  height: 260px;
  margin-bottom: 8px;
}
.proj-canvas { width: 100% !important; height: 100% !important; }

/* Legenda */
.proj-legend {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  margin-top: 12px;
}
.proj-legend-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--ink2);
}
.proj-legend-dot {
  width: 10px; height: 10px; border-radius: 2px; flex-shrink: 0;
}

/* KPIs projeção */
.proj-kpis {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.proj-kpi {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
}
.proj-kpi-label {
  font-size: 10.5px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--ink3); margin-bottom: 6px;
}
.proj-kpi-val { font-family: var(--font-mono); font-size: 18px; font-weight: 500; }
.proj-kpi-sub { font-size: 11px; color: var(--ink3); margin-top: 4px; }

/* Zona de risco no gráfico */
.proj-risk-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 600;
}
.proj-risk-ok     { background: var(--emerald-light); color: var(--emerald); }
.proj-risk-alert  { background: var(--amber-light);   color: var(--amber); }
.proj-risk-danger { background: var(--red-light);      color: var(--red); }

/* Simulador */
.proj-sim {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 20px;
}
.proj-sim-title {
  font-size: 13.5px; font-weight: 600; color: var(--ink);
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.proj-sim-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 16px;
}
.proj-sim-field label {
  display: block; font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--ink3); margin-bottom: 5px;
}
.proj-sim-result {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.proj-sim-res-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  text-align: center;
}
.proj-sim-res-label { font-size: 10.5px; color: var(--ink3); margin-bottom: 4px; text-transform: uppercase; letter-spacing: .06em; }
.proj-sim-res-val   { font-family: var(--font-mono); font-size: 15px; font-weight: 500; }

/* Timeline tabela */
.proj-table-wrap {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 20px;
}
.proj-row {
  display: grid;
  grid-template-columns: 90px 90px 1fr 110px 110px 120px 110px;
  border-bottom: 1px solid var(--border);
  transition: background .1s;
}
.proj-row:last-child { border-bottom: none; }
.proj-row:hover { background: var(--bg); }
.proj-row.header { background: var(--bg2); }
.proj-row.week-sep { background: rgba(26,107,74,.03); border-top: 2px solid var(--emerald-mid); }
.proj-row.danger-row { background: rgba(192,57,43,.04); }
.proj-row.alert-row  { background: rgba(183,105,10,.04); }
.proj-cell {
  padding: 10px 13px;
  font-size: 12.5px;
  color: var(--ink2);
  border-right: 1px solid var(--border);
  display: flex;
  align-items: center;
}
.proj-cell:last-child { border-right: none; }
.proj-cell.mono { font-family: var(--font-mono); font-size: 12px; }
.proj-cell.head {
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; color: var(--ink3);
}

/* Slider antecipação */
.proj-slider {
  width: 100%;
  accent-color: var(--emerald);
  cursor: pointer;
}

/* Tabs projeção */
.proj-tabs {
  display: flex; gap: 2px; background: var(--bg2);
  border-radius: 8px; padding: 3px; margin-bottom: 16px;
}
.proj-tab {
  flex: 1; padding: 7px 12px; border-radius: 6px;
  font-size: 13px; font-weight: 500; border: none;
  cursor: pointer; background: transparent;
  color: var(--ink2); transition: all .12s; text-align: center;
}
.proj-tab.active {
  background: var(--white); color: var(--ink);
  box-shadow: var(--shadow-sm);
}

/* Saldo badge inline */
.saldo-ok     { color: var(--emerald); }
.saldo-alert  { color: var(--amber); }
.saldo-danger { color: var(--red); font-weight: 600; }


/* ═══ ATENDIMENTOS ═══ */
.at-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:12px; margin-bottom:12px;
  box-shadow:var(--shadow-sm); overflow:hidden;
}
.at-header {
  display:grid;
  grid-template-columns:100px 1fr 110px 110px 120px 110px 112px;
  cursor:pointer; transition:background .1s;
}
.at-header:hover { background:var(--bg); }
.at-cell {
  padding:13px 14px; font-size:13px; color:var(--ink2);
  border-right:1px solid var(--border); display:flex; align-items:center;
}
.at-cell:last-child { border-right:none; justify-content:center; }
.at-cell.mono { font-family:var(--font-mono); font-size:12.5px; }

/* Status do atendimento */
.ats-pendente  { background:#efeee9; color:#5a5850; }
.ats-parcial   { background:#fef7ea; color:#b7690a; }
.ats-quitado   { background:#e8f5ee; color:#1a6b4a; }
.ats-cancelado { background:#fdf0ee; color:#c0392b; }

/* Corpo expandido */
.at-body { display:none; border-top:1px solid var(--border); }
.at-body.open { display:block; }

/* Barra de progresso de pagamento */
.at-progress-wrap { padding:14px 16px; background:var(--bg); border-bottom:1px solid var(--border); }
.at-progress-bar  { height:6px; background:var(--border2); border-radius:3px; overflow:hidden; margin-top:6px; }
.at-progress-fill { height:100%; border-radius:3px; background:var(--emerald); transition:width .4s; }
.at-progress-info { display:flex; justify-content:space-between; align-items:center; }
.at-progress-pct  { font-family:var(--font-mono); font-size:13px; font-weight:600; color:var(--emerald); }

/* Lista de pagamentos */
.at-pgto {
  display:grid;
  grid-template-columns:100px 140px 80px 90px 90px 110px 100px 80px;
  border-top:1px solid var(--border);
  transition:background .1s;
}
.at-pgto:hover { background:var(--bg); }
.at-pgto-cell {
  padding:10px 14px; font-size:12.5px; color:var(--ink2);
  border-right:1px solid var(--border); display:flex; align-items:center;
}
.at-pgto-cell:last-child { border-right:none; justify-content:center; }
.at-pgto-cell.mono { font-family:var(--font-mono); font-size:12px; }

/* Botão add pagamento */
.at-add-pgto {
  display:flex; align-items:center; gap:8px;
  padding:12px 16px; cursor:pointer; color:var(--ink3);
  font-size:13px; border-top:1px dashed var(--border2);
  transition:all .12s; background:var(--bg);
}
.at-add-pgto:hover { color:var(--emerald); background:var(--emerald-light); }

/* KPIs atendimentos */
.at-kpis { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:20px; }

/* Modal de pagamento — menor */
.modal-sm { width:460px; }

/* Resumo sinal */
.sinal-tag {
  display:inline-flex; align-items:center; gap:4px;
  background:var(--amber-light); color:var(--amber);
  border:1px solid #f5d48c; border-radius:20px;
  padding:2px 9px; font-size:11px; font-weight:600;
}

/* Modal atendimento — seção pagamentos inline */
.pgto-inline-list { margin-top:10px; }
.pgto-inline-item {
  display:grid; grid-template-columns:1fr 100px 36px;
  gap:8px; align-items:center;
  padding:8px 0; border-bottom:1px solid var(--border);
}
.pgto-inline-item:last-child { border-bottom:none; }

/* Divider seção */
.modal-divider {
  border:none; border-top:1px solid var(--border);
  margin:16px 0 12px;
}


/* ═══ EDITOR DE CATEGORIAS ═══ */
.cat-col {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}
.cat-col-head {
  padding: 14px 16px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cat-col-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
}
.cat-group-block {
  border-bottom: 1px solid var(--border);
}
.cat-group-block:last-child { border-bottom: none; }
.cat-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 10px 12px;
  background: var(--bg);
  cursor: pointer;
  user-select: none;
  transition: background .1s;
}
.cat-group-header:hover { background: var(--bg2); }
.cat-group-name {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--ink2);
  display: flex;
  align-items: center;
  gap: 7px;
}
.cat-group-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--emerald);
  flex-shrink: 0;
}
.cat-group-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}
.cat-items-wrap { display: block; }
.cat-items-wrap.collapsed { display: none; }
.cat-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px 8px 28px;
  border-top: 1px solid var(--border);
  transition: background .1s;
  group: true;
}
.cat-item:hover { background: var(--bg); }
.cat-item-drag {
  color: var(--ink3);
  cursor: grab;
  font-size: 14px;
  flex-shrink: 0;
  opacity: .4;
}
.cat-item:hover .cat-item-drag { opacity: .8; }
.cat-item-input {
  flex: 1;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 4px 8px;
  font-family: var(--font);
  font-size: 13px;
  color: var(--ink);
  background: transparent;
  transition: all .12s;
}
.cat-item-input:hover { background: var(--white); border-color: var(--border2); }
.cat-item-input:focus { outline: none; background: var(--white); border-color: var(--emerald); box-shadow: 0 0 0 3px rgba(26,107,74,.06); }
.cat-item-del {
  width: 24px; height: 24px;
  border-radius: 6px;
  border: none;
  background: transparent;
  color: var(--ink3);
  cursor: pointer;
  font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: all .12s;
  flex-shrink: 0;
}
.cat-item:hover .cat-item-del { opacity: 1; }
.cat-item-del:hover { background: var(--red-light); color: var(--red); }

/* Linha de adicionar item */
.cat-add-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px 7px 28px;
  border-top: 1px dashed var(--border2);
  cursor: pointer;
  color: var(--ink3);
  font-size: 12.5px;
  transition: all .12s;
}
.cat-add-item:hover { color: var(--emerald); background: var(--emerald-light); }

/* Linha de adicionar grupo */
.cat-add-group {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 14px;
  cursor: pointer;
  color: var(--ink3);
  font-size: 12.5px;
  border-top: 1px dashed var(--border2);
  transition: all .12s;
  margin-top: auto;
}
.cat-add-group:hover { color: var(--emerald); background: var(--emerald-light); }

/* Layout duas colunas */
.cat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
}

/* Cor do grupo */
.cat-group-color-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all .12s;
  flex-shrink: 0;
}
.cat-group-color-dot:hover { transform: scale(1.3); }


/* ═══ IMPORTADOR (embutido) ═══ */
.imp-steps { display:flex; align-items:center; gap:0; margin-bottom:28px; }
.imp-step  { display:flex; align-items:center; gap:10px; flex:1; }
.imp-snum  { width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0;transition:all .3s; }
.imp-snum.done    { background:var(--emerald); color:white; }
.imp-snum.active  { background:var(--ink);     color:white; }
.imp-snum.pending { background:var(--bg2); color:var(--ink3); border:1px solid var(--border2); }
.imp-slbl         { font-size:12.5px;font-weight:500;color:var(--ink2); }
.imp-slbl.active  { color:var(--ink);font-weight:600; }
.imp-slbl.pending { color:var(--ink3); }
.imp-conn         { height:1px;background:var(--border2);flex:1;margin:0 12px; }
.imp-conn.done    { background:var(--emerald); }

.imp-drop {
  border:2px dashed var(--border2); border-radius:14px;
  padding:48px 28px; text-align:center; cursor:pointer;
  transition:all .18s; background:var(--white); position:relative;
}
.imp-drop:hover, .imp-drop.drag { border-color:var(--ink); background:var(--bg); }
.imp-drop.has-file { border-style:solid; border-color:var(--emerald); background:var(--emerald-light); }
.imp-drop input[type=file] { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%; }

.imp-sheet-tab { padding:5px 13px; border-radius:6px; font-size:12.5px; cursor:pointer; border:1px solid var(--border2); background:var(--bg); color:var(--ink2); transition:all .12s; }
.imp-sheet-tab.active { background:var(--ink); color:white; border-color:var(--ink); }
.imp-table-scroll { overflow-x:auto; border:1px solid var(--border); border-radius:8px; max-height:220px; overflow-y:auto; }

.imp-ai-box { background:var(--white);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:24px; }
.imp-spinner { width:36px;height:36px;border:3px solid var(--border2);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px; }
.imp-log { background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:12px 14px;font-family:var(--font-mono);font-size:12px;color:var(--ink2);min-height:56px;max-height:110px;overflow-y:auto;line-height:1.8; }

.imp-summary-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px; }
.imp-summary-card { background:var(--white);border:1px solid var(--border);border-radius:10px;padding:14px 16px; }
.imp-summary-label { font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3);margin-bottom:5px; }
.imp-summary-val   { font-family:var(--font-mono);font-size:18px;font-weight:500; }

.imp-tab-bar { display:flex;gap:2px;background:var(--bg2);border-radius:8px;padding:3px;margin-bottom:14px; }
.imp-tab-btn { flex:1;padding:7px;border-radius:6px;font-size:13px;font-weight:500;border:none;cursor:pointer;background:transparent;color:var(--ink2);transition:all .12s; }
.imp-tab-btn.active { background:var(--white);color:var(--ink);box-shadow:var(--shadow-sm); }

.imp-result-card { background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:6px;overflow:hidden; }
.imp-result-row { display:grid;padding:11px 14px;gap:8px;align-items:center;font-size:13px; }
.imp-rec-row  { grid-template-columns:90px 1fr 110px 60px 100px 90px 80px; }
.imp-desp-row { grid-template-columns:90px 1fr 160px 100px; }
.imp-result-row.imp-header { background:var(--bg2);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink3); }
.imp-result-row:not(.imp-header):hover { background:var(--white); }

.imp-hidden { display:none !important; }


/* ═══ MODAL APAGAR DADOS ═══ */
.danger-modal { border-top: 4px solid var(--red); }
.danger-steps-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 16px 0;
}
.danger-step {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1.5px solid var(--border);
  background: var(--bg);
  transition: all .2s;
}
.danger-step.done {
  border-color: var(--emerald);
  background: var(--emerald-light);
}
.danger-step.active {
  border-color: var(--red);
  background: var(--red-light);
}
.danger-step-num {
  width: 24px; height: 24px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  background: var(--border2); color: var(--ink3);
  flex-shrink: 0; transition: all .2s;
}
.danger-step.done .danger-step-num { background: var(--emerald); color: white; }
.danger-step.active .danger-step-num { background: var(--red); color: white; }
.danger-step-label { font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.danger-step-sub   { font-size: 12px; color: var(--ink3); }

.danger-confirm-input {
  width: 100%;
  background: var(--white);
  border: 2px solid var(--border2);
  border-radius: 8px;
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--red);
  letter-spacing: .05em;
  transition: border-color .15s;
  text-align: center;
  margin-top: 8px;
}
.danger-confirm-input:focus { outline: none; border-color: var(--red); }
.danger-confirm-input.ok { border-color: var(--emerald); color: var(--emerald); background: var(--emerald-light); }

.danger-btn-apagar {
  background: var(--red);
  color: white;
  border: none;
  border-radius: 8px;
  padding: 10px 24px;
  font-family: var(--font);
  font-size: 13.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  opacity: .35;
  pointer-events: none;
}
.danger-btn-apagar.liberado {
  opacity: 1;
  pointer-events: auto;
}
.danger-btn-apagar.liberado:hover { background: #a93226; }

.apagar-progress {
  height: 4px;
  background: var(--border2);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 6px;
  display: none;
}
.apagar-progress-fill {
  height: 100%;
  background: var(--red);
  border-radius: 2px;
  width: 0%;
  transition: width .1s linear;
}


/* ═══ NOTIFICAÇÕES ═══ */
.notif-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  gap: 16px;
}
.notif-row:last-child { border-bottom: none; }
.notif-row:hover { background: var(--bg); }
.notif-label  { font-size: 13.5px; font-weight: 500; color: var(--ink); }
.notif-desc   { font-size: 12px; color: var(--ink3); margin-top: 2px; }
.notif-toggle {
  position: relative;
  width: 40px; height: 22px;
  flex-shrink: 0;
}
.notif-toggle input { opacity: 0; width: 0; height: 0; }
.notif-slider {
  position: absolute; inset: 0;
  background: var(--border2);
  border-radius: 22px;
  cursor: pointer;
  transition: .2s;
}
.notif-slider:before {
  content: '';
  position: absolute;
  width: 16px; height: 16px;
  left: 3px; bottom: 3px;
  background: white;
  border-radius: 50%;
  transition: .2s;
}
.notif-toggle input:checked + .notif-slider { background: var(--emerald); }
.notif-toggle input:checked + .notif-slider:before { transform: translateX(18px); }

.notif-test-btn {
  padding: 4px 12px;
  border-radius: 6px;
  border: 1px solid var(--border2);
  background: var(--white);
  font-family: var(--font);
  font-size: 12px;
  color: var(--ink2);
  cursor: pointer;
  transition: all .12s;
  white-space: nowrap;
}
.notif-test-btn:hover { border-color: var(--emerald); color: var(--emerald); }
.notif-test-btn.sending { opacity: .5; pointer-events: none; }

.email-dest-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg2); border: 1px solid var(--border2);
  border-radius: 20px; padding: 3px 10px;
  font-size: 12.5px; color: var(--ink2);
}
.email-dest-tag button {
  background: none; border: none; cursor: pointer;
  color: var(--ink3); font-size: 14px; line-height: 1;
  padding: 0; transition: color .1s;
}
.email-dest-tag button:hover { color: var(--red); }


/* ═══ CONCILIAÇÃO UNIFICADA ═══ */
.cu-pipeline {
  display: grid;
  grid-template-columns: 1fr 28px 1fr 28px 1fr;
  gap: 0;
  align-items: stretch;
  margin-bottom: 20px;
}
.cu-pipe-step {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  text-align: center;
}
.cu-pipe-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink3);
  font-size: 16px;
}
.cu-pipe-icon { font-size: 22px; margin-bottom: 4px; }
.cu-pipe-label { font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; color: var(--ink3); }
.cu-pipe-val { font-family: var(--font-mono); font-size: 18px; font-weight: 500;
  margin-top: 4px; }

/* Card de venda */
.cu-venda {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  margin-bottom: 10px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow .15s;
}
.cu-venda:hover { box-shadow: var(--shadow); }
.cu-venda-header {
  display: grid;
  grid-template-columns: 32px 100px 1fr 90px 90px 110px 120px 32px;
  cursor: pointer;
  transition: background .1s;
}
.cu-venda-header:hover { background: var(--bg); }
.cu-venda-cell {
  padding: 13px 12px;
  font-size: 13px;
  color: var(--ink2);
  border-right: 1px solid var(--border);
  display: flex;
  align-items: center;
}
.cu-venda-cell:last-child { border-right: none; justify-content: center; }
.cu-venda-cell:first-child { justify-content: center; }

/* Status geral da venda */
.cu-status-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Corpo da venda expandido — 3 colunas */
.cu-body {
  display: none;
  border-top: 1px solid var(--border);
}
.cu-body.open { display: block; }
.cu-body-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  background: var(--border);
}
.cu-col {
  background: var(--white);
  padding: 0;
}
.cu-col-head {
  padding: 10px 14px;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink3);
  display: flex;
  align-items: center;
  gap: 6px;
}
.cu-linha {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 12.5px;
  transition: background .1s;
}
.cu-linha:last-child { border-bottom: none; }
.cu-linha:hover { background: var(--bg); }
.cu-linha-left { color: var(--ink2); flex: 1; min-width: 0; }
.cu-linha-desc { font-weight: 500; color: var(--ink); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis; }
.cu-linha-meta { font-size: 11px; color: var(--ink3); margin-top: 2px; }
.cu-linha-right { text-align: right; flex-shrink: 0; }
.cu-linha-val { font-family: var(--font-mono); font-size: 12px; }
.cu-empty-col { padding: 20px 14px; font-size: 12.5px; color: var(--ink3);
  font-style: italic; text-align: center; }

/* Botão de match manual */
.cu-match-btn {
  font-size: 11px; padding: 3px 9px; border-radius: 6px;
  border: 1px dashed var(--border2); background: transparent;
  color: var(--ink3); cursor: pointer; transition: all .12s;
  margin-top: 4px; white-space: nowrap;
}
.cu-match-btn:hover { border-color: var(--emerald); color: var(--emerald);
  background: var(--emerald-light); }

/* Status badges */
.cu-ok     { color: var(--emerald); }
.cu-warn   { color: var(--amber); }
.cu-err    { color: var(--red); }
.cu-pend   { color: var(--ink3); }

/* Linha de match visual entre colunas */
.cu-match-line {
  position: relative;
}
.cu-match-line::after {
  content: '↔';
  position: absolute;
  right: -14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: var(--emerald);
  z-index: 1;
}

/* Barra de progresso de conciliação */
.cu-prog-wrap { height: 4px; background: var(--border2);
  border-radius: 2px; overflow: hidden; margin-top: 8px; }
.cu-prog-fill { height: 100%; border-radius: 2px; transition: width .4s; }

/* Filtros rápidos */
.cu-filter-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 14px;
  align-items: center; }
.cu-chip { padding: 5px 13px; border-radius: 20px; font-size: 12px;
  font-weight: 500; cursor: pointer; border: 1.5px solid var(--border2);
  background: var(--white); color: var(--ink2); transition: all .12s;
  display: flex; align-items: center; gap: 5px; }
.cu-chip:hover { border-color: var(--ink2); }
.cu-chip.active { background: var(--ink); color: white; border-color: var(--ink); }
.cu-chip.c-green.active { background: var(--emerald); border-color: var(--emerald); }
.cu-chip.c-amber.active { background: var(--amber);   border-color: var(--amber); }
.cu-chip.c-red.active   { background: var(--red);     border-color: var(--red); }

/* KPIs superiores */
.cu-kpis { display: grid; grid-template-columns: repeat(5,1fr);
  gap: 12px; margin-bottom: 20px; }
.cu-kpi  { background: var(--white); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px; }
.cu-kpi-label { font-size: 10.5px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; color: var(--ink3); margin-bottom: 6px; }
.cu-kpi-val   { font-family: var(--font-mono); font-size: 18px; font-weight: 500; }
.cu-close-panel { background:var(--white); border:1px solid var(--border); border-radius:12px; overflow:hidden; margin-bottom:16px; box-shadow:var(--shadow-sm); }
.cu-close-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 18px; background:var(--bg2); border-bottom:1px solid var(--border); }
.cu-close-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--ink); }
.cu-close-sub { font-size:12px; color:var(--ink3); margin-top:2px; }
.cu-close-kpis { display:grid; grid-template-columns:repeat(5,1fr); gap:8px; padding:12px 18px; border-bottom:1px solid var(--border); }
.cu-close-kpi { border:1px solid var(--border); border-radius:9px; padding:10px 12px; background:var(--bg); }
.cu-close-kpi-label { font-size:10px; text-transform:uppercase; letter-spacing:.07em; color:var(--ink3); font-weight:700; margin-bottom:5px; }
.cu-close-kpi-val { font-family:var(--font-mono); font-size:18px; color:var(--ink); }
.cu-ex-row { display:grid; grid-template-columns:105px 1fr 145px 135px; border-bottom:1px solid var(--border); }
.cu-ex-row:last-child { border-bottom:none; }
.cu-ex-cell { padding:10px 14px; font-size:12.5px; color:var(--ink2); border-right:1px solid var(--border); min-width:0; display:flex; align-items:center; }
.cu-ex-cell:last-child { border-right:none; justify-content:center; }
.cu-ex-main { font-weight:700; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cu-ex-sub { font-size:11.5px; color:var(--ink3); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cu-ex-empty { padding:18px; text-align:center; color:var(--emerald); font-size:13px; font-weight:600; }
.cu-action-link { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:7px; padding:5px 10px; font-size:12px; font-weight:600; cursor:pointer; }
.cu-action-link:hover { border-color:var(--ink2); color:var(--ink); }


/* ═══ CASCATA DE CONCILIAÇÃO ═══ */
.cu-cascade { padding: 14px 16px; }
.cu-pgto-card { border: 1px solid var(--border); border-radius: 10px; margin-bottom: 12px; overflow: hidden; }
.cu-pgto-card:last-child { margin-bottom: 0; }
.cu-pgto-head { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: var(--bg2); border-bottom: 1px solid var(--border); }
.cu-pgto-body { padding: 0 4px 4px; }
.cu-step-row { display: flex; align-items: flex-start; gap: 10px; padding: 10px 12px; border-bottom: 1px solid var(--border2); }
.cu-step-row:last-child { border-bottom: none; }
.cu-step-icon { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }
.cu-step-icon.ok   { background: #dcfce7; }
.cu-step-icon.pend { background: #fef9c3; }
.cu-step-icon.err  { background: #fee2e2; }
.cu-step-icon.na   { background: var(--bg2); color: var(--ink3); }
.cu-step-body { flex: 1; min-width: 0; }
.cu-step-title { font-size: 13px; font-weight: 600; color: var(--ink); }
.cu-step-sub { font-size: 12px; color: var(--ink3); margin-top: 2px; line-height: 1.5; }
.cu-step-actions { margin-top: 8px; display: flex; gap: 6px; flex-wrap: wrap; }
.cu-nsu { font-family: var(--font-mono); font-size: 12px; background: var(--bg2); border: 1px solid var(--border); border-radius: 5px; padding: 2px 7px; color: var(--ink2); }
.cu-lote-raio { background: var(--bg2); border-radius: 6px; padding: 8px 10px; margin-top: 8px; font-size: 12px; }
.cu-lote-linha { display: flex; justify-content: space-between; padding: 2px 0; color: var(--ink2); }
.cu-lote-linha.destaque { font-weight: 600; color: var(--ink); }
.cu-semaforo { display: flex; align-items: center; gap: 4px; }
.cu-sem-step { display: flex; align-items: center; gap: 3px; font-size: 11px; font-weight: 600; }
.cu-sem-dot { width: 8px; height: 8px; border-radius: 50%; }
.cu-sem-arrow { color: var(--ink3); font-size: 10px; }
.cu-section-sep { padding: 8px 0 6px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--ink3); border-bottom: 1px solid var(--border); margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.cu-section-sep span.cu-sep-count { font-weight: 400; color: var(--ink3); text-transform: none; letter-spacing: 0; }
.cu-history-toggle { background: none; border: none; cursor: pointer; font-size: 12px; color: var(--ink3); font-weight: 600; display: flex; align-items: center; gap: 4px; padding: 0; }
.cu-history-toggle:hover { color: var(--ink); }
.cu-history-wrap { display: none; }
.cu-history-wrap.open { display: block; }
.cu-pgto-badge { font-size: 10px; padding: 2px 7px; border-radius: 10px; font-weight: 700; background: var(--bg); border: 1px solid var(--border2); color: var(--ink3); }
.cu-pgto-badge.sinal { background: #fef3c7; color: #92400e; border-color: #fcd34d; }
.cu-pgto-badge.restante { background: #e0f2fe; color: #0369a1; border-color: #7dd3fc; }

/* ═══ MATCHING AUTOMÁTICO ═══ */
.match-panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  margin-bottom: 16px;
  overflow: hidden;
}
.match-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  gap: 12px;
}
.match-panel-title {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 8px;
}
.match-result-row {
  display: grid;
  grid-template-columns: 100px 1fr 110px 110px 110px 90px;
  border-bottom: 1px solid var(--border);
  transition: background .1s;
}
.match-result-row:hover { background: var(--bg); }
.match-result-row.header { background: var(--bg2); }
.match-cell {
  padding: 10px 13px;
  font-size: 12.5px;
  color: var(--ink2);
  border-right: 1px solid var(--border);
  display: flex;
  align-items: center;
}
.match-cell:last-child { border-right: none; justify-content: center; }
.match-cell.mono { font-family: var(--font-mono); font-size: 12px; }
.match-badge-ok   { background: var(--emerald-light); color: var(--emerald); border: 1px solid var(--emerald-mid); }
.match-badge-warn { background: var(--amber-light);   color: var(--amber);   border: 1px solid #f5d48c; }
.match-badge-err  { background: var(--red-light);     color: var(--red);     border: 1px solid #f5c6c0; }
.match-badge { border-radius: 20px; padding: 2px 9px; font-size: 11px; font-weight: 600; }
.ml-recon-row {
  display: grid;
  grid-template-columns: minmax(220px,1.2fr) minmax(240px,1.35fr) 160px 95px 150px;
  border-bottom: 1px solid var(--border);
}
.ml-recon-row:hover { background: var(--bg); }
.ml-recon-row.header { background: var(--bg2); }
.ml-recon-cell {
  padding: 11px 13px;
  font-size: 12.5px;
  color: var(--ink2);
  border-right: 1px solid var(--border);
  min-width: 0;
}
.ml-recon-cell:last-child { border-right: none; }
.ml-recon-main { font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.ml-recon-sub { font-size: 11.5px; color: var(--ink3); line-height: 1.35; overflow-wrap: anywhere; }
.ml-recon-actions { display: flex; gap: 6px; align-items: center; justify-content: center; flex-wrap: wrap; }
.ml-recon-summary {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 12px 18px;
  background: var(--white);
  border-bottom: 1px solid var(--border);
}
.ml-recon-empty {
  padding: 18px;
  color: var(--ink2);
  font-size: 13px;
  line-height: 1.45;
}

/* Tolerância slider */
.tol-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  font-size: 12.5px;
  color: var(--ink2);
  flex-wrap: wrap;
  gap: 12px;
}
.tol-label { font-weight: 600; color: var(--ink); }

.import-history { background:var(--white); border:1px solid var(--border); border-radius:12px; overflow:hidden; margin-bottom:18px; }
.import-history-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 16px; background:var(--bg2); border-bottom:1px solid var(--border); }
.import-history-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--ink); }
.import-history-sub { font-size:12.5px; color:var(--ink3); margin-top:2px; }
.import-empty { padding:18px 16px; color:var(--ink3); font-size:13px; text-align:center; }
.import-card { border-bottom:1px solid var(--border); }
.import-card:last-child { border-bottom:none; }
.import-card summary { list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:13px 16px; }
.import-card summary::-webkit-details-marker { display:none; }
.import-card-title { font-weight:600; color:var(--ink); font-size:13.5px; }
.import-card-meta { font-size:11.5px; color:var(--ink3); margin-top:2px; }
.import-table { width:100%; border-collapse:collapse; font-size:12px; }
.import-table th { padding:8px 12px; background:var(--bg); color:var(--ink3); font-size:10px; text-transform:uppercase; letter-spacing:.06em; text-align:left; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.import-table td { padding:9px 12px; border-bottom:1px solid var(--border); color:var(--ink2); vertical-align:top; }
.import-table tr:last-child td { border-bottom:none; }
.import-status { display:inline-flex; align-items:center; gap:4px; border-radius:999px; padding:2px 8px; font-size:11px; font-weight:600; white-space:nowrap; }
.import-ok { background:var(--emerald-light); color:var(--emerald); border:1px solid var(--emerald-mid); }
.import-warn { background:var(--amber-light); color:var(--amber); border:1px solid #f5d48c; }
.import-err { background:var(--red-light); color:var(--red); border:1px solid #f5c6c0; }
.import-pend { background:var(--bg2); color:var(--ink3); border:1px solid var(--border); }

/* ═══ PENDÊNCIAS ═══ */
.pend-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:18px; }
.pend-kpi { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:14px; box-shadow:var(--shadow-sm); }
.pend-kpi-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:8px; }
.pend-kpi-val { font-family:var(--font-mono); font-size:22px; font-weight:500; color:var(--ink); }
.pend-kpi-sub { font-size:11.5px; color:var(--ink3); margin-top:3px; }
.pend-section { background:var(--white); border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:var(--shadow-sm); margin-bottom:14px; }
.pend-section-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; background:var(--bg2); border-bottom:1px solid var(--border); }
.pend-section-title { font-family:var(--font-display); font-size:16px; font-weight:600; color:var(--ink); }
.pend-section-sub { font-size:12px; color:var(--ink3); margin-top:2px; }
.pend-count { min-width:28px; height:28px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:13px; font-weight:600; background:var(--bg); color:var(--ink2); border:1px solid var(--border); }
.pend-row { display:grid; grid-template-columns:110px 1fr 130px 130px 120px; gap:0; border-bottom:1px solid var(--border); }
.pend-row:last-child { border-bottom:none; }
.pend-item-wrap:last-child .pend-row { border-bottom:none; }
.pend-item-wrap:last-child .pend-inline { border-bottom:none; }
.pend-cell { padding:11px 14px; border-right:1px solid var(--border); font-size:12.5px; color:var(--ink2); display:flex; align-items:center; min-width:0; }
.pend-cell:last-child { border-right:none; justify-content:center; }
.pend-desc { font-weight:600; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pend-meta { font-size:11.5px; color:var(--ink3); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pend-empty { padding:20px; text-align:center; color:var(--ink3); font-size:13px; }
.pend-chip { display:inline-flex; align-items:center; border-radius:999px; padding:2px 9px; font-size:11px; font-weight:600; white-space:nowrap; }
.pend-chip.red { background:var(--red-light); color:var(--red); border:1px solid #f5c6c0; }
.pend-chip.amber { background:var(--amber-light); color:var(--amber); border:1px solid #f5d48c; }
.pend-chip.blue { background:var(--blue-light); color:var(--blue); border:1px solid #c8dcf4; }
.pend-chip.gray { background:var(--bg2); color:var(--ink3); border:1px solid var(--border); }
.pend-action { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:7px; padding:5px 10px; font-size:12px; font-weight:600; cursor:pointer; }
.pend-action:hover { border-color:var(--ink2); color:var(--ink); }
.pend-resolve-btn { border:1px solid var(--emerald); background:var(--white); color:var(--emerald); border-radius:7px; padding:5px 10px; font-size:12px; font-weight:600; cursor:pointer; transition:background .15s,color .15s; }
.pend-resolve-btn:hover { background:var(--emerald); color:#fff; }
.pend-resolve-btn.open { background:var(--bg2); color:var(--ink3); border-color:var(--border2); }
.pend-inline { display:none; align-items:center; gap:10px; flex-wrap:wrap; padding:10px 16px; background:#f8fdf9; border-top:1px solid #d1ead5; }
.pend-inline-label { font-size:12px; color:var(--ink3); font-weight:600; white-space:nowrap; }
.pend-inline .form-control { height:32px; font-size:13px; padding:4px 10px; }
.pend-inline .btn { padding:5px 14px; font-size:12.5px; }
.todo-board { background:var(--white); border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow-sm); margin-bottom:16px; overflow:hidden; }
.form-grid { display:grid; gap:10px; }
.form-grid.cols-2 { grid-template-columns:repeat(2,minmax(0,1fr)); }
.form-grid.cols-3 { grid-template-columns:repeat(3,minmax(0,1fr)); }
.form-grid.cols-4 { grid-template-columns:repeat(4,minmax(0,1fr)); }
@media (max-width:900px) { .form-grid.cols-2,.form-grid.cols-3,.form-grid.cols-4 { grid-template-columns:1fr; } }
.todo-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:15px 16px; background:var(--bg2); border-bottom:1px solid var(--border); }
.todo-title { font-family:var(--font-display); font-size:17px; font-weight:600; color:var(--ink); }
.todo-sub { font-size:12px; color:var(--ink3); margin-top:2px; }
.todo-form { padding:16px; border-bottom:1px solid var(--border); background:#fffdf9; }
.todo-row { display:grid; grid-template-columns:32px 1fr 105px 110px 110px 90px; gap:0; border-bottom:1px solid var(--border); }
.todo-row:last-child { border-bottom:none; }
.todo-row.done { opacity:.58; }
.todo-row.done .todo-main-title { text-decoration:line-through; color:var(--ink3); }
.todo-cell { padding:11px 12px; border-right:1px solid var(--border); font-size:12.5px; color:var(--ink2); display:flex; align-items:center; min-width:0; }
.todo-cell:last-child { border-right:none; justify-content:center; gap:6px; }
.todo-main { flex-direction:column; align-items:flex-start; gap:2px; }
.todo-main-title { font-weight:700; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.todo-main-meta { font-size:11.5px; color:var(--ink3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.todo-prio { border-radius:999px; padding:2px 8px; font-size:11px; font-weight:700; white-space:nowrap; border:1px solid var(--border); background:var(--bg); color:var(--ink2); }
.todo-prio.urgente,.todo-prio.alta { background:var(--red-light); color:var(--red); border-color:#f5c6c0; }
.todo-prio.media { background:var(--amber-light); color:var(--amber); border-color:#f5d48c; }
.todo-status { border-radius:999px; padding:2px 8px; font-size:11px; font-weight:700; background:var(--blue-light); color:var(--blue); white-space:nowrap; }
.todo-status.concluida { background:var(--emerald-light); color:var(--emerald); }
.todo-status.cancelada { background:var(--bg2); color:var(--ink3); }
.todo-icon-btn { width:30px; height:30px; border-radius:8px; border:1px solid var(--border2); background:var(--white); cursor:pointer; display:inline-flex; align-items:center; justify-content:center; }
.todo-icon-btn:hover { border-color:var(--ink2); }
.todo-empty { padding:18px; text-align:center; color:var(--ink3); font-size:13px; }
.todo-tabs { display:flex; gap:8px; align-items:center; padding:10px 16px; background:var(--white); border-bottom:1px solid var(--border); }
.todo-tab { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:999px; padding:6px 12px; font-size:12px; font-weight:700; cursor:pointer; }
.todo-tab.active { background:var(--ink); color:var(--white); border-color:var(--ink); }
.todo-tab-count { opacity:.75; margin-left:4px; font-family:var(--font-mono); }
.briefing-board { background:linear-gradient(135deg,#fffaf0 0%,#f2fbf8 45%,#f7f8ff 100%); border:1px solid #eadfc8; border-radius:12px; box-shadow:var(--shadow-sm); overflow:hidden; margin-bottom:16px; position:relative; }
.briefing-board::before { content:""; position:absolute; inset:auto 18px -26px auto; width:120px; height:120px; border-radius:50%; background:rgba(26,107,74,.08); pointer-events:none; }
.briefing-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; padding:18px 20px; border-bottom:1px solid rgba(228,226,220,.8); background:rgba(255,255,255,.52); backdrop-filter:blur(6px); }
.briefing-title { font-family:var(--font-display); font-size:20px; font-weight:800; color:var(--ink); display:flex; align-items:center; gap:8px; }
.briefing-title::before { content:"☀"; width:34px; height:34px; border-radius:10px; background:#fff2c6; display:inline-flex; align-items:center; justify-content:center; box-shadow:0 4px 14px rgba(183,105,10,.14); font-family:var(--font-sans); font-size:17px; }
.briefing-sub { font-size:12.5px; color:var(--ink3); margin-top:5px; line-height:1.45; max-width:680px; }
.briefing-actions { display:flex; flex-wrap:wrap; gap:7px; justify-content:flex-end; }
.briefing-actions .pac-mini-btn { background:rgba(255,255,255,.76); }
.briefing-body { padding:16px 18px 18px; position:relative; }
.briefing-hero { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:14px; align-items:center; padding:14px 16px; border:1px solid rgba(228,226,220,.9); border-radius:12px; background:rgba(255,255,255,.72); margin-bottom:14px; }
.briefing-greeting { font-family:var(--font-display); font-size:18px; font-weight:800; color:var(--ink); }
.briefing-message { font-size:13px; color:var(--ink2); margin-top:5px; line-height:1.55; }
.briefing-stats { display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }
.briefing-stat { min-width:86px; border-radius:10px; padding:9px 10px; background:var(--white); border:1px solid var(--border); text-align:center; }
.briefing-stat strong { display:block; font-family:var(--font-mono); font-size:19px; color:var(--ink); line-height:1; }
.briefing-stat span { display:block; font-size:10px; color:var(--ink3); margin-top:4px; text-transform:uppercase; letter-spacing:.06em; }
.briefing-summary { font-size:13px; color:var(--ink2); margin-bottom:12px; line-height:1.55; }
.briefing-list { display:grid; grid-template-columns:repeat(auto-fit,minmax(310px,1fr)); gap:10px; }
.briefing-item { display:grid; grid-template-columns:42px minmax(0,1fr); gap:12px; align-items:start; padding:13px; border:1px solid rgba(228,226,220,.95); border-radius:12px; background:rgba(255,255,255,.88); box-shadow:0 5px 18px rgba(26,25,21,.04); position:relative; overflow:hidden; }
.briefing-item::before { content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--emerald); }
.briefing-item.urgente::before { background:var(--red); }
.briefing-item.alta::before { background:var(--amber); }
.briefing-item.media::before { background:var(--blue); }
.briefing-item.baixa::before { background:var(--emerald); }
.briefing-item.done { opacity:.68; background:#fbfaf7; }
.briefing-item.done .briefing-item-title,
.briefing-item.done .briefing-item-motivo { text-decoration:line-through; color:var(--ink3); }
.briefing-icon { width:34px; height:34px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:var(--bg); border:1px solid var(--border); font-size:15px; }
.briefing-prio { display:inline-flex; border-radius:999px; padding:3px 8px; font-size:10.5px; font-weight:800; text-align:center; white-space:nowrap; text-transform:uppercase; letter-spacing:.04em; margin-bottom:7px; }
.briefing-prio.urgente { background:var(--red-light); color:var(--red); }
.briefing-prio.alta { background:var(--amber-light); color:var(--amber); }
.briefing-prio.media { background:var(--blue-light); color:var(--blue); }
.briefing-prio.baixa { background:var(--emerald-light); color:var(--emerald); }
.briefing-item-title { font-weight:800; color:var(--ink); font-size:13px; }
.briefing-item-meta { font-size:11.5px; color:var(--ink3); margin-top:2px; text-transform:capitalize; }
.briefing-item-motivo { margin-top:6px; font-size:12px; color:var(--ink2); line-height:1.45; white-space:pre-line; }
.briefing-item-actions { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.briefing-whatsapp-msg { margin-top:8px; padding:8px 10px; border-radius:8px; background:#dcfce7; border:1px solid #bbf7d0; font-size:12px; color:#14532d; white-space:pre-line; line-height:1.5; }
.zapi-send-btn { background:#25d366 !important; color:#fff !important; border-color:#25d366 !important; font-weight:700; }
.briefing-empty { padding:18px; text-align:center; color:var(--ink3); font-size:13px; }
@media (max-width:900px) { .briefing-head,.briefing-hero { grid-template-columns:1fr; flex-direction:column; } .briefing-actions,.briefing-stats { justify-content:flex-start; } .briefing-list { grid-template-columns:1fr; } }

/* ═══ RELACIONAMENTO ═══ */
.rel-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(155px,1fr)); gap:12px; margin-bottom:16px; }
.rel-kpi { background:var(--white); border:1px solid var(--border); border-radius:10px; padding:14px; box-shadow:var(--shadow-sm); }
.rel-kpi-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin-bottom:7px; }
.rel-kpi-val { font-family:var(--font-mono); font-size:23px; font-weight:500; color:var(--ink); }
.rel-kpi-sub { font-size:11.5px; color:var(--ink3); margin-top:3px; }
.rel-actions-card,.rel-panel { background:var(--white); border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow-sm); overflow:hidden; margin-bottom:16px; }
.rel-card-head,.rel-panel-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 16px; background:var(--bg2); border-bottom:1px solid var(--border); }
.rel-title { font-family:var(--font-display); font-weight:600; font-size:16px; color:var(--ink); }
.rel-sub { font-size:12px; color:var(--ink3); margin-top:2px; }
.rel-columns { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.rel-row { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:14px; padding:14px 16px; border-bottom:1px solid var(--border); align-items:center; }
.rel-row:last-child { border-bottom:none; }
.rel-main { min-width:0; }
.rel-topline { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:4px; }
.rel-name { font-weight:800; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; }
.rel-meta { font-size:12px; color:var(--ink2); margin-top:2px; line-height:1.45; }
.rel-reason { margin-top:7px; font-size:12px; color:var(--ink3); display:flex; align-items:flex-start; gap:6px; line-height:1.45; }
.rel-reason span:first-child { color:var(--amber); font-size:12px; padding-top:1px; }
.rel-feedback { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-top:9px; }
.rel-feedback-label { font-size:11.5px; color:var(--ink3); font-weight:700; }
.rel-obs-row { display:flex; align-items:center; gap:6px; margin-top:8px; flex-wrap:wrap; }
.rel-obs-input { flex:1; min-width:200px; font-size:12.5px; padding:5px 10px; height:32px; }
.rel-resolution-row { display:flex; align-items:center; gap:6px; margin-top:7px; flex-wrap:wrap; }
.rel-feedback-btn { border:1px solid var(--border2); background:var(--white); border-radius:999px; padding:4px 8px; font-size:11.5px; color:var(--ink2); font-weight:700; cursor:pointer; }
.rel-feedback-btn:hover { border-color:var(--ink2); color:var(--ink); }
.rel-feedback-btn.active { background:var(--emerald-light); border-color:var(--emerald-mid); color:var(--emerald); }
.rel-feedback-btn.negative.active { background:var(--red-light); border-color:#f5c6c0; color:var(--red); }
.rel-feedback-btn.neutral.active { background:var(--blue-light); border-color:#bfdbfe; color:var(--blue); }
.rel-side { display:flex; align-items:center; gap:10px; justify-content:flex-end; min-width:360px; }
.rel-date { font-family:var(--font-mono); font-size:12px; color:var(--ink3); white-space:nowrap; }
.rel-actions { display:flex; align-items:center; gap:6px; }
.rel-chip { border-radius:999px; padding:2px 8px; font-size:11px; font-weight:700; border:1px solid var(--border); background:var(--bg); white-space:nowrap; }
.rel-chip.red { color:var(--red); background:var(--red-light); border-color:#f5c6c0; }
.rel-chip.amber { color:var(--amber); background:var(--amber-light); border-color:#f5d48c; }
.rel-chip.green { color:var(--emerald); background:var(--emerald-light); border-color:var(--emerald-mid); }
.rel-btn { min-width:32px; height:32px; border:1px solid var(--border2); background:var(--white); border-radius:9px; padding:0 9px; font-size:12px; font-weight:700; cursor:pointer; color:var(--ink2); display:inline-flex; align-items:center; justify-content:center; gap:5px; flex:0 0 auto; white-space:nowrap; }
.rel-btn:hover { border-color:var(--ink2); color:var(--ink); background:var(--bg); }
.rel-ai-box { grid-column:1 / -1; border:1px solid var(--border); background:#f8fbfa; border-radius:10px; padding:12px 14px; color:var(--ink2); font-size:12.5px; line-height:1.55; white-space:pre-wrap; }
.rel-ai-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:7px; color:var(--ink); font-weight:800; }
.rel-ai-actions { display:flex; gap:6px; flex-wrap:wrap; margin-top:10px; align-items:center; }
.rel-phone-inline { display:flex; gap:6px; flex-wrap:wrap; align-items:center; padding:6px; border:1px solid var(--border); border-radius:10px; background:var(--white); }
.rel-phone-inline input { width:150px; border:1px solid var(--border2); border-radius:8px; padding:6px 8px; font:inherit; font-size:12px; color:var(--ink); }
.rel-empty { padding:18px; color:var(--ink3); text-align:center; font-size:13px; }
@media (max-width:1000px) { .rel-columns { grid-template-columns:1fr; } .rel-row { grid-template-columns:1fr; align-items:start; } .rel-side { justify-content:space-between; min-width:0; width:100%; } }

/* ═══ LEADS / MARKETING ═══ */
.lead-kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:12px; margin-bottom:16px; }
.lead-form-card,.lead-list { background:var(--white); border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow-sm); overflow:hidden; margin-bottom:16px; }
.lead-insights { display:grid; grid-template-columns:1.15fr 1fr 1fr; gap:12px; margin-bottom:16px; }
.lead-panel { background:var(--white); border:1px solid var(--border); border-radius:12px; box-shadow:var(--shadow-sm); overflow:hidden; min-width:0; }
.lead-panel-head { padding:12px 14px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; gap:10px; align-items:center; }
.lead-panel-title { font-weight:800; color:var(--ink); font-size:13px; }
.lead-panel-sub { font-size:11.5px; color:var(--ink3); margin-top:2px; }
.lead-panel-body { padding:12px 14px; }
.lead-bar-row { display:grid; grid-template-columns:minmax(0,1fr) 62px; gap:10px; align-items:center; margin-bottom:10px; font-size:12px; }
.lead-bar-label { min-width:0; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; color:var(--ink2); }
.lead-bar-track { height:6px; background:var(--bg2); border-radius:999px; overflow:hidden; margin-top:5px; }
.lead-bar-fill { height:100%; background:var(--emerald); border-radius:999px; }
.lead-action-row { display:flex; justify-content:space-between; gap:10px; padding:9px 0; border-bottom:1px solid var(--border); font-size:12px; }
.lead-action-row:last-child { border-bottom:none; }
.lead-action-main { min-width:0; }
.lead-action-name { font-weight:700; color:var(--ink); overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.lead-action-meta { color:var(--ink3); font-size:11.5px; margin-top:2px; }
.lead-preview { margin-top:10px; padding:10px 12px; border:1px solid var(--border); border-radius:8px; background:var(--bg); color:var(--ink2); font-size:12px; line-height:1.6; }
.lead-toolbar { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:12px; }
.lead-period-row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin:-4px 0 14px; }
.lead-period-label { color:var(--ink3); font-size:12px; font-weight:800; margin-right:2px; }
.lead-period { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:999px; padding:6px 11px; font-size:12px; font-weight:700; cursor:pointer; }
.lead-period.active { background:#0f766e; border-color:#0f766e; color:#fff; }
.lead-filter { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:999px; padding:6px 12px; font-size:12px; font-weight:600; cursor:pointer; }
.lead-filter.active { background:var(--ink); color:var(--white); border-color:var(--ink); }
.lead-search-row { display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.lead-search-input { flex:1; min-width:220px; height:34px; border:1px solid var(--border); border-radius:9px; padding:6px 11px; font-size:13px; background:var(--white); }
.lead-bulkbar { display:none; align-items:center; justify-content:space-between; gap:10px; margin:-4px 0 12px; padding:9px 12px; border:1px solid var(--border); border-radius:10px; background:var(--white); box-shadow:var(--shadow-sm); flex-wrap:wrap; }
.lead-bulkbar.active { display:flex; }
.lead-bulk-count { font-size:12px; color:var(--ink2); font-weight:800; }
.lead-bulk-actions { display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.lead-bulk-field { height:30px; border:1px solid var(--border); border-radius:8px; padding:4px 8px; font-size:12px; background:var(--white); max-width:160px; }
.lead-danger-btn { border:1px solid #fecaca; background:#fee2e2; color:#991b1b; border-radius:8px; padding:6px 10px; font-size:12px; font-weight:800; cursor:pointer; }
.lead-danger-btn:disabled { opacity:.45; cursor:not-allowed; }
.lead-row { display:grid; grid-template-columns:112px minmax(280px,1.7fr) 140px minmax(220px,1fr) 70px 252px; border-bottom:1px solid var(--border); }
.lead-row:last-child { border-bottom:none; }
.lead-row.lead-selected { background:#f0fdf4; box-shadow:inset 3px 0 0 var(--emerald); }
.lead-cell { padding:11px 13px; border-right:1px solid var(--border); min-width:0; display:flex; align-items:center; font-size:12.5px; color:var(--ink2); }
.lead-cell:last-child { border-right:none; justify-content:center; gap:6px; }
.lead-select-check { width:16px; height:16px; margin-right:8px; accent-color:var(--emerald); cursor:pointer; flex-shrink:0; }
.lead-name-line { display:flex; align-items:center; gap:6px; min-width:0; max-width:100%; }
.lead-name { font-weight:700; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lead-meta { font-size:11.5px; color:var(--ink3); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.lead-badges { display:flex; align-items:center; gap:4px; flex-wrap:wrap; min-width:0; }
.lead-badge { display:inline-flex; align-items:center; justify-content:center; min-width:20px; height:20px; padding:0 6px; border-radius:999px; border:1px solid var(--border); background:var(--bg); color:var(--ink2); font-size:10.5px; font-weight:800; line-height:1; white-space:nowrap; }
.lead-badge.ads { background:#fff7e6; border-color:#f3d49c; color:#9a6200; }
.lead-badge.org { background:#eef6ff; border-color:#cfe4ff; color:#1f5f9e; }
.lead-badge.social { background:#fce7f3; border-color:#fbcfe8; color:#9d174d; }
.lead-badge.ref { background:#f5f3ff; border-color:#ddd6fe; color:#5b21b6; max-width:120px; overflow:hidden; text-overflow:ellipsis; }
.lead-badge.track { background:#ecfdf5; border-color:#bbf7d0; color:#047857; }
.lead-badge.warn { background:#fff7ed; border-color:#fed7aa; color:#c2410c; }
.lead-badge.interest { background:var(--emerald-light); border-color:#bfe2d3; color:var(--emerald); max-width:92px; overflow:hidden; text-overflow:ellipsis; }
.lead-message-preview { display:block; min-width:0; max-width:100%; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--ink2); line-height:1.35; }
.lead-message-muted { color:var(--ink3); }
.lead-status { border-radius:999px; padding:2px 8px; font-size:11px; font-weight:700; white-space:nowrap; background:var(--bg2); color:var(--ink2); }
.lead-status.novo,.lead-status.em_conversa { background:var(--blue-light); color:var(--blue); }
.lead-status.agendou,.lead-status.paciente { background:var(--emerald-light); color:var(--emerald); }
.lead-status.nao_agendou { background:var(--amber-light); color:var(--amber); }
.lead-status.perdido { background:var(--red-light); color:var(--red); }
/* CRM badges */
.lead-temp { border-radius:999px; padding:2px 7px; font-size:11px; font-weight:700; white-space:nowrap; }
.lead-temp.quente { background:#fef3c7; color:#92400e; }
.lead-temp.morno  { background:#fefce8; color:#854d0e; }
.lead-temp.frio   { background:#eff6ff; color:#1e40af; }
.lead-estagio { font-size:10px; color:var(--text-muted); margin-top:2px; }
.lead-actions { display:flex; align-items:center; justify-content:center; gap:5px; flex-wrap:wrap; }
.lead-action-btn { border:1px solid var(--border2); background:var(--white); color:var(--ink2); border-radius:8px; min-height:28px; padding:5px 8px; font-size:11.5px; font-weight:800; cursor:pointer; display:inline-flex; align-items:center; gap:4px; white-space:nowrap; }
.lead-action-btn:hover { border-color:var(--ink3); color:var(--ink); background:var(--bg); }
.lead-action-btn.whatsapp { background:#e8f8ef; border-color:#afe7c6; color:#0b7a3b; }
.lead-action-btn.convert { background:#eef6ff; border-color:#cfe4ff; color:#1d4ed8; }
.lead-action-btn.danger { background:#fff1f2; border-color:#fecdd3; color:#be123c; }
.lead-action-btn:disabled { opacity:.45; cursor:not-allowed; }
.lead-rec-row { padding:10px 0; border-bottom:1px solid var(--border); }
.lead-rec-row:last-child { border-bottom:none; }
.lead-rec-title { font-weight:800; color:var(--ink); font-size:12.5px; }
.lead-rec-meta { color:var(--ink3); font-size:11.5px; margin-top:3px; line-height:1.45; }
.crm-details summary { cursor:pointer; font-size:12px; color:var(--text-muted); font-weight:600; user-select:none; padding:6px 0; }
.crm-details summary:hover { color:var(--ink2); }
/* Inbox CRM bar */
.wa-crm-bar { padding:7px 16px; background:linear-gradient(90deg,#1b3a33,#0f2922); border-bottom:1px solid rgba(255,255,255,.08); display:flex; align-items:center; gap:8px; flex-wrap:wrap; font-size:11.5px; color:rgba(255,255,255,.75); }
.wa-crm-pill { border-radius:999px; padding:2px 8px; font-size:11px; font-weight:700; white-space:nowrap; }
.wa-crm-pill.quente { background:#fef3c7; color:#92400e; }
.wa-crm-pill.morno  { background:#fefce8; color:#854d0e; }
.wa-crm-pill.frio   { background:#eff6ff; color:#1e40af; }
.wa-crm-pill.info   { background:rgba(255,255,255,.13); color:rgba(255,255,255,.9); }
.wa-crm-sep         { opacity:.3; }
/* Playbooks panel */
.wa-playbooks { border-top:1px solid var(--border); background:#f9fafb; padding:8px 10px; flex-shrink:0; max-height:160px; overflow-y:auto; }
.wa-playbooks-head  { font-size:11px; font-weight:700; color:var(--ink3); margin-bottom:6px; display:flex; align-items:center; justify-content:space-between; }
.wa-playbook-item   { background:#fff; border:1px solid var(--border); border-radius:8px; padding:8px 10px; margin-bottom:6px; display:flex; align-items:flex-start; gap:8px; }
.wa-playbook-item:last-child { margin-bottom:0; }
.wa-playbook-body   { flex:1; min-width:0; }
.wa-playbook-title  { font-size:11px; font-weight:700; color:var(--ink2); margin-bottom:3px; }
.wa-playbook-msg    { font-size:12px; color:var(--ink); line-height:1.4; white-space:pre-wrap; word-break:break-word; max-height:54px; overflow:hidden; }
.wa-playbook-use    { flex-shrink:0; }
/* Sidebar lead temperature indicator */
.wa-conv-item.temp-quente { border-left:3px solid #f59e0b; }
.wa-conv-item.temp-morno  { border-left:3px solid #fde68a; }
.wa-conv-item.temp-frio   { border-left:3px solid #93c5fd; }
.lead-empty { padding:22px; text-align:center; color:var(--ink3); font-size:13px; }
@media (max-width:1000px) { .lead-row { grid-template-columns:90px 1fr 110px; } .lead-row .lead-cell:nth-child(3), .lead-row .lead-cell:nth-child(4), .lead-row .lead-cell:nth-child(5) { display:none; } }
@media (max-width:1100px) { .lead-insights { grid-template-columns:1fr; } }

/* ═══ INBOX WHATSAPP ═══ */
.inbox-section { background:var(--white); border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:var(--shadow-sm); margin-top:20px; }
.inbox-head { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 18px; background:var(--bg2); border-bottom:1px solid var(--border); }
.inbox-head-left { display:flex; align-items:center; gap:10px; }
.inbox-title { font-family:var(--font-display); font-size:15px; font-weight:700; color:var(--ink); }
.inbox-badge { display:inline-flex; align-items:center; justify-content:center; min-width:20px; height:20px; padding:0 6px; border-radius:999px; background:#25d366; color:#fff; font-size:11px; font-weight:800; }
.inbox-row { display:grid; grid-template-columns:40px 1fr auto; gap:0; border-bottom:1px solid var(--border); align-items:stretch; transition:background .1s; cursor:default; }
.inbox-row:last-child { border-bottom:none; }
.inbox-row.nao-lida { background:#f0fdf4; }
.inbox-row:hover { background:var(--bg); }
.inbox-dot-col { display:flex; align-items:center; justify-content:center; padding:0 4px; }
.inbox-dot { width:8px; height:8px; border-radius:50%; background:#25d366; }
.inbox-dot.lida { background:transparent; }
.inbox-body { padding:11px 14px 11px 6px; min-width:0; }
.inbox-from { font-weight:700; font-size:13px; color:var(--ink); display:flex; align-items:center; gap:6px; }
.inbox-phone { font-size:11.5px; color:var(--ink3); font-weight:400; }
.inbox-assoc { font-size:11px; padding:1px 7px; border-radius:999px; background:var(--emerald-light); color:var(--emerald); font-weight:600; }
.inbox-assoc.lead { background:var(--blue-light); color:var(--blue); }
.inbox-preview { font-size:12.5px; color:var(--ink2); margin-top:3px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:600px; line-height:1.4; }
.inbox-actions { display:flex; align-items:center; gap:6px; padding:10px 14px; white-space:nowrap; flex-direction:column; justify-content:center; }
.inbox-time { font-size:11px; color:var(--ink3); text-align:right; white-space:nowrap; }
.inbox-empty { padding:28px; text-align:center; color:var(--ink3); font-size:13px; }
.nav-unread-dot { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; padding:0 5px; border-radius:999px; background:#25d366; color:#fff; font-size:10px; font-weight:800; margin-left:auto; }
/* ═══ SUGESTÃO IA INBOX ═══ */
.inbox-sugestao-box { background:linear-gradient(135deg,#f0fdf4,#eff6ff); border:1px solid #bfdbfe; border-radius:8px; padding:11px 14px; font-size:12.5px; color:var(--ink); line-height:1.65; white-space:pre-wrap; max-height:140px; overflow:auto; }

/* ═══ BADGES DE INTENÇÃO ═══ */
.intencao-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 8px; border-radius:999px; font-size:11px; font-weight:700; white-space:nowrap; margin:1px; }
.intencao-badge.quer_agendar     { background:#dbeafe; color:#1d4ed8; border:1px solid #bfdbfe; }
.intencao-badge.pergunta_preco   { background:#fef3c7; color:#b45309; border:1px solid #fde68a; }
.intencao-badge.retorno_paciente { background:#ede9fe; color:#6d28d9; border:1px solid #ddd6fe; }
.intencao-badge.cancelamento     { background:#fee2e2; color:#b91c1c; border:1px solid #fecaca; }
.intencao-badge.urgencia_medica  { background:#fee2e2; color:#7f1d1d; border:1px solid #f87171; animation:pulse-urgencia 1.5s infinite; }
.intencao-badge.outro            { background:var(--bg2); color:var(--ink3); border:1px solid var(--border); }
.intencao-badge.classificando    { background:var(--bg2); color:var(--ink3); border:1px solid var(--border); }
@keyframes pulse-urgencia { 0%,100%{opacity:1} 50%{opacity:.6} }
.inbox-grupo { border-bottom:1px solid var(--border); }
.inbox-grupo:last-child { border-bottom:none; }
.inbox-grupo.nao-lida { background:#f0fdf4; }
.inbox-grupo-header { display:grid; grid-template-columns:40px 1fr auto; align-items:stretch; cursor:pointer; transition:background .1s; }
.inbox-grupo-header:hover { background:rgba(0,0,0,.03); }
.inbox-cnt { display:inline-flex; align-items:center; padding:1px 7px; border-radius:999px; background:#25d366; color:#fff; font-size:10.5px; font-weight:700; }
.inbox-cnt-total { display:inline-flex; align-items:center; padding:1px 7px; border-radius:999px; background:var(--bg2); color:var(--ink3); font-size:10.5px; font-weight:600; border:1px solid var(--border); }
.inbox-thread { border-top:1px solid var(--border); background:var(--bg); padding:0 0 6px 40px; }
.inbox-thread-msg { display:flex; align-items:flex-start; gap:8px; padding:8px 14px 8px 0; border-bottom:1px solid var(--border2); }
.inbox-thread-msg:last-child { border-bottom:none; }
.inbox-thread-msg.nao-lida-thread { background:#f0fdf4; border-radius:6px; }
.inbox-thread-dot { width:7px; height:7px; border-radius:50%; background:#25d366; margin-top:5px; flex-shrink:0; }
.inbox-thread-dot.lida { background:var(--border); }
.inbox-thread-body { display:flex; align-items:baseline; justify-content:space-between; gap:10px; flex:1; min-width:0; }
.inbox-thread-text { font-size:12.5px; color:var(--ink2); line-height:1.45; flex:1; min-width:0; }
.inbox-thread-time { font-size:11px; color:var(--ink3); white-space:nowrap; flex-shrink:0; }

/* ── WhatsApp Web layout ──────────────────────────────── */
.wa-section { margin-top:24px; }
.wa-section-title { font-size:15px; font-weight:700; margin-bottom:14px; display:flex; align-items:center; gap:8px; }
.wa-container { display:grid; grid-template-columns:320px 1fr; height:calc(100vh - 195px); min-height:480px; max-height:820px; border:1px solid var(--border); border-radius:12px; overflow:hidden; background:var(--white); box-shadow:var(--shadow-sm); }
.wa-container.info-open { grid-template-columns:320px minmax(0,1fr) 280px; }
.wa-sidebar { display:flex; flex-direction:column; border-right:1px solid var(--border); background:#f0f2f5; min-height:0; overflow:hidden; }
.wa-chat { display:flex; flex-direction:column; background:#efeae2; min-height:0; overflow:hidden; }
.wa-sidebar-head { padding:10px 14px; background:#128C7E; color:#fff; display:flex; align-items:center; justify-content:space-between; gap:8px; min-height:52px; }
.wa-sidebar-head-title { font-size:14px; font-weight:700; }
.wa-sidebar-actions { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.wa-sidebar-search { padding:6px 10px; border-bottom:1px solid var(--border); background:#f0f2f5; }
.wa-sidebar-search input { width:100%; padding:6px 12px; border-radius:20px; border:none; font-size:13px; background:#fff; outline:none; box-shadow:inset 0 0 0 1px var(--border); }
.wa-filters { display:flex; gap:6px; padding:7px 10px; overflow-x:auto; background:#f0f2f5; border-bottom:1px solid var(--border); }
.wa-filter { border:1px solid transparent; background:#fff; color:var(--ink2); border-radius:999px; padding:5px 10px; font-size:11.5px; font-weight:700; cursor:pointer; white-space:nowrap; }
.wa-filter.active { background:#d9fdd3; color:#0d5c50; border-color:#9be7a0; }
.wa-select-bar { display:none; align-items:center; justify-content:space-between; gap:8px; padding:8px 10px; background:#fff; border-bottom:1px solid var(--border); }
.wa-select-bar.active { display:flex; }
.wa-select-count { font-size:12px; font-weight:800; color:var(--ink2); white-space:nowrap; }
.wa-select-actions { display:flex; gap:6px; align-items:center; }
.wa-select-danger { border:1px solid #fecaca; color:#991b1b; background:#fee2e2; border-radius:7px; padding:4px 8px; font-size:11.5px; font-weight:800; cursor:pointer; }
.wa-select-danger:disabled { opacity:.45; cursor:not-allowed; }
.wa-conv-list { flex:1; overflow-y:auto; }
.wa-conv-item { display:flex; gap:10px; align-items:center; padding:10px 14px; cursor:pointer; border-bottom:1px solid rgba(0,0,0,.06); transition:background .12s; }
.wa-conv-item:hover { background:rgba(0,0,0,.04); }
.wa-conv-item.wa-active { background:#d9f5d0; }
.wa-conv-item.wa-unread { background:#fff; }
.wa-conv-item.wa-selected { background:#e7f7ee; box-shadow:inset 3px 0 0 #128C7E; }
.wa-select-check { width:18px; height:18px; border-radius:5px; accent-color:#128C7E; flex-shrink:0; cursor:pointer; }
.wa-conv-item:not(.selecting) .wa-select-check { display:none; }
.wa-conv-avatar { width:42px; height:42px; border-radius:50%; background:#128C7E; color:#fff; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.wa-conv-info { flex:1; min-width:0; }
.wa-conv-name { font-size:13.5px; font-weight:600; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.wa-conv-preview { font-size:12px; color:var(--ink3); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-top:2px; }
.wa-conv-preview .draft { color:#0d7066; font-weight:800; }
.wa-conv-meta { display:flex; flex-direction:column; align-items:flex-end; gap:4px; flex-shrink:0; }
.wa-conv-time { font-size:11px; color:var(--ink3); }
.wa-conv-badge { background:#25d366; color:#fff; font-size:11px; font-weight:700; min-width:18px; height:18px; border-radius:999px; display:flex; align-items:center; justify-content:center; padding:0 5px; }
.wa-chat-head { padding:10px 16px; background:#128C7E; color:#fff; display:flex; align-items:center; justify-content:space-between; gap:10px; min-height:52px; }
.wa-chat-head-info { min-width:0; }
.wa-chat-head-name { font-size:14px; font-weight:700; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.wa-chat-head-sub { font-size:11px; opacity:.8; margin-top:1px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.wa-lead-toggle { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:12px; font-size:11px; font-weight:600; cursor:pointer; border:1.5px solid transparent; transition:all .15s; white-space:nowrap; }
.wa-lead-toggle.on  { background:#d1fae5; color:#065f46; border-color:#6ee7b7; }
.wa-lead-toggle.off { background:#fee2e2; color:#991b1b; border-color:#fca5a5; }
.wa-chat-body { flex:1; overflow-y:auto; padding:12px 14px; display:flex; flex-direction:column; gap:5px; }
.wa-chat-empty { flex:1; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:10px; color:var(--ink3); font-size:13px; text-align:center; background:#efeae2; }
.wa-bubble-wrap { display:flex; flex-direction:column; }
.wa-bubble-wrap.recv { align-items:flex-start; }
.wa-bubble-wrap.sent { align-items:flex-end; }
.wa-bubble { max-width:78%; padding:7px 11px 4px; border-radius:8px; font-size:13px; line-height:1.45; word-break:break-word; box-shadow:0 1px 2px rgba(0,0,0,.12); }
.wa-bubble.recv { background:#fff; border-radius:0 8px 8px 8px; }
.wa-bubble.sent { background:#d9fdd3; border-radius:8px 8px 0 8px; }
.wa-bubble-time { font-size:10.5px; color:rgba(0,0,0,.45); text-align:right; margin-top:2px; }
.wa-date-sep { align-self:center; background:rgba(255,255,255,.75); border:1px solid rgba(0,0,0,.06); color:var(--ink3); border-radius:8px; padding:4px 10px; font-size:11px; font-weight:800; margin:8px 0; box-shadow:0 1px 2px rgba(0,0,0,.05); }
.wa-unread-sep { align-self:stretch; display:flex; align-items:center; gap:8px; color:#08745f; font-size:11px; font-weight:800; margin:10px 0 8px; }
.wa-unread-sep::before,.wa-unread-sep::after { content:""; height:1px; background:rgba(8,116,95,.25); flex:1; }
.wa-chat-footer { padding:8px 10px; background:#f0f2f5; border-top:1px solid var(--border); display:flex; gap:6px; align-items:flex-end; flex-shrink:0; }
.wa-input-wrap { flex:1; background:#fff; border:1px solid var(--border); border-radius:22px; padding:6px 14px; display:flex; align-items:flex-end; gap:8px; min-height:40px; max-height:120px; }
.wa-input { flex:1; border:none; outline:none; font-size:14px; font-family:inherit; resize:none; line-height:1.45; max-height:100px; overflow-y:auto; background:transparent; color:var(--ink); }
.wa-input::placeholder { color:var(--ink3); }
.wa-send-btn { width:38px; height:38px; border-radius:50%; background:#128C7E; color:#fff; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:16px; transition:background .15s; }
.wa-send-btn:hover { background:#0d7066; }
.wa-send-btn:disabled { background:#a0a0a0; cursor:not-allowed; }
.wa-ai-btn { width:32px; height:32px; border-radius:50%; background:#e0e7ff; color:#3730a3; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:13px; margin-bottom:3px; transition:background .15s; }
.wa-ai-btn:hover { background:#c7d2fe; }
.wa-setup-prompt { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:40px 24px; color:var(--ink3); font-size:13.5px; text-align:center; }
.wa-info-panel { border-left:1px solid var(--border); background:#f7f8fa; overflow-y:auto; min-width:0; }
.wa-info-head { padding:14px 16px; background:#fff; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; gap:10px; align-items:center; }
.wa-info-title { font-weight:800; color:var(--ink); font-size:14px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.wa-info-sub { color:var(--ink3); font-size:11.5px; margin-top:2px; }
.wa-info-body { padding:14px; display:grid; gap:10px; }
.wa-info-card { background:#fff; border:1px solid var(--border); border-radius:10px; padding:12px; }
.wa-info-label { font-size:10px; text-transform:uppercase; letter-spacing:.08em; font-weight:800; color:var(--ink3); margin-bottom:6px; }
.wa-info-line { font-size:12.5px; color:var(--ink2); line-height:1.5; display:flex; justify-content:space-between; gap:10px; padding:3px 0; }
.wa-info-actions { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
/* ── Disparos Proativos redesign ───────────────────────── */
.disparos-card { background:var(--white); border:1px solid var(--border); border-radius:12px; padding:18px 20px; margin-top:20px; box-shadow:var(--shadow-sm); }
.disparos-card-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:16px; }
.disparos-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media(max-width:900px){ .wa-container.info-open { grid-template-columns:1fr; } .wa-info-panel { display:none !important; } }
@media(max-width:640px){ .disparos-grid{grid-template-columns:1fr;} .wa-container{grid-template-columns:1fr;} .wa-sidebar{min-height:220px;} }
.disparos-item { border:1px solid var(--border); border-radius:10px; padding:14px 16px; background:var(--bg2); }
.disparos-item-title { font-size:13.5px; font-weight:700; margin-bottom:4px; }
.disparos-item-desc { font-size:12px; color:var(--ink3); line-height:1.55; margin-bottom:10px; }
.disparos-item-cnt { font-size:28px; font-weight:800; line-height:1; margin-bottom:6px; }
.disparos-item-cnt.blue { color:var(--blue); }
.disparos-item-cnt.amber { color:#d97706; }

/* ═══ TIMELINE DO PACIENTE ═══ */
.pac-detail-row td { padding:0 !important; background:#fffdf9; }
/* wrapper */
.pac-tl { padding:18px 20px 22px; border-top:1px solid var(--border); }
.pac-dash { background:linear-gradient(135deg,#f7fbff 0%,#f4fff8 46%,#fff8ed 100%); border-top:1px solid var(--border); padding:18px; }
.pac-hero { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:16px; align-items:start; background:rgba(255,255,255,.82); border:1px solid rgba(228,226,220,.9); border-radius:14px; padding:16px; box-shadow:0 8px 24px rgba(26,25,21,.06); }
.pac-hero-name { font-family:var(--font-display); font-size:23px; font-weight:850; color:var(--ink); line-height:1.15; }
.pac-hero-sub { color:var(--ink3); font-size:12.5px; margin-top:5px; display:flex; gap:8px; flex-wrap:wrap; }
.pac-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.pac-tag { display:inline-flex; align-items:center; gap:4px; border:1px solid var(--border); border-radius:999px; padding:4px 9px; background:var(--white); color:var(--ink2); font-size:11.5px; font-weight:800; white-space:nowrap; }
.pac-tag.green { background:#ecfdf5; border-color:#bbf7d0; color:#047857; }
.pac-tag.blue { background:#eff6ff; border-color:#bfdbfe; color:#1d4ed8; }
.pac-tag.purple { background:#f5f3ff; border-color:#ddd6fe; color:#5b21b6; }
.pac-tag.amber { background:#fffbeb; border-color:#fde68a; color:#b45309; }
.pac-tag.red { background:#fff1f2; border-color:#fecdd3; color:#be123c; }
.pac-hero-actions { display:flex; gap:7px; flex-wrap:wrap; justify-content:flex-end; max-width:360px; }
.pac-dash-grid { display:grid; grid-template-columns:repeat(6,minmax(120px,1fr)); gap:10px; margin-top:12px; }
.pac-dash-card { background:rgba(255,255,255,.88); border:1px solid var(--border); border-radius:12px; padding:12px; min-height:88px; box-shadow:0 4px 18px rgba(26,25,21,.04); }
.pac-dash-card-label { font-size:10px; text-transform:uppercase; letter-spacing:.07em; color:var(--ink3); font-weight:850; }
.pac-dash-card-value { font-family:var(--font-display); font-size:20px; font-weight:850; color:var(--ink); margin-top:5px; line-height:1.15; overflow:hidden; text-overflow:ellipsis; }
.pac-dash-card-sub { font-size:11.5px; color:var(--ink3); margin-top:4px; line-height:1.35; }
.pac-dash-card.green .pac-dash-card-value { color:var(--emerald); }
.pac-dash-card.blue .pac-dash-card-value { color:var(--blue); }
.pac-dash-card.amber .pac-dash-card-value { color:var(--amber); }
.pac-dash-card.red .pac-dash-card-value { color:var(--red); }
.pac-dash-main { display:grid; grid-template-columns:minmax(0,1.65fr) minmax(280px,.9fr); gap:14px; margin-top:14px; align-items:start; }
.pac-panel { background:rgba(255,255,255,.9); border:1px solid var(--border); border-radius:12px; overflow:hidden; box-shadow:0 4px 18px rgba(26,25,21,.04); }
.pac-panel-head { padding:13px 15px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; gap:10px; align-items:center; background:rgba(255,255,255,.72); }
.pac-panel-title { font-weight:850; color:var(--ink); font-size:13.5px; }
.pac-panel-sub { color:var(--ink3); font-size:11.5px; margin-top:2px; }
.pac-panel-body { padding:14px 15px; }
.pac-section-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin-top:14px; }
.pac-section-grid .pac-panel { min-width:0; }
.pac-fin-row { display:grid; grid-template-columns:minmax(0,1fr) auto; gap:10px; align-items:center; padding:8px 0; border-bottom:1px solid var(--border2); }
.pac-fin-row:last-child { border-bottom:none; }
.pac-fin-label { color:var(--ink2); font-size:12.5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.pac-fin-val { font-family:var(--font-mono); font-weight:850; color:var(--ink); font-size:12.5px; white-space:nowrap; }
.pac-bar { height:7px; background:var(--bg2); border-radius:999px; overflow:hidden; margin-top:5px; }
.pac-bar-fill { height:100%; background:var(--emerald); border-radius:999px; }
.pac-highlight { border:1px solid #bbf7d0; background:#f0fdf4; border-radius:10px; padding:10px 12px; color:#14532d; font-size:12.5px; line-height:1.45; margin-bottom:10px; }
.pac-highlight.purple { border-color:#ddd6fe; background:#f5f3ff; color:#4c1d95; }
.pac-highlight.blue { border-color:#bfdbfe; background:#eff6ff; color:#1e3a8a; }
.pac-wa-list { display:grid; gap:8px; }
.pac-wa-item { border:1px solid var(--border); background:#fff; border-radius:9px; padding:9px 10px; }
.pac-wa-top { display:flex; justify-content:space-between; gap:8px; align-items:center; font-size:11.5px; color:var(--ink3); margin-bottom:4px; }
.pac-wa-msg { color:var(--ink2); font-size:12.5px; line-height:1.45; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pac-ai-spotlight { margin-top:14px; border:1px solid #c7d2fe; background:linear-gradient(135deg,#eef2ff,#f8fafc); border-radius:12px; padding:14px 15px; }
.pac-ai-spotlight-head { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; flex-wrap:wrap; }
.pac-ai-title { font-weight:850; color:#3730a3; font-size:14px; }
.pac-ai-sub { color:var(--ink3); font-size:12px; margin-top:3px; }
.pac-side-line { display:flex; justify-content:space-between; gap:12px; padding:8px 0; border-bottom:1px solid var(--border2); font-size:12.5px; color:var(--ink2); }
.pac-side-line:last-child { border-bottom:none; }
.pac-side-line strong { color:var(--ink); text-align:right; }
.pac-name-link { border:none; background:transparent; padding:0; margin:0; color:var(--ink); font:inherit; font-weight:800; cursor:pointer; text-align:left; }
.pac-name-link:hover { color:var(--blue); text-decoration:underline; }
@media (max-width:1200px) { .pac-dash-grid { grid-template-columns:repeat(3,minmax(0,1fr)); } .pac-dash-main,.pac-section-grid { grid-template-columns:1fr; } }
@media (max-width:760px) { .pac-hero { grid-template-columns:1fr; } .pac-hero-actions { justify-content:flex-start; } .pac-dash-grid { grid-template-columns:1fr 1fr; } }
/* cabeçalho */
.pac-tl-head { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.pac-tl-title { font-size:15px; font-weight:800; color:var(--ink); }
.pac-tl-sub { color:var(--ink3); font-size:12px; margin-top:3px; }
/* strip de estatísticas */
.pac-tl-stats { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.pac-tl-stat { display:flex; align-items:center; gap:5px; font-size:12px; font-weight:600; padding:4px 10px; border-radius:999px; background:var(--bg2); color:var(--ink2); border:1px solid var(--border); }
.pac-tl-stat span { font-size:14px; }
/* filtro */
.pac-tl-filters { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.pac-tl-filter { font-size:11px; font-weight:600; padding:3px 10px; border-radius:999px; border:1px solid var(--border); background:var(--bg2); color:var(--ink3); cursor:pointer; transition:all .15s; }
.pac-tl-filter.ativo { background:var(--ink); color:#fff; border-color:var(--ink); }
/* linha do tempo vertical */
.pac-tl-body { position:relative; padding-left:42px; }
.pac-tl-body::before { content:''; position:absolute; left:17px; top:12px; bottom:12px; width:2px; background:linear-gradient(to bottom,#93c5fd 0%,#bbf7d0 46%,#fed7aa 100%); border-radius:2px; }
/* separador de mês */
.pac-tl-month { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--ink3); margin:18px 0 10px -42px; padding-left:0; display:flex; align-items:center; gap:10px; }
.pac-tl-month::after { content:''; flex:1; height:1px; background:var(--border); }
/* evento */
.pac-tl-ev { position:relative; margin-bottom:10px; }
.pac-tl-dot { position:absolute; left:-31px; top:8px; width:26px; height:26px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:13px; z-index:1; box-shadow:0 0 0 3px #fffdf9; }
.pac-tl-card { border-radius:10px; padding:10px 13px; border:1px solid var(--border); background:#fff; display:grid; grid-template-columns:1fr auto; gap:8px; align-items:start; box-shadow:0 4px 14px rgba(26,25,21,.045); }
.pac-tl-card-body { min-width:0; }
.pac-tl-badge { display:inline-flex; align-items:center; gap:4px; font-size:10px; font-weight:700; padding:2px 8px; border-radius:999px; white-space:nowrap; margin-bottom:4px; }
.pac-tl-etitle { font-weight:700; font-size:13px; color:var(--ink); line-height:1.3; }
.pac-tl-edesc { font-size:12px; color:var(--ink3); margin-top:3px; line-height:1.45; }
.pac-tl-tags { display:flex; gap:5px; margin-top:6px; flex-wrap:wrap; }
.pac-tl-tag { font-size:10.5px; padding:2px 8px; border-radius:999px; background:var(--bg2); color:var(--ink2); border:1px solid var(--border); }
.pac-tl-card-right { text-align:right; white-space:nowrap; padding-top:2px; }
.pac-tl-date { font-family:var(--font-mono); font-size:11px; color:var(--ink3); }
.pac-tl-valor { font-family:var(--font-mono); font-size:13px; font-weight:700; color:var(--emerald); margin-top:4px; }
.pac-tl-stars { font-size:12px; color:#f59e0b; margin-top:3px; }
/* cores por tipo */
.pac-tl-t-atendimento .pac-tl-dot { background:#16a34a; }
.pac-tl-t-atendimento .pac-tl-card { border-left:3px solid #16a34a; }
.pac-tl-t-atendimento .pac-tl-badge { background:#dcfce7; color:#15803d; }
.pac-tl-t-pagamento .pac-tl-dot { background:#0ea5e9; }
.pac-tl-t-pagamento .pac-tl-card { border-left:3px solid #0ea5e9; }
.pac-tl-t-pagamento .pac-tl-badge { background:#e0f2fe; color:#0369a1; }
.pac-tl-t-pendencia .pac-tl-dot { background:#f59e0b; }
.pac-tl-t-pendencia .pac-tl-card { border-left:3px solid #f59e0b; }
.pac-tl-t-pendencia .pac-tl-badge { background:#fef3c7; color:#b45309; }
.pac-tl-t-pendencia_concluida .pac-tl-dot { background:#22c55e; }
.pac-tl-t-pendencia_concluida .pac-tl-card { border-left:3px solid #22c55e; }
.pac-tl-t-pendencia_concluida .pac-tl-badge { background:#dcfce7; color:#15803d; }
.pac-tl-t-sinal .pac-tl-dot { background:#a855f7; }
.pac-tl-t-sinal .pac-tl-card { border-left:3px solid #a855f7; }
.pac-tl-t-sinal .pac-tl-badge { background:#f3e8ff; color:#7e22ce; }
.pac-tl-t-marketing .pac-tl-dot { background:#6366f1; }
.pac-tl-t-marketing .pac-tl-card { border-left:3px solid #6366f1; }
.pac-tl-t-marketing .pac-tl-badge { background:#e0e7ff; color:#3730a3; }
.pac-tl-t-lead .pac-tl-dot { background:#f97316; }
.pac-tl-t-lead .pac-tl-card { border-left:3px solid #f97316; }
.pac-tl-t-lead .pac-tl-badge { background:#ffedd5; color:#c2410c; }
.pac-tl-t-lead_agendamento .pac-tl-dot { background:#10b981; }
.pac-tl-t-lead_agendamento .pac-tl-card { border-left:3px solid #10b981; }
.pac-tl-t-lead_agendamento .pac-tl-badge { background:#d1fae5; color:#065f46; }
.pac-tl-t-whatsapp .pac-tl-dot { background:#25d366; }
.pac-tl-t-whatsapp .pac-tl-card { border-left:3px solid #25d366; }
.pac-tl-t-whatsapp .pac-tl-badge { background:#dcfce7; color:#14532d; }
.pac-row-actions { display:flex; gap:6px; align-items:center; }
.pac-mini-btn { border:1px solid var(--border2); background:var(--white); border-radius:8px; padding:4px 8px; font-size:12px; cursor:pointer; color:var(--ink2); }
.pac-mini-btn:hover { border-color:var(--ink2); color:var(--ink); }
.ai-box { margin-top:12px; border:1px solid var(--border); background:#f8fbfa; border-radius:10px; padding:12px 14px; color:var(--ink2); font-size:12.5px; line-height:1.55; white-space:pre-wrap; }
.ai-box-head { display:flex; justify-content:space-between; align-items:center; gap:10px; margin-bottom:7px; color:var(--ink); font-weight:800; }
.ai-provider { color:var(--ink3); font-size:11px; font-weight:600; }
.ai-actions { display:flex; flex-wrap:wrap; gap:6px; align-items:center; }


/* ═══ CAIXA INTERNO ═══ */
.cx-entry {
  display: grid;
  grid-template-columns: 100px 1fr 110px 100px 90px 36px;
  border-bottom: 1px solid var(--border);
  transition: background .1s;
}
.cx-entry:hover { background: var(--bg); }
.cx-entry.depositado { opacity: .55; }
.cx-cell {
  padding: 11px 13px;
  font-size: 12.5px;
  color: var(--ink2);
  border-right: 1px solid var(--border);
  display: flex;
  align-items: center;
}
.cx-cell:last-child { border-right: none; justify-content: center; }
.cx-cell.mono { font-family: var(--font-mono); font-size: 12px; }

/* Card de depósito agrupado */
.cx-dep-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow: hidden;
}
.cx-dep-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  gap: 12px;
  cursor: pointer;
}
.cx-dep-head:hover { background: var(--bg2); }

/* Saldo do caixa */
.cx-saldo-box {
  background: var(--ink);
  color: white;
  border-radius: 12px;
  padding: 20px 24px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.cx-saldo-label { font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; opacity: .7; margin-bottom: 4px; }
.cx-saldo-val   { font-family: var(--font-mono); font-size: 28px; font-weight: 500; }
.cx-saldo-sub   { font-size: 12px; opacity: .6; margin-top: 3px; }
.cx-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin-bottom: 20px; }

/* Tabs */
.cx-tabs { display: flex; gap: 2px; background: var(--bg2); border-radius: 8px;
  padding: 3px; margin-bottom: 16px; }
.cx-tab  { flex: 1; padding: 7px 12px; border-radius: 6px; font-size: 13px;
  font-weight: 500; border: none; cursor: pointer; background: transparent;
  color: var(--ink2); transition: all .12s; text-align: center; }
.cx-tab.active { background: var(--white); color: var(--ink); box-shadow: var(--shadow-sm); }

/* Botão depositar */
.btn-depositar {
  padding: 5px 13px; border-radius: 7px; font-size: 12px; font-weight: 600;
  cursor: pointer; border: 1.5px solid var(--emerald-mid);
  background: var(--emerald-light); color: var(--emerald); transition: all .12s;
}
.btn-depositar:hover { background: var(--emerald); color: white; }
.btn-depositar:disabled { opacity: .4; cursor: default; }
