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)}.disconnect-toast{display:flex;align-items:center;gap:var(--space-3);background:#ffb4001f;border-left:4px solid #f5a623;padding:var(--space-3) var(--space-5);margin:var(--space-3) var(--space-4) 0;border-radius:var(--radius-sm);font-size:var(--text-sm);color:#f5c842}.disconnect-icon{flex-shrink:0}.disconnect-text{flex:1;opacity:.9}.reconnect-btn{flex-shrink:0;padding:var(--space-1) var(--space-4);background:#f5a62333;border:1px solid rgba(245,166,35,.5);border-radius:var(--radius-sm);color:#f5c842;font-size:var(--text-xs);cursor:pointer;transition:background .15s}.reconnect-btn:hover{background:#f5a62359}.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)}}.read-aloud-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:#666;cursor:pointer;transition:all var(--transition-fast);opacity:0;flex-shrink:0}.timeline-header:hover .read-aloud-btn,.read-aloud-btn.playing,.read-aloud-btn.loading{opacity:1}.read-aloud-btn:hover{color:var(--accent-orange);border-color:var(--accent-orange);background:#d777571a}.read-aloud-btn.playing{color:#ef4444;border-color:#ef4444;background:#ef44441a}.read-aloud-btn.loading{color:var(--accent-orange);opacity:.7}.tts-spinner{animation:tts-spin 1s linear infinite}@keyframes tts-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auto-speak-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid #555;border-radius:var(--radius-sm);color:#888;cursor:pointer;transition:all var(--transition-fast)}.auto-speak-toggle:hover{border-color:var(--accent-orange);color:var(--accent-orange)}.auto-speak-toggle.active{border-color:var(--accent-orange);color:var(--accent-orange);background:#d7775726}@media (max-width: 768px){.read-aloud-btn{opacity:1}}.ov-root{position:relative;display:flex;flex-direction:column;flex:1;min-height:0;background:#1a1a1a;overflow:hidden}.ov-scroller{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:20px 16px 32px;scroll-behavior:smooth}.ov-scroller::-webkit-scrollbar{width:5px}.ov-scroller::-webkit-scrollbar-track{background:transparent}.ov-scroller::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.ov-scroller::-webkit-scrollbar-thumb:hover{background:#555}.ov-feed{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.ov-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:300px;gap:12px;color:#555;text-align:center;-webkit-user-select:none;user-select:none}.ov-empty-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d777571f,#d777570a);border:1px solid rgba(215,119,87,.15);border-radius:16px;color:#d7775799}.ov-empty-title{font-size:15px;font-weight:500;color:#777;margin:0}.ov-empty-sub{font-size:13px;color:#444;margin:0}.ov-turn{display:flex;gap:12px;animation:ov-in .25s ease both}@keyframes ov-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ov-turn-user{flex-direction:row-reverse}.ov-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.ov-avatar-user{background:#2d2d2d;border:1px solid #3d3d3d;color:#888}.ov-avatar-assistant{background:linear-gradient(135deg,#d77757,#c05a3a);color:#fff;box-shadow:0 2px 8px #d777574d}.ov-bubble{flex:1;min-width:0;max-width:calc(100% - 42px)}.ov-bubble-user{background:#2a2a2a;border:1px solid #383838;border-radius:16px 4px 16px 16px;padding:10px 14px;display:inline-block;max-width:100%;float:right;clear:right}.ov-user-text{font-size:14px;color:#d4d4d4;line-height:1.55;word-break:break-word;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.ov-bubble-assistant{display:flex;flex-direction:column;gap:10px}.ov-tools-group{display:flex;flex-direction:column;gap:4px;border-radius:10px;overflow:hidden;border:1px solid #2a2a2a;background:#1e1e1e}.ov-tool-row{font-size:12px}.ov-tool-header{display:flex;align-items:center;gap:7px;padding:7px 12px;background:transparent;border:none;border-radius:0;color:#888;cursor:pointer;width:100%;text-align:left;height:auto;min-width:0;font-size:12px;transition:background .15s}.ov-tool-header:hover{background:#252525!important;transform:none!important;box-shadow:none!important;border-color:transparent!important;color:#aaa!important}.ov-tool-indicator{color:#555;flex-shrink:0;display:flex}.ov-tool-running .ov-tool-indicator{color:#569cd6}.ov-tool-done .ov-tool-indicator{color:#4ec9b0}.ov-tool-error .ov-tool-indicator{color:#f48771}.ov-tool-name{font-family:SF Mono,Menlo,monospace;font-weight:600;color:#999;flex-shrink:0}.ov-tool-running .ov-tool-name{color:#569cd6}.ov-tool-done .ov-tool-name{color:#6b9e8a}.ov-tool-summary{color:#555;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:SF Mono,Menlo,monospace}.ov-tool-chevron{flex-shrink:0;color:#444;display:flex}.ov-tool-detail{padding:8px 12px 10px;font-size:11px;color:#666;font-family:SF Mono,Menlo,monospace;line-height:1.5;white-space:pre-wrap;word-break:break-word;border-top:1px solid #2a2a2a;background:#191919;margin:0}.ov-prose{font-size:14px;line-height:1.65;color:#c9d1d9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;word-break:break-word}.ov-prose p{margin:0 0 10px}.ov-prose p:last-child{margin-bottom:0}.ov-prose h1,.ov-prose h2,.ov-prose h3,.ov-prose h4,.ov-prose h5,.ov-prose h6{color:#e0e0e0;font-weight:600;margin:16px 0 8px;line-height:1.3}.ov-prose h1{font-size:20px}.ov-prose h2{font-size:17px}.ov-prose h3{font-size:15px}.ov-prose ul,.ov-prose ol{padding-left:20px;margin:6px 0 10px}.ov-prose li{margin-bottom:4px}.ov-prose a{color:#d77757;text-decoration:underline;text-underline-offset:3px}.ov-prose strong{color:#e0e0e0;font-weight:600}.ov-prose em{color:#bbb}.ov-prose blockquote{border-left:3px solid #d77757;padding-left:12px;margin:8px 0;color:#888;font-style:italic}.ov-prose hr{border:none;border-top:1px solid #333;margin:16px 0}.ov-prose table{width:100%;border-collapse:collapse;font-size:13px;margin:10px 0}.ov-prose th{background:#252525;padding:7px 10px;text-align:left;border:1px solid #333;color:#ccc;font-weight:600}.ov-prose td{padding:6px 10px;border:1px solid #2a2a2a;color:#aaa}.ov-prose tr:nth-child(2n) td{background:#1e1e1e}.ov-inline-code{font-family:SF Mono,Menlo,monospace;font-size:12.5px;background:#252525;border:1px solid #333;border-radius:4px;padding:1px 5px;color:#ce9178}.ov-code-block{border:1px solid #2d2d2d;border-radius:8px;overflow:hidden;margin:6px 0}.ov-code-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:#252525;border-bottom:1px solid #2d2d2d}.ov-code-lang{font-size:11px;font-family:SF Mono,Menlo,monospace;color:#666;text-transform:lowercase}.ov-code-body{margin:0;padding:12px;overflow-x:auto;background:#1a1a1a}.ov-code-body code{font-family:SF Mono,Menlo,Monaco,monospace;font-size:12.5px;line-height:1.6;color:#abb2bf;white-space:pre}.ov-action-bar{display:flex;align-items:center;gap:6px;opacity:0;transition:opacity .2s}.ov-turn-assistant:hover .ov-action-bar,.ov-turn-assistant:focus-within .ov-action-bar{opacity:1}@media (hover: none){.ov-action-bar{opacity:1}}.ov-copy-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:unset;padding:0;background:#252525;border:1px solid #333;border-radius:6px;color:#666;cursor:pointer;transition:all .15s}.ov-copy-btn:hover:not(:disabled){background:#303030!important;border-color:#444!important;color:#aaa!important;transform:none!important;box-shadow:none!important}.ov-scroll-btn{position:absolute;bottom:20px;right:20px;width:36px;height:36px;min-width:unset;padding:0;background:#d77757;border:none;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 14px #0006,0 0 10px #d777574d;transition:all .2s;animation:ov-in .2s ease both;z-index:10}.ov-scroll-btn:hover:not(:disabled){transform:scale(1.1)!important;background:#c06040!important}@media (max-width: 768px){.ov-scroller{padding:16px 12px 24px}.ov-feed{gap:20px}.ov-avatar{width:26px;height:26px}.ov-avatar svg{width:13px;height:13px}.ov-prose{font-size:14px}.ov-code-body code{font-size:12px}.ov-action-bar{opacity:1}.ov-scroll-btn{width:40px;height:40px;bottom:16px;right:14px}}@media (max-width: 480px){.ov-scroller{padding:12px 10px 20px}.ov-turn{gap:8px}.ov-feed{gap:16px}.ov-avatar{width:24px;height:24px}.ov-bubble-user{padding:8px 12px}.ov-user-text{font-size:13px}.ov-prose{font-size:13.5px}.ov-code-body code{font-size:11.5px}.ov-tool-header{padding:6px 10px}.ov-code-header{padding:5px 10px}.ov-code-body{padding:10px}}.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}}.voice-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;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:none}.voice-button:hover:not(:disabled){border-color:var(--accent-orange);color:var(--accent-orange)}.voice-button:disabled{opacity:.4;cursor:not-allowed}.voice-button.recording{border-color:#ef4444;color:#ef4444;background:#ef44441a;animation:voice-pulse 1.2s ease-in-out infinite}.voice-button.processing{border-color:var(--accent-orange);color:var(--accent-orange);opacity:.7}@keyframes voice-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.voice-spinner{animation:voice-spin 1s linear infinite}@keyframes voice-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.voice-recording-indicator{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;display:flex;align-items:center;gap:8px;padding:8px 16px;background:#1e1e1ef2;border:1px solid #ef4444;border-radius:var(--radius-md);white-space:nowrap;z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.voice-recording-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:voice-dot-blink 1s ease-in-out infinite}@keyframes voice-dot-blink{0%,to{opacity:1}50%{opacity:.3}}.voice-recording-text{font-size:var(--text-sm);color:#ef4444;font-weight:500}.voice-processing-indicator{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;display:flex;align-items:center;gap:6px;padding:6px 12px;background:#1e1e1ef2;border:1px solid var(--accent-orange);border-radius:var(--radius-md);white-space:nowrap;z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--accent-orange);font-size:var(--text-xs)}.voice-error{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;padding:6px 12px;background:#ef4444e6;color:#fff;font-size:var(--text-xs);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;z-index:200;animation:voice-error-fade 3s ease-out forwards}@keyframes voice-error-fade{0%,80%{opacity:1}to{opacity:0}}@media (max-width: 768px){.voice-button{width:40px;height:40px}.voice-recording-indicator{padding:6px 12px;font-size:var(--text-xs)}}@media (max-width: 480px){.voice-button{width:36px;height:36px}}.dpad-toggle{position:fixed;z-index:1000;width:48px;height:48px;border-radius:50%;background:#64646e99;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:-4px;left:-4px;z-index:1001;width:12px;height:12px;padding:0;border-radius:50%;background:#ff5f56;border:none;cursor:pointer;transition:all .2s}.dpad-close:hover{background:#e04942;transform:scale(1.1)}.dpad-close:active{transform:scale(.95)}.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:#64646e99;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:18px;height:18px;min-width:18px;min-height:18px;max-width:18px;max-height:18px;padding:0;background:transparent;border:none;color:#ffffff80;cursor:pointer;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.gamepad-close-btn:hover{color:#ff5f56e6;transform:scale(1.1)}.gamepad-close-btn:active{transform:scale(.9)}.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;display:flex;align-items:center;justify-content:center}.gamepad-btn.control.icon{padding:8px}.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;flex-shrink:0}.terminal-user{font-size:12px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-body{padding:8px;touch-action:pan-y;flex:1 1 auto;min-height:0}.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}
