@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f5f4f0;--surface:#fff;--surface2:#f0efe9;--surface3:#e8e6df;--border:#00000014;--border2:#00000024;--text:#1a1917;--text2:#6b6960;--text3:#9b9890;--accent:#2563eb;--accent-bg:#eff4ff;--green:#16a34a;--green-bg:#f0fdf4;--red:#dc2626;--red-bg:#fef2f2;--amber:#d97706;--amber-bg:#fffbeb;--purple:#7c3aed;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014}[data-theme=dark]{--bg:#111110;--surface:#1c1b19;--surface2:#242320;--surface3:#2e2c28;--border:#ffffff12;--border2:#ffffff1f;--text:#f0ede6;--text2:#908d84;--text3:#5c5a54;--accent:#60a5fa;--accent-bg:#1e2d45;--green:#4ade80;--green-bg:#052e16;--red:#f87171;--red-bg:#2d0f0f;--amber:#fbbf24;--amber-bg:#261900;--purple:#a78bfa}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.5}.app{min-height:100vh;display:flex}.main{flex-direction:column;flex:1;min-width:0;margin-left:220px;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:220px;min-height:100vh;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-backdrop{z-index:99;background:#0000004d;display:none;position:fixed;inset:0}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:20px 20px 16px;display:flex}.logo-mark{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;font-weight:600;display:flex}.logo-name{letter-spacing:-.3px;flex:1;font-size:16px;font-weight:600}.sidebar-close{margin-left:auto;display:none}.sidebar-nav{flex:1;padding:12px 10px}.nav-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);padding:8px 10px 4px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text2);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--accent-bg);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.role-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:6px;font-size:10px;font-weight:600}.role-select{border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface2);width:100%;color:var(--text);cursor:pointer;outline:none;padding:7px 10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500}.role-badge{border-radius:20px;align-items:center;gap:4px;margin-top:6px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.role-badge.admin{background:var(--amber-bg);color:var(--amber)}.role-badge.viewer{background:var(--accent-bg);color:var(--accent)}.topbar{z-index:50;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.topbar-right{align-items:center;gap:8px;display:flex}.topbar-title{letter-spacing:-.3px;font-size:16px;font-weight:600}.btn{border-radius:var(--radius-sm);border:1px solid var(--border2);color:var(--text);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:6px;padding:6px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .15s;display:flex}.btn:hover{background:var(--surface2)}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.primary:hover{opacity:.9}.icon-btn{border-radius:var(--radius-sm);border:1px solid var(--border2);cursor:pointer;width:34px;height:34px;color:var(--text);background:0 0;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.icon-btn:hover{background:var(--surface2)}.hamburger{border:none}.action-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:12px;transition:background .1s}.action-btn.edit{color:var(--accent)}.action-btn.edit:hover{background:var(--accent-bg)}.action-btn.del{color:var(--red)}.action-btn.del:hover{background:var(--red-bg)}.page{flex:1;padding:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-title{letter-spacing:-.2px;font-size:15px;font-weight:600}.section-sub{color:var(--text3);margin-top:1px;font-size:12px}.cards-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}.card-accent{border-radius:2px;width:32px;height:3px;margin-bottom:10px}.card-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:8px;font-size:11px;font-weight:600}.card-value{letter-spacing:-.8px;font-family:DM Mono,monospace;font-size:24px;font-weight:600}.card-trend{align-items:center;gap:4px;margin-top:6px;font-size:11.5px;font-weight:500;display:flex}.card-trend.up{color:var(--green)}.card-trend.down{color:var(--red)}.charts-grid{grid-template-columns:2fr 1fr;gap:14px;margin-bottom:24px;display:grid}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px}.chart-legend{flex-wrap:wrap;gap:12px;margin-bottom:14px;display:flex}.legend-item{color:var(--text2);align-items:center;gap:5px;font-size:12px;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:10px;height:10px}.tx-controls{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.search-box{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-sm);flex:1;align-items:center;gap:8px;min-width:180px;padding:7px 12px;display:flex}.search-box input{color:var(--text);background:0 0;border:none;outline:none;width:100%;font-family:DM Sans,sans-serif;font-size:13px}.filter-select{border-radius:var(--radius-sm);border:1px solid var(--border2);background:var(--surface);color:var(--text);cursor:pointer;outline:none;min-width:110px;padding:7px 10px;font-family:DM Sans,sans-serif;font-size:13px}.tx-table{border-collapse:collapse;width:100%}.tx-table th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;padding:8px 12px;font-size:11px;font-weight:600}.tx-table th:hover{color:var(--text2)}.tx-table td{border-bottom:1px solid var(--border);padding:11px 12px;font-size:13.5px}.tx-table tr:last-child td{border-bottom:none}.tx-table tr:hover td{background:var(--surface2)}.category-badge{border-radius:20px;align-items:center;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.amount-positive{color:var(--green);font-family:DM Mono,monospace;font-weight:500}.amount-negative{color:var(--red);font-family:DM Mono,monospace;font-weight:500}.empty-state{text-align:center;color:var(--text3);padding:48px 24px;font-size:13px}.empty-state svg{opacity:.3;margin:0 auto 12px;display:block}.pagination{justify-content:space-between;align-items:center;margin-top:14px;display:flex}.page-info{color:var(--text3);font-size:12px}.page-btns{gap:6px;display:flex}.page-btn{border-radius:var(--radius-sm);border:1px solid var(--border2);color:var(--text);cursor:pointer;background:0 0;padding:5px 10px;font-size:12px;transition:background .1s}.page-btn:hover{background:var(--surface2)}.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border-radius:var(--radius);width:420px;max-width:95vw;box-shadow:var(--shadow-md);padding:24px;animation:.2s slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-title{letter-spacing:-.3px;margin-bottom:20px;font-size:16px;font-weight:600}.form-group{margin-bottom:14px}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-label{color:var(--text2);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.form-input{border:1px solid var(--border2);border-radius:var(--radius-sm);background:var(--surface2);width:100%;color:var(--text);outline:none;padding:8px 12px;font-family:DM Sans,sans-serif;font-size:13.5px;transition:border .15s}.form-input:focus{border-color:var(--accent)}.modal-btns{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.insights-grid{grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;display:grid}.insight-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px}.insight-icon{border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;margin-bottom:12px;font-size:18px;display:flex}.insight-title{color:var(--text2);margin-bottom:4px;font-size:13px}.insight-value{letter-spacing:-.5px;font-size:22px;font-weight:600}.insight-sub{color:var(--text3);margin-top:4px;font-size:12px}@media (width<=1024px){.cards-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.insights-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-md);transform:translate(0)}.sidebar-backdrop{display:block}.sidebar-close{display:flex}.main{margin-left:0}.cards-grid{grid-template-columns:1fr 1fr;gap:10px}.insights-grid{grid-template-columns:1fr}.page{padding:16px}.topbar{padding:0 16px}.charts-grid{grid-template-columns:1fr!important}}@media (width<=480px){.cards-grid,.form-row{grid-template-columns:1fr}}
