*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}#root{width:100%;height:100%}.teleop-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000;overflow:hidden;display:flex}.robot-view{position:relative;flex:1;height:100%;display:flex;align-items:center;justify-content:center}.robot-camera-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.robot-camera{width:100%;height:100%;object-fit:contain;background:#000}.offline-message{text-align:center;color:#666}.offline-message h2{font-size:48px;margin-bottom:10px;color:#888}.offline-message p{font-size:18px;color:#666}.pip-container{position:absolute;bottom:80px;right:20px;width:200px;height:150px;border:2px solid #333;border-radius:8px;overflow:hidden;background:#000}.local-video{width:100%;height:100%;object-fit:cover}.status-overlay{position:absolute;top:20px;left:20px;display:flex;gap:20px;color:#fff;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.8)}.status-indicator.connected{color:#4caf50}.status-indicator.disconnected{color:#f44336}.mode-indicator{color:#fff}.keyboard-hints{color:#ccc;font-size:12px;margin-top:5px}.control-bar{position:absolute;bottom:0;left:0;right:0;height:60px;background:#1e1e1ef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;gap:30px;padding:0 20px;border-top:1px solid #333}.movement-controls,.rotation-controls,.mode-controls,.audio-controls{display:flex;gap:10px;align-items:center}button{padding:8px 16px;font-size:18px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}button:hover{background:#fff3;border-color:#ffffff4d}button:active{transform:scale(.95)}button.active{background:#4caf50;border-color:#4caf50}.mode-controls button{font-size:14px;padding:8px 16px;min-width:60px}.movement-controls:after,.rotation-controls:after,.mode-controls:after{content:"";width:1px;height:30px;background:#fff3;margin-left:10px}.tracking-overlay{position:absolute;top:20px;right:20px;display:flex;flex-direction:column;gap:10px;color:#fff;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.8);align-items:flex-end}.tracking-indicator{background:#00000080;padding:4px 12px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.head-joystick-container{background:#00000080;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.2);text-align:center}.joystick-label{font-size:12px;margin-bottom:8px;color:#ccc}.joystick{width:80px;height:80px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.3);position:relative;cursor:pointer;margin:0 auto 8px;-webkit-user-select:none;user-select:none}.joystick.disabled{opacity:.5;cursor:not-allowed}.joystick-knob{width:20px;height:20px;border-radius:50%;background:#4caf50;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:transform .1s ease;box-shadow:0 2px 4px #0000004d}.joystick-values{font-size:10px;color:#999;margin-bottom:8px}.reset-button{padding:4px 12px;font-size:10px;background:#ffa50033;color:orange;border:1px solid rgba(255,165,0,.4);border-radius:4px;cursor:pointer;transition:all .2s}.reset-button:hover:not(.disabled){background:#ffa5004d;border-color:#ffa50099}.reset-button.disabled{opacity:.5;cursor:not-allowed}.hand-control-container{background:#00000080;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.2);text-align:center;margin-top:10px}.hand-control-label{font-size:12px;margin-bottom:8px;color:#ccc}.hand-controls{display:flex;flex-direction:column;gap:8px}.hand-toggle{padding:6px 12px;font-size:11px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;transition:all .2s;min-width:100px}.hand-toggle:hover:not(.disabled){background:#fff3}.hand-toggle.active{background:#4caf50;border-color:#4caf50}.hand-toggle.disabled{opacity:.5;cursor:not-allowed}.hand-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.action-button{padding:6px 8px;font-size:11px;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap}.action-button:hover:not(.disabled){background:#fff3}.action-button.active{background:#ff5722;border-color:#ff5722;animation:pulse 1s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.action-button.disabled{opacity:.5;cursor:not-allowed}.chat-window{width:350px;height:100vh;background:#0f0f0ff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid #333;display:flex;flex-direction:column;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}@media (max-width: 768px){.teleop-container{flex-direction:column}.robot-view{flex:1;min-height:0}.chat-window{width:100%;height:40vh;border-left:none;border-top:1px solid #333;order:2}.control-bar{order:3;position:relative;height:50px;padding:0 10px;gap:15px}.control-bar button{min-width:40px;height:40px;font-size:16px;padding:6px 12px}.mode-controls button{font-size:12px;min-width:50px}.pip-container{width:120px;height:90px;bottom:60px;right:10px}.status-overlay{top:10px;left:10px;font-size:12px}.tracking-overlay{top:10px;right:10px;font-size:12px}.joystick{width:60px;height:60px}.hand-control-container{padding:8px}.chat-header{padding:12px}.chat-header h3{font-size:14px}.chat-messages{padding:12px;gap:12px}.conversation-pair{padding:10px}.question-bubble,.answer-bubble{padding:8px 10px;margin-left:8px;margin-right:8px}.message-content{font-size:12px;line-height:1.3}.message-label{font-size:10px}.speak-hint{font-size:9px}.chat-footer{padding:10px 12px}.chat-footer small{font-size:10px}.answer-bubble.clickable{min-height:44px;display:flex;flex-direction:column;justify-content:center}.chat-input{padding:10px 12px}.text-input{font-size:16px;padding:12px;height:44px;box-sizing:border-box}.send-button{min-width:44px;height:44px;font-size:18px}}@media (max-width: 1024px) and (min-width: 769px){.chat-window{width:300px}.control-bar{padding:0 15px;gap:20px}}@media (max-width: 480px){.chat-window{height:35vh}.control-bar{height:45px;gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch}.control-bar button{min-width:36px;height:36px;font-size:14px;flex-shrink:0}.movement-controls,.rotation-controls,.mode-controls,.audio-controls{gap:8px}.movement-controls:after,.rotation-controls:after,.mode-controls:after{display:none}.pip-container{width:100px;height:75px;bottom:50px;right:5px}.status-overlay,.tracking-overlay{font-size:11px}.joystick{width:50px;height:50px}.joystick-knob{width:16px;height:16px}}.chat-header{padding:16px;border-bottom:1px solid #333;background:#00000080}.chat-header h3{margin:0 0 8px;font-size:16px;font-weight:600;color:#fff}.chat-status{display:flex;align-items:center;font-size:12px;color:#aaa}.processing-indicator{display:flex;align-items:center;gap:6px;color:#4caf50;font-size:11px}.processing-dot{width:6px;height:6px;background:#4caf50;border-radius:50%;animation:processing-pulse 1.5s ease-in-out infinite}@keyframes processing-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#ffffff0d}.chat-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}@media (max-width: 768px){.chat-messages{-webkit-overflow-scrolling:touch;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:3px}}.empty-state{text-align:center;color:#666;margin-top:40px}.empty-state p{margin:0 0 8px;font-size:14px}.empty-state small{font-size:12px;color:#555}.conversation-pair{display:flex;flex-direction:column;gap:8px;padding:12px;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.timestamp{font-size:10px;color:#666;text-align:center;margin-bottom:4px}.question-bubble,.answer-bubble{padding:10px 12px;border-radius:8px;position:relative}.question-bubble{background:#2196f326;border:1px solid rgba(33,150,243,.3);margin-left:16px}.answer-bubble{background:#4caf5026;border:1px solid rgba(76,175,80,.3);margin-right:16px;transition:all .2s ease}.answer-bubble.clickable{cursor:pointer}.answer-bubble.clickable:hover{background:#4caf5040;border-color:#4caf5080;transform:translateY(-1px)}.message-label{font-size:11px;font-weight:600;margin-bottom:4px;opacity:.8}.question-bubble .message-label{color:#2196f3}.answer-bubble .message-label{color:#4caf50}.message-content{font-size:13px;line-height:1.4;color:#fff}.speak-hint{font-size:10px;color:#4caf50;margin-top:6px;opacity:0;transition:opacity .2s ease}.answer-bubble.clickable:hover .speak-hint{opacity:1}.chat-footer{padding:12px 16px;border-top:1px solid #333;background:#0000004d;text-align:center}.chat-footer small{font-size:11px;color:#666}.episode-recorder-card{position:absolute;top:120px;left:20px;min-width:220px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px;color:#fff;font-size:13px;z-index:50}.episode-recorder-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.episode-recorder-title{font-weight:600;font-size:12px;color:#ccc;text-transform:uppercase}.recording-badge{display:flex;align-items:center;gap:6px;background:#f4433633;border:1px solid rgba(244,67,54,.5);padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;color:#f44336}.recording-dot{width:8px;height:8px;background:#f44336;border-radius:50%;animation:recording-blink 1.5s ease-in-out infinite}@keyframes recording-blink{0%,to{opacity:1}50%{opacity:.3}}.episode-error{background:#f4433626;border:1px solid rgba(244,67,54,.3);padding:8px;border-radius:4px;color:#f44336;font-size:11px;margin-bottom:12px}.recording-stats{display:flex;flex-direction:column;gap:8px}.stat{display:flex;justify-content:space-between;align-items:center;padding:6px;background:#ffffff0d;border-radius:4px}.stat-label{font-size:11px;color:#aaa}.stat-value{font-size:13px;font-weight:600;color:#4caf50}.recording-controls{display:flex;flex-direction:column;gap:8px}.episode-button{padding:10px 12px;font-size:13px;border:1px solid rgba(255,255,255,.2);border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500;width:100%;text-align:center}.episode-button:hover:not(:disabled){transform:translateY(-1px)}.episode-button:disabled{opacity:.5;cursor:not-allowed}.episode-button-start{background:#4caf5033;border-color:#4caf5080;color:#4caf50}.episode-button-start:hover:not(:disabled){background:#4caf504d;border-color:#4caf50b3}.episode-button-stop{background:#f4433633;border-color:#f4433680;color:#f44336;margin-top:4px}.episode-button-stop:hover:not(:disabled){background:#f443364d;border-color:#f44336b3}.episode-button-manage{background:#2196f333;border-color:#2196f380;color:#2196f3;margin-top:8px}.episode-button-manage:hover:not(:disabled){background:#2196f34d;border-color:#2196f3b3}.episode-manager-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000}.episode-manager-modal{background:#1a1a1a;border:1px solid #333;border-radius:10px;width:90%;max-width:900px;max-height:80vh;display:flex;flex-direction:column;color:#fff}.episode-manager-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #333}.episode-manager-header h2{margin:0;font-size:20px;font-weight:600}.close-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-button:hover{background:#fff3;border-color:#ffffff4d}.episode-manager-content{flex:1;overflow-y:auto;padding:20px 24px}.loading-state,.error-state,.empty-episodes-state{text-align:center;padding:40px;color:#aaa}.empty-episodes-state p{margin:0 0 8px;font-size:16px}.empty-episodes-state small{font-size:14px;color:#666}.episode-manager-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #333}.episode-count{font-size:14px;color:#aaa}.delete-all-button{padding:8px 16px;background:#f4433633;border:1px solid rgba(244,67,54,.5);border-radius:6px;color:#f44336;font-size:13px;cursor:pointer;transition:all .2s;font-weight:500}.delete-all-button:hover:not(:disabled){background:#f443364d;border-color:#f44336b3}.delete-all-button:disabled{opacity:.5;cursor:not-allowed}.episodes-table-container{overflow-x:auto}.episodes-table{width:100%;border-collapse:collapse}.episodes-table thead{background:#ffffff0d}.episodes-table th{padding:12px;text-align:left;font-size:12px;font-weight:600;color:#aaa;text-transform:uppercase;border-bottom:1px solid #333}.episodes-table td{padding:14px 12px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05)}.episodes-table tbody tr{transition:background .2s}.episodes-table tbody tr:hover{background:#ffffff08}.episode-id{font-family:monospace;font-size:12px;color:#2196f3}.episode-actions{display:flex;gap:8px}.action-btn{padding:6px 12px;font-size:12px;border:1px solid rgba(255,255,255,.2);border-radius:4px;cursor:pointer;transition:all .2s;font-weight:500}.download-btn{background:#2196f333;border-color:#2196f380;color:#2196f3}.download-btn:hover:not(:disabled){background:#2196f34d;border-color:#2196f3b3}.download-btn:disabled{opacity:.5;cursor:wait}.delete-btn{background:#f4433633;border-color:#f4433680;color:#f44336}.delete-btn:hover{background:#f443364d;border-color:#f44336b3}.episode-manager-footer{padding:16px 24px;border-top:1px solid #333;display:flex;justify-content:flex-end}.close-modal-button{padding:10px 24px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s;font-weight:500}.close-modal-button:hover{background:#fff3;border-color:#ffffff4d}@media (max-width: 768px){.episode-recorder-card{top:80px;left:10px;min-width:180px;font-size:12px}.episode-manager-modal{width:95%;max-height:90vh}.episode-manager-header{padding:16px}.episode-manager-header h2{font-size:18px}.episode-manager-content{padding:16px}.episodes-table{font-size:12px}.episodes-table th,.episodes-table td{padding:8px}.episode-actions{flex-direction:column;gap:4px}.action-btn{width:100%}}.chat-input{padding:12px 16px;border-top:1px solid #333;background:#0000004d}.input-container{display:flex;gap:8px;align-items:center}.text-input{flex:1;padding:10px 12px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:#fff;font-size:13px;font-family:inherit;outline:none;transition:all .2s ease}.text-input::placeholder{color:#666}.text-input:focus{background:#ffffff26;border-color:#4caf5080;box-shadow:0 0 0 2px #4caf501a}.text-input:disabled{opacity:.5;cursor:not-allowed}.send-button{padding:10px 12px;background:#4caf5033;border:1px solid rgba(76,175,80,.4);border-radius:6px;color:#4caf50;font-size:16px;cursor:pointer;transition:all .2s ease;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.send-button:hover:not(:disabled){background:#4caf504d;border-color:#4caf5099;transform:translateY(-1px)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{opacity:.4;cursor:not-allowed;transform:none}
