html,body{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{-webkit-text-size-adjust:100%}body{overscroll-behavior:none;position:fixed;width:100%;height:100%}#root{height:100%;width:100%}:root{--bg-dark: #1e1e1e;--bg-darker: #0c0c0c;--bg-panel: #252526;--accent-orange: #d77757;--text-primary: #d4d4d4;--text-dim: #808080;--border: #2d2d30;--success: #4ec9b0;--danger: #f48771;--warning: #dcdcaa;--info: #569cd6;--terminal-bg: #1e1e1e;--terminal-text: #d4d4d4;--terminal-cursor: #d77757;--font-family: "SF Mono", "Monaco", "Menlo", "Consolas", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--button-height-desktop: 36px;--button-height-tablet: 44px;--button-height-mobile: 40px;--button-min-width: 44px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out;--transition-slow: .35s ease-in-out}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-dark);color:var(--text-primary);font-size:var(--text-base);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:var(--font-family);font-size:var(--text-sm);font-weight:500;height:var(--button-height-desktop);min-width:var(--button-min-width);padding:0 var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-panel);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast)}button:hover:not(:disabled){background:var(--accent-orange);border-color:var(--accent-orange);transform:scale(1.05);box-shadow:0 4px 12px #d777574d}button:active:not(:disabled){transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent-orange);border-color:var(--accent-orange);color:#fff}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}@keyframes slideInFromBottomRight{0%{transform:translate(100%,100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){button{height:var(--button-height-tablet);padding:0 var(--space-5)}}@media (max-width: 480px){button{height:var(--button-height-mobile);padding:0 var(--space-4)}}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background:var(--bg-dark);color:var(--text-primary)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);background:var(--bg-darker);border-bottom:2px solid var(--accent-orange);flex-shrink:0}.app-title{display:flex;align-items:center;gap:var(--space-3)}.app-icon{color:var(--accent-orange);flex-shrink:0}.app-title h1{font-size:var(--text-lg);font-weight:600;color:var(--text-primary);letter-spacing:.5px}.connection-dot{width:10px;height:10px;border-radius:50%;margin-left:var(--space-2);flex-shrink:0}.connection-dot.connected{background:var(--success);box-shadow:0 0 8px var(--success);animation:pulse-green 2s infinite}.connection-dot.disconnected{background:var(--text-dim)}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.6}}.header-actions{display:flex;gap:var(--space-2);align-items:center}.btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--success);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .15s ease}.btn-icon:hover:not(:disabled){background:#2ea043;transform:scale(1.1)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.app-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;position:relative}.scanner-view{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-8)}.scanner-content{text-align:center;max-width:500px}.scanner-content h2{margin-bottom:var(--space-2);color:var(--text-primary);font-size:var(--text-xl)}.scanner-content p{color:var(--text-dim);margin-bottom:var(--space-8);font-size:var(--text-base)}.error-banner{background:#f487711a;border-left:4px solid var(--danger);padding:var(--space-4) var(--space-6);margin:var(--space-4) var(--space-6);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--danger)}.error-message{color:var(--danger);background:#f4877126;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-top:var(--space-4);font-size:var(--text-sm);border:1px solid var(--danger)}.connecting-message{text-align:center;padding:var(--space-8);color:var(--info);font-size:var(--text-lg);animation:pulse 2s infinite}.tasks-panel{border-top:1px solid var(--border);background:var(--bg-panel);padding:var(--space-4) var(--space-6);max-height:200px;overflow-y:auto;flex-shrink:0}.tasks-panel h3{font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-3);color:var(--text-primary)}.task-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-3);background:var(--bg-dark);border-radius:var(--radius-sm);margin-bottom:var(--space-2);font-size:var(--text-sm)}.task-id{font-family:var(--font-family);color:var(--text-dim)}.task-status{color:var(--success);font-weight:500}.btn-terminal{background:var(--bg-panel);border-color:var(--info);color:var(--info)}.btn-terminal:hover:not(:disabled){background:var(--info);color:#fff}.btn-disconnect{background:var(--bg-panel);border-color:var(--danger);color:var(--danger)}.btn-disconnect:hover:not(:disabled){background:var(--danger);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-darker)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--accent-orange)}::selection{background:var(--accent-orange);color:#fff}*:focus-visible{outline:2px solid var(--accent-orange);outline-offset:2px}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-dim);font-size:var(--text-lg)}.loading:after{content:"...";animation:loading 1.5s infinite}@keyframes loading{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}@media print{.mobile-dpad,.status-bar,.input-panel,.app-header,.tasks-panel{display:none!important}.output-view{height:auto;overflow:visible}}@media (max-width: 768px){.app{height:100dvh}.app-header{padding:var(--space-3) var(--space-4)}.app-title h1{font-size:var(--text-base)}.app-icon{font-size:var(--text-lg)}.header-actions button{font-size:var(--text-xs);padding:0 var(--space-3)}.scanner-view{padding:var(--space-4)}.scanner-content h2{font-size:var(--text-lg)}.tasks-panel{padding:var(--space-3) var(--space-4);max-height:150px}}@media (max-width: 480px){.app-content{font-size:var(--text-sm)}.header-actions{gap:var(--space-1)}.app-title h1{display:none}.error-banner,.error-message{margin:var(--space-2) var(--space-3);padding:var(--space-2) var(--space-3)}}.output-view{display:flex;flex-direction:column;flex:1;min-height:0;background:#1a1a1a;overflow:hidden}.output-container{flex:1;min-height:0;overflow-y:auto;padding:16px}.timeline-list{display:flex;flex-direction:column;max-width:900px;margin:0 auto;position:relative;padding-left:32px}.timeline-list:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:#333}.output-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666;gap:16px}.output-empty p{font-size:16px;margin:0}.timeline-node{display:flex;gap:16px;margin-bottom:4px;animation:fadeIn .2s ease;position:relative}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.timeline-marker{position:absolute;left:-26px;top:8px;width:12px;height:12px;border-radius:50%;background:#444;border:2px solid #1a1a1a;z-index:1}.command-node .timeline-marker{background:var(--accent-orange);box-shadow:0 0 8px #d7775766}.thinking-node .timeline-marker{background:#4a90e2}.tool-node .timeline-marker{background:#888}.error-node .timeline-marker{background:#cd3131}.result-node .timeline-marker{background:#51cf66}.timeline-content{flex:1;min-width:0}.timeline-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#2d2d2d;border-radius:8px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.command-node .timeline-header{background:#d777571a;border:1px solid rgba(215,119,87,.3);cursor:default}.timeline-header:hover{background:#333}.command-node .timeline-header:hover{background:#d7775726}.timeline-icon{display:flex;align-items:center;justify-content:center;color:#888;flex-shrink:0}.command-node .timeline-icon{color:var(--accent-orange)}.thinking-node .timeline-icon{color:#4a90e2}.error-node .timeline-icon{color:#cd3131}.timeline-title{flex:1;font-size:14px;color:#d4d4d4;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.command-node .timeline-title{color:var(--accent-orange);font-family:Menlo,Monaco,Courier New,monospace;white-space:normal;word-break:break-all}.collapse-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#666;cursor:pointer;padding:0;transition:all .2s;flex-shrink:0}.collapse-btn:hover{color:#fff}.timeline-body{margin-top:8px;padding:12px;background:#1e1e1e;border:1px solid #3b3b3b;border-radius:8px;position:relative}.tool-node .timeline-body{border-left:3px solid #666}.thinking-node .timeline-body{border-left:3px solid #4a90e2}.error-node .timeline-body{border-left:3px solid #cd3131;background:#cd31310d}.result-node .timeline-body{border-left:3px solid #51cf66}.timeline-text{margin:0;font-family:Menlo,Monaco,Courier New,monospace;font-size:13px;line-height:1.5;color:#abb2bf;white-space:pre-wrap;word-break:break-word;overflow-x:auto}.error-node .timeline-text{color:#ff6b6b}.copy-btn-inline{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:4px;background:#2d2d2d;border:1px solid #3b3b3b;color:#888;font-size:11px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:all .2s;opacity:.7}.copy-btn-inline:hover{opacity:1;background:#3b3b3b;color:#fff}.timeline-node.collapsed .timeline-body{display:none}.output-container::-webkit-scrollbar{width:8px}.output-container::-webkit-scrollbar-track{background:#111}.output-container::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.output-container::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.output-container{padding:12px}.timeline-list{padding-left:24px}.timeline-marker{left:-20px;width:10px;height:10px}.timeline-header{padding:6px 10px}.timeline-title{font-size:13px}.timeline-body{padding:10px}.timeline-text{font-size:12px}}@media (max-width: 480px){.output-container{padding:8px}.timeline-list{padding-left:20px}.timeline-marker{left:-16px;width:8px;height:8px}.timeline-header{gap:6px}.timeline-icon svg{width:14px;height:14px}}.input-panel{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);background:var(--bg-darker);border-top:2px solid #444;flex-shrink:0;z-index:100;position:relative}.image-previews{display:flex;gap:var(--space-2);flex-wrap:wrap;max-height:120px;overflow-y:auto}.image-preview{position:relative;width:60px;height:60px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid #555}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:2px;right:2px;width:18px;height:18px;padding:0;display:flex;align-items:center;justify-content:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:background .15s}.remove-image:hover{background:var(--danger)}.input-row{display:flex;gap:var(--space-2);align-items:flex-end}.image-button{width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;background:transparent;border:2px solid #555;border-radius:var(--radius-md);color:#888;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.image-button:hover:not(:disabled){border-color:var(--accent-orange);color:var(--accent-orange)}.image-button:disabled{opacity:.4;cursor:not-allowed}.input-textarea{flex:1;font-family:var(--font-family);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-dark);border:2px solid #555;border-radius:var(--radius-md);padding:var(--space-3);resize:none;min-height:40px;max-height:200px;overflow-y:auto;transition:border-color var(--transition-fast)}.input-textarea:focus{outline:none;border-color:var(--accent-orange);box-shadow:0 0 0 2px #d7775733}.input-textarea:disabled{opacity:.5;cursor:not-allowed}.input-textarea::placeholder{color:var(--text-dim)}.send-button{align-self:flex-end;width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--accent-orange);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.send-button svg{margin-left:2px}.send-button:hover:not(:disabled){background:var(--accent-orange);transform:scale(1.1)}.send-button:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 768px){.input-panel{padding:var(--space-3);gap:var(--space-2)}.input-textarea{font-size:var(--text-sm);padding:var(--space-2)}.send-button{width:40px;height:40px}.send-button svg{width:18px;height:18px}}@media (max-width: 480px){.input-panel{padding:var(--space-2)}.input-textarea{font-size:16px;padding:var(--space-2)}.send-button{width:36px;height:36px}.send-button svg{width:16px;height:16px}}.dpad-toggle{position:fixed;z-index:1000;width:48px;height:48px;border-radius:50%;background:var(--accent-orange);border:none;color:#fff;font-size:20px;box-shadow:0 4px 12px #0000004d;cursor:move;touch-action:none}.dpad-container{position:fixed;bottom:80px;left:12px;z-index:999}.dpad-close{position:absolute;top:-6px;left:-6px;z-index:1001;width:28px;height:28px;border-radius:50%;background:#64646ee6;border:none;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000004d}.dpad-panel{background:#282c34f2;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:12px;box-shadow:0 8px 32px #0006;animation:slideInFromBottomLeft .2s ease-out}.dpad-arrows{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:8px}.dpad-btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .1s ease;-webkit-tap-highlight-color:transparent}.dpad-btn.arrow{width:48px;height:48px;background:#373c46e6;border-radius:12px;color:#ffffffe6}.dpad-btn.arrow:active{background:var(--accent-orange);transform:scale(.95)}.dpad-btn.arrow svg{width:18px;height:18px}.dpad-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.dpad-btn.control{height:36px;background:#373c46e6;border-radius:8px;color:#ffffffd9;font-size:11px;font-weight:600;letter-spacing:.3px}.dpad-btn.control:active{background:var(--accent-orange);transform:scale(.95)}@keyframes slideInFromBottomLeft{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 769px){.dpad-toggle,.dpad-container{display:none!important}}.totp-login{display:flex;flex-direction:column;align-items:center;padding:2rem;max-width:400px;margin:0 auto}.totp-header{text-align:center;margin-bottom:2rem}.totp-header h2{font-size:1.5rem;margin-bottom:.5rem;color:#d4d4d4}.totp-header p{font-size:.875rem;color:gray}.totp-input-group{display:flex;gap:.5rem;margin-bottom:1rem}.totp-input-group input{width:3rem;height:3.5rem;text-align:center;font-size:1.5rem;font-weight:600;border:2px solid #2d2d30;border-radius:8px;background:#1e1e1e;color:#d4d4d4;transition:all .2s}.totp-input-group input:focus{outline:none;border-color:#d77757;box-shadow:0 0 0 3px #d7775733}.totp-input-group input.error{border-color:#f48771;animation:shake .3s}.totp-error{color:#f48771;font-size:.875rem;margin-top:.5rem;text-align:center}.totp-warning{color:#dcdcaa;font-size:.875rem;margin-top:.5rem;text-align:center;padding:.5rem;background:#dcdcaa1a;border-radius:6px;border:1px solid rgba(220,220,170,.3)}.totp-loading{color:#4ec9b0;font-size:.875rem;margin-top:.5rem;text-align:center}.totp-lockout{background:#f487711a;border:2px solid rgba(244,135,113,.3);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;width:100%}.lockout-icon{font-size:3rem;margin-bottom:.75rem}.lockout-message{color:#f48771;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.lockout-timer{color:#d4d4d4;font-size:.875rem}.lockout-timer strong{color:#f48771;font-size:1.25rem;font-variant-numeric:tabular-nums}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (max-width: 480px){.totp-input-group input{width:2.5rem;height:3rem;font-size:1.25rem}}/**
 * Copyright (c) 2014 The xterm.js authors. All rights reserved.
 * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
 * https://github.com/chjj/term.js
 * @license MIT
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 *
 * Originally forked from (with the author's permission):
 *   Fabrice Bellard's javascript vt100 for jslinux:
 *   http://bellard.org/jslinux/
 *   Copyright (c) 2011 Fabrice Bellard
 *   The original design remains. The terminal itself
 *   has been extended to include xterm CSI codes, among
 *   other features.
 */.xterm{cursor:text;position:relative;user-select:none;-ms-user-select:none;-webkit-user-select:none}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{position:absolute;top:0;z-index:5}.xterm .xterm-helper-textarea{padding:0;border:0;margin:0;position:absolute;opacity:0;left:-9999em;top:0;width:0;height:0;z-index:-5;white-space:nowrap;overflow:hidden;resize:none}.xterm .composition-view{background:#000;color:#fff;display:none;position:absolute;white-space:nowrap;z-index:1}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{background-color:#000;overflow-y:scroll;cursor:default;position:absolute;right:0;left:0;top:0;bottom:0}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;left:0;top:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{display:inline-block;visibility:hidden;position:absolute;top:0;left:-9999em;line-height:normal}.xterm.enable-mouse-events{cursor:default}.xterm.xterm-cursor-pointer,.xterm .xterm-cursor-pointer{cursor:pointer}.xterm.column-select.focus{cursor:crosshair}.xterm .xterm-accessibility,.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .live-region{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{text-decoration:double underline}.xterm-underline-3{text-decoration:wavy underline}.xterm-underline-4{text-decoration:dotted underline}.xterm-underline-5{text-decoration:dashed underline}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:overline underline}.xterm-overline.xterm-underline-2{text-decoration:overline double underline}.xterm-overline.xterm-underline-3{text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{text-decoration:overline dashed underline}.xterm-strikethrough{text-decoration:line-through}.xterm-screen .xterm-decoration-container .xterm-decoration{z-index:6;position:absolute}.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer{z-index:7}.xterm-decoration-overview-ruler{z-index:8;position:absolute;top:0;right:0;pointer-events:none}.xterm-decoration-top{z-index:2;position:relative}.terminal-window{position:fixed;bottom:20px;right:20px;width:600px;height:400px;background:#1e1e1e;border-radius:8px;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column;overflow:hidden;z-index:1000;transition:all .3s ease}.terminal-window.maximized{top:20px;left:20px;right:20px;bottom:20px;width:auto;height:auto}.terminal-header{background:#2d2d30;padding:8px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #3e3e42}.terminal-controls{display:flex;align-items:center;gap:12px}.terminal-btn{width:12px;height:12px;border-radius:50%;cursor:pointer;transition:all .2s;border:none}.terminal-btn.close{background:#ff5f56}.terminal-btn.close:hover{background:#e04942}.terminal-user{font-family:Menlo,Monaco,Courier New,monospace;font-size:13px;color:#d4d4d4}.terminal-actions{display:flex;gap:8px}.terminal-maximize-btn{background:transparent;border:none;color:#a0a0a0;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.terminal-maximize-btn:hover{color:#fff}.terminal-body{flex:1;padding:12px;background:#1e1e1e;overflow:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.terminal-content{width:100%;height:100%;overflow:hidden}.virtual-gamepad-container{position:fixed;z-index:1001}.gamepad-fab{position:fixed;width:48px;height:48px;border-radius:50%;background:var(--accent-orange);border:none;box-shadow:0 4px 12px #0000004d;display:flex;align-items:center;justify-content:center;color:#fff;cursor:move;transition:all .2s;touch-action:none}.gamepad-fab:active{transform:scale(.95)}.gamepad-panel-container{position:fixed;z-index:1002}.gamepad-close-btn{position:absolute;top:-6px;left:-6px;z-index:1003;width:28px;height:28px;border-radius:50%;background:#64646ee6;border:none;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000004d}.gamepad-close-btn:active{transform:scale(.95)}.gamepad-panel{background:#282c34f2;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:12px;box-shadow:0 8px 32px #0006;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.gamepad-arrows{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:8px}.arrow-row{display:flex;gap:4px;align-items:center}.gamepad-btn{display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .1s ease;-webkit-tap-highlight-color:transparent}.gamepad-btn.arrow{width:48px;height:48px;background:#373c46e6;border-radius:12px;color:#ffffffe6}.gamepad-btn.arrow:active{background:var(--accent-orange);transform:scale(.95)}.gamepad-btn.arrow svg{width:18px;height:18px}.gamepad-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.gamepad-btn.control{height:36px;background:#373c46e6;border-radius:8px;color:#ffffffd9;font-size:11px;font-weight:600;letter-spacing:.3px}.gamepad-btn.control:active{background:var(--accent-orange);transform:scale(.95)}@media (max-width: 768px){.terminal-window{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;border-radius:0;z-index:1000;overscroll-behavior:contain;touch-action:none}.terminal-window.maximized{top:0;left:0;right:0;bottom:0}.terminal-header{padding:10px 12px}.terminal-user{font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-body{padding:8px;touch-action:pan-y}.terminal-content{font-size:12px}}.terminal-content ::-webkit-scrollbar{width:8px;height:8px}.terminal-content ::-webkit-scrollbar-track{background:#1e1e1e}.terminal-content ::-webkit-scrollbar-thumb{background:#424242;border-radius:4px}.terminal-content ::-webkit-scrollbar-thumb:hover{background:#4e4e4e}
