.ai-chat-fab{position:fixed;bottom:24px;right:24px;height:44px;padding:0 20px;border-radius:22px;border:none;background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff;cursor:pointer;box-shadow:0 4px 16px #7c3aed66;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;font-size:.9rem;font-weight:600;transition:all .2s ease;z-index:1000}.ai-chat-fab:hover{transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed80}.ai-chat-fab .ai-icon{font-size:1rem;line-height:1}.ai-chat-fab .ai-label{font-size:.85rem;font-weight:600}.ai-chat-window{position:fixed;bottom:80px;right:24px;width:380px;height:500px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;z-index:1001;overflow:hidden}[data-theme=dark] .ai-chat-window,body:not([data-theme]) .ai-chat-window{background:var(--bg-panel);border-color:var(--border)}.ai-chat-window.hidden{display:none}.ai-chat-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff}.ai-chat-header-left{display:flex;align-items:center;gap:12px}.ai-header-icon{width:36px;height:36px;background:#fff3;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.ai-header-text{display:flex;flex-direction:column;gap:2px}.ai-header-title{font-weight:600;font-size:.95rem}.ai-header-subtitle{font-size:.7rem;opacity:.85}.ai-chat-close{background:none;border:none;color:#fffc;font-size:1.5rem;cursor:pointer;padding:0 4px;line-height:1;transition:color .2s}.ai-chat-close:hover{color:#fff}.ai-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f9fafb}[data-theme=dark] .ai-chat-messages,body:not([data-theme]) .ai-chat-messages{background:var(--bg-primary)}.ai-message{max-width:90%;display:flex;align-items:flex-start;gap:10px}.ai-message.user{align-self:flex-end;flex-direction:row-reverse}.ai-message.assistant,.ai-message.thinking,.ai-message.error{align-self:flex-start}.ai-msg-icon{width:32px;height:32px;background:#e5e7eb;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0}[data-theme=dark] .ai-msg-icon,body:not([data-theme]) .ai-msg-icon{background:var(--bg-input)}.ai-msg-text{background:#fff;padding:12px 14px;border-radius:12px;font-size:.9rem;line-height:1.6;color:#374151;box-shadow:0 1px 3px #00000014}[data-theme=dark] .ai-msg-text,body:not([data-theme]) .ai-msg-text{background:var(--bg-input);color:var(--text-primary)}.ai-message.user .ai-msg-text{background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff}.ai-message.thinking .ai-msg-text{color:#9ca3af;font-style:italic}.ai-chat-input-area{display:flex;gap:10px;padding:14px 16px;border-top:1px solid #e5e7eb;background:#fff}[data-theme=dark] .ai-chat-input-area,body:not([data-theme]) .ai-chat-input-area{background:var(--bg-panel);border-color:var(--border)}#ai-chat-input{flex:1;padding:12px 16px;border:1px solid #e5e7eb;border-radius:24px;background:#f9fafb;color:#374151;font-size:.9rem;outline:none;transition:border-color .2s}[data-theme=dark] #ai-chat-input,body:not([data-theme]) #ai-chat-input{background:var(--bg-input);border-color:var(--border);color:var(--text-primary)}#ai-chat-input:focus{border-color:#8b5cf6}#ai-chat-input::placeholder{color:#9ca3af}[data-theme=dark] #ai-chat-input::placeholder,body:not([data-theme]) #ai-chat-input::placeholder{color:var(--text-muted)}.ai-chat-send{width:44px;height:44px;border:none;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#8b5cf6);color:#fff;font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.ai-chat-send:hover{transform:scale(1.05);box-shadow:0 4px 12px #7c3aed66}.ai-chat-send:disabled{opacity:.5;cursor:not-allowed;transform:none}.ai-chat-messages::-webkit-scrollbar{width:4px}.ai-chat-messages::-webkit-scrollbar-track{background:transparent}.ai-chat-messages::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}[data-theme=dark] .ai-chat-messages::-webkit-scrollbar-thumb,body:not([data-theme]) .ai-chat-messages::-webkit-scrollbar-thumb{background:var(--border)}.ai-chat-messages::-webkit-scrollbar-thumb:hover{background:#9ca3af}*{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}}.webgl-error{position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1a2ef2;display:flex;align-items:center;justify-content:center;z-index:900}.webgl-error.hidden{display:none}.webgl-error-content{background:var(--bg-panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:16px;padding:40px;max-width:500px;text-align:center;border:1px solid var(--border);box-shadow:0 20px 60px #00000080}.webgl-error-icon{font-size:4rem;display:block;margin-bottom:20px}.webgl-error-content h2{font-size:1.5rem;color:#f87171;margin-bottom:16px}.webgl-error-content p{font-size:.95rem;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}.webgl-error-content ul{list-style:none;text-align:left;margin-bottom:20px;padding:16px;background:#0003;border-radius:8px}.webgl-error-content li{font-size:.85rem;color:var(--text-secondary);margin:8px 0;padding-left:20px;position:relative}.webgl-error-content li:before{content:"•";position:absolute;left:0;color:var(--accent)}.webgl-error-note{font-size:.9rem;color:var(--accent)!important;font-weight:700;background:#6ee7b71a;padding:12px;border-radius:8px;margin-bottom:0!important}.webgl-supported,.webgl-tips{text-align:left;margin-bottom:16px;padding:16px;background:#0003;border-radius:8px}.webgl-supported h3,.webgl-tips h3{font-size:.9rem;color:var(--accent);margin-bottom:10px}.webgl-tips h3{color:#fbbf24}.webgl-supported ul,.webgl-tips ul{list-style:none;margin:0;padding:0}.webgl-supported li,.webgl-tips li{font-size:.85rem;color:var(--text-secondary);margin:6px 0;padding-left:20px;position:relative}.webgl-supported li:before{content:"✓";position:absolute;left:0;color:var(--accent)}.webgl-tips li:before{content:"→";position:absolute;left:0;color:#fbbf24}.webgl-supported li strong{color:var(--text-primary)}.app-footer{position:fixed;bottom:0;left:0;right:0;background:var(--bg-panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border);padding:8px 20px;z-index:100}.footer-content{display:flex;justify-content:center;align-items:center;gap:12px;font-size:.75rem;color:var(--text-muted)}.footer-divider{opacity:.5}#footer-version{color:var(--accent);font-weight:700}#footer-author{color:var(--text-secondary)}.demo-fab{position:fixed;bottom:140px;right:24px;display:flex;align-items:center;gap:8px;padding:14px 20px;border:none;border-radius:50px;background:linear-gradient(135deg,#a78bfa,#8b5cf6);color:#fff;cursor:pointer;font-size:1rem;font-weight:700;box-shadow:0 4px 20px #8b5cf666;z-index:999;transition:all .3s ease;animation:demo-fab-pulse 2s ease-in-out infinite}.demo-fab:hover{transform:scale(1.05);box-shadow:0 6px 28px #8b5cf680;animation:none}.demo-fab:active{transform:scale(.98)}.demo-fab.running{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 20px #f59e0b66;animation:none}.demo-fab.running .demo-fab-icon{animation:spin 1s linear infinite}.demo-fab-icon{font-size:1.2rem;display:flex;align-items:center;justify-content:center}.demo-fab-label{font-size:.9rem;letter-spacing:.5px}@keyframes demo-fab-pulse{0%,to{box-shadow:0 4px 20px #8b5cf666}50%{box-shadow:0 4px 30px #8b5cf699}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
