*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:#f5f7fa;color:#1a1a2e;line-height:1.5}.app-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:#1a1a2e;color:#e0e0e0;padding:0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto;z-index:100;display:flex;flex-direction:column}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header h1{font-size:18px;font-weight:700;color:#fff;letter-spacing:-.3px}.sidebar-header p{font-size:11px;color:#888;margin-top:4px;text-transform:uppercase;letter-spacing:1px}.sidebar-nav{padding:12px 0}.sidebar-section-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:#666;padding:16px 20px 6px;font-weight:600}.nav-link{display:flex;align-items:center;gap:10px;padding:10px 20px;color:#aaa;text-decoration:none;font-size:13px;font-weight:500;transition:all .15s ease;border-left:3px solid transparent}.nav-link:hover{background:#ffffff0d;color:#fff}.nav-link.active{background:#ffffff14;color:#fff;border-left-color:#4f8cff}.main-content{flex:1;margin-left:260px;padding:32px;max-width:1400px}.page-header{margin-bottom:28px}.page-header h2{font-size:24px;font-weight:700;color:#1a1a2e}.page-header p{font-size:14px;color:#666;margin-top:4px}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;margin-bottom:20px}.card h3{font-size:14px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}.kpi-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000000f}.kpi-card .kpi-label{font-size:12px;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.kpi-card .kpi-value{font-size:32px;font-weight:700;color:#1a1a2e;margin-top:4px;line-height:1.2}.kpi-card .kpi-sub{font-size:12px;color:#888;margin-top:4px}.kpi-card.deficit{border-left:4px solid #e74c3c}.kpi-card.surplus{border-left:4px solid #f39c12}.kpi-card.coverage{border-left:4px solid #2ecc71}.kpi-card.info{border-left:4px solid #4f8cff}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:10px 12px;font-weight:600;color:#666;text-transform:uppercase;font-size:11px;letter-spacing:.5px;border-bottom:2px solid #eee;background:#fafbfc;position:sticky;top:0}.data-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0;color:#333}.data-table tr:hover{background:#f8f9ff}.data-table .number{text-align:right;font-variant-numeric:tabular-nums}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.badge.deficit{background:#fde8e8;color:#c0392b}.badge.surplus{background:#fef3e2;color:#d68910}.badge.ok{background:#e8f8e8;color:#27ae60}.badge.critical{background:#fde8e8;color:#c0392b}.badge.high{background:#fef3e2;color:#d68910}.badge.medium{background:#fff8e1;color:#f57f17}.badge.low,.badge.released{background:#e8f8e8;color:#27ae60}.badge.pending{background:#fff8e1;color:#f57f17}.badge.blocked{background:#fde8e8;color:#c0392b}.badge.knitting{background:#e3f2fd;color:#1565c0}.badge.dyeing{background:#f3e5f5;color:#7b1fa2}.badge.finishing{background:#fff3e0;color:#ef6c00}.badge.finished{background:#e8f5e9;color:#2e7d32}.upload-zone{border:2px dashed #ccc;border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .2s ease;background:#fafbfc}.upload-zone:hover{border-color:#4f8cff;background:#f0f5ff}.upload-zone input[type=file]{display:none}.upload-zone p{color:#888;font-size:14px;margin-top:8px}.btn{padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s ease}.btn-primary{background:#4f8cff;color:#fff}.btn-primary:hover{background:#3a7afe}.btn-secondary{background:#eee;color:#333}.btn-secondary:hover{background:#ddd}.wip-pipeline{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}.wip-stage-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 1px 3px #0000000f;position:relative}.wip-stage-card .stage-name{font-size:14px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px}.wip-stage-card .stage-value{font-size:28px;font-weight:700;margin-top:8px}.wip-stage-card .stage-sub{font-size:12px;color:#888;margin-top:4px}.wip-stage-card.knitting{border-top:4px solid #1565c0}.wip-stage-card.dyeing{border-top:4px solid #7b1fa2}.wip-stage-card.finishing{border-top:4px solid #ef6c00}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}.message{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:13px}.message.success{background:#e8f8e8;color:#27ae60;border:1px solid #c3e6c3}.message.error{background:#fde8e8;color:#c0392b;border:1px solid #f5c6c6}.message.info{background:#e3f2fd;color:#1565c0;border:1px solid #bbdefb}.loading{text-align:center;padding:40px;color:#888}.empty-state{text-align:center;padding:60px 20px;color:#888}.empty-state h3{font-size:18px;color:#333;margin-bottom:8px}.lang-switcher{display:flex;gap:4px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.08);margin-top:auto}.lang-btn{flex:1;padding:6px 0;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:transparent;color:#888;font-size:11px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:all .15s ease}.lang-btn:hover{background:#ffffff14;color:#fff}.lang-btn.active{background:#4f8cff;color:#fff;border-color:#4f8cff}.mobile-menu-toggle{display:none;position:fixed;top:12px;left:12px;z-index:200;background:#1a1a2e;color:#fff;border:none;border-radius:8px;width:40px;height:40px;font-size:20px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.sidebar-overlay{display:none}.card{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 1400px){.main-content{max-width:100%}}@media (max-width: 1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}.sidebar{width:220px}.main-content{margin-left:220px;padding:24px}}@media (max-width: 1024px){.sidebar{width:200px}.main-content{margin-left:200px;padding:20px}.kpi-card .kpi-value{font-size:26px}.page-header h2{font-size:20px}.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.mobile-menu-toggle{display:flex}.sidebar{width:260px;transform:translate(-100%);transition:transform .3s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99;display:none}.sidebar-overlay.open{display:block}.main-content{margin-left:0;padding:64px 16px 16px}.kpi-grid{grid-template-columns:repeat(2,1fr);gap:10px}.kpi-card{padding:14px}.kpi-card .kpi-value{font-size:22px}.kpi-card .kpi-label{font-size:10px}.kpi-card .kpi-sub{font-size:11px}.grid-2,.grid-3{grid-template-columns:1fr}.wip-pipeline{grid-template-columns:1fr;gap:10px}.wip-stage-card .stage-value{font-size:22px}.page-header{margin-bottom:20px}.page-header h2{font-size:18px}.page-header p{font-size:12px}.card{padding:16px;border-radius:10px;margin-bottom:14px}.card h3{font-size:12px}.data-table{font-size:12px;min-width:600px}.data-table th,.data-table td{padding:8px}.data-table th{font-size:10px}.btn{padding:8px 12px;font-size:12px}.message{font-size:12px;padding:10px 12px}.empty-state{padding:40px 16px}.empty-state h3{font-size:16px}}@media (max-width: 480px){.main-content{padding:60px 12px 12px}.kpi-grid{grid-template-columns:1fr;gap:8px}.kpi-card{padding:12px;display:flex;align-items:center;gap:12px}.kpi-card .kpi-value{font-size:20px;margin-top:0;white-space:nowrap}.kpi-card .kpi-label{font-size:10px;margin-bottom:2px}.kpi-card .kpi-sub{display:none}.page-header h2{font-size:16px}.page-header p{font-size:11px}.data-table{min-width:500px}.wip-stage-card{padding:14px}.wip-stage-card .stage-value{font-size:20px}.lang-switcher{padding:12px 16px}}.pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:#fff;border:1px solid #e8eaf0;border-top:none;border-radius:0 0 10px 10px;flex-wrap:wrap;gap:8px}.pagination-info{font-size:12px;color:#888}.pagination-controls{display:flex;gap:4px;align-items:center}.page-btn{min-width:30px;height:30px;padding:0 7px;border:1.5px solid #e8eaf0;background:#fff;color:#1a1a2e;border-radius:6px;font-size:13px;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.page-btn:hover:not(:disabled){border-color:#4f8cff;color:#4f8cff}.page-btn.active{background:#4f8cff;border-color:#4f8cff;color:#fff;font-weight:700}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-ellipsis{padding:0 4px;color:#bbb;font-size:13px}.totals-bar{display:flex;align-items:stretch;background:#fff;border:1px solid #e8eaf0;border-radius:10px;margin-bottom:16px;flex-wrap:wrap;overflow:hidden}.total-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 20px;flex:1;min-width:80px;border-right:1px solid #f0f2f5}.total-item:last-child{border-right:none}.t-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#888;white-space:nowrap;margin-bottom:2px}.t-value{font-size:20px;font-weight:700;color:#1a1a2e;line-height:1.2}.t-value.t-deficit{color:#c0392b}.t-value.t-surplus{color:#d68910}.t-value.t-ok{color:#27ae60}.filter-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.search-input{flex:1;min-width:160px;max-width:300px;padding:7px 12px;border:1.5px solid #e8eaf0;border-radius:8px;font-size:13px;background:#fff;color:#1a1a2e;outline:none;transition:border-color .15s}.search-input:focus{border-color:#4f8cff}.filter-btns{display:flex;gap:6px;flex-wrap:wrap}.filter-count{display:inline-flex;align-items:center;justify-content:center;background:#00000021;border-radius:9px;font-size:10px;font-weight:700;padding:1px 5px;min-width:18px;margin-left:5px}.btn-primary .filter-count{background:#ffffff47}.showing-info{font-size:12px;color:#888;margin-bottom:8px;padding:0 2px}.page-size-selector{display:flex;align-items:center;gap:6px}.page-size-label{font-size:12px;color:#888;white-space:nowrap}.page-size-select{height:28px;padding:0 6px;border-radius:6px;border:1.5px solid #e8eaf0;background:#fff;font-size:12px;color:#333;cursor:pointer;outline:none}.page-size-select:focus{border-color:#4f8cff}.filter-select{height:34px;padding:0 10px;border-radius:8px;border:1.5px solid #e8eaf0;background:#fff;font-size:13px;color:#1a1a2e;cursor:pointer;min-width:130px;outline:none;transition:border-color .15s}.filter-select:focus{border-color:#4f8cff}.export-bar{display:flex;gap:6px;align-items:center;margin-left:auto}.btn-export{display:flex;align-items:center;gap:4px;padding:5px 12px;border-radius:7px;border:1.5px solid #e8eaf0;background:#fff;font-size:12px;font-weight:600;cursor:pointer;color:#444;transition:background .15s,border-color .15s}.btn-export:hover{background:#f0f4ff;border-color:#4f8cff;color:#4f8cff}.btn-export.excel:hover{background:#f0fff4;border-color:#27ae60;color:#27ae60}.btn-export.pdf:hover{background:#fff5f5;border-color:#c0392b;color:#c0392b}.period-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.period-tab{padding:6px 18px;border-radius:20px;border:1.5px solid #e8eaf0;background:#fff;font-size:13px;font-weight:500;cursor:pointer;color:#555;transition:background .15s,border-color .15s,color .15s}.period-tab:hover{border-color:#4f8cff;color:#4f8cff}.period-tab.active{background:#4f8cff;border-color:#4f8cff;color:#fff;font-weight:700}.pivot-wrapper{overflow-x:auto;border-radius:10px;box-shadow:0 1px 4px #00000012}.pivot-table{width:100%;border-collapse:collapse;font-size:13px;background:#fff}.pivot-table th{background:#f0f4ff;color:#333;font-weight:700;padding:10px 14px;text-align:center;border-bottom:2px solid #d8e0f0;white-space:nowrap}.pivot-table th:first-child,.pivot-table th:nth-child(2){text-align:left}.pivot-table td{padding:8px 14px;text-align:right;border-bottom:1px solid #f0f0f0;white-space:nowrap}.pivot-style-cell{text-align:left!important;font-weight:700;color:#1a1a2e;vertical-align:top;padding-top:10px!important}.pivot-color-cell{text-align:left!important;color:#444}.pivot-group-row td{border-top:2px solid #d8e0f0!important}.pivot-total-row td{background:#e8f0ff!important;font-weight:700;border-top:2px solid #a0b8e8!important;color:#1a1a2e;text-align:right}.pivot-total-row .pivot-style-cell{text-align:left!important}.pivot-total-col{background:#f4f8ff!important;font-weight:700;border-left:2px solid #d8e0f0!important}.pivot-total-row .pivot-total-col{background:#dce8ff!important;color:#1a46b0}.pivot-zero{color:#ccc;font-weight:400}.pivot-table tr:hover td{background:#fafbff}.pivot-table .pivot-total-row:hover td{background:#e8f0ff!important}.pivot-meta{font-size:12px;color:#888;margin-bottom:12px;padding:0 2px}
