*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafafa;--surface:#fff;--surface-2:#f4f5f7;--border:#e4e7ec;--border-dark:#d0d5dd;--text:#101828;--text-muted:#667085;--text-faint:#98a2b3;--blue:#2563eb;--blue-light:#eff6ff;--green:#059669;--green-light:#ecfdf5;--red:#dc2626;--red-light:#fef2f2;--yellow:#d97706;--yellow-light:#fffbeb;--purple:#7c3aed;--font-mono:"JetBrains Mono", "SF Mono", "Fira Mono", monospace;--sidebar-w:232px;--radius:8px;--radius-lg:12px;--shadow-sm:0 1px 2px #1018280d;--shadow-md:0 1px 3px #1018281a, 0 1px 2px #1018280f;--shadow-lg:0 4px 6px -1px #10182814, 0 2px 4px -2px #1018280a}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;font-size:14px;line-height:1.5}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;padding:20px 0;display:flex}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:8px;padding:0 20px 20px;display:flex}.logo-mark{background:var(--text);color:#fff;border-radius:7px;place-items:center;width:30px;height:30px;font-size:14px;font-weight:700;display:grid}.logo-text{letter-spacing:-.01em;color:var(--text);font-size:14px;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;list-style:none;display:flex}.nav-item{width:100%;color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s;display:flex}.nav-item svg{stroke-width:1.75px;flex-shrink:0;width:16px;height:16px}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--blue-light);color:var(--blue);font-weight:600}.sign-out{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;margin:8px 12px 0;padding:8px 10px;font-size:13px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.sign-out:hover{background:var(--surface-2);color:var(--text);border-color:var(--border-dark)}.main-content{background:var(--bg);flex:1;overflow-y:auto}.page{max-width:1440px;margin:0 auto;padding:28px 32px 60px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-title{letter-spacing:-.02em;color:var(--text);font-size:20px;font-weight:600}.page-sub{color:var(--text-muted);margin-top:2px;font-size:13px}.header-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.btn-primary{background:var(--text);color:#fff;border:1px solid var(--text);cursor:pointer;border-radius:6px;padding:8px 16px;font-size:13.5px;font-weight:500;transition:opacity .12s}.btn-primary:hover:not(:disabled){opacity:.85}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .12s,border-color .12s}.btn-ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-dark)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.btn-sync{background:var(--text);color:#fff;border:1px solid var(--text);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .12s;display:flex}.btn-sync:hover:not(:disabled){opacity:.85}.btn-sync:disabled{opacity:.5;cursor:not-allowed}.spin{animation:1s linear infinite rotate;display:inline-block}@keyframes rotate{to{transform:rotate(360deg)}}select,input[type=text],input[type=email],input[type=password],input[type=date],input[type=number]{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:6px;outline:none;padding:7px 10px;font-size:13px;transition:border-color .12s,box-shadow .12s}select:focus,input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-light)}.month-select{min-width:140px}.month-inputs{gap:8px;display:flex}.preset-pills{flex-wrap:wrap;gap:6px;display:flex}.preset-pill{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:100px;padding:6px 12px;font-size:12.5px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.preset-pill:hover{background:var(--surface-2);color:var(--text)}.preset-pill.active{background:var(--text);color:#fff;border-color:var(--text)}.sync-banner{border:1px solid;border-radius:6px;margin-bottom:20px;padding:10px 14px;font-size:13px}.sync-banner.success{background:var(--green-light);color:var(--green);border-color:#a7f3d0}.sync-banner.error{background:var(--red-light);color:var(--red);border-color:#fecaca}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width<=900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:6px;padding:18px 20px;display:flex}.kpi-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:11.5px;font-weight:600}.kpi-value{letter-spacing:-.02em;color:var(--text);font-size:26px;font-weight:650}.kpi-sub{color:var(--text-faint);font-size:11.5px}.charts-row{grid-template-columns:1fr 340px;gap:12px;margin-bottom:12px;display:grid}@media (width<=900px){.charts-row{grid-template-columns:1fr}}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.chart-card.full-width{margin-bottom:12px}.chart-title{color:var(--text);margin-bottom:16px;font-size:12.5px;font-weight:600}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden}.table-card h2{color:var(--text);border-bottom:1px solid var(--border);padding:16px 20px 12px;font-size:12.5px;font-weight:600}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);padding:10px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:11px 16px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.data-table tr.clickable{cursor:pointer;transition:background .1s}.data-table tr.clickable:hover td{background:var(--surface-2)}th.num,td.num{text-align:right}td.mono{font-family:var(--font-mono);font-size:12px}td.profit{color:var(--green);font-weight:500}td.item-name{white-space:nowrap;text-overflow:ellipsis;max-width:220px;overflow:hidden}td.date{color:var(--text-muted);white-space:nowrap;font-size:12px}td.msg{max-width:300px;color:var(--text-muted);font-size:12px}.data-table tfoot td{background:var(--surface-2);border-top:2px solid var(--border-dark);border-bottom:none;font-weight:600}.badge{border-radius:100px;padding:3px 9px;font-size:12px;font-weight:600;display:inline-block}.badge.good{background:var(--green-light);color:var(--green)}.badge.ok{background:var(--yellow-light);color:var(--yellow)}.badge.low{background:var(--red-light);color:var(--red)}.badge.sm{padding:2px 7px;font-size:11px}.tag{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;border-radius:5px;padding:3px 9px;font-size:11.5px;font-weight:500;display:inline-block}.status-dot{font-size:13px;font-weight:600}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px;display:flex}.filter-bar label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);flex-direction:column;gap:4px;font-size:11px;font-weight:600;display:flex}.pagination{color:var(--text-muted);justify-content:center;align-items:center;gap:16px;padding:16px 0;font-size:13px;display:flex}.table-meta{color:var(--text-muted);margin-bottom:8px;font-size:12px}.login-screen{background:var(--bg);place-items:center;min-height:100vh;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:36px}.login-logo{justify-content:center;margin-bottom:18px;display:flex}.login-logo .logo-mark{border-radius:10px;width:44px;height:44px;font-size:19px}.login-card h1{text-align:center;letter-spacing:-.02em;color:var(--text);margin-bottom:4px;font-size:19px;font-weight:650}.login-sub{text-align:center;color:var(--text-muted);margin-bottom:26px;font-size:13px}.login-card form{flex-direction:column;gap:14px;display:flex}.login-card label{color:var(--text-muted);flex-direction:column;gap:6px;font-size:12px;font-weight:600;display:flex}.login-card input{width:100%;padding:9px 12px;font-size:14px}.login-card .btn-primary{width:100%;margin-top:4px;padding:11px;font-size:14px}.form-error{color:var(--red);background:var(--red-light);border:1px solid #fecaca;border-radius:6px;padding:8px 12px;font-size:13px}.loading-screen{place-items:center;min-height:100vh;display:grid}.page-loading{justify-content:center;padding:60px;display:flex}.spinner{border:2.5px solid var(--border);border-top-color:var(--text);border-radius:50%;width:26px;height:26px;animation:.7s linear infinite rotate}.empty{color:var(--text-muted);text-align:center;padding:36px 0;font-size:13.5px}.detail-table th,.detail-table td{padding:8px 12px}
