:root{--bg: #f4f5f7;--panel: #ffffff;--border: #e1e4e8;--text: #1f2328;--muted: #656d76;--accent: #1f6feb;--accent-d: #1858c2;--ok: #1a7f37;--warn: #9a6700;--err: #cf222e;--warn-bg: #fff8c5;--err-bg: #ffebe9;--shadow: 0 1px 3px rgba(27, 31, 36, .08)}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background-color:var(--bg);background-image:radial-gradient(1100px 560px at 100% -8%,rgba(31,111,235,.07),transparent 60%),radial-gradient(820px 480px at -8% 108%,rgba(26,127,55,.06),transparent 55%);background-attachment:fixed;color:var(--text);font-size:14px;line-height:1.45}:root[data-theme=dark] body{background-image:radial-gradient(1100px 560px at 100% -8%,rgba(56,139,253,.12),transparent 60%),radial-gradient(820px 480px at -8% 108%,rgba(63,185,80,.1),transparent 55%)}a{color:var(--accent)}.login-wrap{position:relative;min-height:100vh;display:grid;place-items:center;padding:1rem}.login-toggle{position:absolute;top:1rem;right:1rem}.login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--border);border-top:3px solid var(--accent);border-radius:14px;box-shadow:0 12px 40px #1b1f2429;padding:2rem}.login-brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1.5rem}.login-logo{flex:0 0 auto;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:var(--accent);color:#fff}.login-card h1{margin:0;font-size:1.3rem}.login-card p.sub{margin:.15rem 0 0;color:var(--muted);font-size:.85rem}.topbar{background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem;padding:.6rem 1.25rem;position:sticky;top:0;z-index:10}.topbar .brand{font-weight:700;font-size:1.05rem;white-space:nowrap}.topbar .spacer{flex:1}.topbar .user{color:var(--muted);white-space:nowrap}.nav{display:flex;gap:.25rem;padding:0 1.25rem;background:var(--panel);border-bottom:1px solid var(--border)}.nav button{background:none;border:none;border-bottom:2px solid transparent;padding:.6rem .9rem;cursor:pointer;color:var(--muted);font-size:.95rem}.nav button:hover{color:var(--text)}.nav button.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.content{max-width:1200px;margin:1.5rem auto;padding:0 1.25rem}label.field{display:block;margin-bottom:.9rem}label.field>span{display:block;margin-bottom:.25rem;color:var(--muted);font-size:.85rem}input[type=text],input[type=password],input[type=number],select{width:100%;padding:.5rem .6rem;border:1px solid var(--border);border-radius:8px;font:inherit;background:#fff}input:focus,select:focus{outline:2px solid var(--accent);outline-offset:-1px}.row{display:flex;gap:.75rem;align-items:flex-end;flex-wrap:wrap}.row label.field{margin-bottom:0}.checkbox{display:flex;align-items:center;gap:.45rem;cursor:pointer}.checkbox input{width:auto}button.btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.5rem .9rem;font:inherit;font-weight:600;cursor:pointer}button.btn:hover{background:var(--accent-d)}button.btn:disabled{opacity:.5;cursor:not-allowed}button.btn.full{width:100%}button.btn.ghost{background:none;color:var(--accent);border:1px solid var(--border)}button.btn.ghost:hover{background:#f0f4ff}button.btn.danger{background:var(--err)}button.btn.danger:hover{background:#a40e26}button.btn.sm{padding:.3rem .6rem;font-size:.85rem}.panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:1.25rem;margin-bottom:1.25rem}.panel h2{margin:0 0 1rem;font-size:1.15rem}.panel h3{margin:1.25rem 0 .5rem;font-size:1rem}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.45rem .6rem;border-bottom:1px solid var(--border);vertical-align:middle}th{color:var(--muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.02em}td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}tr:hover td{background:#fafbfc}.table-scroll{overflow-x:auto}.tag{display:inline-block;padding:.1rem .45rem;border-radius:999px;font-size:.75rem;font-weight:600}.tag.ok{background:#dafbe1;color:var(--ok)}.tag.muted{background:#eaeef2;color:var(--muted)}.saldo-plus{color:var(--ok);font-weight:600}.saldo-minus{color:var(--err);font-weight:600}.msg{padding:.6rem .8rem;border-radius:8px;margin-bottom:1rem}.msg.err{background:var(--err-bg);color:var(--err)}.msg.warn{background:var(--warn-bg);color:var(--warn)}.msg.info{background:#ddf4ff;color:var(--accent-d)}.msg.ok{background:#dafbe1;color:var(--ok)}.muted{color:var(--muted)}.center{text-align:center}.loading{padding:2rem;text-align:center;color:var(--muted)}.unassigned select{border-color:var(--warn);background:#fffdf5}button.btn.ghost.active{background:var(--accent);color:#fff;border-color:var(--accent)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b1f2459;z-index:20}.drawer{position:fixed;top:0;right:0;height:100vh;width:min(760px,94vw);background:var(--panel);border-left:1px solid var(--border);box-shadow:-6px 0 22px #1b1f2438;z-index:21;display:flex;flex-direction:column;animation:drawer-in .18s ease-out}@keyframes drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.7rem 1rem;border-bottom:1px solid var(--border)}.drawer-actions{display:flex;gap:.5rem;white-space:nowrap}.drawer-frame{flex:1;width:100%;border:none;background:#525659}:root[data-theme=dark]{--bg: #0d1117;--panel: #161b22;--border: #30363d;--text: #e6edf3;--muted: #9198a1;--accent: #4493f8;--accent-d: #2f81f7;--ok: #3fb950;--warn: #d29922;--err: #f85149;--warn-bg: #2e2a13;--err-bg: #2c1416;--shadow: 0 1px 3px rgba(1, 4, 9, .7);color-scheme:dark}[data-theme=dark] input[type=text],[data-theme=dark] input[type=password],[data-theme=dark] input[type=number],[data-theme=dark] select{background:#0d1117;color:var(--text)}[data-theme=dark] button.btn.ghost:hover{background:#1f2937}[data-theme=dark] tr:hover td{background:#1c2128}[data-theme=dark] .tag.ok{background:#3fb9502e}[data-theme=dark] .tag.muted{background:#21262d}[data-theme=dark] .msg.info{background:#122031;color:#6cb6ff}[data-theme=dark] .msg.ok{background:#3fb95026}[data-theme=dark] .unassigned select{background:#251f10}.inline-edit{width:100%;border:1px solid transparent;background:transparent;color:var(--text);font:inherit;padding:.3rem .45rem;border-radius:6px}.inline-edit:hover{border-color:var(--border)}.inline-edit:focus{border-color:var(--accent);background:var(--panel);outline:none}.inline-edit::placeholder{color:var(--muted);opacity:.7}.btn.icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin:.25rem 0 1.25rem}.stat-card{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:.7rem .9rem}.stat-card .muted{font-size:.78rem;text-transform:uppercase;letter-spacing:.02em}.stat-card strong{display:block;margin-top:.2rem;font-size:1.25rem}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:1rem;margin-bottom:1.25rem}.panel-inner{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:1rem 1.1rem}.panel-inner h3{font-size:1rem;margin-bottom:.8rem}
