:root{--ink:#11161f;--ink-2:#1c2533;--panel:#ffffff;--bg:#eef1f6;--muted:#6b7686;--line:#e3e7ee;--line-2:#d3d9e3;--brand:#1d2a4d;--brand-2:#2c3e6e;--accent:#0f9d8c;--accent-soft:#e2f5f1;--gold:#b8893b;--gold-soft:#f6edda;--ok:#1f9d55;--ok-soft:#e4f5ec;--warn:#c9821a;--warn-soft:#fbeed9;--info:#2f6fdb;--info-soft:#e6eefb;--danger:#c0392b;--danger-soft:#fbe7e4;--client:#7a3bb8;--client-soft:#f1e8fa;--supplier:#0f6f9d;--supplier-soft:#e2f1f8;--radius:12px;--shadow:0 1px 2px rgba(17,22,31,.06),0 8px 24px rgba(17,22,31,.06)}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit}a{color:inherit;text-decoration:none}.login-wrap{display:grid;place-items:center;min-height:100vh;background:radial-gradient(1200px 600px at 70% -10%,#2c3e6e 0%,transparent 60%),var(--brand)}.login{background:var(--panel);border-radius:18px;box-shadow:0 30px 80px #0006;width:380px;padding:34px 32px;text-align:center}.login .seal{width:52px;height:52px;border-radius:14px;margin:0 auto 16px;font-size:20px}.login h2{margin:0 0 4px;font-size:24px}.login p{color:var(--muted);margin:0 0 22px;font-size:13px}.zbtn{width:100%;background:var(--ink);color:#fff;border:0;padding:13px;border-radius:10px;font-weight:700;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px}.zbtn:hover{background:#000}.login .ftr{font-size:11px;color:var(--muted);margin-top:20px}.login-roles{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;margin:10px 0 2px}.seal{border-radius:9px;background:linear-gradient(135deg,var(--accent),#0c7d70);display:grid;place-items:center;color:#fff;font-weight:800;box-shadow:inset 0 0 0 2px #ffffff2e}.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}.side{background:var(--brand);color:#cfd6e6;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px}.brand .seal{width:34px;height:34px}.brand b{color:#fff;font-size:16px;letter-spacing:.2px}.brand small{display:block;color:#8d98b5;font-size:11px;font-weight:500;margin-top:1px}.tenant{margin:0 12px 6px;background:var(--brand-2);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:9px 11px;cursor:pointer;position:relative}.tenant .lab{color:#8d98b5;font-size:9.5px;text-transform:uppercase;letter-spacing:.8px;font-weight:700}.tenant .cur{display:flex;align-items:center;gap:8px;margin-top:4px}.tenant .ti{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-weight:800;font-size:11px;color:#fff;flex-shrink:0}.tenant b{color:#fff;font-size:13px;line-height:1.15;display:block}.tenant .none{color:#8d98b5;font-size:12.5px}.tenant .chev{margin-left:auto;color:#8d98b5}.tmenu{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border-radius:10px;box-shadow:0 16px 40px #00000059;padding:6px;z-index:30;max-height:320px;overflow:auto}.tmenu .opt{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:8px;cursor:pointer;color:var(--ink)}.tmenu .opt:hover{background:var(--bg)}.tmenu .opt.active{background:var(--accent-soft)}.tmenu .opt b{color:var(--ink);font-size:13px}.tmenu .opt .ti{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-weight:800;font-size:11px;color:#fff;flex-shrink:0}.tmenu .empty{padding:10px 9px;color:var(--muted);font-size:12.5px}.nav{padding:6px 10px;flex:1;overflow:auto}.nav .grp{color:#74809f;font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;margin:13px 10px 6px;font-weight:700}.nav a{display:flex;align-items:center;gap:11px;padding:8px 11px;border-radius:9px;color:#cfd6e6;font-weight:500;cursor:pointer;margin:2px 0;font-size:13.5px}.nav a .ic{width:18px;text-align:center;opacity:.85}.nav a:hover{background:#ffffff0f;color:#fff}.nav a.active{background:var(--brand-2);color:#fff;box-shadow:inset 0 0 0 1px #ffffff12}.nav a.disabled{opacity:.45;cursor:not-allowed}.nav a .pill{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px}.side .who{border-top:1px solid rgba(255,255,255,.08);padding:11px 16px;display:flex;align-items:center;gap:10px}.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#56a,#33407a);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;flex-shrink:0}.who small{color:#8d98b5;font-size:11px;display:block}.who b{color:#fff;font-size:12.5px}.who .out{margin-left:auto;color:#8d98b5;background:transparent;border:0;cursor:pointer;font-size:16px}.who .out:hover{color:#fff}.main{display:flex;flex-direction:column;min-width:0}.topbar{background:var(--panel);border-bottom:1px solid var(--line);padding:11px 26px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:5}.topbar h1{font-size:17px;margin:0;font-weight:700}.ctx{display:flex;align-items:center;gap:8px;background:var(--accent-soft);border:1px solid #bfe7e0;color:#0b6e63;font-weight:700;font-size:12px;padding:5px 11px;border-radius:8px}.ctx.none{background:var(--bg);border-color:var(--line);color:var(--muted)}.ctx .ti{width:18px;height:18px;border-radius:5px;display:grid;place-items:center;font-weight:800;font-size:10px;color:#fff}.role-tag{margin-left:auto;background:var(--gold-soft);color:var(--gold);border:1px solid #ecdcbb;font-weight:600;padding:5px 10px;border-radius:8px;font-size:11.5px}.content{padding:24px 26px 40px;overflow:auto}.page-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px;flex-wrap:wrap}.page-head h2{font-size:20px;margin:0 0 2px;letter-spacing:-.3px}.page-head p{margin:0;color:var(--muted);font-size:13px}.page-head .spacer{margin-left:auto}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:16px 18px}.client-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.client-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative}.client-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 8px #11161f14,0 16px 40px #11161f1a}.client-card.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent),var(--shadow)}.client-card .ti-lg{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;font-weight:800;color:#fff;font-size:16px;margin-bottom:12px}.client-card b{font-size:15px;display:block}.client-card .sub{color:var(--muted);font-size:12px;margin-top:3px}.client-card .chip{position:absolute;top:14px;right:14px;font-size:10.5px;font-weight:700;color:var(--accent);background:var(--accent-soft);border-radius:20px;padding:2px 8px}.btn{border:1px solid var(--line-2);background:var(--panel);padding:8px 14px;border-radius:9px;font-weight:600;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:7px;color:var(--ink)}.btn:hover{border-color:#b9c1cf}.btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn.primary:hover{background:var(--brand-2)}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.accent:hover{background:#0c8a7b}.btn:disabled{opacity:.55;cursor:not-allowed}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;padding:11px 16px;border-bottom:1px solid var(--line);background:#fafbfd}tbody td{padding:12px 16px;border-bottom:1px solid var(--line)}tbody tr:last-child td{border-bottom:0}.doc-id{font-weight:700}.mono{font-variant-numeric:tabular-nums}.amt{font-variant-numeric:tabular-nums;font-weight:700;text-align:right}th.amt{text-align:right}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:700;white-space:nowrap}.t-supplier{background:var(--supplier-soft);color:var(--supplier)}.state{padding:48px 24px;text-align:center;color:var(--muted)}.state .ico{font-size:30px;display:block;margin-bottom:10px;opacity:.7}.state b{display:block;color:var(--ink);font-size:15px;margin-bottom:4px}.state.err b{color:var(--danger)}.spinner{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;display:inline-block;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.banner{margin-bottom:16px;background:var(--danger-soft);border:1px solid #f1c8c2;color:#962a1f;padding:11px 14px;border-radius:10px;font-size:12.5px;display:flex;gap:10px;align-items:center}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11161f80;display:grid;place-items:center;z-index:60;padding:20px}.modal{background:var(--panel);border-radius:16px;box-shadow:0 30px 80px #0006;width:420px;max-width:100%;padding:24px}.modal h3{margin:0 0 4px;font-size:18px}.modal .hint{color:var(--muted);font-size:12.5px;margin:0 0 18px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;font-weight:600;color:var(--ink-2);margin-bottom:6px}.field input{width:100%;border:1px solid var(--line-2);border-radius:9px;padding:10px 12px;font-size:14px;font-family:inherit}.field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field .help{font-size:11px;color:var(--muted);margin-top:5px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.form-err{color:var(--danger);font-size:12px;margin-top:10px}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.kpi{padding:16px 18px}.kpi .lab{color:var(--muted);font-size:12px;font-weight:600;display:flex;align-items:center;gap:7px}.kpi .val{font-size:26px;font-weight:780;letter-spacing:-.5px;margin-top:7px}.kpi .delta{font-size:11.5px;font-weight:600;margin-top:5px;color:var(--muted)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.ch{padding:16px 18px}.ch h3{margin:0 0 4px;font-size:15px}.ch .hint{color:var(--muted);font-size:12.5px;margin:0 0 14px}.bars{display:flex;align-items:flex-end;gap:12px;height:150px;padding-top:6px}.bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:6px;height:100%}.bar i{width:60%;max-width:46px;min-height:2px;border-radius:6px 6px 0 0;transition:height .3s ease}.bar small{color:var(--muted);font-size:11px}.legend{display:flex;gap:16px;margin-top:12px;font-size:12px;color:var(--muted);flex-wrap:wrap}.legend span{display:flex;align-items:center;gap:6px}@media(max-width:880px){.kpis{grid-template-columns:repeat(2,1fr)}}.badge.st-idle{background:var(--info-soft);color:var(--info)}.badge.st-ok{background:var(--ok-soft);color:var(--ok)}.badge.st-error{background:var(--danger-soft);color:var(--danger)}.muted-sm{margin-top:4px;font-size:11px;color:var(--muted);max-width:260px}.row-actions{display:flex;gap:8px;justify-content:flex-end;white-space:nowrap}.btn.sm{padding:5px 10px;font-size:12px}.btn.danger-ghost{color:var(--danger);border-color:#f1c8c2}.btn.danger-ghost:hover{background:var(--danger-soft);border-color:#e6a79f}.field input:disabled{background:#f4f6fa;color:var(--muted);cursor:not-allowed}
