:root{color-scheme:dark;font-family:ui-sans-serif,system-ui,-apple-system,sans-serif;--bg: #0b0d10;--panel: #14181d;--panel-2: #1c2128;--border: #2a313a;--text: #e6edf3;--muted: #8b949e;--accent: #5eead4;--accent-2: #38bdf8;--danger: #f87171;--recording: #ef4444}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);overflow:hidden}button{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:13px;cursor:pointer;transition:background .12s,border-color .12s}button:hover{background:#232a33}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#042f2e;border-color:var(--accent);font-weight:600}button.primary:hover{background:#4ad6c0}button.danger{background:var(--recording);color:#fff;border-color:var(--recording);font-weight:600}input,select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;width:100%}input:focus,select:focus{outline:none;border-color:var(--accent-2)}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:1px solid var(--border);border-radius:3px;background:transparent;cursor:pointer;overflow:hidden}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}input[type=color]::-moz-color-swatch{border:none;border-radius:2px}input[type=color]:hover{border-color:var(--accent-2)}label.field,div.field{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.ei-project-name{padding:8px 10px;background:#1a1f26;border:1px solid #2a313b;border-radius:6px;font-size:13px;color:var(--text);text-transform:none;letter-spacing:normal}.app{position:relative;width:100vw;height:100vh;display:grid;grid-template-columns:1fr 340px}.scene{position:relative;overflow:hidden}.sidebar{background:var(--panel);border-left:1px solid var(--border);padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:10px}.card h3{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.row{display:flex;gap:8px}.row>*{flex:1}.webcam-control{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px;border:1px solid var(--border);border-radius:6px;background:#0000001f}.webcam-control-copy{min-width:0;display:flex;flex-direction:column;gap:3px}.webcam-control-heading{display:flex;align-items:center;gap:8px;min-width:0}.webcam-control-title{color:var(--text);font-size:13px;font-weight:650}.webcam-control-state{color:var(--muted);font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.webcam-control-state.on{color:var(--accent)}.webcam-control-state.off{color:var(--muted)}.webcam-control-help{color:var(--muted);font-size:11px;line-height:1.35}.webcam-switch{flex:none;width:46px;height:26px;padding:2px;border-radius:999px;border-color:#3a4350;background:#20262e}.webcam-switch:hover{background:#262d36}.webcam-switch.on{border-color:var(--accent);background:#5eead42e}.webcam-switch.on:hover{background:#5eead43d}.webcam-switch-thumb{display:block;width:20px;height:20px;border-radius:999px;background:#9aa4af;box-shadow:0 1px 3px #00000059;transform:translate(0);transition:transform .14s ease,background .14s ease}.webcam-switch.on .webcam-switch-thumb{background:var(--accent);transform:translate(20px)}.motion-pills{display:flex;flex-wrap:wrap;gap:6px}.motion-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid #2a313b;background:#1a1f26;color:#9aa4af;font-size:12px;text-transform:capitalize;cursor:pointer;-webkit-user-select:none;user-select:none}.motion-pill input{position:absolute;opacity:0;pointer-events:none}.motion-pill.on{border-color:var(--accent);background:#5eead42e;color:#d6ecea}.motion-pill:hover{background:#262d36}.motion-pill.on:hover{background:#5eead43d}.capture-card{gap:12px}.capture-footer,.capture-batch-topline{display:flex;align-items:center;gap:10px}.capture-frame-button{width:100%;min-height:44px;font-size:14px}.capture-batch-section{border-top:1px solid var(--border);padding-top:12px;display:flex;flex-direction:column;gap:10px}.capture-batch-count{flex:0 0 92px}.capture-batch-button{flex:1;min-height:40px}.capture-randomize-group{border:0;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}.capture-randomize-group legend{padding:0;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.capture-toggle-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.ei-fetch-group{border:1px solid var(--border);border-radius:6px;padding:10px 12px 12px;margin:0;display:flex;flex-direction:column;gap:8px;background:#00000026}.inline-status{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;font-size:11px;font-family:ui-monospace,monospace;line-height:1.35;word-break:break-word}.inline-status.busy{color:var(--accent-2);background:#38bdf814;border:1px solid rgba(56,189,248,.3)}.inline-status.ok{color:var(--accent);background:#5eead414;border:1px solid rgba(94,234,212,.3)}.inline-status.err{color:var(--danger);background:#f8717114;border:1px solid rgba(248,113,113,.3)}.spinner{flex:none;width:12px;height:12px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ei-fetch-group legend{padding:0 6px;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-2)}.check-row{display:flex;align-items:center;gap:6px;min-width:0;color:var(--muted);font-size:12px;line-height:1}.check-row input[type=checkbox]{flex:none;width:16px;height:16px;margin:0}.check-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.capture-footer{justify-content:space-between;color:var(--muted);font-size:12px}.capture-footer button{min-width:64px;padding:5px 10px}.cam-overlay{position:absolute;bottom:16px;left:16px;width:240px;height:180px;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:#000;z-index:5}.cam-overlay.resizable{resize:horizontal;min-width:160px;max-width:720px}.cam-overlay.resizable.fixed-aspect-43{aspect-ratio:4 / 3;height:auto}.cam-overlay.resizable:after{content:"";position:absolute;right:2px;bottom:2px;width:12px;height:12px;border-right:2px solid var(--accent-2);border-bottom:2px solid var(--accent-2);pointer-events:none;opacity:.7}.cam-overlay video,.cam-overlay canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:scaleX(-1)}.cam-overlay .label{position:absolute;top:6px;left:8px;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;z-index:2;text-shadow:0 1px 2px rgba(0,0,0,.8)}.hud{position:absolute;top:16px;left:16px;display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted);font-family:ui-monospace,monospace;z-index:5;pointer-events:none}.hud .pill{background:#14181db3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:999px;padding:4px 10px}.hud .pill.live{color:var(--accent)}.hud .pill.rec{color:#fff;background:var(--recording);border-color:var(--recording);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.status{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace;white-space:pre-wrap;max-height:100px;overflow-y:auto}.status.ok{color:var(--accent)}.status.err{color:var(--danger)}
