:root{--bg: #1e1f22;--panel: #2a2c30;--panel2: #232529;--line: #3a3d43;--txt: #e3e3e6;--muted: #9a9da3;--accent: #4d8be6;--empty: #555;--ai: #d9a521;--human: #4caf72}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--txt);font:13px/1.4 -apple-system,system-ui,Segoe UI,sans-serif}code{font-family:ui-monospace,Menlo,monospace}.muted{color:var(--muted)}.small{font-size:11px}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--panel);border-bottom:1px solid var(--line)}.topbar .spacer{flex:1}.topbar .stat{color:var(--muted);margin-right:8px}button{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:6px;padding:5px 10px;cursor:pointer}button:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.4;cursor:default}button.link{background:none;border:none;color:var(--accent);padding:0}.error{background:#5a2230;color:#ffd9df;padding:6px 12px}.dropzone{flex:1;display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center;color:var(--muted);font-size:16px;border:2px dashed var(--line);margin:24px;border-radius:12px}.main{flex:1;display:flex;min-height:0}.gallery{flex:1;display:flex;flex-direction:column;min-width:0}.gallery-bar{display:flex;gap:10px;align-items:center;padding:8px 12px;border-bottom:1px solid var(--line)}.gallery-bar input[type=text],.gallery-bar input:not([type]){flex:0 0 320px}input[type=text],input:not([type]),.role-filter{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:6px;padding:5px 8px;width:100%}.grid{flex:1;overflow:auto;padding:12px;display:grid;grid-template-columns:repeat(auto-fill,76px);gap:8px;align-content:start}.cell{width:76px;background:var(--panel2);border:2px solid var(--empty);border-radius:6px;padding:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.cell.ai_suggested{border-color:var(--ai)}.cell.human_verified{border-color:var(--human)}.cell.sel{outline:2px solid var(--accent);outline-offset:1px}.swatch{background-repeat:no-repeat;image-rendering:pixelated;border-radius:3px;background-color:#15161a}.cell-meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:3px}.cell-meta .idx{color:var(--muted);font-size:11px}.cell-meta .role{font-size:10px;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:48px}.inspector{flex:0 0 320px;background:var(--panel);border-left:1px solid var(--line);padding:12px;overflow:auto;display:flex;flex-direction:column;gap:16px}.insp-head{display:flex;flex-direction:column;gap:2px;border-bottom:1px solid var(--line);padding-bottom:8px;position:relative}.insp-head .link{position:absolute;right:0;top:0}.lbl{font-weight:600;margin-bottom:6px}.cur-role{margin-bottom:6px}.role-list{margin-top:6px;max-height:280px;overflow:auto;border:1px solid var(--line);border-radius:6px}.role-row{display:flex;justify-content:space-between;gap:8px;width:100%;background:none;border:none;border-bottom:1px solid var(--panel2);border-radius:0;text-align:left;padding:4px 8px}.role-row:hover{background:var(--panel2)}.role-row.active{background:#294063}.role-row .rp{font-family:ui-monospace,monospace;font-size:12px}.role-row .ot{color:var(--muted);font-size:10px}.role-row.d1 .rp{padding-left:10px}.role-row.d2 .rp{padding-left:22px}.role-row.d3 .rp{padding-left:34px}.chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}.chip{background:#2c3a52;border:1px solid var(--accent);border-radius:12px;padding:2px 8px;cursor:pointer;font-size:12px}.chip:hover{background:#3a2c30;border-color:#d9636b}.presets{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.preset{font-size:11px;padding:2px 7px;color:var(--muted)}
