:root{--bg: #0a0e14;--bg-elevated: #0f141d;--bg-card: #131a25;--bg-card-hover: #18202d;--border: #1e2a3a;--border-strong: #2a3a52;--text: #e6edf3;--text-muted: #9aa9bd;--text-dim: #5f6f85;--green: #10b981;--green-soft: rgba(16, 185, 129, .12);--red: #f43f5e;--red-soft: rgba(244, 63, 94, .12);--amber: #f59e0b;--amber-soft: rgba(245, 158, 11, .12);--blue: #3b82f6;--cyan: #22d3ee;--accent: #10b981;--accent-2: #06b6d4;--radius: 12px;--radius-sm: 8px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow: 0 4px 12px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .5), 0 4px 12px rgba(0, 0, 0, .3);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01","ss03"}body{min-height:100vh;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(16,185,129,.08),transparent),radial-gradient(ellipse 60% 50% at 90% 100%,rgba(6,182,212,.05),transparent),var(--bg)}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;color:var(--text)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.app{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 8px 24px;margin-bottom:8px;border-bottom:1px solid var(--border)}.sidebar-logo-mark{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;letter-spacing:-.5px}.sidebar-logo-text{font-weight:700;font-size:15px;letter-spacing:-.3px}.sidebar-logo-sub{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);margin-top:2px}.nav-item{padding:10px 12px;border-radius:var(--radius-sm);color:var(--text-muted);font-weight:500;font-size:13.5px;display:flex;align-items:center;gap:10px;transition:background .15s,color .15s;cursor:pointer;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--bg-card);color:var(--text)}.nav-item.active{background:linear-gradient(90deg,#10b98126,#06b6d40d);color:var(--text);border-left:2px solid var(--accent);padding-left:10px}.nav-spacer{flex:1}.nav-footer{padding:16px 12px 10px;font-size:11px;color:var(--text-dim);font-family:var(--font-mono);border-top:1px solid var(--border);margin-top:8px}.logout-btn{background:none;border:none;color:var(--text-muted);padding:10px 12px;border-radius:var(--radius-sm);text-align:left;font-size:13px;width:100%;display:flex;align-items:center;gap:10px}.logout-btn:hover{background:var(--bg-card);color:var(--text)}.main{padding:32px 40px;max-width:1280px;width:100%;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px;gap:16px}.page-title{font-size:28px;font-weight:700;letter-spacing:-.6px;margin:0}.page-subtitle{font-size:13px;color:var(--text-dim);margin-top:4px;font-family:var(--font-mono)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.card-strong{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.grid-4{grid-template-columns:1fr 1fr 1fr 1fr}.kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);font-weight:600;margin-bottom:8px}.kpi-value{font-size:28px;font-weight:700;letter-spacing:-.5px;font-family:var(--font-mono)}.kpi-value.lg{font-size:36px}.kpi-sub{font-size:12px;color:var(--text-muted);margin-top:6px;font-family:var(--font-mono)}.txt-green{color:var(--green)}.txt-red{color:var(--red)}.txt-amber{color:var(--amber)}.txt-muted{color:var(--text-muted)}.txt-dim{color:var(--text-dim)}.txt-mono{font-family:var(--font-mono)}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;font-family:var(--font-mono)}.pill-green{background:var(--green-soft);color:var(--green)}.pill-red{background:var(--red-soft);color:var(--red)}.pill-amber{background:var(--amber-soft);color:var(--amber)}.pill-muted{background:var(--bg-elevated);color:var(--text-muted)}.btn{padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-card);color:var(--text);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:8px;transition:background .15s,border-color .15s,transform .05s}.btn:hover{background:var(--bg-card-hover);border-color:var(--accent)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(180deg,var(--accent) 0%,#0d9668 100%);border-color:var(--accent);color:#001b12}.btn-primary:hover{background:linear-gradient(180deg,#14c794 0%,var(--accent) 100%);border-color:var(--accent);color:#001b12}.btn-ghost{background:transparent;border-color:var(--border)}.btn-danger{color:var(--red);border-color:var(--red)}.btn-danger:hover{background:var(--red-soft);border-color:var(--red)}.btn-icon-danger{width:22px;height:22px;padding:0;line-height:1;font-size:16px;border-radius:4px;border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .12s}.btn-icon-danger:hover{color:var(--red);background:var(--red-soft);border-color:var(--red)}.input,.textarea,.select{width:100%;padding:11px 13px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13.5px;outline:none;transition:border-color .15s;font-family:var(--font-mono)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent)}.textarea{font-family:var(--font-mono);font-size:12.5px;line-height:1.55;resize:vertical}.label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);font-weight:600;margin-bottom:6px}table.t{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}table.t th{text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}table.t td{padding:11px 12px;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:12.5px;vertical-align:middle}table.t tr:hover td{background:var(--bg-card-hover)}table.t tr:last-child td{border-bottom:none}.divider{height:1px;background:var(--border);margin:16px 0}.empty{padding:48px 24px;text-align:center;color:var(--text-dim)}.empty-title{font-size:15px;font-weight:600;color:var(--text-muted);margin-bottom:4px}.spinner{width:18px;height:18px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.heatmap{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.heat-cell{aspect-ratio:1;border-radius:4px;background:var(--bg-elevated);position:relative;cursor:default;transition:transform .1s}.heat-cell[data-pnl]:hover{transform:scale(1.15);z-index:2}.heat-cell-empty{opacity:.25}@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;overflow-x:auto;padding:12px 16px;gap:4px}.sidebar-logo{border-bottom:none;padding:0 8px 0 0;margin-bottom:0;border-right:1px solid var(--border);margin-right:8px}.sidebar-logo>div:last-child{display:none}.nav-spacer,.nav-footer,.logout-btn{display:none}.nav-item{padding:8px 10px;font-size:12.5px;white-space:nowrap}.main{padding:20px 16px}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-title{font-size:22px}}.flash{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;border:1px solid}.flash-success{background:var(--green-soft);color:var(--green);border-color:var(--green)}.flash-error{background:var(--red-soft);color:var(--red);border-color:var(--red)}.flash-info{background:var(--amber-soft);color:var(--amber);border-color:var(--amber)}.toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:24px}.toolbar-group{display:flex;align-items:center;gap:8px}.toolbar-spacer{flex:1}.seg{display:inline-flex;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:2px}.seg-btn{background:transparent;border:none;color:var(--text-muted);padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:600;font-family:var(--font-mono);white-space:nowrap}.seg-btn:hover{color:var(--text)}.seg-btn.active{background:linear-gradient(180deg,#10b98138,#10b9811a);color:var(--text);box-shadow:inset 0 0 0 1px #10b9814d}.field{display:flex;flex-direction:column;gap:4px}.field-inline{display:flex;align-items:center;gap:8px}.select-sm,.input-sm{padding:7px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:12.5px;font-family:var(--font-mono);outline:none}.select-sm:focus,.input-sm:focus{border-color:var(--accent)}.input-sm[type=date]{color-scheme:dark}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 18px 16px;position:relative;overflow:hidden}.kpi-card.accent:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:linear-gradient(180deg,var(--accent),var(--accent-2))}.kpi-card .kpi-value{font-size:24px}.kpi-card .kpi-value.lg{font-size:30px}.section-title{font-size:12px;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-muted);font-weight:600;margin:0 0 14px;display:flex;align-items:center;justify-content:space-between;gap:10px}.chart-card{padding:20px}.chart-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:16px}.chart-title{font-size:14px;font-weight:600}.chart-sub{font-size:11.5px;color:var(--text-dim);font-family:var(--font-mono)}.gauge{display:flex;flex-direction:column;align-items:center;gap:2px}.gauge-value{font-family:var(--font-mono);font-weight:700;font-size:26px;letter-spacing:-.5px}.gauge-label{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-dim);font-weight:600}.meter{position:relative;height:6px;background:var(--bg-elevated);border-radius:4px;overflow:hidden;width:100%}.meter-fill{position:absolute;left:0;top:0;bottom:0;border-radius:4px;background:linear-gradient(90deg,var(--accent-2),var(--accent))}.meter-fill.red{background:linear-gradient(90deg,#b91c3c,var(--red))}.rc-tooltip{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;box-shadow:var(--shadow)}.rc-tooltip-label{color:var(--text-dim);font-family:var(--font-mono);font-size:11px;margin-bottom:4px}.rc-tooltip-row{font-family:var(--font-mono);display:flex;justify-content:space-between;gap:14px}table.t th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}table.t th.sortable:hover{color:var(--text-muted)}table.t th .sort-ind{color:var(--accent);margin-left:4px}table.t td.num,table.t th.num{text-align:right}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-note{font-size:11.5px;color:var(--text-dim);font-family:var(--font-mono);display:flex;gap:6px;align-items:flex-start;margin-top:10px}.dir-dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle}.legend{display:flex;flex-wrap:wrap;gap:14px;font-size:11.5px;color:var(--text-muted);font-family:var(--font-mono)}.legend-item{display:flex;align-items:center;gap:6px}.legend-swatch{width:10px;height:10px;border-radius:3px}.row-link{cursor:pointer}.row-link.selected td{background:#10b98114}@media(max-width:900px){.toolbar{gap:8px}.toolbar-spacer{display:none}.kpi-card .kpi-value{font-size:21px}.kpi-card .kpi-value.lg{font-size:25px}}
