:root{color:#1d1d1f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--bg:#f5f5f7;--panel:#ffffffdb;--panel-solid:#fff;--text:#1d1d1f;--muted:#6e6e73;--border:#0000001a;--blue:#0071e3;--blue-dark:#005bb5;--danger:#b42318;--warning:#8a6116;--shadow:0 18px 50px #00000014;background:#f5f5f7;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(180deg, #ffffffb8, #f5f5f7eb), radial-gradient(circle at 20% 0%, #0071e31a, transparent 32%), var(--bg);min-width:320px;min-height:100vh;margin:0}button,textarea,summary{font:inherit}button,summary{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}#app{min-height:100vh}.shell{width:min(1440px,100%);margin:0 auto;padding:32px}.topbar{justify-content:space-between;align-items:center;gap:24px;margin-bottom:24px;display:flex}.eyebrow{color:var(--muted);margin:0 0 6px;font-size:13px;font-weight:600}h1,h2{color:var(--text);letter-spacing:0;margin:0}h1{font-size:clamp(32px,4vw,54px);font-weight:650;line-height:1.05}h2{font-size:22px;font-weight:650;line-height:1.2}.status-pill{border:1px solid var(--border);min-height:34px;color:var(--muted);white-space:nowrap;text-overflow:ellipsis;background:#ffffffa3;border-radius:999px;align-items:center;gap:8px;max-width:min(520px,52vw);padding:6px 12px;font-size:13px;display:inline-flex;overflow:hidden}.dot{background:#34c759;border-radius:50%;width:8px;height:8px}.workspace{grid-template-columns:390px minmax(0,1fr);align-items:start;gap:20px;display:grid}.control-panel,.result-panel{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:8px}.control-panel{gap:16px;padding:16px;display:grid;position:sticky;top:20px}.segmented{background:#0000000f;border-radius:8px;grid-template-columns:1fr 1fr;gap:4px;padding:4px;display:grid}.segmented button,.primary,.secondary{border:0;border-radius:7px;min-height:36px;padding:8px 12px;font-size:14px;transition:background .16s,color .16s,border-color .16s}.segmented button{color:var(--muted);background:0 0}.segmented button.active{color:var(--text);background:var(--panel-solid);box-shadow:0 1px 4px #00000014}.dropzone{text-align:center;cursor:pointer;background:#ffffff9e;border:1.5px dashed #0000002e;border-radius:8px;place-items:center;gap:10px;min-height:186px;padding:20px;transition:border-color .16s,background .16s;display:grid}.dropzone.dragging,.dropzone:hover{border-color:var(--blue);background:#0071e30f}.dropzone input{display:none}.dropzone svg{fill:none;width:34px;height:34px;stroke:var(--blue);stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round}.dropzone strong{font-size:17px}.dropzone span,.section-title,.output-row small,.preview-toolbar,.file-row{color:var(--muted)}.section-title{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:600;display:flex}.section-title b{color:var(--blue);font-weight:650}.link-button{color:var(--blue);background:0 0;border:0;padding:0;font-size:13px;font-weight:650}.file-list,.mapping-box{min-width:0}.file-row,.output-row{border:1px solid var(--border);text-align:left;background:#ffffffb8;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;width:100%;min-height:42px;padding:8px 10px;display:grid}.file-row{cursor:default}.file-row>div{gap:3px;min-width:0;display:grid}.file-row small{text-overflow:ellipsis;white-space:nowrap;background:#0000000f;border-radius:999px;width:fit-content;max-width:100%;padding:2px 7px;font-size:11px;overflow:hidden}.file-row.kind-sub2api small,.file-row.kind-cpa-auth small{color:var(--blue);background:#0071e31a}.file-row.kind-error small{color:var(--danger);background:#b4231817}.file-row.kind-unknown small{color:var(--warning);background:#8a61161a}.file-row>button{width:30px;height:30px;color:var(--muted);background:0 0;border:0;border-radius:7px;place-items:center;display:inline-grid}.file-row>button:hover{background:#0000000f}.file-row+.file-row,.output-row+.output-row{margin-top:8px}.file-row span,.output-row span,.preview-toolbar span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.file-row svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;width:18px;height:18px}.mapping-box{border:1px solid var(--border);background:#ffffff8f;border-radius:8px;overflow:hidden}.mapping-box summary{min-height:44px;color:var(--muted);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:0 12px;font-size:13px;font-weight:650;list-style:none;display:grid}.mapping-box summary::-webkit-details-marker{display:none}.mapping-box summary b{color:var(--blue);font-weight:650}.mapping-body{padding:0 12px 12px}textarea{resize:vertical;border:1px solid var(--border);width:100%;height:220px;color:var(--text);background:#ffffffc7;border-radius:8px;padding:12px;font-family:SF Mono,ui-monospace,Menlo,Consolas,monospace;font-size:12px;line-height:1.45}.button-row{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.primary{color:#fff;background:var(--blue)}.primary:hover:not(:disabled){background:var(--blue-dark)}.secondary{color:var(--text);background:#0000000f}.secondary:hover:not(:disabled){background:#0000001a}.result-panel{min-width:0;padding:16px}.summary-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.summary-grid div{border:1px solid var(--border);background:#ffffffad;border-radius:8px;min-width:0;padding:14px}.summary-grid span{color:var(--muted);margin-bottom:8px;font-size:13px;display:block}.summary-grid strong{color:var(--text);font-size:28px;line-height:1}.result-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.output-list{gap:8px;margin-bottom:16px;display:grid}.output-row.active{background:#0071e314;border-color:#0071e36b}.issue-list{gap:8px;margin-bottom:16px;display:grid}.issue{border:1px solid var(--border);border-radius:8px;gap:2px;padding:10px 12px;font-size:13px;display:grid}.issue.error{color:var(--danger);background:#b4231814}.issue.warning{color:var(--warning);background:#8a611614}.issue.info{color:var(--blue-dark);background:#0071e314}.preview{border:1px solid var(--border);background:#111114;border-radius:8px;overflow:hidden}.preview-toolbar{color:#ffffffb8;background:#1c1c1e;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;gap:12px;min-height:50px;padding:8px 10px 8px 14px;font-size:13px;display:flex}.preview-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}pre{color:#f5f5f7;text-align:left;white-space:pre-wrap;word-break:break-word;min-height:500px;max-height:68vh;margin:0;padding:18px;font-family:SF Mono,ui-monospace,Menlo,Consolas,monospace;font-size:12px;line-height:1.55;overflow:auto}.error-text{color:var(--danger);margin:8px 0 0;font-size:13px}@media (width<=980px){.shell{padding:18px}.topbar,.result-header{flex-direction:column;align-items:flex-start}.workspace{grid-template-columns:1fr}.control-panel{position:static}.summary-grid{grid-template-columns:repeat(2,1fr)}.status-pill{max-width:100%}}@media (width<=520px){.shell{padding:12px}.summary-grid,.segmented{grid-template-columns:1fr}.preview-toolbar,.preview-actions{flex-direction:column;align-items:stretch}.preview-actions,.preview-actions button{width:100%}}
