: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}.detect-params{display:flex;flex-direction:column;gap:10px}.detect-params .param{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-2)}.detect-params .param span{display:flex;justify-content:space-between}.detect-params .param b{color:var(--text-1);font-weight:600}.detect-params input[type=range]{width:100%;accent-color:var(--text-1)}.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 22px;color:var(--text-1);font-size:14px;line-height:1.6}.vlm-text>:first-child{margin-top:0}.vlm-text>:last-child{margin-bottom:0}.vlm-text h1,.vlm-text h2,.vlm-text h3,.vlm-text h4{color:var(--text-1);margin:1.2em 0 .5em;line-height:1.25}.vlm-text h1{font-size:1.4em}.vlm-text h2{font-size:1.25em}.vlm-text h3{font-size:1.1em}.vlm-text h4{font-size:1em;text-transform:uppercase;letter-spacing:.03em;color:var(--text-2)}.vlm-text p{margin:.6em 0}.vlm-text ul,.vlm-text ol{margin:.6em 0;padding-left:1.4em}.vlm-text li{margin:.2em 0}.vlm-text li>p{margin:.2em 0}.vlm-text strong{color:var(--text-1);font-weight:600}.vlm-text em{color:var(--text-2)}.vlm-text a{color:#7dd3fc;text-decoration:underline;text-underline-offset:2px}.vlm-text code{background:var(--bg-0);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:.9em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.vlm-text pre{background:var(--bg-0);border:1px solid var(--border);border-radius:6px;padding:12px 14px;overflow-x:auto;margin:.8em 0}.vlm-text pre code{background:transparent;border:0;padding:0}.vlm-text blockquote{margin:.8em 0;padding:.2em 0 .2em 12px;border-left:3px solid var(--border);color:var(--text-2)}.vlm-text hr{border:0;border-top:1px solid var(--border);margin:1.2em 0}.vlm-text table{border-collapse:collapse;margin:.8em 0;font-size:.95em}.vlm-text th,.vlm-text td{border:1px solid var(--border);padding:6px 10px;text-align:left}.vlm-text th{background:var(--bg-0)}.error{border:1px solid var(--danger);background:#d4d4d80d;padding:12px 14px;border-radius:6px;color:var(--danger);font-size:13px}.rating{margin-top:16px;padding:14px 16px;border:1px solid var(--border);border-radius:8px;background:var(--bg-1);display:flex;flex-direction:column;gap:10px}.rating .stars{display:flex;gap:4px}.rating .star{background:none;border:none;font-size:26px;line-height:1;color:#3f3f46;cursor:pointer;padding:0 2px;transition:color .12s ease}.rating .star.on{color:#facc15}.rating .star:hover{animation:star-jiggle .42s ease-in-out}@keyframes star-jiggle{0%{transform:rotate(0) scale(1)}20%{transform:rotate(-14deg) scale(1.15)}40%{transform:rotate(12deg) scale(1.15)}60%{transform:rotate(-8deg) scale(1.1)}80%{transform:rotate(6deg) scale(1.05)}to{transform:rotate(0) scale(1)}}.rating-comment{width:100%;min-height:56px;resize:vertical;background:var(--bg-0);color:var(--text-1);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;font-family:inherit}.rating-submit{align-self:flex-start;background:var(--text-1);color:var(--bg-0);border:none;padding:8px 14px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.rating-submit:disabled{opacity:.4;cursor:not-allowed}.rating-thanks{color:var(--text-2);font-size:13px}.archive-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;color:var(--text-2);opacity:.6}.details-btn{display:inline-block;background:var(--bg-1);color:var(--text-1);border:1px solid var(--border);padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;margin-top:12px}.details-btn:hover{border-color:var(--text-2)}.details-btn.ghost{background:transparent}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;z-index:100;overflow-y:auto}.modal{background:var(--bg-1);border:1px solid var(--border);border-radius:10px;padding:22px 24px;max-width:1100px;width:100%;max-height:calc(100vh - 80px);overflow-y:auto;box-shadow:0 20px 50px #00000080}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.modal-title{font-size:16px;font-weight:600;color:var(--text-1)}.modal-actions{display:flex;gap:8px}.modal-actions .details-btn{margin-top:0}.modal-images{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.modal-images figure{margin:0;display:flex;flex-direction:column;gap:6px}.modal-images figcaption{font-size:12px;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.modal-images img{width:100%;height:auto;border-radius:6px;border:1px solid var(--border);display:block}.modal details summary{cursor:pointer;font-size:13px;color:var(--text-2);margin-bottom:8px;-webkit-user-select:none;user-select:none}.modal .json-block{max-height:400px;overflow:auto;margin:0}@media (max-width: 700px){.modal-images{grid-template-columns:1fr}}.model-loading-banner{margin:10px 14px 0;padding:10px 12px;background:#eab3081f;border:1px solid rgba(234,179,8,.35);border-radius:6px;color:#e8c547;font-size:13px}.reasoning-panel{margin:12px 14px 0;padding:10px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;font-size:12px}.reasoning-panel>summary{cursor:pointer;color:var(--text-2);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:11px}.reasoning-block{margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.reasoning-block:first-of-type{border-top:none;padding-top:4px}.reasoning-label{color:var(--text-3);font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.reasoning-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}.reasoning-list li{display:flex;justify-content:space-between;gap:10px}.reasoning-list .k{color:var(--text-3)}.reasoning-list .v{color:var(--text-1);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;word-break:break-word;text-align:right}.raw-json-panel{margin:12px 14px 0;padding:10px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;font-size:12px}.raw-json-panel>summary{cursor:pointer;color:var(--text-2);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:11px}.raw-json{margin:10px 0 0;padding:10px 12px;background:var(--bg-1);border:1px solid var(--border);border-radius:6px;color:var(--text-1);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;line-height:1.4;white-space:pre-wrap;word-break:break-word;max-height:400px;overflow-y:auto}
