/* UI v6 - modern + responsive */
:root{--bg:#f3f6fb;--card:#fff;--ink:#0f172a;--muted:#64748b;--line:#e6edf7;--shadow:0 10px 30px rgba(15,23,42,.08);--radius:16px;--primary:#2563eb;--primary2:#1d4ed8;--danger:#ef4444;--danger2:#dc2626;--green:#16a34a;--orange:#d97706;--red:#dc2626;--blue:#2563eb}
*{box-sizing:border-box}html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--ink);
background:radial-gradient(1200px 600px at 20% -10%, #e7f0ff 0%, transparent 60%),radial-gradient(1200px 600px at 90% 0%, #e9fbff 0%, transparent 55%),var(--bg)}
.page{max-width:1200px;margin:22px auto 26px;padding:0 18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.muted{color:var(--muted);font-size:12.5px;line-height:1.4}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;background:rgba(255,255,255,.7);border:1px solid var(--line);border-radius:18px;backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.brand{display:flex;align-items:center;gap:12px;min-width:280px}
.brand-logo{width:48px;height:48px;object-fit:contain;border-radius:12px;background:#fff;border:1px solid var(--line);padding:6px}
.brand h1{margin:0;font-size:18px}.brand p{margin:2px 0 0;font-size:12.5px;color:var(--muted)}
.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.btn{appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink);padding:10px 12px;border-radius:12px;font-weight:600;font-size:13px;cursor:pointer;transition:transform .06s ease,background .2s ease,border-color .2s ease}
.btn:hover{background:#f7faff;border-color:#d5e3ff}.btn:active{transform:translateY(1px)}
.btn.primary{background:linear-gradient(180deg,var(--primary),var(--primary2));color:#fff;border-color:transparent}
.btn.danger{background:linear-gradient(180deg,var(--danger),var(--danger2));color:#fff;border-color:transparent}
.hero{margin-top:14px;display:flex;flex-direction:column;gap:14px}
.filters{display:flex;justify-content:space-between;gap:14px;padding:14px;background:rgba(255,255,255,.75);border:1px solid var(--line);border-radius:18px;backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.filter-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.filter-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.label{color:var(--muted);font-size:13px}.pills{display:flex;gap:8px}
.pill{border:1px solid var(--line);background:#fff;padding:8px 10px;border-radius:999px;cursor:pointer;font-weight:700;font-size:12.5px;color:#334155}
.pill.active{border-color:#c7dcff;background:#eef5ff;color:#1d4ed8}
.range,.month{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.range label,.month label{color:var(--muted);font-size:12px}
.quick{display:flex;gap:6px;flex-wrap:wrap}
.chip{border:1px solid var(--line);background:#fff;padding:7px 9px;border-radius:999px;font-size:12px;cursor:pointer;color:#334155}
.chip:hover{background:#f7faff}
.hint{font-size:12.5px;color:var(--muted)}
.input{width:220px;border:1px solid var(--line);background:#fff;padding:10px 12px;border-radius:12px;outline:none;font-size:13px}
.input:focus{border-color:#b7d0ff;box-shadow:0 0 0 4px rgba(37,99,235,.10)}
.input.small{width:140px}.input.tiny{width:92px;padding:8px 10px;border-radius:10px}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi{padding:14px}.kpi-title{color:var(--muted);font-size:12px;font-weight:700}.kpi-value{font-size:26px;font-weight:900;margin-top:6px}.kpi-sub{color:var(--muted);font-size:12px;margin-top:4px}
.green{color:var(--green)}.orange{color:var(--orange)}.red{color:var(--red)}.blue{color:var(--blue)}
.dash{padding:14px}.dash-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:8px}
.dash-title{font-weight:900}.dash-note{color:var(--muted);font-size:12px}
.dash-chart{border:1px solid var(--line);border-radius:14px;padding:10px;background:#fbfdff;height:300px}
.content{margin-top:14px}.panel{padding:14px}
.tabs{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.tab{border:1px solid var(--line);background:#fff;padding:9px 12px;border-radius:999px;cursor:pointer;font-weight:800;color:#334155}
.tab.active{border-color:#c7dcff;background:#eef5ff;color:#1d4ed8}
.form{display:flex;flex-direction:column;gap:10px}.row{display:flex;gap:10px;flex-wrap:wrap}
.field{display:flex;flex-direction:column;gap:6px;min-width:220px;flex:1}
.field>label{font-size:12px;color:var(--muted);font-weight:800}
.field .input{width:100%}
.field.actions{min-width:160px;flex:0;justify-content:flex-end}
.field.actions>label{visibility:hidden}
.field.actions .btn{width:100%}
.table-head{margin-top:14px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.table-left{display:flex;align-items:center;gap:10px}
.pager{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.pagebtn{border:1px solid var(--line);background:#fff;padding:8px 10px;border-radius:12px;font-weight:800;font-size:12px;cursor:pointer}
.pagebtn.active{background:#eef5ff;border-color:#c7dcff;color:#1d4ed8}.pagebtn:disabled{opacity:.5;cursor:not-allowed}
.table-wrap{margin-top:10px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;max-height:520px}
.table{width:100%;border-collapse:collapse;font-size:13px}
thead th{position:sticky;top:0;background:#f8fbff;border-bottom:1px solid var(--line);padding:10px;text-align:left;color:#334155;font-size:12px;letter-spacing:.02em;z-index:2}
tbody td{border-bottom:1px solid var(--line);padding:10px;vertical-align:middle}
tbody tr:hover{background:#fbfdff}.right{text-align:right}
.badge{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;border:1px solid var(--line);background:#fff;display:inline-flex;gap:6px;align-items:center}
.badge.in{background:#ecfdf3;border-color:#bbf7d0;color:#166534}.badge.out{background:#fff1f2;border-color:#fecdd3;color:#9f1239}.badge.rec{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.row-actions{display:flex;gap:8px;justify-content:flex-end}
.iconbtn2{border:1px solid var(--line);background:#fff;padding:7px 10px;border-radius:12px;cursor:pointer;font-weight:900;font-size:12px;display:inline-flex;align-items:center;gap:6px}
.iconbtn2:hover{background:#f7faff}.iconbtn2.danger{border-color:#ffd3d3;background:#fff7f7}.iconbtn2.danger:hover{background:#fff1f1}
.footer{margin-top:16px;text-align:center;color:var(--muted);font-size:12.5px;padding:10px 0}
dialog::backdrop{background:rgba(15,23,42,.45)}
.modal{width:min(720px,92vw);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:0;overflow:hidden}
.modal.modal-wide{width:min(980px,96vw)}
.textarea-lg{min-height:260px;resize:vertical}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px;background:#f8fbff;border-bottom:1px solid var(--line)}
.modal-title{font-weight:900}
.iconbtn{border:1px solid var(--line);background:#fff;width:34px;height:34px;border-radius:12px;cursor:pointer;font-weight:900}
.modal-body{padding:14px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:12px 14px;border-top:1px solid var(--line);background:#fbfdff}
.modal-hint{margin-top:10px;color:var(--muted);font-size:12px}
@media(max-width:980px){.cards{grid-template-columns:repeat(2,1fr)}.input{width:100%}.filter-right{justify-content:flex-start}}
@media(max-width:640px){.topbar{flex-direction:column;align-items:flex-start}.actions{width:100%;justify-content:flex-start}.cards{grid-template-columns:1fr}.filters{flex-direction:column}.dash-chart{height:260px}.table-wrap{max-height:420px}}

/* === Financeiro (Boletos) extras === */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:980px){.grid2{grid-template-columns:1fr}}

.badge.status{font-weight:900}
.badge.status.pago{background:#eef5ff;border-color:#c7dcff;color:#1d4ed8}
.badge.status.aguardando{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.badge.status.sem_contato{background:#fefce8;border-color:#fde68a;color:#854d0e}

.row-alert{background:#fff1f2}
