@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");:root{--sidebar-w:224px;--topbar-h:52px;--sb-bg:#1a1c2e;--sb-border:#252840;--sb-ink:#8c90b0;--sb-ink2:#c4c7de;--sb-acc:#818cf8;--sb-acc-bg:rgba(129,140,248,0.1);--sb-hover:rgba(255,255,255,0.046);--bg:#f8f9fc;--surface:#ffffff;--surface-2:#f3f4f8;--border:#e4e6ee;--border-2:#d0d3e0;--ink:#1a1c2e;--ink-2:#5b607a;--ink-3:#9297b0;--ink-4:#c5c8d8;--indigo:#4f46e5;--indigo-mid:#6366f1;--indigo-dark:#4338ca;--indigo-light:#eef2ff;--indigo-border:#c7d2fe;--green:#059669;--green-mid:#10b981;--green-light:#ecfdf5;--green-border:#a7f3d0;--red:#dc2626;--red-light:#fef2f2;--red-border:#fecaca;--amber:#d97706;--amber-light:#fffbeb;--amber-border:#fde68a;--font-sans:"Plus Jakarta Sans",-apple-system,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow:0 1px 4px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 14px rgba(0,0,0,.09),0 2px 4px rgba(0,0,0,.04);--r-sm:5px;--r:8px;--r-lg:12px}*,:after,:before{margin:0;padding:0;box-sizing:border-box}body,html{height:100%}body{font-family:var(--font-sans);font-size:13px;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.app-layout{height:100vh}.app-layout,.app-main{display:flex;overflow:hidden}.app-main{flex:1 1;flex-direction:column;min-width:0}.app-content{flex:1 1;overflow-y:auto;padding:20px 24px 40px}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--sb-bg);border-right:1px solid var(--sb-border);display:flex;flex-direction:column;overflow:hidden}.sb-header{padding:18px 16px 14px;border-bottom:1px solid var(--sb-border)}.sb-logo{gap:9px;margin-bottom:11px}.sb-logo,.sb-logo-mark{display:flex;align-items:center}.sb-logo-mark{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#6366f1,#4f46e5);justify-content:center;flex-shrink:0;box-shadow:0 2px 10px rgba(99,102,241,.35)}.sb-logo-mark svg{width:15px;height:15px;color:white}.sb-logo-name{font-size:14px;font-weight:700;color:#e8eaf6;letter-spacing:-.2px}.sb-rfc{font-family:var(--font-mono);font-size:9.5px;color:rgba(255,255,255,.22);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);padding:3px 9px;display:inline-block;letter-spacing:.5px}.sb-nav{flex:1 1;padding:10px 8px;overflow-y:auto}.sb-section{margin-bottom:16px}.sb-section-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:rgba(255,255,255,.16);padding:0 8px;margin-bottom:3px}.sb-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r);cursor:pointer;color:var(--sb-ink);font-size:13px;font-weight:400;transition:background .12s,color .12s;margin-bottom:1px;text-decoration:none}.sb-item:hover{background:var(--sb-hover);color:var(--sb-ink2)}.sb-item.active{background:var(--sb-acc-bg);color:var(--sb-acc);font-weight:600}.sb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.sb-count{margin-left:auto;font-family:var(--font-mono);font-size:10px;color:rgba(255,255,255,.2);background:rgba(255,255,255,.06);padding:1px 7px;border-radius:20px}.sb-item.active .sb-count{background:rgba(129,140,248,.2);color:var(--sb-acc)}.sb-footer{padding:12px;border-top:1px solid var(--sb-border)}.sb-user{display:flex;align-items:center;gap:9px;padding:8px;border-radius:var(--r);cursor:pointer;transition:background .12s}.sb-user:hover{background:var(--sb-hover)}.sb-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#4f46e5);display:flex;align-items:center;justify-content:center;color:white;font-size:11px;font-weight:700;flex-shrink:0}.sb-user-name{font-size:12px;font-weight:500;color:var(--sb-ink2);line-height:1.2}.sb-user-role{font-size:10px;color:rgba(255,255,255,.2)}.topbar{height:var(--topbar-h);flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;justify-content:space-between}.topbar,.topbar-left{display:flex;align-items:center}.topbar-left{gap:10px}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-title{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.3px}.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:.5px}.sp-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.sp-green{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}.sp-indigo{background:var(--indigo-light);color:var(--indigo);border:1px solid var(--indigo-border)}.sp-amber{background:var(--amber-light);color:var(--amber);border:1px solid var(--amber-border)}.sp-red{background:var(--red-light);color:var(--red);border:1px solid var(--red-border)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;border:none;transition:all .12s;white-space:nowrap}.btn svg{width:13px;height:13px}.btn-ghost{background:transparent;border:1px solid var(--border-2);color:var(--ink-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-primary{background:var(--indigo);color:white}.btn-primary:hover{background:var(--indigo-dark)}.btn-primary:active{transform:scale(.98)}.filter-bar{gap:8px;margin-bottom:20px;flex-wrap:wrap}.filter-bar,.filter-group{display:flex;align-items:center}.filter-group{gap:6px}.filter-label{font-size:12px;font-weight:500;color:var(--ink-2);white-space:nowrap}.filter-sep{width:1px;height:20px;background:var(--border)}.filter-select{background:var(--surface);border:1px solid var(--border-2);color:var(--ink);padding:7px 28px 7px 10px;border-radius:var(--r);font-family:var(--font-sans);font-size:12px;outline:none;cursor:pointer;box-shadow:var(--shadow-sm);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%239297b0' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .12s}.filter-select:focus{border-color:var(--indigo)}.ml-auto{margin-left:auto}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:15px 16px 13px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r-lg) var(--r-lg) 0 0}.kpi-indigo:before{background:linear-gradient(90deg,var(--indigo-mid),var(--indigo))}.kpi-green:before{background:linear-gradient(90deg,var(--green-mid),var(--green))}.kpi-amber:before{background:linear-gradient(90deg,#f59e0b,var(--amber))}.kpi-red:before{background:linear-gradient(90deg,#ef4444,var(--red))}.kpi-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:9px}.kpi-label{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--ink-4)}.kpi-trend-up{color:var(--green)}.kpi-trend-down,.kpi-trend-up{font-family:var(--font-mono);font-size:10px;font-weight:600}.kpi-trend-down{color:var(--red)}.kpi-value{font-family:var(--font-mono);font-size:22px;font-weight:500;color:var(--ink);letter-spacing:-.8px;line-height:1;margin-bottom:5px}.kpi-sub{font-size:11px;color:var(--ink-4)}.chart-row{display:grid;grid-template-columns:1fr 260px;grid-gap:14px;gap:14px;margin-bottom:18px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.card-header{padding:12px 16px;border-bottom:1px solid var(--border);background:var(--surface-2);justify-content:space-between}.card-header,.card-title{display:flex;align-items:center}.card-title{gap:8px;font-size:12px;font-weight:600;color:var(--ink-2)}.card-title-bar{width:3px;height:13px;border-radius:2px;flex-shrink:0}.ctb-indigo{background:var(--indigo)}.ctb-green{background:var(--green)}.chart-legend{display:flex;gap:14px}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-3)}.legend-dot{width:8px;height:8px;border-radius:2px}.card-body{padding:16px}.bars-wrap{gap:8px;height:115px}.bar-group,.bars-wrap{display:flex;align-items:flex-end}.bar-group{flex:1 1;gap:3px}.bar{flex:1 1;border-radius:4px 4px 0 0;min-height:3px;cursor:pointer;transition:opacity .15s}.bar:hover{opacity:.72}.bar-e{background:linear-gradient(180deg,var(--indigo-mid),var(--indigo))}.bar-r{background:linear-gradient(180deg,var(--green-mid),var(--green))}.bar-month-row{display:flex;gap:8px;border-top:1px solid var(--border);padding-top:8px;margin-top:8px}.bar-month{flex:1 1;text-align:center;font-family:var(--font-mono);font-size:10px;color:var(--ink-4)}.donut-area{align-items:center;padding:4px 0 0}.donut-area,.donut-legend{display:flex;flex-direction:column}.donut-legend{width:100%;margin-top:12px;gap:5px}.donut-row{display:flex;align-items:center;justify-content:space-between;padding:5px 6px;border-radius:var(--r-sm);transition:background .12s;cursor:default}.donut-row:hover{background:var(--surface-2)}.donut-row-left{display:flex;align-items:center;gap:8px}.donut-swatch{width:9px;height:9px;border-radius:3px;flex-shrink:0}.donut-label{font-size:12px;color:var(--ink-2)}.donut-count{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--ink)}.tab-bar{display:flex;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:3px;margin-bottom:14px;width:-moz-fit-content;width:fit-content}.tab-btn{padding:6px 18px;border-radius:6px;font-family:var(--font-sans);font-size:12.5px;font-weight:500;cursor:pointer;color:var(--ink-3);background:transparent;border:none;transition:all .12s;white-space:nowrap}.tab-btn:hover{color:var(--ink-2)}.tab-btn.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.section-head{justify-content:space-between;margin-bottom:10px}.section-head,.section-title{display:flex;align-items:center}.section-title{gap:8px;font-size:12px;font-weight:600;color:var(--ink-2)}.section-title:before{content:"";width:3px;height:13px;background:var(--indigo);border-radius:2px;display:inline-block}.section-meta{font-family:var(--font-mono);font-size:10px;color:var(--ink-4)}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:22px}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse}thead tr{background:var(--surface-2);border-bottom:1px solid var(--border)}th{padding:10px 13px;text-align:right;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--ink-4);white-space:nowrap}th:first-child{text-align:left}tbody tr{border-bottom:1px solid var(--border);transition:background .08s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--surface-2)}td{padding:10px 13px;font-family:var(--font-mono);font-size:12px;text-align:right;color:var(--ink-3);white-space:nowrap}td:first-child{font-family:var(--font-sans);text-align:left;font-weight:500;font-size:12.5px}td.num,td:first-child{color:var(--ink)}td.total{color:var(--indigo);font-weight:600}td.zero{color:var(--ink-4)}td.neg{color:var(--red)}tr.totals-row{background:var(--indigo-light);border-top:1px solid var(--indigo-border)!important}tr.totals-row td{font-weight:700;color:var(--ink)!important}tr.totals-row td.total{color:var(--indigo)!important}.chip{display:inline-block;font-family:var(--font-mono);font-size:11px;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border-2);border-radius:4px;padding:2px 8px}.badge-f{background:var(--indigo-light);color:var(--indigo)}.badge-e,.badge-f{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.badge-e{background:var(--red-light);color:var(--red)}.uuid-cell{color:var(--ink-4);font-size:10.5px}.detail-bar{padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);justify-content:space-between}.detail-bar,.detail-bar-left{display:flex;align-items:center}.detail-bar-left{gap:10px}.detail-title{font-size:12px;font-weight:600;color:var(--ink-2)}.rec-count{font-family:var(--font-mono);font-size:10px;background:var(--indigo-light);color:var(--indigo);border:1px solid var(--indigo-border);padding:2px 9px;border-radius:20px}.search-wrap{position:relative}.search-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--ink-4);pointer-events:none}.search-input{background:var(--surface);border:1px solid var(--border-2);color:var(--ink);padding:7px 12px 7px 30px;border-radius:var(--r);font-family:var(--font-sans);font-size:12px;outline:none;width:240px;box-shadow:var(--shadow-sm);transition:border-color .12s}.search-input::placeholder{color:var(--ink-4)}.search-input:focus{border-color:var(--indigo)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:var(--surface-2);border-top:1px solid var(--border)}.page-info{font-family:var(--font-mono);font-size:11px;color:var(--ink-4)}.page-btns{display:flex;gap:4px}.page-btn{background:var(--surface);border:1px solid var(--border-2);color:var(--ink-2);padding:5px 10px;border-radius:var(--r-sm);font-family:var(--font-mono);font-size:11px;cursor:pointer;transition:all .12s}.page-btn:hover{border-color:var(--indigo);color:var(--indigo)}.page-btn.active{background:var(--indigo);color:white;border-color:var(--indigo)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}