/**
 * 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:not(.debug),.xterm .xterm-message{position:absolute;left:0;top:0;bottom:0;right:0;z-index:10;color:transparent;pointer-events:none}.xterm .xterm-accessibility-tree:not(.debug) *::selection{color:transparent}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre}.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}@font-face{font-family:Geist;src:url(/fonts/Geist-Variable.woff2) format("woff2");font-weight:100 900;font-display:swap}:root{--bg-primary: #090d13;--bg-secondary: #111820;--bg-tertiary: #1a2230;--bg-surface: #1e2a3a;--bg-overlay: rgba(0, 0, 0, .6);--text-primary: #e2e8f0;--text-secondary: #7a8696;--text-tertiary: #3e4a5a;--state-active: #3fb950;--state-active-bg: rgba(63, 185, 80, .08);--state-active-border: rgba(63, 185, 80, .25);--state-waiting: #d29922;--state-waiting-bg: rgba(210, 153, 34, .1);--state-waiting-border: rgba(210, 153, 34, .3);--state-waiting-glow: 0 0 12px rgba(210, 153, 34, .4);--state-completed: #06b6d4;--state-completed-bg: rgba(6, 182, 212, .08);--state-idle: #db6d28;--state-idle-bg: rgba(219, 109, 40, .06);--accent-blue: #3b82f6;--accent-red: #ef4444;--accent-purple: #a78bfa;--border: rgba(255, 255, 255, .06);--border-hover: rgba(255, 255, 255, .12);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-view: .35s;--font-sans: "Geist", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", monospace;--safe-bottom: env(safe-area-inset-bottom)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}.app{height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes breathe{0%,to{box-shadow:0 0 0 0 var(--state-waiting-border)}50%{box-shadow:var(--state-waiting-glow)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scan-line{0%{top:0}50%{top:calc(100% - 2px)}to{top:0}}@keyframes slide-up{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes stagger-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes corner-pulse{0%,to{opacity:.6}50%{opacity:1}}.view-container{position:absolute;top:0;right:0;bottom:0;left:0;will-change:transform,opacity}.view-enter-right{animation:slideInRight var(--duration-view) var(--ease-out) forwards}.view-exit-left{animation:slideOutLeft var(--duration-view) var(--ease-out) forwards}.view-enter-left{animation:slideInLeft var(--duration-view) var(--ease-out) forwards}.view-exit-right{animation:slideOutRight var(--duration-view) var(--ease-out) forwards}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideOutLeft{0%{transform:translate(0);opacity:1}to{transform:translate(-30%);opacity:.5}}@keyframes slideInLeft{0%{transform:translate(-30%);opacity:.5}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0)}to{transform:translate(100%)}}.scanner-page{height:100%;display:flex;flex-direction:column;align-items:center;padding:48px 24px 24px;gap:12px;animation:fade-in var(--duration-normal) var(--ease-out)}.scanner-logo{width:48px;height:48px;color:var(--accent-blue);margin-bottom:4px}.scanner-title{font-family:var(--font-sans);font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.scanner-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.scanner-viewport-wrapper{position:relative;width:100%;max-width:280px;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-secondary)}.scanner-viewport-wrapper #qr-reader{width:100%;height:100%}.scanner-viewport-wrapper #qr-reader video{object-fit:cover;border-radius:var(--radius-lg)}.scanner-corner{position:absolute;width:24px;height:24px;z-index:2;animation:corner-pulse 2s ease-in-out infinite}.scanner-corner:before,.scanner-corner:after{content:"";position:absolute;background:var(--accent-blue);border-radius:2px}.scanner-corner--tl{top:8px;left:8px}.scanner-corner--tl:before{top:0;left:0;width:24px;height:3px}.scanner-corner--tl:after{top:0;left:0;width:3px;height:24px}.scanner-corner--tr{top:8px;right:8px}.scanner-corner--tr:before{top:0;right:0;width:24px;height:3px}.scanner-corner--tr:after{top:0;right:0;width:3px;height:24px}.scanner-corner--bl{bottom:8px;left:8px}.scanner-corner--bl:before{bottom:0;left:0;width:24px;height:3px}.scanner-corner--bl:after{bottom:0;left:0;width:3px;height:24px}.scanner-corner--br{bottom:8px;right:8px}.scanner-corner--br:before{bottom:0;right:0;width:24px;height:3px}.scanner-corner--br:after{bottom:0;right:0;width:3px;height:24px}.scanner-line{position:absolute;left:12px;right:12px;height:2px;background:linear-gradient(90deg,transparent,var(--accent-blue),transparent);z-index:2;animation:scan-line 3s ease-in-out infinite;opacity:.8}.scanner-error{font-size:13px;color:var(--state-waiting);text-align:center;padding:14px 16px;background:var(--state-waiting-bg);border:1px solid var(--state-waiting-border);border-radius:var(--radius-md);width:100%;max-width:280px}.scanner-progress{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px;width:100%;max-width:280px}.scanner-progress-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.scanner-progress-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.scanner-progress-success{color:var(--state-active)}.scanner-manual-toggle{width:100%;max-width:280px;margin-top:auto}.scanner-manual-toggle summary{font-size:13px;color:var(--text-secondary);cursor:pointer;padding:8px 0;list-style:none;display:flex;align-items:center;gap:6px}.scanner-manual-toggle summary::-webkit-details-marker{display:none}.scanner-manual-toggle summary:after{content:"▾";font-size:10px;transition:transform var(--duration-fast)}.scanner-manual-toggle[open] summary:after{transform:rotate(180deg)}.scanner-manual-content{display:flex;flex-direction:column;gap:8px;padding-top:8px;animation:slide-up var(--duration-fast) var(--ease-out)}.manual-textarea{font-family:var(--font-mono);font-size:11px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px;resize:none;outline:none;transition:border-color var(--duration-fast)}.manual-textarea:focus{border-color:var(--accent-blue)}.btn-primary{font-family:var(--font-sans);font-size:14px;font-weight:600;background:var(--accent-blue);color:#fff;border:none;border-radius:var(--radius-sm);padding:12px 24px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:opacity var(--duration-fast)}.btn-primary:active{opacity:.8}.btn-back{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0}.btn-back:active{color:var(--text-primary)}.btn-disconnect{font-family:var(--font-sans);font-size:13px;font-weight:500;background:none;border:1px solid rgba(239,68,68,.3);color:var(--accent-red);border-radius:var(--radius-sm);padding:10px 20px;cursor:pointer;margin:12px auto;-webkit-tap-highlight-color:transparent;transition:background var(--duration-fast)}.btn-disconnect:active{background:#ef44441a}.projects-footer{display:flex;align-items:center;justify-content:center;gap:12px;padding:0 16px 12px;padding-bottom:max(12px,var(--safe-bottom))}.version-label{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.btn-hard-refresh{display:flex;align-items:center;gap:5px;font-family:var(--font-sans);font-size:11px;font-weight:500;color:var(--text-tertiary);background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--duration-fast),border-color var(--duration-fast)}.btn-hard-refresh:active{color:var(--text-secondary);border-color:var(--border-hover)}.status-pill{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;background:var(--bg-tertiary);border:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-secondary);transition:all var(--duration-fast)}.status-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);flex-shrink:0;transition:all var(--duration-fast)}.status-pill[data-state=connected]{border-color:var(--state-active-border)}.status-pill[data-state=connected] .status-pill-dot{background:var(--state-active);box-shadow:0 0 6px #3fb95066}.status-pill[data-state=connected] .status-pill-text{color:var(--state-active)}.status-pill[data-state=waiting] .status-pill-dot{background:var(--state-waiting);animation:pulse 2s ease-in-out infinite}.status-pill[data-state=connecting] .status-pill-dot{background:var(--accent-blue);animation:pulse 1.5s ease-in-out infinite}.state-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:100px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.state-badge--active{background:var(--state-active-bg);color:var(--state-active)}.state-badge--waitingForInput{background:var(--state-waiting-bg);color:var(--state-waiting);animation:pulse 2s ease-in-out infinite}.state-badge--completed{background:var(--state-completed-bg);color:var(--state-completed)}.state-badge--idle{background:var(--state-idle-bg);color:var(--state-idle)}.summary-bar{padding:0 16px 8px;font-size:13px;color:var(--text-secondary)}.summary-bar-waiting{color:var(--state-waiting);font-weight:600}.skeleton-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:12px}.skeleton-line{height:12px;border-radius:6px;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-surface) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.skeleton-line--title{width:60%;height:14px}.skeleton-line--subtitle{width:80%;height:10px}.skeleton-line--row{width:100%;height:40px;border-radius:var(--radius-sm)}.projects-page{height:100%;display:flex;flex-direction:column;overflow:hidden}.projects-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.projects-title{font-family:var(--font-sans);font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.project-list{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch}.project-list-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:48px 24px;text-align:center}.project-list-empty-icon{width:64px;height:64px;color:var(--text-tertiary);margin-bottom:8px}.project-list-empty-title{font-size:16px;font-weight:600;color:var(--text-secondary)}.project-list-empty-subtitle{font-size:13px;color:var(--text-tertiary);line-height:1.5}.project-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;border-left:3px solid var(--border);animation:stagger-in var(--duration-normal) var(--ease-out) backwards;transition:border-color var(--duration-fast)}.project-card[data-priority=active]{border-left-color:var(--state-active)}.project-card[data-priority=waitingForInput]{border-left-color:var(--state-waiting);animation:breathe 3s ease-in-out infinite,stagger-in var(--duration-normal) var(--ease-out) backwards;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--state-waiting-bg) 100%)}.project-card[data-priority=completed]{border-left-color:var(--state-completed)}.project-card[data-priority=idle]{border-left-color:var(--state-idle)}.project-card-header{padding:12px 14px 8px;display:flex;flex-direction:column;gap:2px}.project-name{font-family:var(--font-sans);font-size:15px;font-weight:600;color:var(--text-primary)}.project-dir{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-list{display:flex;flex-direction:column}.terminal-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;background:none;border:none;border-top:1px solid var(--border);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-fast);width:100%}.terminal-btn:active{background:var(--bg-tertiary)}.terminal-state-bar{width:3px;height:28px;border-radius:2px;flex-shrink:0}.terminal-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.terminal-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-task{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-chevron{color:var(--text-tertiary);font-size:16px;flex-shrink:0}.pull-indicator{display:flex;justify-content:center;padding:12px 0;overflow:hidden;transition:height var(--duration-fast),opacity var(--duration-fast)}.pull-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}.terminal-view{height:100%;display:flex;flex-direction:column}.terminal-header{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 4px;background:var(--bg-secondary);border-bottom:2px solid var(--border);flex-shrink:0;transition:border-color var(--duration-fast)}.terminal-header[data-state=active]{border-bottom-color:var(--state-active)}.terminal-header[data-state=waitingForInput]{border-bottom-color:var(--state-waiting)}.terminal-header[data-state=completed]{border-bottom-color:var(--state-completed)}.terminal-header[data-state=idle]{border-bottom-color:var(--state-idle)}.terminal-header-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.terminal-header-name{font-family:var(--font-sans);font-size:15px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-header-task{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.terminal-container{flex:1;padding:4px;overflow:hidden;-webkit-user-select:text;user-select:text}.terminal-container .xterm .xterm-viewport{touch-action:pan-y;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.terminal-container .xterm .xterm-screen{touch-action:pan-y}.quick-response-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-top:1px solid var(--state-waiting-border);animation:slide-up var(--duration-normal) var(--ease-out)}.quick-response-chip{font-family:var(--font-sans);font-size:13px;font-weight:600;padding:8px 16px;border-radius:100px;border:1px solid var(--border-hover);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:all var(--duration-fast);flex-shrink:0}.quick-response-chip:active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.quick-response-chip--yes{background:var(--state-active-bg);border-color:var(--state-active-border);color:var(--state-active)}.quick-response-chip--no{background:#ef444414;border-color:#ef444440;color:var(--accent-red)}.quick-response-input{flex:1;font-family:var(--font-sans);font-size:13px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:8px 12px;outline:none;min-width:0}.quick-response-input:focus{border-color:var(--accent-blue)}.quick-response-send{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent-blue);border:none;border-radius:50%;color:#fff;font-size:16px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.mobile-keyboard{display:flex;flex-direction:column;gap:4px;padding:6px;padding-bottom:max(6px,var(--safe-bottom));background:var(--bg-secondary);border-top:1px solid var(--border)}.keyboard-row{display:flex;gap:4px;justify-content:center}.key-btn{font-family:var(--font-mono);font-size:12px;font-weight:600;min-width:42px;height:36px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center;transition:background var(--duration-fast),color var(--duration-fast);padding:0 6px}.key-btn:active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.key-btn--arrow{min-width:48px}.key-btn--enter{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff;min-width:56px}.key-btn--enter:active{opacity:.8}.key-btn--ctrl{transition:background var(--duration-fast),color var(--duration-fast)}.key-btn--ctrl-active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.swipe-indicator{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent-blue);opacity:0;transition:opacity var(--duration-fast);z-index:10;border-radius:0 4px 4px 0}.swipe-indicator--active{opacity:.6}@keyframes bannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.connection-banner{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;gap:8px;padding:10px 16px;font-family:var(--font-sans);font-size:13px;font-weight:600;animation:bannerSlideDown var(--duration-normal) var(--ease-out)}.connection-banner--warning{background:var(--state-waiting-bg);color:var(--state-waiting);border-bottom:1px solid var(--state-waiting-border)}.connection-banner--error{background:#ef44441a;color:var(--accent-red);border-bottom:1px solid rgba(239,68,68,.3)}.connection-banner-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:pulse 2s ease-in-out infinite;flex-shrink:0}.toast{position:fixed;bottom:calc(env(safe-area-inset-bottom,0px) + 70px);left:50%;transform:translate(-50%);z-index:200;background:var(--bg-surface);color:var(--text-primary);font-family:var(--font-sans);font-size:13px;font-weight:500;padding:8px 16px;border-radius:var(--radius-md);border:1px solid var(--state-completed-border);box-shadow:0 4px 12px #0006;animation:toastIn var(--duration-normal) var(--ease-out);cursor:pointer;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.tab-content{flex:1;position:relative;overflow:hidden}.tab-pane{position:absolute;top:0;right:0;bottom:0;left:0;visibility:hidden;opacity:0;transition:opacity var(--duration-fast) ease;will-change:opacity}.tab-pane--active{visibility:visible;opacity:1;position:relative;height:100%}.tab-empty{display:flex;align-items:center;justify-content:center;height:100%}.tab-empty-text{font-size:14px;color:var(--text-tertiary)}.bottom-nav{display:flex;align-items:stretch;background:var(--bg-secondary);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);flex-shrink:0;position:relative;z-index:50}.bottom-nav:before{content:"";position:absolute;top:-20px;left:0;right:0;height:20px;background:linear-gradient(to top,rgba(0,0,0,.3),transparent);pointer-events:none}.bottom-nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 0;background:none;border:none;color:var(--text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color var(--duration-fast);position:relative}.bottom-nav-tab:active{color:var(--text-secondary)}.bottom-nav-tab--active{color:var(--accent-blue)}.bottom-nav-tab--active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:2px;background:var(--accent-blue);border-radius:0 0 2px 2px}.bottom-nav-tab--disabled{opacity:.3;pointer-events:none}.bottom-nav-icon{width:20px;height:20px}.bottom-nav-label{font-family:var(--font-sans);font-size:10px;font-weight:600;letter-spacing:.02em}.bottom-nav-badge{position:absolute;top:4px;right:50%;transform:translate(14px);min-width:16px;height:16px;line-height:16px;padding:0 4px;background:var(--state-waiting);color:#000;font-family:var(--font-sans);font-size:10px;font-weight:700;text-align:center;border-radius:100px}.settings-view{height:100%;display:flex;flex-direction:column;overflow:hidden}.settings-header{display:flex;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.settings-title{font-family:var(--font-sans);font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.settings-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:20px;-webkit-overflow-scrolling:touch}.settings-section{display:flex;flex-direction:column;gap:8px}.settings-section-title{font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;padding-left:2px}.settings-section-title--danger{color:var(--accent-red)}.settings-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;gap:12px}.settings-row+.settings-row{border-top:1px solid var(--border)}.settings-label{font-family:var(--font-sans);font-size:14px;color:var(--text-primary)}.settings-value{font-family:var(--font-sans);font-size:13px;color:var(--text-secondary);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.settings-value--mono{font-family:var(--font-mono);font-size:11px}.settings-actions{display:flex;flex-direction:column;gap:8px}.settings-btn{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-size:14px;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);padding:12px 16px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--duration-fast),border-color var(--duration-fast)}.settings-btn:active{background:var(--bg-tertiary);border-color:var(--border-hover)}.settings-btn--danger{color:var(--accent-red);border-color:#ef44444d}.settings-btn--danger:active{background:#ef44441a}.settings-btn--confirm{background:#ef444426;border-color:#ef444466;animation:pulse 1.5s ease-in-out infinite}.settings-toggle{width:44px;height:26px;border-radius:13px;background:var(--bg-tertiary);border:1px solid var(--border);cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;transition:background var(--duration-fast),border-color var(--duration-fast);flex-shrink:0}.settings-toggle--on{background:var(--accent-blue);border-color:var(--accent-blue)}.settings-toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform var(--duration-fast) var(--ease-out)}.settings-toggle--on .settings-toggle-thumb{transform:translate(18px)}.settings-stepper{display:flex;align-items:center;gap:4px}.settings-stepper-btn{width:30px;height:30px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);font-family:var(--font-mono);font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.settings-stepper-btn:active{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.settings-stepper-value{font-family:var(--font-mono);font-size:13px;color:var(--text-primary);min-width:40px;text-align:center}.share-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:300;display:flex;align-items:flex-end;animation:fade-in var(--duration-fast) ease}.share-modal{width:100%;background:var(--bg-secondary);border-top:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:20px 16px;padding-bottom:max(20px,var(--safe-bottom));animation:slide-up var(--duration-normal) var(--ease-out)}.share-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.share-modal-title{font-family:var(--font-sans);font-size:18px;font-weight:700;color:var(--text-primary)}.modal-close-btn{width:32px;height:32px;background:var(--bg-tertiary);border:none;border-radius:50%;color:var(--text-secondary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.share-modal-body{display:flex;flex-direction:column;gap:16px}.share-modal-desc{font-size:13px;color:var(--text-secondary);line-height:1.5}.share-modal-section{display:flex;flex-direction:column;gap:6px}.share-modal-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.share-modal-value{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.share-modal-code{flex:1;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-modal-copy-btn{font-family:var(--font-sans);font-size:12px;font-weight:600;background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:#fff;padding:4px 10px;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.share-modal-share-btn{width:100%;margin-top:4px}
