:root{--brand-primary: #0f172a;--brand-secondary: #2563eb;--ink: #0f172a;--bg: #ffffff;--muted: #6b7280;--card: #f8fafc;--ring: #e5e7eb}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg)}.screen{min-height:100%;display:grid;place-items:center;padding:24px}.card{background:var(--card);border:1px solid var(--ring);border-radius:14px;padding:20px;width:min(720px,100%)}.card h2{margin:0 0 12px}.brand{display:flex;gap:12px;align-items:center;margin-bottom:12px}.brand img{height:32px}.appbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--ring);position:sticky;top:0;background:#fff}.brand-l{display:flex;gap:10px;align-items:center}.brand-l img{height:28px}.logo-fallback{width:28px;height:28px;border-radius:8px;background:var(--brand-secondary)}.appbar h1{margin:0;font-size:18px}.subtitle{font-size:12px;color:var(--muted)}.actions button{padding:8px 12px}.content{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px}.panel{background:var(--card);border:1px solid var(--ring);border-radius:14px;padding:16px}.grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.addrow{display:grid;grid-template-columns:120px 1fr 1fr 100px;gap:8px;margin:10px 0}.addrow input{padding:8px;border:1px solid var(--ring);border-radius:10px}.addrow button{padding:8px 12px}.summary{display:flex;gap:16px;margin:8px 0 12px}.summary .neg{color:#dc2626}.list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.list li{display:grid;grid-template-columns:120px 1fr 1fr;gap:8px;padding:8px;border:1px solid var(--ring);border-radius:10px;background:#fff}.muted{color:var(--muted)}.charts{display:grid;grid-template-columns:1fr 1fr;gap:12px}.chart.card{padding:12px}.bar{background:#e5e7eb;border-radius:999px;height:10px;overflow:hidden}.bar-fill{height:10px;background:var(--brand-secondary);width:0;transition:width .3s}.pie{width:120px;height:120px;display:block;margin:8px auto;transform:rotate(-90deg);color:var(--brand-secondary)}.legend-col{columns:2;font-size:12px;margin:0;padding:0;list-style:none}.legend-col li{break-inside:avoid;margin-bottom:4px}.swatch{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:6px;background:var(--brand-secondary)}.s1{color:#2563eb;background:#2563eb}.s2{color:#16a34a;background:#16a34a}.s3{color:#f59e0b;background:#f59e0b}.s4{color:#ef4444;background:#ef4444}.s5{color:#7c3aed;background:#7c3aed}.s6{color:#0ea5e9;background:#0ea5e9}.s7{color:#22c55e;background:#22c55e}.s8{color:#eab308;background:#eab308}.line{width:100%;height:120px;color:var(--brand-secondary)}.grid2{display:grid;grid-template-columns:1fr auto;gap:6px}.grid2 .r{text-align:right}.linky{background:transparent;border:none;color:var(--brand-secondary);text-decoration:underline;cursor:pointer}
