:root{--bg-0: #0f0f10;--bg-1: #161617;--bg-2: #1d1d1f;--bg-3: #262628;--border: #2a2a2c;--text-1: #f4f4f5;--text-2: #a1a1a6;--text-3: #6e6e73;--accent: #f4f4f5;--danger: #d4d4d8;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-0);color:var(--text-1);-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-rows:auto 1fr;height:100vh;height:100dvh}.header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-bottom:1px solid var(--border);background:var(--bg-1)}.header h1{margin:0;font-size:15px;font-weight:600;letter-spacing:.02em;color:var(--text-1)}.header .sub{color:var(--text-3);font-size:12px;margin-left:10px}.header a{color:var(--text-2);font-size:12px;text-decoration:none;border:1px solid var(--border);padding:6px 10px;border-radius:6px}.header a:hover{color:var(--text-1);border-color:var(--text-3)}.main{display:grid;grid-template-columns:360px 1fr;min-height:0}@media (max-width: 860px){.main{grid-template-columns:1fr;grid-template-rows:auto 1fr;overflow-y:auto}}.sidebar{border-right:1px solid var(--border);background:var(--bg-1);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}@media (max-width: 860px){.sidebar{border-right:none;border-bottom:1px solid var(--border);overflow-y:visible;padding:16px;gap:16px}.modes{grid-template-columns:repeat(3,1fr)}}@media (max-width: 540px){.header{padding:12px 16px;flex-wrap:wrap;gap:8px}.header .sub{display:none}.modes{grid-template-columns:1fr 1fr}}.section-label{font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px}.modes{display:grid;grid-template-columns:1fr 1fr;gap:6px}.mode-btn{background:var(--bg-2);border:1px solid var(--border);color:var(--text-2);padding:10px 12px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease;text-align:left}.mode-btn:hover{border-color:var(--text-3);color:var(--text-1)}.mode-btn.active{background:var(--text-1);color:var(--bg-0);border-color:var(--text-1)}.drop{border:1px dashed var(--border);border-radius:8px;padding:24px;text-align:center;color:var(--text-3);font-size:13px;cursor:pointer;background:var(--bg-2);transition:all .12s ease}.drop:hover,.drop.over{border-color:var(--text-2);color:var(--text-1);background:var(--bg-3)}.drop.has-file{border-style:solid;border-color:var(--border);color:var(--text-1);padding:10px;text-align:left}.drop .thumb{display:flex;align-items:center;gap:12px}.drop .thumb img{width:48px;height:48px;object-fit:cover;border-radius:4px;border:1px solid var(--border)}.drop .thumb .meta{font-size:12px;color:var(--text-2)}.drop .thumb .meta .name{color:var(--text-1)}textarea{width:100%;background:var(--bg-2);color:var(--text-1);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:13px;resize:vertical;min-height:70px}textarea:focus{outline:none;border-color:var(--text-3)}.toggle{display:flex;align-items:center;gap:8px;color:var(--text-2);font-size:13px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input{accent-color:var(--text-1);width:14px;height:14px}.run-btn{background:var(--text-1);color:var(--bg-0);border:none;padding:12px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;letter-spacing:.02em}.run-btn:hover{background:#fff}.run-btn:disabled{background:var(--bg-3);color:var(--text-3);cursor:not-allowed}@media (max-width: 860px){.mode-btn,.run-btn{min-height:44px;font-size:14px}.drop{padding:20px}textarea{font-size:16px}}.result{padding:20px 24px;overflow:auto;display:flex;flex-direction:column;gap:16px;background:var(--bg-0);min-width:0}@media (max-width: 860px){.result{padding:16px;overflow:visible}}.result-head{display:flex;justify-content:space-between;align-items:center;color:var(--text-3);font-size:11px;text-transform:uppercase;letter-spacing:.12em}.result-head .status{display:inline-flex;align-items:center;gap:6px}.dot{width:6px;height:6px;border-radius:50%;background:var(--text-3)}.dot.busy{background:var(--text-1);animation:pulse 1s infinite}.dot.ok{background:var(--text-1)}.dot.err{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.preview{border:1px solid var(--border);border-radius:8px;background:var(--bg-1);padding:16px;display:flex;justify-content:center;align-items:center;min-height:200px}.preview .empty{color:var(--text-3);font-size:13px}.preview-row{display:grid;grid-template-columns:1fr;gap:16px}.preview-row.with-legend{grid-template-columns:1fr 240px}@media (max-width: 1100px){.preview-row.with-legend{grid-template-columns:1fr}}.legend{border:1px solid var(--border);border-radius:8px;background:var(--bg-1);padding:14px 16px;align-self:start}.legend ul{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}.legend li{display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:10px;font-size:12px;color:var(--text-2)}.legend .swatch{width:12px;height:12px;border-radius:3px;border:1px solid rgba(255,255,255,.1)}.legend .lbl{color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend .pct{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:11px}.conf-list li{display:block}.conf-row{display:grid;grid-template-columns:14px 1fr auto auto;align-items:center;gap:8px;margin-bottom:4px;font-size:12px}.conf-row .count{color:var(--text-3);font-family:JetBrains Mono,monospace;font-size:10px}.conf-bar{position:relative;height:4px;background:var(--bg-3);border-radius:2px;overflow:visible;margin-left:22px}.conf-fill{position:absolute;inset:0 auto 0 0;border-radius:2px;opacity:.9}.conf-mean{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--text-1);transform:translate(-1px);border-radius:1px}.zoom-wrap{position:relative;width:100%;max-width:100%;max-height:65vh;overflow:hidden;display:flex;justify-content:center;align-items:center;user-select:none;touch-action:none;-webkit-user-select:none;-webkit-touch-callout:none}.zoom-wrap img{max-width:100%;max-height:65vh;border-radius:4px;display:block;pointer-events:none;will-change:transform}@media (max-width: 860px){.zoom-wrap,.zoom-wrap img{max-height:50vh}.preview{padding:8px;min-height:160px}}.zoom-hud{position:absolute;top:10px;right:10px;display:flex;gap:8px;align-items:center;background:#0f0f10d9;border:1px solid var(--border);padding:6px 10px;border-radius:6px;font-size:11px;color:var(--text-2);font-family:JetBrains Mono,monospace;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.zoom-hud button{background:transparent;border:1px solid var(--border);color:var(--text-2);padding:3px 8px;border-radius:4px;font-size:11px;cursor:pointer}.zoom-hud button:hover{color:var(--text-1);border-color:var(--text-3)}.json-block{background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:16px;font-family:JetBrains Mono,SF Mono,Menlo,monospace;font-size:12px;line-height:1.6;color:var(--text-2);overflow-x:auto;white-space:pre-wrap;word-break:break-word}.vlm-text{background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:18px 20px;color:var(--text-1);font-size:14px;line-height:1.6;white-space:pre-wrap}.error{border:1px solid var(--danger);background:#d4d4d80d;padding:12px 14px;border-radius:6px;color:var(--danger);font-size:13px}
