:root{--bg: #0b0f14;--bg-elev: #121822;--bg-card: #161d29;--bg-card-hover: #1b2433;--border: #243044;--border-soft: #1c2636;--text: #e6edf6;--text-dim: #9fb0c6;--text-faint: #647088;--accent: #4f9cf9;--accent-soft: #1d3a5f;--green: #34d399;--green-soft: #10331f;--red: #f87171;--red-soft: #3a1b1b;--amber: #fbbf24;--amber-soft: #3a300f;--purple: #a78bfa;--teal: #2dd4bf;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.25);--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "SF Mono", ui-monospace, "Menlo", monospace}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;min-height:100vh}.sidebar{width:230px;flex-shrink:0;background:var(--bg-elev);border-right:1px solid var(--border);padding:18px 12px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.brand{padding:4px 10px 18px}.brand h1{font-size:15px;font-weight:700;letter-spacing:-.2px}.brand p{font-size:11px;color:var(--text-faint);margin-top:2px}.nav{display:flex;flex-direction:column;gap:2px;flex:1}.nav-section{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);padding:14px 10px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-dim);cursor:pointer;border:none;background:none;font-size:13px;text-align:left;width:100%;font-family:inherit;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg-card);color:var(--text)}.nav-item.active{background:var(--accent-soft);color:#cfe2ff;font-weight:600}.nav-item .ico{font-size:15px;width:18px;text-align:center}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--border);background:#0b0f14cc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:20}.topbar h2{font-size:18px;font-weight:700;letter-spacing:-.3px}.topbar .sub{font-size:12px;color:var(--text-faint)}.content{padding:24px 28px 60px;max-width:1280px;width:100%}.hamburger{display:none;background:var(--bg-card);border:1px solid var(--border);color:var(--text);width:38px;height:38px;border-radius:var(--radius-sm);font-size:18px;cursor:pointer;flex-shrink:0}.nav-backdrop{display:none}@media (max-width: 860px){.sidebar{position:fixed;top:0;left:0;z-index:60;transform:translate(-100%);transition:transform .2s ease;box-shadow:var(--shadow);padding-top:calc(18px + env(safe-area-inset-top))}.sidebar.open{transform:translate(0)}.nav-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:55}.hamburger{display:inline-flex;align-items:center;justify-content:center}.topbar{gap:12px;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top))}.topbar h2{font-size:16px}.topbar .sub{font-size:11px}.content{padding:16px 14px calc(60px + env(safe-area-inset-bottom))}.kpi .value{font-size:22px}.modal{width:100%}.month-pill{padding:6px 12px;font-size:13px}.nav-item{padding:11px 10px;font-size:14px}}.month-pills{display:flex;gap:3px;flex-wrap:wrap}.month-pill{padding:5px 11px;border-radius:999px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-dim);cursor:pointer;font-size:12px;font-family:inherit;transition:all .12s}.month-pill:hover{border-color:var(--accent);color:var(--text)}.month-pill.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.card-title{font-size:13px;font-weight:600;color:var(--text-dim);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}.card-title .tag{font-size:10px;color:var(--text-faint);font-weight:500}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1100px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 720px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.kpi .label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px}.kpi .value{font-size:26px;font-weight:700;margin-top:6px;letter-spacing:-.5px;font-variant-numeric:tabular-nums}.kpi .delta{font-size:12px;margin-top:4px}.kpi.accent{border-color:var(--accent)}.pos{color:var(--green)}.neg{color:var(--red)}.warn{color:var(--amber)}.dim{color:var(--text-faint)}.hint-wrap{position:relative;outline:none}.hint-dot{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;margin-left:5px;border-radius:50%;background:var(--border);color:var(--text-dim);font-size:9px;font-weight:700;font-style:normal;line-height:1;font-family:var(--font);text-transform:none;letter-spacing:0;vertical-align:middle;cursor:help;flex-shrink:0;transition:background .12s,color .12s}.hint-wrap:hover .hint-dot,.hint-wrap:focus-within .hint-dot{background:var(--accent);color:#fff}.hint-pop{position:absolute;left:0;top:100%;margin-top:8px;z-index:50;width:max-content;max-width:260px;background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 11px;font-size:12px;line-height:1.45;font-weight:400;text-transform:none;letter-spacing:0;text-align:left;box-shadow:var(--shadow);white-space:normal;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(4px);transition:opacity .14s ease,visibility .14s ease,transform .14s ease;transition-delay:0s}.hint-wrap:hover .hint-pop,.hint-wrap:focus-within .hint-pop{opacity:1;visibility:visible;transform:translateY(0);transition-delay:1s}.hint-pop:before{content:"";position:absolute;bottom:100%;left:14px;border:6px solid transparent;border-bottom-color:var(--border)}.hint-pop:after{content:"";position:absolute;bottom:100%;left:15px;border:5px solid transparent;border-bottom-color:var(--bg-elev)}.grid-4>.kpi:last-child .hint-pop,.grid-3>.kpi:last-child .hint-pop{left:auto;right:0}.grid-4>.kpi:last-child .hint-pop:before,.grid-3>.kpi:last-child .hint-pop:before{left:auto;right:14px}.grid-4>.kpi:last-child .hint-pop:after,.grid-3>.kpi:last-child .hint-pop:after{left:auto;right:15px}table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}th,td{padding:8px 10px;text-align:right;border-bottom:1px solid var(--border-soft);white-space:nowrap}th{font-size:11px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.4px}th:first-child,td:first-child{text-align:left}tbody tr:hover{background:var(--bg-card-hover)}tr.total-row td{font-weight:700;border-top:2px solid var(--border);border-bottom:none}tr.subtle td{color:var(--text-dim)}.table-wrap{overflow-x:auto}td.num,th.num{font-family:var(--mono);font-size:12.5px}input,select,textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:7px 10px;font-size:13px;font-family:inherit;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}input.cell{padding:4px 6px;text-align:right;background:transparent;border:1px solid transparent;border-radius:4px;font-family:var(--mono);font-size:12.5px}input.cell:hover{border-color:var(--border)}input.cell:focus{border-color:var(--accent);background:var(--bg)}label{font-size:12px;color:var(--text-dim);display:block;margin-bottom:4px}.field{margin-bottom:12px}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.row>.field{flex:1;margin-bottom:0;min-width:120px}button.btn{background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:filter .12s}button.btn:hover{filter:brightness(1.1)}button.btn.ghost{background:var(--bg-card);color:var(--text-dim);border:1px solid var(--border)}button.btn.ghost:hover{color:var(--text);border-color:var(--accent)}button.btn.danger{background:var(--red-soft);color:var(--red)}button.btn.sm{padding:4px 10px;font-size:12px}button.icon-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:14px;padding:4px 6px;border-radius:4px}button.icon-btn:hover{color:var(--red);background:var(--red-soft)}.toggle{position:relative;width:34px;height:20px;flex-shrink:0;cursor:pointer}.toggle input{display:none}.toggle .track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:999px;transition:background .15s}.toggle .thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .15s}.toggle input:checked+.track{background:var(--green)}.toggle input:checked+.track+.thumb,.toggle input:checked~.thumb{transform:translate(14px)}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.badge.green{background:var(--green-soft);color:var(--green)}.badge.red{background:var(--red-soft);color:var(--red)}.badge.blue{background:var(--accent-soft);color:#9fc6ff}.badge.amber{background:var(--amber-soft);color:var(--amber)}.badge.gray{background:var(--bg-card-hover);color:var(--text-dim)}.alert{display:flex;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;align-items:flex-start}.alert.ok{background:var(--green-soft);color:var(--green)}.alert.warn{background:var(--amber-soft);color:var(--amber)}.alert.bad{background:var(--red-soft);color:var(--red)}.section-head{display:flex;align-items:center;justify-content:space-between;margin:26px 0 12px}.section-head h3{font-size:15px;font-weight:700}.stack{display:flex;flex-direction:column;gap:16px}.spacer{flex:1}.hr{height:1px;background:var(--border);margin:18px 0;border:none}.muted{color:var(--text-faint)}.right{text-align:right}.chart-wrap{width:100%;height:300px}.chart-wrap.tall{height:360px}.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--text-dim);margin-top:8px}.legend .dot{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:5px;vertical-align:middle}.inline-edit{display:flex;gap:6px;align-items:center}.bar-cell{position:relative}.tab-row{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}.tab{padding:8px 14px;cursor:pointer;border:none;background:none;color:var(--text-dim);font-size:13px;font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--text);border-bottom-color:var(--accent);font-weight:600}.tab:hover{color:var(--text)}.empty{text-align:center;color:var(--text-faint);padding:40px;font-size:13px}.range-row{display:grid;grid-template-columns:1fr 60px;gap:10px;align-items:center;margin-bottom:10px}input[type=range]{accent-color:var(--accent);padding:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;width:480px;max-width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow)}.modal h3{margin-bottom:16px}.kv{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border-soft);font-size:13px}.kv .k{color:var(--text-dim)}.kv .v{font-variant-numeric:tabular-nums;font-weight:600}.lock-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#15233a 0%,var(--bg) 60%)}.lock-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;width:360px;max-width:100%;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px;text-align:center}.lock-card .lock-logo{font-size:32px}.lock-card h1{font-size:18px;font-weight:700}.lock-card input{text-align:center;font-size:18px;letter-spacing:4px;padding:12px}.lock-card .btn{width:100%;padding:11px}.lock-err{color:var(--red);font-size:13px}
