:root{color-scheme:light;--su-bg: #f7f8fa;--su-surface: #ffffff;--su-surface-muted: #f1f3f5;--su-border: #e5e7eb;--su-text: #111827;--su-muted: #6b7280;--su-accent: #2563eb;--su-danger: #dc2626;--su-success: #16a34a;--su-warning: #d97706;--su-radius: 12px;--su-shadow: 0 10px 30px rgba(15, 23, 42, .08);--su-font: Inter, Geist, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Microsoft YaHei", sans-serif}:root[data-theme=dark]{color-scheme:dark;--su-bg: #0b0d12;--su-surface: #111318;--su-surface-muted: #181b22;--su-border: #2a2f3a;--su-text: #f3f4f6;--su-muted: #9ca3af;--su-accent: #60a5fa;--su-danger: #f87171;--su-success: #4ade80;--su-warning: #fbbf24;--su-shadow: 0 18px 40px rgba(0,0,0,.35)}.su-button{border:1px solid var(--su-border);border-radius:10px;background:var(--su-surface);color:var(--su-text);padding:.55rem .85rem;font:inherit;cursor:pointer;transition:border-color .15s,background .15s,transform .08s}.su-button:hover{border-color:var(--su-accent);background:var(--su-surface-muted)}.su-button:active{transform:translateY(1px)}.su-button.primary{background:var(--su-accent);color:#fff;border-color:var(--su-accent)}.su-field{display:grid;gap:.35rem}.su-field label{color:var(--su-muted);font-size:.85rem}.su-field input,.su-field textarea,.su-field select,.su-input,.su-textarea,.su-select{border:1px solid var(--su-border);border-radius:10px;background:var(--su-surface);color:var(--su-text);padding:.65rem .75rem;font:inherit}.su-field textarea,.su-textarea{min-height:9rem;resize:vertical}.su-badge{display:inline-flex;align-items:center;border:1px solid var(--su-border);border-radius:999px;padding:.15rem .55rem;font-size:.78rem;color:var(--su-muted);background:var(--su-surface-muted)}.su-panel{background:var(--su-surface);border:1px solid var(--su-border);border-radius:var(--su-radius);box-shadow:var(--su-shadow)}.su-command-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:12vh 16px 16px;z-index:1000}.su-command-panel{width:min(560px,100%);background:var(--su-surface, #fff);border:1px solid var(--su-border, #cbd5e1);border-radius:12px;box-shadow:0 20px 50px #0f172a2e;padding:12px}.su-command-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:.9rem}.su-command-header kbd{font-size:.75rem;padding:2px 6px;border-radius:6px;border:1px solid var(--su-border, #cbd5e1);background:var(--su-surface-muted, #f8fafc)}.su-command-input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--su-border, #cbd5e1);border-radius:8px;margin-bottom:8px}.su-command-list{list-style:none;margin:0;padding:0;max-height:320px;overflow:auto}.su-command-list button{width:100%;text-align:left;border:none;background:transparent;padding:8px 10px;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:2px}.su-command-list button:hover,.su-command-list button:focus-visible{background:var(--su-surface-muted, #f1f5f9)}.su-command-list small{color:var(--su-muted, #64748b);font-size:.75rem}.su-command-empty{padding:12px;color:var(--su-muted, #64748b)}.su-oss-benchmarks{margin-top:32px;padding:20px;border:1px solid var(--su-border, #e2e8f0);border-radius:12px;background:var(--su-surface, #fff)}.su-oss-benchmarks h2{margin:0 0 8px;font-size:1.1rem}.su-oss-list{list-style:none;margin:16px 0 0;padding:0;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.su-oss-card{padding:12px;border:1px solid var(--su-border-soft, #e2e8f0);border-radius:10px;background:var(--su-surface-muted, #f8fafc)}.su-oss-card a{font-weight:600;color:var(--su-accent, #2563eb)}.su-oss-card>p{margin:6px 0 8px;font-size:.85rem;color:var(--su-muted, #64748b)}.su-oss-card ul{margin:0;padding-left:18px;font-size:.82rem}.su-compare{display:grid;gap:12px;margin:16px 0}@media(min-width:720px){.su-compare-text,.su-compare-images{grid-template-columns:1fr 1fr}}.su-compare pre{margin:8px 0 0;padding:10px;border-radius:8px;border:1px solid var(--su-border-soft, #e2e8f0);background:var(--su-surface-muted, #f8fafc);max-height:240px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-size:.85rem}.su-compare-images figure{margin:0}.su-compare-images figcaption{font-size:.85rem;font-weight:600;margin-bottom:6px}.su-compare-images img{width:100%;max-height:280px;object-fit:contain;border-radius:8px;border:1px solid var(--su-border-soft, #e2e8f0);background:#fff}.su-file-queue{margin:16px 0;border:1px solid var(--su-border, #e2e8f0);border-radius:10px;background:var(--su-surface, #fff)}.su-file-queue header{padding:8px 12px;border-bottom:1px solid var(--su-border-soft, #e2e8f0)}.su-file-queue-toggle{border:none;background:transparent;font-weight:600;cursor:pointer}.su-file-queue ul{list-style:none;margin:0;padding:8px 12px}.su-file-queue li{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:6px 0;border-bottom:1px dashed var(--su-border-soft, #e2e8f0);font-size:.85rem}.su-file-queue li:last-child{border-bottom:none}.su-file-queue li[data-status=running] .su-file-status{color:var(--su-accent, #2563eb)}.su-file-queue li[data-status=done] .su-file-status{color:#059669}.su-file-queue li[data-status=error] .su-file-status{color:#dc2626}.su-file-actions button{margin-left:6px;font-size:.75rem}.su-compare-slider{position:relative;width:100%;max-height:320px;overflow:hidden;border-radius:10px;border:1px solid var(--su-border-soft, #e2e8f0);touch-action:none;cursor:ew-resize;-webkit-user-select:none;user-select:none}.su-compare-slider-after,.su-compare-slider-before img{display:block;width:100%;max-height:320px;object-fit:contain}.su-compare-slider-before{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.su-compare-slider-handle{position:absolute;top:0;bottom:0;width:3px;margin-left:-1px;background:var(--su-accent, #2563eb);box-shadow:0 0 0 1px #fffc}.su-compare-slider-labels{position:absolute;left:8px;right:8px;bottom:8px;display:flex;justify-content:space-between;font-size:.75rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6);pointer-events:none}.su-diff-view .d2h-wrapper{overflow:auto;border:1px solid var(--su-border-soft, #e2e8f0);border-radius:8px;font-size:.82rem}.su-diff-view .d2h-file-side-by-side{display:grid;grid-template-columns:1fr 1fr}.su-diff-view .d2h-diff-table{width:100%;border-collapse:collapse;table-layout:fixed}.su-diff-view .d2h-code-linenumber{width:3em;padding:0 6px;text-align:right;color:var(--su-muted, #64748b);background:var(--su-surface-muted, #f8fafc);border-right:1px solid var(--su-border-soft, #e2e8f0);vertical-align:top}.su-diff-view td span{display:block;padding:1px 6px;white-space:pre-wrap;word-break:break-word}.su-diff-view .d2h-del{background:#fee2e2}.su-diff-view .d2h-ins{background:#dcfce7}.su-diff-view .d2h-cntx{background:#fff}.su-diff-view .d2h-empty{background:#f1f5f9}:root{--text: var(--su-text, #172033);--muted: var(--su-muted, #475569);--subtle: var(--su-muted, #64748b);--page-bg: var(--su-bg, #f7f8fb);--surface: var(--su-surface, #ffffff);--surface-soft: var(--su-surface-muted, #f8fafc);--border: var(--su-border, #cbd5e1);--border-soft: var(--su-border, #e2e8f0);--primary: var(--su-accent, #2563eb);--primary-strong: var(--su-accent, #1d4ed8);--primary-soft: #dbeafe;--code-bg: #0f172a;--code-text: #e2e8f0;--danger-bg: #fee2e2;--danger-text: #b91c1c;--warning-bg: #fef3c7;--warning-text: #92400e;color:var(--text);background:var(--page-bg);font-family:Inter,Segoe UI,Microsoft YaHei,system-ui,sans-serif;line-height:1.5}:root[data-theme=dark]{--text: #e5eefb;--muted: #b8c4d6;--subtle: #93a4bb;--page-bg: #101522;--surface: #182033;--surface-soft: #111827;--border: #46546d;--border-soft: #2b3548;--primary: #7aa2ff;--primary-strong: #a8c1ff;--primary-soft: #20375f;--code-bg: #060b15;--code-text: #dce8f8;--danger-bg: #5b1f2a;--danger-text: #ffd1d8;--warning-bg: #4c3517;--warning-text: #ffe1a6}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--page-bg);color:var(--text)}button,input,select,textarea{font:inherit}button,.tool-card{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px}button{min-height:38px;padding:8px 12px;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}textarea,input,select{width:100%;border:1px solid var(--border);border-radius:6px;padding:10px 12px;background:var(--surface);color:var(--text)}textarea{resize:vertical;min-height:160px;font-family:Cascadia Mono,Consolas,monospace;font-size:13px}pre,code{font-family:Cascadia Mono,Consolas,monospace}.app-shell{min-height:100vh}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;background:color-mix(in srgb,var(--surface) 94%,transparent);border-bottom:1px solid var(--border-soft);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand,.topbar nav{display:flex;align-items:center;gap:10px}.brand,.topbar a,.tool-card{color:inherit;text-decoration:none}.brand-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:6px;background:var(--primary);color:#fff;font-weight:800}.topbar nav a{padding:6px 8px;border-radius:6px}.topbar nav a.active{background:var(--primary-soft);color:var(--primary-strong)}.topbar-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.topbar-actions .su-field{min-width:132px}.topbar-actions .su-field span{display:none}.page{width:min(1180px,calc(100% - 32px));margin:0 auto;padding:24px 0 48px}.hero{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:end;padding:24px 0 18px}.hero h1{margin:6px 0 10px;font-size:38px;line-height:1.12}.hero p{max-width:780px;margin:0;color:var(--muted)}.eyebrow{margin:0;color:var(--primary);font-size:13px;font-weight:700}.hero-stats{display:grid;grid-template-columns:auto auto;gap:4px 10px;min-width:220px;padding:16px;border:1px solid var(--border-soft);border-radius:8px;background:var(--surface)}.hero-stats strong{color:var(--primary-strong)}.filters,.settings-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;align-items:end;padding:14px;border:1px solid var(--border-soft);border-radius:8px;background:var(--surface)}label{display:grid;gap:6px;color:var(--muted);font-size:13px;font-weight:700}.check{display:flex;align-items:center;min-height:38px}.check input{width:auto}.quick-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:18px 0}.panel-card,.group-section,.result-card,.editor-card,.recipe-card,.batch-card,.metric-card{border:1px solid var(--border-soft);border-radius:8px;background:var(--surface);padding:16px}.panel-card h2,.group-section h2,.result-card h2,.editor-card h2,.recipe-card h2,.batch-card h2{margin:0 0 10px;font-size:18px}.group-section{margin-top:18px}.group-section>p,.panel-card p,.recipe-card p,.batch-card p{color:var(--subtle)}.tool-directory{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.tool-controls{display:grid;gap:10px}.tool-controls .control-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.tool-controls .control-row.diff-row{align-items:stretch}.tool-controls .diff-col{flex:1 1 240px;display:grid;gap:6px}.tool-controls .inline-check{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.tool-controls .inline-check input[type=checkbox]{width:auto}.tool-controls .inline-check input[type=number],.tool-controls .control-row>input,.tool-controls .inline-check select{width:auto;min-width:90px}.tool-controls textarea{min-height:120px}.tool-controls button[aria-pressed=true]{border-color:var(--primary);background:var(--primary-soft);color:var(--primary-strong)}.advanced-editor{margin-top:14px}.advanced-editor summary{cursor:pointer;color:var(--subtle)}.tool-directory.compact{grid-template-columns:1fr}.tool-card{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;padding:12px}.tool-card:hover{border-color:var(--primary);box-shadow:0 10px 24px #2563eb14}.tool-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:6px;background:var(--primary-soft);color:var(--primary-strong);font-weight:800}.tool-card strong,.tool-card small,.tool-card em{display:block;overflow-wrap:anywhere}.tool-card small{margin-top:4px;color:var(--subtle)}.tool-card em{margin-top:8px;color:var(--primary);font-size:12px;font-style:normal}.workbench{display:grid;grid-template-columns:260px minmax(0,1fr) 320px;gap:16px;width:min(1500px,calc(100% - 24px));margin:0 auto;padding:18px 0 48px}.left-panel,.right-panel{align-self:start;position:sticky;top:72px;max-height:calc(100vh - 90px);overflow:auto}.left-panel h2{margin:0 0 10px;font-size:16px}.center-panel{min-width:0}.tool-heading{display:flex;justify-content:space-between;gap:16px;align-items:start;margin-bottom:14px;padding:16px;border:1px solid var(--border-soft);border-radius:8px;background:var(--surface)}.tool-heading h1{margin:3px 0 8px;font-size:28px}.badge{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:4px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary-strong);font-size:12px;font-weight:700;white-space:nowrap}.badge.danger{background:var(--danger-bg);color:var(--danger-text)}.toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.status{margin:8px 0 12px;color:var(--muted)}.result-heading{display:flex;justify-content:space-between;gap:12px}.output-box,.recipe-card pre,.batch-card pre{min-height:120px;max-height:360px;overflow:auto;padding:12px;border:1px solid var(--border-soft);border-radius:6px;background:var(--code-bg);color:var(--code-text);white-space:pre-wrap;overflow-wrap:anywhere}.warnings{color:var(--warning-text);background:var(--warning-bg);border-radius:6px;padding:10px 10px 10px 28px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin:12px 0}.metric-card span{display:block;color:var(--subtle);font-size:12px}.metric-card strong{display:block;margin-top:4px;overflow-wrap:anywhere}.tool-view{display:grid;gap:12px}.schema-row{display:grid;gap:3px;padding:10px 0;border-bottom:1px solid var(--border-soft)}.schema-row span,.schema-row small{color:var(--subtle);overflow-wrap:anywhere}.validation{padding:10px;border-radius:6px;background:var(--surface-soft)}.validation.error{background:var(--danger-bg)}.validation.warning{background:var(--warning-bg)}.validation.info{background:var(--primary-soft)}.ok{color:#28a36d}.history-item{display:grid;width:100%;gap:4px;margin-bottom:8px;text-align:left}.history-item small{color:var(--subtle)}.risk-note{padding:10px;border-radius:6px;background:var(--surface-soft)}.big-number{display:block;font-size:34px;color:var(--primary-strong)}.empty{padding:20px;text-align:center;color:var(--subtle)}@media(max-width:1180px){.workbench{grid-template-columns:220px minmax(0,1fr)}.right-panel{position:static;grid-column:1 / -1;max-height:none}.right-stack{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}}@media(max-width:820px){.topbar{align-items:stretch;flex-direction:column;padding:12px 16px}.topbar nav{flex-wrap:wrap}.hero,.quick-grid,.filters,.settings-grid,.workbench,.right-stack{grid-template-columns:1fr}.page,.workbench{width:min(100% - 20px,760px)}.left-panel,.right-panel{position:static;max-height:none}.tool-heading,.result-heading{display:grid}.hero h1,.tool-heading h1{font-size:28px}.toolbar button{flex:1 1 130px}}
