*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Segoe UI,Arial,sans-serif;color:#1f2933;background:#edf1f5}button,input,select{font:inherit}button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;border:1px solid #c8d0dc;border-radius:7px;padding:7px 10px;background:#fff;color:#263241;cursor:pointer}button:hover:not(:disabled){border-color:#91a6bf;background:#f4f7fb}button:disabled{color:#9aa3af;background:#f2f4f7;cursor:not-allowed}input,select{width:100%;min-height:38px;border:1px solid #c8d0dc;border-radius:7px;padding:7px 10px;background:#fff;color:#1f2933}label{display:grid;gap:6px;color:#374151;font-size:13px;font-weight:650}.web-shell{display:grid;grid-template-columns:352px minmax(850px,1fr);min-height:100vh}.control-panel{display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8fafc;border-right:1px solid #d8dee8}.brand{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:7px;background:#1e5aa8;color:#fff;font-weight:800}.brand h1{margin:0;font-size:20px;color:#172033}.brand p{margin:2px 0 0;color:#667085;font-size:13px}.drop-zone{display:grid;justify-items:center;gap:8px;padding:16px;border:1.5px dashed #b7c2d2;border-radius:8px;background:#fff;text-align:center}.drop-zone.drag-over{border-color:#1e5aa8;background:#eef5ff}.drop-zone span,.file-name,.status-line,.preview-panel p,.mapping-panel p{color:#667085;font-size:13px}.file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.primary{background:#1e5aa8;border-color:#1e5aa8;color:#fff;font-weight:700}.primary:hover:not(:disabled){background:#184a8b;border-color:#184a8b}.hidden-file{display:none}.setting-group{display:grid;gap:8px}.setting-group>span{color:#374151;font-size:13px;font-weight:750}.swatches{display:flex;align-items:center;gap:8px}.swatch{width:28px;height:28px;min-height:28px;border-radius:50%;border:2px solid transparent;padding:0}.swatch.selected{border-color:#172033}.native-color{width:38px;height:32px;min-height:32px;padding:2px}.segmented{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #c8d0dc;border-radius:7px;overflow:hidden;background:#fff}.segmented.two{grid-template-columns:repeat(2,1fr)}.segmented button{border:0;border-radius:0;min-height:36px}.segmented button+button{border-left:1px solid #d8dee8}.segmented button.active{background:#dbeafe;color:#164785;font-weight:800}.check-row,.map-options label{display:flex;align-items:center;gap:8px}.check-row input,.map-options input{width:16px;min-height:16px}.action-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.action-grid .primary{grid-column:1 / -1}.status-line{margin:0;padding:10px;border-radius:7px;background:#eef2f7}.main-panel{display:grid;grid-template-rows:auto minmax(430px,1fr) 230px;gap:12px;min-width:0;padding:16px}.map-options{display:flex;flex-wrap:wrap;gap:14px;align-items:center;min-height:44px;padding:9px 12px;border:1px solid #d8dee8;border-radius:8px;background:#fff}.map-options label{font-size:13px;font-weight:650}.map-stage{display:flex;align-items:center;justify-content:center;min-width:0;min-height:0;overflow:hidden;border:1px solid #d8dee8;border-radius:8px;background:#fff}.map-stage svg{width:100%;height:100%;max-height:100%;aspect-ratio:16 / 9;display:block}.lower-panels{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);gap:12px;min-height:0}.preview-panel,.mapping-panel{min-width:0;overflow:auto;border:1px solid #d8dee8;border-radius:8px;background:#fff;padding:13px}.preview-panel h2{margin:0 0 10px;font-size:16px}.table-wrap{overflow:auto}table{width:max-content;min-width:100%;border-collapse:collapse;font-size:12px}td{max-width:220px;padding:6px 8px;overflow:hidden;border:1px solid #e3e7ee;text-overflow:ellipsis;white-space:nowrap}tr:first-child td{background:#f3f6fa;font-weight:750}.mapping-panel summary{cursor:pointer;font-weight:800;margin-bottom:10px}.mapping-stats{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 12px}.mapping-stats span{padding:5px 8px;border-radius:6px;background:#eef2f7;font-size:12px;font-weight:750}.mapping-list{display:grid;gap:10px;margin-bottom:12px}.mapping-item{display:grid;grid-template-columns:minmax(150px,1fr) minmax(180px,.9fr);gap:10px;align-items:center}.mapping-item strong,.mapping-item span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mapping-item strong{font-size:13px}.mapping-item span{color:#667085;font-size:12px}@media(max-width:1180px){.web-shell{grid-template-columns:330px minmax(760px,1fr)}.control-panel,.main-panel{padding:12px}}
