@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --ink:#0f172a;--ink2:#1e293b;--muted:#64748b;--line:rgba(15,23,42,.07);
  --glass:rgba(255,255,255,.60);--glass-brd:rgba(255,255,255,.65);
  --side:#0b1220;--side2:#111a2e;--indigo:#6366f1;--violet:#8b5cf6;--cyan:#06b6d4;
}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink2);min-height:100vh;
  background:
    radial-gradient(620px circle at 8% 6%,rgba(99,102,241,.30),transparent 55%),
    radial-gradient(560px circle at 95% 4%,rgba(236,72,153,.18),transparent 55%),
    radial-gradient(680px circle at 88% 92%,rgba(6,182,212,.22),transparent 55%),
    radial-gradient(520px circle at 18% 96%,rgba(139,92,246,.20),transparent 55%),
    linear-gradient(135deg,#eef2ff 0%,#faf5ff 45%,#ecfeff 100%);
  background-attachment:fixed;}
a{text-decoration:none;}
.app{display:flex;min-height:100vh;}
/* sidebar */
.side{width:248px;flex:0 0 248px;background:linear-gradient(180deg,var(--side),var(--side2));color:#cbd5e1;padding-bottom:24px;position:sticky;top:0;height:100vh;overflow-y:auto;}
.side::-webkit-scrollbar{width:7px;}.side::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px;}
.nav a.soon{opacity:.5;}
.nav a .tag{margin-left:auto;font-size:8px;font-weight:700;background:rgba(255,255,255,.08);color:#94a3b8;padding:2px 6px;border-radius:6px;text-transform:uppercase;letter-spacing:.03em;}
.brand{display:flex;align-items:center;gap:12px;padding:20px 22px;}
.brand .logo{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--indigo),var(--violet));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:15px;box-shadow:0 8px 20px rgba(99,102,241,.45);}
.brand b{color:#fff;font-size:15px;letter-spacing:.04em;}.brand small{display:block;color:#64748b;font-weight:500;font-size:11px;}
.logo svg{width:62%;height:62%;display:block;}
.brand .blogo{width:178px;height:auto;display:block;filter:drop-shadow(0 4px 10px rgba(0,0,0,.35));}
.login-card .blogo{width:220px;max-width:80%;height:auto;display:block;margin:0 auto 14px;}
.nav-sec{color:#475569;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:18px 22px 8px;}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 22px;color:#94a3b8;font-size:13.5px;font-weight:500;border-left:3px solid transparent;transition:.15s;}
.nav a svg{width:18px;height:18px;stroke:#64748b;}
.nav a:hover{background:rgba(255,255,255,.05);color:#e2e8f0;}
.nav a.active{color:#fff;border-left-color:var(--indigo);background:linear-gradient(90deg,rgba(99,102,241,.28),transparent);}
.nav a.active svg{stroke:#a5b4fc;}
/* main */
.main{flex:1;min-width:0;}
.topbar{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 26px;background:rgba(11,18,32,.72);backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:10;}
.crumb{color:#e2e8f0;font-weight:600;font-size:15px;}.crumb small{display:block;color:#7c8aa3;font-weight:500;font-size:11px;}
.top-right{display:flex;align-items:center;gap:10px;}
.pill{background:linear-gradient(135deg,rgba(99,102,241,.9),rgba(139,92,246,.9));color:#fff;font-size:12px;font-weight:700;padding:7px 14px;border-radius:999px;box-shadow:0 6px 16px rgba(99,102,241,.4);}
.ic{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);cursor:pointer;}
.ic svg{width:18px;height:18px;stroke:#cbd5e1;}
.avatar{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#22d3ee,#3b82f6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;}
.content{padding:26px;}
.page-h{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px;}
.page-h h1{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.4px;}
.page-h p{color:var(--muted);font-size:13px;margin-top:3px;}
.btn{border:none;cursor:pointer;font-family:inherit;font-weight:600;font-size:13px;padding:10px 16px;border-radius:11px;color:#fff;background:linear-gradient(135deg,var(--indigo),var(--violet));box-shadow:0 8px 18px rgba(99,102,241,.35);display:inline-flex;align-items:center;gap:8px;}
.btn svg{width:16px;height:16px;stroke:#fff;}
.btn.ghost{background:rgba(255,255,255,.7);color:#334155;box-shadow:none;border:1px solid rgba(15,23,42,.1);}
.btn.ghost svg{stroke:#334155;}
.grid{display:grid;gap:18px;}.g4{grid-template-columns:repeat(4,1fr);}.g2{grid-template-columns:1.6fr 1fr;}
.card{background:var(--glass);backdrop-filter:blur(16px) saturate(150%);-webkit-backdrop-filter:blur(16px) saturate(150%);border:1px solid var(--glass-brd);border-radius:20px;padding:20px;box-shadow:0 10px 34px rgba(15,23,42,.10),inset 0 1px 0 rgba(255,255,255,.6);}
.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;}
.tile{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;}
.tile svg{width:24px;height:24px;stroke:#fff;stroke-width:2.2;}
.t-green{background:linear-gradient(135deg,#10b981,#34d399);box-shadow:0 10px 20px rgba(16,185,129,.42);}
.t-orange{background:linear-gradient(135deg,#f97316,#fb923c);box-shadow:0 10px 20px rgba(249,115,22,.42);}
.t-red{background:linear-gradient(135deg,#ef4444,#f87171);box-shadow:0 10px 20px rgba(239,68,68,.42);}
.t-purple{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 10px 20px rgba(139,92,246,.42);}
.t-amber{background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 10px 20px rgba(245,158,11,.42);}
.t-fuchsia{background:linear-gradient(135deg,#a855f7,#d946ef);box-shadow:0 10px 20px rgba(168,85,247,.42);}
.t-blue{background:linear-gradient(135deg,#3b82f6,#06b6d4);box-shadow:0 10px 20px rgba(59,130,246,.42);}
.trend{font-size:11.5px;font-weight:700;padding:4px 9px;border-radius:999px;}
.up{color:#059669;background:rgba(16,185,129,.13);}.down{color:#dc2626;background:rgba(239,68,68,.13);}.flat{color:#64748b;background:rgba(100,116,139,.12);}
.kpi-num{font-size:34px;font-weight:800;color:var(--ink);letter-spacing:-1px;margin-top:14px;line-height:1;}
.kpi-num small{font-size:18px;color:var(--muted);font-weight:700;}
.kpi-lbl{color:var(--muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:6px;}
.spark{width:100%;height:34px;margin-top:12px;display:block;}
.sec-title{font-size:15px;font-weight:700;color:var(--ink);}.sec-sub{font-size:12px;color:var(--muted);}
.legend{display:flex;gap:16px;}.legend span{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:6px;}.ld{width:9px;height:9px;border-radius:3px;}
table{width:100%;border-collapse:collapse;}
.tbl thead th{text-align:left;font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:12px 18px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:rgba(255,255,255,.35);}
.tbl tbody td{padding:13px 18px;font-size:13px;color:var(--ink2);border-bottom:1px solid var(--line);}
.tbl tbody tr:hover{background:rgba(99,102,241,.05);}
.tbl tfoot td{padding:14px 18px;font-size:13.5px;border-top:1px solid var(--line);}
.tbl tbody tr:last-child td{border-bottom:0;}
.simple td{padding:13px 8px;font-size:13px;border-bottom:1px solid var(--line);}.simple th{text-align:left;font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:10px 8px;border-bottom:1px solid var(--line);}
.u{display:flex;align-items:center;gap:12px;}
.u .ava{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;}
.u b{color:var(--ink);font-weight:600;display:block;font-size:13.5px;}.u span{color:var(--muted);font-size:12px;}
.badge{font-size:11px;font-weight:700;padding:5px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;}
.b-ativo{background:rgba(16,185,129,.14);color:#059669;}.b-esg{background:rgba(249,115,22,.14);color:#ea580c;}.b-bloq{background:rgba(239,68,68,.14);color:#dc2626;}.b-teste{background:rgba(139,92,246,.14);color:#7c3aed;}
.on{width:9px;height:9px;border-radius:50%;display:inline-block;}.on-y{background:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.18);}.on-n{background:#cbd5e1;}
.venc b{color:var(--ink);font-weight:600;}.venc span{display:block;color:var(--muted);font-size:11px;}.venc .soon{color:#ea580c;}
.acts{display:flex;gap:6px;justify-content:flex-end;}
.act{width:30px;height:30px;border-radius:9px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s;}
.act svg{width:15px;height:15px;stroke:#64748b;}.act:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 10px rgba(15,23,42,.1);}
.toolbar{display:flex;gap:12px;align-items:center;padding:16px 18px;flex-wrap:wrap;}
.search{flex:1;position:relative;min-width:200px;}
.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;stroke:#94a3b8;}
.search input{width:100%;padding:11px 14px 11px 38px;border:1px solid rgba(15,23,42,.1);border-radius:11px;background:rgba(255,255,255,.7);font-family:inherit;font-size:13.5px;color:var(--ink2);outline:none;}
.foot{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;flex-wrap:wrap;gap:10px;}
.foot .info{font-size:12.5px;color:var(--muted);}
.pag{display:flex;gap:6px;}
.pag a,.pag span{min-width:32px;height:32px;border-radius:9px;border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.6);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--ink2);font-weight:600;padding:0 6px;}
.pag a.on{background:linear-gradient(135deg,var(--indigo),var(--violet));color:#fff;border:none;}
.chips{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.chip{flex:1;min-width:150px;background:var(--glass);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--glass-brd);border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 6px 20px rgba(15,23,42,.07);}
.chip .dot{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;}
.chip .dot svg{width:18px;height:18px;stroke:#fff;stroke-width:2.4;}
.chip b{font-size:20px;font-weight:800;color:var(--ink);display:block;line-height:1;}.chip span{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;}
.c-green{background:linear-gradient(135deg,#10b981,#34d399);}.c-orange{background:linear-gradient(135deg,#f97316,#fb923c);}.c-red{background:linear-gradient(135deg,#ef4444,#f87171);}.c-purple{background:linear-gradient(135deg,#8b5cf6,#a78bfa);}
.fchips{display:flex;gap:6px;flex-wrap:wrap;}
.fchip{font-size:12px;font-weight:600;padding:7px 13px;border-radius:999px;border:1px solid rgba(15,23,42,.12);color:var(--ink2);background:rgba(255,255,255,.5);transition:all .15s;}
.fchip:hover{border-color:#8b5cf6;color:#7c3aed;}
.fchip.on{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(99,102,241,.3);}
.iptip{position:relative;color:var(--muted);border-bottom:1px dashed rgba(99,102,241,.5);cursor:help;outline:none;}
.iptip-box{position:absolute;left:0;top:calc(100% + 8px);z-index:30;min-width:220px;background:#0f172a;color:#e2e8f0;border-radius:12px;padding:12px 14px;box-shadow:0 14px 40px rgba(15,23,42,.4);opacity:0;visibility:hidden;transform:translateY(-4px);transition:all .16s;display:flex;flex-direction:column;gap:3px;font-size:12px;font-weight:500;}
.iptip-box::before{content:"";position:absolute;left:18px;top:-6px;width:12px;height:12px;background:#0f172a;transform:rotate(45deg);}
.iptip-box b{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#818cf8;margin-bottom:2px;}
.iptip-box .mut{color:#94a3b8;font-size:11px;}
.iptip:hover .iptip-box,.iptip:focus .iptip-box{opacity:1;visibility:visible;transform:translateY(0);}
.statgrid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:18px;}
@media(max-width:1100px){.statgrid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:560px){.statgrid{grid-template-columns:repeat(2,1fr);}}
a.card.cardlink{text-decoration:none;color:inherit;display:block;cursor:pointer;transition:transform .2s,box-shadow .2s;}
a.card.cardlink:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(15,23,42,.16);}
.statc{border-radius:16px;padding:22px 18px;color:#fff;text-align:center;box-shadow:0 10px 28px rgba(15,23,42,.14);transition:transform .25s,box-shadow .25s;display:block;text-decoration:none;cursor:pointer;}
.statc:hover{transform:translateY(-4px);box-shadow:0 16px 38px rgba(15,23,42,.2);}
.statc h3{font-size:34px;font-weight:800;margin:0;line-height:1;text-shadow:0 2px 6px rgba(0,0,0,.18);}
.statc p{font-size:12.5px;margin:9px 0 0;opacity:.95;font-weight:600;}
.sc-purple{background:linear-gradient(135deg,#667eea,#764ba2);}
.sc-green{background:linear-gradient(135deg,#43a047,#7cb342);}
.sc-red{background:linear-gradient(135deg,#ff416c,#ff4b2b);}
.sc-amber{background:linear-gradient(135deg,#f7971e,#f5c518);}
.sc-cyan{background:linear-gradient(135deg,#36d1dc,#5b86e5);}
.sc-teal{background:linear-gradient(135deg,#11998e,#38ef7d);}
.fsection{margin-top:16px;margin-bottom:6px;padding:15px 16px;background:rgba(99,102,241,.05);border-radius:12px;border-left:4px solid #8b5cf6;}
.fsection h4{color:#6d5bd0;margin:0 0 12px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;}
.fcheck{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;}
.fcheck input{width:17px;height:17px;cursor:pointer;}
button.fchip{cursor:pointer;font-family:inherit;}
.lbl{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:5px;}
.inp{width:100%;padding:10px 12px;border:1px solid rgba(15,23,42,.12);border-radius:10px;background:rgba(255,255,255,.7);font-family:inherit;font-size:13px;color:var(--ink);}
.inp:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px rgba(139,92,246,.12);}
/* LOGIN */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;}
.login-card{width:100%;max-width:400px;background:var(--glass);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);border:1px solid var(--glass-brd);border-radius:24px;padding:34px 30px;box-shadow:0 20px 60px rgba(15,23,42,.18),inset 0 1px 0 rgba(255,255,255,.6);}
.login-card .logo{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,var(--indigo),var(--violet));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:18px;box-shadow:0 12px 26px rgba(99,102,241,.45);margin:0 auto 18px;}
.login-card h2{text-align:center;font-size:21px;font-weight:800;color:var(--ink);}
.login-card p{text-align:center;color:var(--muted);font-size:13px;margin:4px 0 22px;}
.field{margin-bottom:14px;}
.field label{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin-bottom:6px;}
.field input{width:100%;padding:12px 14px;border:1px solid rgba(15,23,42,.12);border-radius:12px;background:rgba(255,255,255,.8);font-family:inherit;font-size:14px;color:var(--ink);outline:none;}
.field input:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.18);}
.btn-full{width:100%;justify-content:center;padding:13px;font-size:14px;margin-top:6px;}
.alert{background:rgba(239,68,68,.12);color:#dc2626;border:1px solid rgba(239,68,68,.25);padding:11px 14px;border-radius:12px;font-size:13px;margin-bottom:16px;text-align:center;}
/* flash + acoes + modal */
.flash{background:rgba(16,185,129,.14);color:#059669;border:1px solid rgba(16,185,129,.3);padding:11px 16px;border-radius:12px;font-size:13px;margin-bottom:16px;font-weight:600;}
.flash.err{background:rgba(239,68,68,.12);color:#dc2626;border-color:rgba(239,68,68,.3);}
.acts form{display:inline;margin:0;}
button.act{font-family:inherit;}
.act.warn:hover svg{stroke:#f59e0b;}.act.ok:hover svg{stroke:#10b981;}.act.danger:hover svg{stroke:#ef4444;}.act.blue:hover svg{stroke:#3b82f6;}
.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:50;padding:20px;}
.modal-bg.show{display:flex;}
.modal{width:100%;max-width:540px;max-height:92vh;overflow:auto;background:rgba(255,255,255,.94);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-brd);border-radius:20px;padding:24px;box-shadow:0 30px 70px rgba(15,23,42,.3);}
.modal h3{font-size:18px;font-weight:800;color:var(--ink);margin-bottom:6px;}
.modal .sub{font-size:12.5px;color:var(--muted);margin-bottom:16px;}
.modal .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.modal label{display:block;font-size:12px;font-weight:600;color:var(--ink2);margin:10px 0 5px;}
.modal input,.modal select,.modal textarea{width:100%;padding:10px 12px;border:1px solid rgba(15,23,42,.12);border-radius:10px;background:#fff;font-family:inherit;font-size:13.5px;color:var(--ink);outline:none;}
.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.15);}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;}
.btn-sec{background:rgba(15,23,42,.06)!important;color:#334155!important;box-shadow:none!important;}
.modal-head{margin:-24px -24px 18px;padding:18px 24px;border-radius:20px 20px 0 0;background:linear-gradient(120deg,#6366f1,#06b6d4);color:#fff;font-weight:800;font-size:17px;display:flex;align-items:center;gap:10px;}
.modal-head svg{width:22px;height:22px;stroke:#fff;}
.periodos{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;}
.periodo{border:none;cursor:pointer;font-family:inherit;color:#fff;font-weight:700;font-size:14px;padding:22px 10px;border-radius:14px;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 8px 18px rgba(0,0,0,.15);transition:.15s;}
.periodo:hover{transform:translateY(-3px);filter:brightness(1.06);}
.periodo svg{width:22px;height:22px;stroke:#fff;}
.p-green{background:linear-gradient(135deg,#10b981,#34d399);}
.p-purple{background:linear-gradient(135deg,#8b5cf6,#a78bfa);}
.p-orange{background:linear-gradient(135deg,#f59e0b,#fb923c);}
.p-indigo{background:linear-gradient(135deg,#6366f1,#818cf8);}
.p-red{background:linear-gradient(135deg,#ef4444,#f87171);}
.perfis-box{display:flex;flex-wrap:wrap;gap:10px;}
.perfil-chk{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink2);background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.22);padding:8px 12px;border-radius:10px;cursor:pointer;}
.perfil-chk input{width:auto!important;margin:0;}
.srv-badge{display:inline-block;font-size:10.5px;font-weight:700;color:#4f46e5;background:rgba(99,102,241,.12);border-radius:7px;padding:3px 8px;margin:1px 2px 1px 0;}
.ch{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink);max-width:230px;}
.ch b{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ch-tag{flex:none;font-size:9.5px;font-weight:700;letter-spacing:.3px;color:#0369a1;background:rgba(14,165,233,.13);border-radius:6px;padding:2px 6px;}
.ch-logo{flex:none;height:24px;width:auto;max-width:48px;object-fit:contain;border-radius:4px;background:#fff;padding:1px 2px;box-shadow:0 1px 3px rgba(0,0,0,.12);}
.fatura{display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;position:relative;overflow:hidden;margin-bottom:18px;padding-left:24px;}
.fatura::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg,#6366f1,#8b5cf6);}
.fatura-l{min-width:240px;}
.fatura-tag{font-size:11px;font-weight:800;letter-spacing:.09em;text-transform:uppercase;color:#7c3aed;}
.fatura-total{font-size:42px;font-weight:800;color:var(--ink);line-height:1.02;margin:6px 0 12px;letter-spacing:-1px;}
.fatura-meta{display:flex;gap:8px;flex-wrap:wrap;}
.fatura-chip{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink2);background:rgba(15,23,42,.05);border-radius:999px;padding:6px 12px;}
.fatura-chip b{color:var(--ink);}
.fatura-chip.chip-due{background:rgba(239,68,68,.12);color:#b91c1c;}
.fatura-chip.chip-ok{background:rgba(34,197,94,.14);color:#0f7a3d;}
.fatura-r{display:flex;flex-direction:column;align-items:flex-end;gap:10px;text-align:right;}
.fatura-r .btn{font-size:15px;padding:13px 26px;}
.rfr{display:inline-flex;align-items:center;gap:8px;color:var(--muted);}
.rfr-count{min-width:42px;font-size:12px;font-weight:700;color:#0369a1;}
.perfil-imgs{display:flex;flex-wrap:wrap;gap:4px;align-items:center;}
.perfil-ic{width:30px;height:30px;border-radius:50%;object-fit:contain;padding:2px;background:#fff;border:1.5px solid #fff;box-shadow:0 0 0 1px rgba(15,23,42,.12),0 1px 3px rgba(15,23,42,.18);cursor:help;transition:transform .12s;}
.perfil-ic:hover{transform:scale(1.7);box-shadow:0 6px 16px rgba(15,23,42,.28);position:relative;z-index:5;}
.tb-sel{padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:13px;background:#fff;color:var(--ink2);cursor:pointer;}
.ic.ic-wa svg{stroke:#25d366;}
.ic.ic-tg svg{stroke:#29a9eb;}
.ic.ic-wa:hover{background:rgba(37,211,102,.18);}
.ic.ic-tg:hover{background:rgba(41,169,235,.18);}
.info-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:13.5px;}
.info-row span{color:var(--muted);}.info-row b{color:var(--ink);font-weight:600;text-align:right;}
/* selo de status OSCam */
.osbadge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;padding:7px 13px;border-radius:999px;border:1px solid transparent;}
.osbadge .osdot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.os-on{color:#047857;background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.3);}
.os-on .osdot{background:#10b981;box-shadow:0 0 0 3px rgba(16,185,129,.2);animation:ospulse 1.8s infinite;}
.os-off{color:#b91c1c;background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.28);}
.os-off .osdot{background:#ef4444;}
.os-safe{color:#92400e;background:rgba(245,158,11,.13);border-color:rgba(245,158,11,.3);}
@keyframes ospulse{0%,100%{opacity:1;}50%{opacity:.45;}}
/* badge de sincronização OSCam por usuário */
.syncb{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:7px;}
.sync-ok{color:#047857;background:rgba(16,185,129,.12);}
.sync-pend{color:#92400e;background:rgba(245,158,11,.13);}
.sync-fail{color:#b91c1c;background:rgba(239,68,68,.1);}
.sync-na{color:#64748b;background:rgba(100,116,139,.1);}
/* ============================================================
   RESPONSIVO (mobile) — gaveta da sidebar + tabelas em cards
   ============================================================ */
.hamb{display:none;width:38px;height:38px;border-radius:11px;align-items:center;justify-content:center;background:rgba(255,255,255,.08);cursor:pointer;border:none;flex:none;}
.hamb svg{width:20px;height:20px;stroke:#cbd5e1;}
.tb-left{display:flex;align-items:center;gap:10px;min-width:0;}
.menu-ov{position:fixed;inset:0;background:rgba(15,23,42,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:55;display:none;}
.menu-ov.show{display:block;}

@media(max-width:920px){
  .side{position:fixed;top:0;left:0;height:100vh;z-index:60;transform:translateX(-100%);
    transition:transform .25s ease;box-shadow:0 0 40px rgba(0,0,0,.45);}
  .side.open{transform:translateX(0);}
  .hamb{display:flex;}
  .main{width:100%;min-width:0;}
  .content{padding:18px 14px;}
  .crumb{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .g4,.g2{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .topbar{padding:0 14px;}
  .top-right{gap:6px;}
  .pill{display:none;}
  .page-h h1{font-size:19px;}
}

/* tabelas .tbl viram cartoes em telas estreitas */
@media(max-width:760px){
  .tbl thead{display:none;}
  .tbl,.tbl tbody,.tbl tbody tr,.tbl tbody td{display:block;width:100%;}
  .tbl tbody tr{background:rgba(255,255,255,.55);border:1px solid var(--line);
    border-radius:14px;margin-bottom:12px;padding:4px 2px;overflow:hidden;
    box-shadow:0 4px 14px rgba(15,23,42,.06);}
  .tbl tbody tr:hover{background:rgba(255,255,255,.55);}
  .tbl tbody td{border:none!important;display:flex;align-items:center;gap:14px;
    justify-content:space-between;padding:9px 14px;text-align:right;font-size:13px;
    border-bottom:1px solid var(--line)!important;}
  .tbl tbody tr td:last-child{border-bottom:none!important;}
  .tbl tbody td::before{content:attr(data-label);flex:0 0 38%;text-align:left;
    font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);}
  .tbl tbody td:empty{display:none;}
  .tbl tbody td>*{margin-left:auto;}
  .u{justify-content:flex-end;}
  .acts{justify-content:flex-end;width:100%;}
  .ch{max-width:100%;}
  /* toolbar/rodape/filtros respiram */
  .toolbar,.foot{padding:14px;}
  .search{min-width:100%;}
  .chips,.fchips{gap:8px;}
}
