:root,[data-theme=light]{--surface-1: #fcfcfb;--surface-2: #f9f9f7;--surface-3: #f0efec;--text-primary: #0b0b0b;--text-secondary: #52514e;--text-muted: #898781;--grid: #e1e0d9;--baseline: #c3c2b7;--border: rgba(11, 11, 11, .1);--accent: #2a78d6;--accent-soft: #e3eefb;--good: #0ca30c;--good-text: #006300;--warning: #fab219;--serious: #ec835a;--critical: #d03b3b;--shadow: 0 1px 3px rgba(11, 11, 11, .07), 0 4px 14px rgba(11, 11, 11, .05)}[data-theme=dark]{--surface-1: #1a1a19;--surface-2: #0d0d0d;--surface-3: #2c2c2a;--text-primary: #ffffff;--text-secondary: #c3c2b7;--text-muted: #898781;--grid: #2c2c2a;--baseline: #383835;--border: rgba(255, 255, 255, .1);--accent: #3987e5;--accent-soft: #14243a;--good-text: #0ca30c;--shadow: 0 1px 3px rgba(0, 0, 0, .4)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--surface-2);color:var(--text-primary);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0 0 8px;line-height:1.2}h1{font-size:1.5rem}h2{font-size:1.2rem}h3{font-size:1.02rem}a{color:var(--accent);text-decoration:none}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:var(--text-primary)}.app-shell{display:flex;min-height:100vh}.sidebar{width:232px;background:var(--surface-1);border-right:1px solid var(--border);padding:16px 10px;position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column;gap:2px}.sidebar .brand{font-weight:700;font-size:1.1rem;padding:6px 12px 14px;display:flex;align-items:center;gap:8px}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;color:var(--text-secondary);font-weight:500}.nav-link:hover{background:var(--surface-3)}.nav-link.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.nav-link .icon{width:20px;text-align:center}.main{flex:1;min-width:0;padding:20px clamp(14px,3vw,32px) 90px;max-width:1180px;margin:0 auto;width:100%}.topbar{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap}.topbar-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface-1);border-top:1px solid var(--border);z-index:40;padding:4px 2px calc(4px + env(safe-area-inset-bottom));justify-content:space-around}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:1px;font-size:.62rem;color:var(--text-muted);padding:4px 6px;border-radius:8px;min-width:52px}.bottom-nav a.active{color:var(--accent);font-weight:600}.bottom-nav a .icon{font-size:1.25rem}@media (max-width: 860px){.sidebar{display:none}.bottom-nav{display:flex}.main{padding-bottom:110px}}.card{background:var(--surface-1);border:1px solid var(--border);border-radius:14px;padding:16px;box-shadow:var(--shadow)}.card+.card{margin-top:14px}.card-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.grid{display:grid;gap:14px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.stat-tile .label{font-size:.8rem;color:var(--text-secondary)}.stat-tile .value{font-size:1.55rem;font-weight:650;margin-top:2px}.stat-tile .delta{font-size:.78rem;margin-top:2px;color:var(--text-muted)}.delta.up-bad{color:var(--critical)}.delta.down-good{color:var(--good-text)}.btn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface-1);color:var(--text-primary);padding:8px 14px;border-radius:10px;font-weight:550;transition:background .12s}.btn:hover{background:var(--surface-3)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#1c5cab}.btn-danger{color:var(--critical);border-color:var(--critical);background:transparent}.btn-danger:hover{background:#d03b3b14}.btn-sm{padding:5px 10px;font-size:.82rem;border-radius:8px}.btn-ghost{border-color:transparent;background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--surface-3)}.btn:disabled{opacity:.5;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.field label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.input,select.input,textarea.input{border:1px solid var(--baseline);border-radius:10px;padding:9px 11px;background:var(--surface-1);width:100%}.input:focus{outline:2px solid var(--accent);outline-offset:0;border-color:transparent}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 560px){.form-row{grid-template-columns:1fr}}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:999px;border:1px solid var(--baseline);background:var(--surface-1);font-size:.82rem;cursor:pointer;-webkit-user-select:none;user-select:none}.chip.selected{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:600}.chip-row{display:flex;flex-wrap:wrap;gap:7px}.avatar{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.avatar-sm{width:22px;height:22px;font-size:.62rem}.badge{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--surface-3);color:var(--text-secondary)}.list-row{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--grid)}.list-row:last-child{border-bottom:none}.list-row .grow{flex:1;min-width:0}.list-row .title{font-weight:550;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-row .sub{font-size:.78rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-row .amount{font-weight:650;white-space:nowrap;font-variant-numeric:tabular-nums}.cat-dot{width:34px;height:34px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}.empty{text-align:center;color:var(--text-muted);padding:34px 16px}.empty .big{font-size:2.2rem;margin-bottom:8px}.meter{height:10px;border-radius:6px;background:var(--surface-3);overflow:hidden}.meter>div{height:100%;border-radius:6px;transition:width .3s}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:60;display:flex;align-items:flex-end;justify-content:center}@media (min-width: 640px){.modal-backdrop{align-items:center;padding:24px}}.modal{background:var(--surface-1);border-radius:18px 18px 0 0;width:100%;max-width:640px;max-height:92vh;overflow-y:auto;padding:20px}@media (min-width: 640px){.modal{border-radius:18px}}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse;font-size:.86rem}table.data th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:7px 10px;border-bottom:1px solid var(--baseline)}table.data td{padding:8px 10px;border-bottom:1px solid var(--grid)}table.data td.num{text-align:right;font-variant-numeric:tabular-nums}table.data th.num{text-align:right}.notif-pop{position:absolute;top:46px;right:0;width:min(360px,92vw);max-height:60vh;overflow-y:auto;background:var(--surface-1);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);z-index:50;padding:8px}.notif-item{padding:9px 10px;border-radius:9px;font-size:.85rem}.notif-item.unread{background:var(--accent-soft)}.notif-item .when{font-size:.72rem;color:var(--text-muted)}.icon-btn{position:relative;border:1px solid var(--border);background:var(--surface-1);width:38px;height:38px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem}.icon-btn:hover{background:var(--surface-3)}.icon-btn .dot{position:absolute;top:6px;right:7px;width:8px;height:8px;border-radius:50%;background:var(--critical);border:2px solid var(--surface-1)}.chart-box{height:260px}.chart-box-lg{height:300px}.recharts-tooltip-wrapper{outline:none}.viz-tooltip{background:var(--surface-1);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:9px 12px;font-size:.82rem}.viz-tooltip .t-title{font-weight:650;margin-bottom:4px}.viz-tooltip .t-row{display:flex;align-items:center;gap:6px;color:var(--text-secondary)}.viz-tooltip .t-row .swatch{width:9px;height:9px;border-radius:3px}.legend-row{display:flex;flex-wrap:wrap;gap:5px 14px;margin-top:8px;font-size:.78rem;color:var(--text-secondary)}.legend-row .key{display:inline-flex;align-items:center;gap:5px}.legend-row .swatch{width:10px;height:10px;border-radius:3px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:4px 0 14px;flex-wrap:wrap}.filters-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px}.filters-row .input{width:auto}.fab{position:fixed;right:18px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:30;background:var(--accent);color:#fff;border:none;border-radius:16px;width:56px;height:56px;font-size:1.7rem;box-shadow:0 6px 18px #2a78d666;display:none;align-items:center;justify-content:center}@media (max-width: 860px){.fab{display:flex}}.muted{color:var(--text-muted);font-size:.82rem}.pos{color:var(--good-text);font-weight:650}.neg{color:var(--critical);font-weight:650}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.flex{display:flex;align-items:center;gap:8px}.flex-wrap{flex-wrap:wrap}.spread{justify-content:space-between}.attach-thumb{width:76px;height:76px;object-fit:cover;border-radius:10px;border:1px solid var(--border);cursor:pointer}.attach-file{width:76px;height:76px;border-radius:10px;border:1px solid var(--border);display:inline-flex;flex-direction:column;align-items:center;justify-content:center;font-size:.6rem;gap:4px;color:var(--text-secondary);cursor:pointer;text-align:center;padding:4px}
