:root{--bg: #f1f5f9;--sidebar: #0f172a;--sidebar-hover: rgba(255, 255, 255, .06);--sidebar-active: rgba(255, 255, 255, .12);--sidebar-text: #94a3b8;--sidebar-text-active: #f1f5f9;--panel: #ffffff;--line: #e2e8f0;--ink: #0f172a;--muted: #64748b;--accent: #0d9488;--accent-dark: #0f766e;--green: #16a34a;--amber: #d97706;--red: #dc2626;--blue: #2563eb;--teal: #0d9488;--border: #e2e8f0;--radius: 10px}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,sans-serif;font-size:14px;line-height:1.5;color:var(--ink);background:var(--bg)}button,input,select,textarea{font:inherit}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}.sidebar{background:var(--sidebar);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}.brand{padding:1.5rem 1.25rem 1.1rem;border-bottom:1px solid rgba(255,255,255,.07)}.brand-name{font-size:1.35rem;font-weight:800;color:#fff;letter-spacing:-.03em}.brand-sub{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--sidebar-text);margin-top:.15rem}.nav-list{list-style:none;margin:.75rem 0 0;padding:.5rem;flex:1}.nav-list li{margin-bottom:2px}.nav-btn{display:flex;align-items:center;gap:.6rem;width:100%;padding:.65rem .85rem;border:none;border-radius:8px;background:transparent;color:var(--sidebar-text);text-align:left;cursor:pointer;font-size:.88rem;font-weight:500;transition:background .15s,color .15s}.nav-btn:hover{background:var(--sidebar-hover);color:#fff}.nav-btn.active{background:var(--sidebar-active);color:var(--sidebar-text-active);font-weight:600}.nav-icon{font-size:1rem;opacity:.8}.nav-badge{display:inline-flex;align-items:center;justify-content:center;background:#f59e0b;color:#000;font-size:.65rem;font-weight:800;border-radius:999px;min-width:18px;height:18px;padding:0 4px;margin-left:auto;line-height:1}.sidebar-foot{padding:.85rem 1rem;border-top:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--sidebar-text)}.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot.ok{background:#22c55e;box-shadow:0 0 6px #22c55e88}.dot.err{background:#f87171}.api-status{flex:1}.refresh-btn{background:transparent;border:none;color:var(--sidebar-text);cursor:pointer;font-size:1rem;padding:.2rem .4rem;border-radius:4px;line-height:1;transition:color .15s}.refresh-btn:hover{color:#fff}.refresh-btn:disabled{opacity:.3;cursor:not-allowed}.main{overflow-y:auto;min-width:0}.toast{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1.25rem;font-size:.875rem;font-weight:500;position:sticky;top:0;z-index:200;gap:1rem}.toast-ok{background:#f0fdf4;color:#15803d;border-bottom:1px solid #bbf7d0}.toast-error{background:#fef2f2;color:#b91c1c;border-bottom:1px solid #fecaca}.toast-x{background:none;border:none;cursor:pointer;color:inherit;opacity:.5;font-size:.9rem;padding:0 .25rem}.toast-x:hover{opacity:1}.loading-bar{height:3px;background:linear-gradient(90deg,var(--accent) 0%,transparent 100%);animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.page{max-width:1080px;margin:0 auto;padding:2rem 1.75rem 4rem}.page-hd{margin-bottom:1.75rem}.page-hd h1{margin:0;font-size:1.6rem;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.page-sub{margin:.3rem 0 0;font-size:.875rem;color:var(--muted)}.net-profit-banner{border-radius:12px;padding:1.5rem 2rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.net-profit-banner.profit{background:linear-gradient(135deg,#10b98126,#10b9810d);border:1px solid rgba(16,185,129,.3)}.net-profit-banner.loss{background:linear-gradient(135deg,#ef444426,#ef44440d);border:1px solid rgba(239,68,68,.3)}.net-profit-label{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);min-width:180px}.net-profit-value{font-size:2.25rem;font-weight:800;letter-spacing:-.02em;line-height:1}.net-profit-banner.profit .net-profit-value{color:#10b981}.net-profit-banner.loss .net-profit-value{color:#ef4444}.net-profit-sub{font-size:.9rem;color:var(--muted)}.alert-banner{background:#f59e0b14;border:1px solid rgba(245,158,11,.35);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.5rem}.alert-banner.mb-card{margin-bottom:1.5rem}.alert-title{font-size:.85rem;font-weight:700;color:#f59e0b;margin-bottom:.65rem;text-transform:uppercase;letter-spacing:.04em}.alert-list{display:flex;flex-direction:column;gap:.4rem}.alert-item{display:flex;align-items:center;gap:.6rem;font-size:.85rem;flex-wrap:wrap}.alert-stock{color:var(--muted);font-size:.8rem}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem;box-shadow:0 1px 4px #0000000a}.card-title{font-size:.95rem;font-weight:600;margin:0 0 1rem;color:var(--ink)}.mt-card{margin-top:1rem}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.25rem 1.25rem 1.1rem;border-left:4px solid;box-shadow:0 1px 4px #0000000a}.kpi-green{border-left-color:var(--green)}.kpi-amber{border-left-color:var(--amber)}.kpi-teal{border-left-color:var(--teal)}.kpi-blue{border-left-color:var(--blue)}.kpi-red{border-left-color:var(--red)}.kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:.4rem;font-weight:600}.kpi-value{font-size:1.55rem;font-weight:700;letter-spacing:-.02em;line-height:1.1;color:var(--ink)}.kpi-sub{font-size:.72rem;color:var(--muted);margin-top:.35rem}.dash-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:1rem}.counters{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}.counter{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;text-align:center;box-shadow:0 1px 4px #0000000a}.counter-val{font-size:1.3rem;font-weight:700;color:var(--ink);letter-spacing:-.02em}.counter-label{font-size:.75rem;color:var(--muted);margin-top:.2rem}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}.lot-grid{display:grid;grid-template-columns:380px 1fr;gap:1.5rem;align-items:start}.bom-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:1rem;align-items:start}.sales-top{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:start}.fstack{display:flex;flex-direction:column;gap:.65rem}.row2{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.field{display:flex;flex-direction:column;gap:.2rem}.field-lbl{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;padding:.55rem .75rem;color:var(--ink);transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0d94881f}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}textarea{resize:vertical;min-height:100px}.mt-sm{margin-top:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:.55rem 1rem;cursor:pointer;font-size:.875rem;font-weight:500;white-space:nowrap;transition:background .12s,border-color .12s}.btn:hover{background:#f8fafc;border-color:#cbd5e1}.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent-dark)}.btn.primary:hover{background:var(--accent-dark)}.btn.small{padding:.35rem .65rem;font-size:.8rem}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.tbl{width:100%;border-collapse:collapse;font-size:.85rem}.tbl th,.tbl td{padding:.5rem .6rem;text-align:left;vertical-align:middle;border-bottom:1px solid var(--line)}.tbl th{color:var(--muted);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em}.tbl tbody tr:last-child td{border-bottom:0}.tbl tbody tr:hover{background:#f8fafc}.row-sel{background:#f0fdf4!important}.mt{margin-top:.75rem}.badge{display:inline-block;font-size:.72rem;font-weight:600;padding:.2rem .55rem;border-radius:9999px}.badge-ok{background:#dcfce7;color:#15803d}.badge-warn{background:#fef9c3;color:#92400e}.badge-err{background:#fee2e2;color:#b91c1c}.formula-hd{margin-bottom:.5rem;font-size:.82rem}.formula-header{display:grid;grid-template-columns:1fr 120px 32px;gap:.5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:0 0 .3rem}.formula-rows{display:flex;flex-direction:column;gap:.4rem}.formula-row{display:grid;grid-template-columns:1fr 120px 32px;gap:.5rem;align-items:center}.qty-in{text-align:right}.rm-btn{width:32px;height:32px;border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--muted);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;padding:0;transition:color .12s,border-color .12s}.rm-btn:hover{color:var(--red);border-color:var(--red);background:#fef2f2}.formula-actions{display:flex;gap:.6rem;margin-top:.75rem}.formula-cur{margin-top:1.25rem;border-top:1px solid var(--line);padding-top:1rem}.formula-cur-hd{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:.5rem}.order-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem;margin-bottom:1rem}.detail-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem;margin-bottom:1rem}.dkpi{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:.65rem .75rem}.dkpi-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.dkpi-val{font-size:1.05rem;font-weight:700;margin-top:.25rem;color:var(--ink)}.section-lbl{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin:.75rem 0 .4rem}.c-green{color:var(--green)}.c-amber{color:var(--amber)}.c-red{color:var(--red)}.c-teal{color:var(--teal)}.c-muted{color:var(--muted)}code{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:.82em;background:#f1f5f9;padding:.1em .35em;border-radius:4px;color:var(--ink)}.empty{color:var(--muted);font-size:.85rem;margin:.5rem 0}.hint{font-size:.75rem;color:var(--muted);margin:.5rem 0 0;font-style:italic}@media(max-width:1100px){.kpi-row,.counters{grid-template-columns:repeat(2,1fr)}.dash-grid,.lot-grid{grid-template-columns:1fr}.order-kpis{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.bom-grid,.sales-top,.two-col{grid-template-columns:1fr}.detail-kpis,.order-kpis{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.layout{grid-template-columns:1fr}.sidebar{height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center;gap:0}.brand{padding:.75rem 1rem;border-bottom:none;border-right:1px solid rgba(255,255,255,.07)}.brand-sub{display:none}.nav-list{display:flex;flex-direction:row;margin:0;padding:.35rem;flex:1}.nav-list li{margin:0}.nav-btn{padding:.5rem .65rem;font-size:.8rem}.nav-icon{display:none}.sidebar-foot{padding:.5rem .75rem}.kpi-row,.counters{grid-template-columns:1fr 1fr}.row2{grid-template-columns:1fr}.formula-header,.formula-row{grid-template-columns:1fr 90px 32px}.detail-kpis,.order-kpis{grid-template-columns:1fr 1fr}.net-profit-banner{padding:1rem 1.25rem;gap:1rem}.net-profit-value{font-size:1.75rem}.page{padding:1.25rem 1rem 3rem}}
