*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1a1a2e;--bg-panel: rgba(30, 30, 50, .95);--bg-input: rgba(255, 255, 255, .1);--bg-hover: rgba(255, 255, 255, .15);--text-primary: #eee;--text-secondary: #ccc;--text-muted: #888;--accent: #6ee7b7;--accent-hover: #34d399;--border: rgba(255, 255, 255, .1);--shadow: rgba(0, 0, 0, .3)}[data-theme=light]{--bg-primary: #f0f4f8;--bg-panel: rgba(255, 255, 255, .95);--bg-input: rgba(0, 0, 0, .05);--bg-hover: rgba(0, 0, 0, .1);--text-primary: #1a1a2e;--text-secondary: #444;--text-muted: #666;--accent: #059669;--accent-hover: #047857;--border: rgba(0, 0, 0, .1);--shadow: rgba(0, 0, 0, .15)}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;transition:background .3s ease}#app{width:100vw;height:100vh;position:relative}#canvas{width:100%;height:100%;display:block}#controls-panel{position:fixed;top:20px;left:20px;background:var(--bg-panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:20px;width:280px;max-height:calc(100vh - 40px);overflow-y:auto;border:1px solid var(--border);box-shadow:0 8px 32px var(--shadow);transition:background .3s ease,border .3s ease}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.panel-header h3{font-size:1.2rem;color:var(--accent);margin:0}.theme-btn{background:var(--bg-input);border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.theme-btn:hover{background:var(--bg-hover);transform:rotate(20deg)}#controls-panel h3{font-size:1.2rem;margin-bottom:15px;color:var(--accent);text-align:center}.mode-tabs{display:flex;gap:8px;margin-bottom:15px}.mode-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;background:#ffffff1a;color:#aaa;cursor:pointer;font-size:.85rem;transition:all .2s}.mode-btn:hover{background:#ffffff26}.mode-btn.active{background:linear-gradient(135deg,#6ee7b7,#34d399);color:#1a1a2e;font-weight:700}.control-section{margin-bottom:15px}.control-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.control-section.hidden{display:none}.slider-group{margin-bottom:12px}.slider-group label{display:flex;justify-content:space-between;font-size:.8rem;margin-bottom:4px;color:#ccc}.slider-group span{color:#6ee7b7;font-weight:700;min-width:50px;text-align:right}.slider-group input[type=range]{width:100%;height:6px;border-radius:3px;background:#ffffff1a;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:linear-gradient(135deg,#6ee7b7,#34d399);cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:transform .1s}.slider-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.ik-status{font-size:.8rem;color:#888;margin-top:10px;padding:8px;background:#0003;border-radius:6px}.ik-status.success{color:#6ee7b7}.ik-status.error{color:#f87171}.motion-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.motion-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.btn-group{display:flex;gap:6px}.action-btn{flex:1;padding:8px 10px;border:none;border-radius:6px;background:#ffffff1a;color:#ccc;cursor:pointer;font-size:.75rem;transition:all .2s}.action-btn:hover:not(:disabled){background:#fff3;color:#fff}.action-btn:disabled{opacity:.4;cursor:not-allowed}.action-btn.recording{background:linear-gradient(135deg,#f87171,#ef4444);color:#fff;animation:pulse-record 1s ease-in-out infinite}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.7}}.action-btn.playing{background:linear-gradient(135deg,#60a5fa,#3b82f6);color:#fff}.frame-count{font-size:.75rem;color:#888;margin-top:8px}.frame-count span{color:#6ee7b7}.help{padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.help h4{font-size:.85rem;margin-bottom:8px;color:#a78bfa}.help ul{list-style:none;font-size:.75rem}.help li{margin:4px 0;display:flex;align-items:center;gap:6px;color:#999}kbd{background:linear-gradient(135deg,#4a4a6a,#3a3a5a);padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.7rem;border:1px solid #5a5a7a}#controls-panel::-webkit-scrollbar{width:6px}#controls-panel::-webkit-scrollbar-track{background:#0003;border-radius:3px}#controls-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.collision-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.collision-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.collision-status{font-size:.9rem;padding:10px;border-radius:6px;text-align:center;font-weight:700}.collision-status.ok{background:#6ee7b733;color:#6ee7b7}.collision-status.warning{background:#f8717133;color:#f87171;animation:pulse-warning .5s ease-in-out infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.preset-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.preset-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.preset-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}.preset-btn{padding:6px 4px;border:none;border-radius:4px;background:#ffffff1a;color:#ccc;cursor:pointer;font-size:.7rem;transition:all .2s}.preset-btn:hover{background:#6ee7b74d;color:#fff}.preset-btn:active{transform:scale(.95)}.demo-btn{width:100%;padding:10px;border:none;border-radius:6px;background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#fff;cursor:pointer;font-size:.85rem;font-weight:700;transition:all .2s;margin-bottom:10px}.demo-btn:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:translateY(-1px)}.demo-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.demo-btn.running{background:linear-gradient(135deg,#f59e0b,#d97706)}.speed-control{display:flex;align-items:center;gap:8px}.speed-control label{font-size:.8rem;color:#999;min-width:70px}.speed-control span{color:#6ee7b7}.speed-control input[type=range]{flex:1;height:6px;border-radius:3px;background:#ffffff1a;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.speed-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#8b5cf6);cursor:pointer}.coords-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.coords-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.coord-display{display:grid;grid-template-columns:auto 1fr auto 1fr auto 1fr;gap:4px 8px;font-size:.85rem;background:#0003;padding:10px;border-radius:6px;font-family:monospace}.coord-label{color:#888}.coord-display span:not(.coord-label){color:#6ee7b7;text-align:right}.gripper-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.gripper-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.trajectory-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.trajectory-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.action-btn.active{background:linear-gradient(135deg,#6ee7b7,#34d399);color:#1a1a2e}.camera-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.camera-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.camera-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.camera-btn{padding:6px 4px;border:none;border-radius:4px;background:#ffffff1a;color:#ccc;cursor:pointer;font-size:.65rem;transition:all .2s}.camera-btn:hover{background:#60a5fa4d;color:#fff}.save-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.save-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.save-input{display:flex;gap:6px;margin-bottom:10px}.save-input input{flex:1;padding:6px 10px;border:none;border-radius:4px;background:#ffffff1a;color:#fff;font-size:.8rem}.save-input input::placeholder{color:#888}#saved-poses{width:100%;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:4px;color:#ccc;font-size:.8rem;margin-bottom:8px}#saved-poses option{padding:4px 8px;background:#2a2a4a}#saved-poses option:checked{background:linear-gradient(135deg,#6ee7b7,#34d399);color:#1a1a2e}.pickplace-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.pickplace-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.pickplace-status{font-size:.85rem;padding:8px;background:#0003;border-radius:6px;text-align:center;margin-bottom:10px;color:#6ee7b7}.pickplace-status.holding{background:#f8717133;color:#f87171}.pickplace-status.near{background:#fbbf2433;color:#fbbf24}.websocket-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.websocket-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}.ws-status{font-size:.85rem;padding:8px;background:#0003;border-radius:6px;text-align:center;margin-bottom:10px;color:#888}.ws-status.connected{background:#6ee7b733;color:#6ee7b7}.ws-status.connecting{background:#fbbf2433;color:#fbbf24}.ws-status.error{background:#f8717133;color:#f87171}.gcode-section{margin-bottom:15px;padding-top:15px;border-top:1px solid rgba(255,255,255,.1)}.gcode-section h4{font-size:.9rem;margin-bottom:10px;color:#a78bfa}#gcode-input{width:100%;height:120px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#6ee7b7;font-family:Consolas,Monaco,monospace;font-size:.75rem;padding:10px;resize:vertical;margin-bottom:8px}#gcode-input::placeholder{color:#666}.gcode-controls{display:flex;gap:8px;margin-bottom:8px}.gcode-status{font-size:.8rem;padding:6px 10px;background:#0003;border-radius:4px;text-align:center;color:#888}.gcode-status.running{background:#6ee7b733;color:#6ee7b7;animation:pulse 1s infinite}.gcode-status.error{background:#f8717133;color:#f87171}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}
