:root{color:#111827;background:#f5f7fb;font-family:Inter,Segoe UI,Microsoft YaHei,Arial,sans-serif;font-size:14px}*{box-sizing:border-box}body{margin:0;background:#f5f7fb;overflow:hidden}button,select,input{font:inherit}.app-shell{height:100vh;display:grid;grid-template-columns:250px minmax(560px,1fr) 320px;grid-template-rows:58px minmax(0,1fr);gap:10px;padding:10px;overflow:hidden}.topbar{grid-column:1 / 4;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:20;background:#111827;color:#fff;padding:0 18px;border-radius:8px}.topbar h1{margin:0;display:inline-block;font-size:20px;letter-spacing:0}.version{margin-left:10px;color:#cbd5e1;font-size:12px}.actions{display:flex;align-items:center;gap:10px}.usage-guide{position:relative}.usage-guide summary{min-height:36px;border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;color:#111827;background:#fff;cursor:pointer;list-style:none}.usage-guide summary::-webkit-details-marker{display:none}.usage-guide-body{position:absolute;top:44px;right:0;width:min(460px,88vw);padding:12px 14px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#111827;box-shadow:0 18px 44px #0f172a38;line-height:1.5;z-index:50}.usage-guide-body strong{display:block;margin:4px 0 6px}.usage-guide-body p{margin:0 0 7px;color:#475569;font-size:13px}.button{min-height:36px;border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;color:#111827;background:#fff;cursor:pointer}.button.primary{color:#fff;border-color:#b91c1c;background:#b91c1c}.button:disabled{opacity:.45;cursor:not-allowed}#fileInput,#firstLegInput{display:none}.sidebar,.rightbar{display:flex;flex-direction:column;gap:10px;min-height:0;overflow:hidden}.sidebar,.rightbar{overflow-y:auto;padding-right:2px}.panel,.map-panel{background:#fff;border:1px solid #dbe3ef;border-radius:8px}.panel{padding:10px;min-height:0;flex:0 0 auto}.panel-title{margin-bottom:8px;color:#0f172a;font-weight:700}.file-name{min-height:18px;margin-bottom:6px;color:#475569;word-break:break-all;line-height:1.3}.field{display:grid;gap:4px;margin-bottom:7px}.field span{color:#475569;font-size:12px;font-weight:700}.field select,.field input,.sku-select{width:100%;min-height:32px;border:1px solid #cbd5e1;border-radius:6px;padding:5px 8px;background:#fff}.mapping-panel{max-height:32vh;overflow-y:auto}.mapping-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px}.mapping-grid .field{margin-bottom:0}.settings-panel{position:relative;z-index:1}.warehouse-auto-mode{display:grid;gap:4px;margin-bottom:7px;padding:7px 8px;border:1px solid #dbe3ef;border-radius:6px;background:#f8fafc}.warehouse-auto-mode span{color:#475569;font-size:12px;font-weight:700}.warehouse-auto-mode strong{color:#0f172a;font-size:14px}.metrics-panel{flex:0 0 auto;overflow:visible}.zip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px;margin-top:2px}.warehouse-zip-field{margin-bottom:4px}.warehouse-zip-field input{min-height:30px;font-size:12px}.zip-note,.zip-warning{margin-top:6px;color:#64748b;font-size:11px;line-height:1.35}.zip-warning{color:#b45309}.split-settings{margin-top:10px;padding-top:10px;border-top:1px solid #e5edf6}.kpi{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid #e5edf6}.kpi:last-child{border-bottom:0}.kpi span{color:#64748b}.kpi strong{color:#b91c1c;font-size:18px}.workspace{min-width:0;min-height:0;display:flex;flex-direction:column;gap:10px}.tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.tabs button{min-height:36px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155;cursor:pointer}.tabs button.active{color:#fff;border-color:#0f766e;background:#0f766e;font-weight:700}.map-panel{min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden}.map-head{min-height:52px;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #dbe3ef}.map-head h2{margin:0 0 3px;font-size:18px}.map-head span{color:#64748b}#map{display:block;width:100%;flex:1;min-height:0}.map-marker{pointer-events:none}.map-marker-emoji{font-size:16px;text-anchor:middle;paint-order:stroke}.map-marker-label-bg{fill:#ffffffe6;stroke:#0f172a29}.map-marker-label{fill:#111827;font-size:11px;font-weight:800;paint-order:stroke;stroke:#fff;stroke-width:2px}.map-summary-card{pointer-events:none}.map-summary-card rect{fill:#fffffff0;stroke:#0f766e40;stroke-width:1.2;filter:drop-shadow(0 8px 16px rgba(15,23,42,.14))}.map-summary-title{fill:#0f172a;font-size:13px;font-weight:900}.map-summary-subtitle,.map-summary-label{fill:#64748b;font-size:11px;font-weight:700}.map-summary-value{fill:#0f172a;font-size:11px;font-weight:900;text-anchor:end}table{width:100%;border-collapse:collapse}th,td{padding:5px;border-bottom:1px solid #e5edf6;text-align:left;vertical-align:middle;font-size:11px}th{color:#475569;background:#f8fafc;font-weight:700}td:nth-child(n+3),th:nth-child(n+3){text-align:right}.compact,.split-summary-panel,.split-table-panel{overflow:hidden}.split-table-panel{overflow-x:auto}.split-table-panel table{min-width:500px}.split-table-panel.compact table{min-width:560px}.split-file{margin-bottom:8px;color:#64748b;font-size:12px;line-height:1.35;word-break:break-all}.split-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.split-kpis div{min-width:0;padding:8px;border:1px solid #e5edf6;border-radius:6px;background:#f8fafc}.split-kpis span,.empty-state{color:#64748b;font-size:12px;line-height:1.4}.split-kpis strong{display:block;margin-top:3px;color:#0f172a;font-size:15px}.split-note{margin-top:8px;color:#64748b;font-size:12px;line-height:1.4}.scenario-card{border-left:4px solid #cbd5e1;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.scenario-card.active{border-color:#0f766e;border-left-width:6px;background:#ecfdf5;box-shadow:0 0 0 2px #0f766e29,0 12px 24px #0f172a14}.scenario-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.scenario-warehouses,.scenario-allocation{color:#64748b;font-size:12px;line-height:1.4}.scenario-allocation{margin-bottom:8px}.scenario-active-badge{flex:0 0 auto;padding:4px 8px;border-radius:999px;background:#0f766e;color:#fff;font-size:11px;font-weight:800;line-height:1}.scenario-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.scenario-config{display:grid;gap:8px;margin-top:10px}.scenario-config-head{display:grid;gap:8px}.scenario-config-head span{display:block;color:#64748b;font-size:12px}.scenario-config-head strong{display:block;margin-top:3px;color:#0f172a;font-size:13px}.scenario-mode-buttons,.scenario-count-buttons{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.scenario-count-buttons{grid-template-columns:repeat(4,minmax(0,1fr))}.button.active-lite{border-color:#0f766e;background:#ecfdf5;color:#0f766e}.scenario-warehouse-list{display:grid;gap:6px}.scenario-warehouse-row{display:grid;grid-template-columns:64px minmax(0,1fr) 76px;gap:6px;align-items:center;padding:6px;border:1px solid #e5edf6;border-radius:6px;background:#f8fafc}.scenario-warehouse-row.checked{border-color:#0f766e59;background:#f0fdfa}.scenario-warehouse-check{display:inline-flex;align-items:center;gap:5px;color:#0f172a;font-size:12px;font-weight:800}.scenario-warehouse-zip,.scenario-share-field input{width:100%;min-width:0;padding:6px 7px;border:1px solid #d7e1ec;border-radius:6px;background:#fff;color:#0f172a;font-size:12px}.scenario-share-field{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:3px;align-items:center;color:#64748b;font-size:12px}.manual-first-leg-form{display:grid;gap:6px}.first-leg-plan-list{display:grid;gap:8px;margin-top:8px}.first-leg-plan-row{padding:8px;border:1px solid #e5edf6;border-radius:6px;background:#f8fafc}.first-leg-row-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:7px}.first-leg-row-head strong,.first-leg-row-head span{display:block;line-height:1.25}.first-leg-row-head strong{color:#0f172a;font-size:13px}.first-leg-row-head span{color:#64748b;font-size:11px}.first-leg-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px}.first-leg-edit-grid .field{margin-bottom:0}.icon-button{width:24px;height:24px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#64748b;cursor:pointer;font-size:15px;font-weight:800;line-height:1}.icon-button:hover{border-color:#fca5a5;color:#b91c1c}.manual-first-leg-form .field{margin-bottom:0}.manual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px}.first-leg-add-button{width:100%;margin-top:2px}.first-leg-apply-button{width:100%;margin-top:8px}.money-positive{color:#047857!important;font-weight:700}.money-negative{color:#b91c1c!important;font-weight:700}.money-neutral{color:#475569!important;font-weight:700}.map-legend{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:5px;color:#475569;font-size:12px;line-height:1.3}.legend-swatch{display:inline-block;width:10px;height:10px;margin-right:4px;border-radius:2px;vertical-align:-1px}.legend-swatch.save{background:#22c55e}.legend-swatch.cost{background:#ef4444}.dot{display:inline-block;width:9px;height:9px;margin-right:6px;border-radius:50%}.warehouse-chip{display:inline-block;width:13px;height:13px;margin-right:7px;border:2px solid #ffffff;border-radius:3px;background:var(--warehouse-color);box-shadow:0 0 0 1px #334155;vertical-align:-2px}.state-label{pointer-events:none}.tooltip{position:absolute;z-index:1000;display:none;min-width:190px;padding:10px 12px;color:#fff;background:#0f172af0;border-radius:6px;pointer-events:none;box-shadow:0 12px 30px #0f172a40}.tooltip strong,.tooltip span{display:block;line-height:1.45}.tooltip span{color:#dbeafe}
