/**
 * 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}:root{--bg-base: #1e1e2e;--bg-mantle: #181825;--bg-crust: #11111b;--bg-surface0: #313244;--bg-surface1: #45475a;--bg-surface2: #585b70;--text: #cdd6f4;--text-sub: #a6adc8;--text-muted: #585b70;--blue: #89b4fa;--red: #f38ba8;--yellow: #f9e2af;--green: #a6e3a1;--mauve: #cba6f7;--teal: #94e2d5;--peach: #fab387;--radius: 8px;--radius-lg: 12px;--shadow: 0 4px 24px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6);--transition: .2s ease}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;height:100dvh;width:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-base);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-screen{display:flex;align-items:center;justify-content:center;height:100%;background:radial-gradient(ellipse at 20% 50%,rgba(137,180,250,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(203,166,247,.06) 0%,transparent 50%),radial-gradient(ellipse at 50% 80%,rgba(148,226,213,.05) 0%,transparent 50%),var(--bg-base)}.login-card{text-align:center;padding:2.5rem 2rem;max-width:380px;width:100%;background:#18182599;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(49,50,68,.6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.login-card h1{font-size:2rem;margin-bottom:.4rem;background:linear-gradient(135deg,var(--blue),var(--mauve));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.login-card p{color:var(--text-sub);margin-bottom:1.5rem;font-size:.85rem}.login-card input{width:100%;padding:.75rem 1rem;border:1px solid var(--bg-surface0);border-radius:var(--radius);background:var(--bg-surface0);color:var(--text);font-size:1rem;margin-bottom:1rem;transition:border-color var(--transition),box-shadow var(--transition);outline:none}.login-card input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #89b4fa26}.login-card input::placeholder{color:var(--text-muted)}.login-card button{width:100%;padding:.75rem;border:none;border-radius:var(--radius);background:linear-gradient(135deg,var(--blue),#74a8f7);color:var(--bg-crust);font-size:1rem;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}.login-card button:hover{transform:translateY(-1px);box-shadow:0 4px 16px #89b4fa4d;filter:brightness(1.05)}.login-card button:active{transform:translateY(0);box-shadow:none}.app{display:flex;flex-direction:column;height:100%}.app-header{display:flex;align-items:center;gap:.5rem;padding:0 .5rem;background:linear-gradient(180deg,var(--bg-crust) 0%,rgba(17,17,27,.95) 100%);border-bottom:1px solid var(--bg-surface0);min-height:38px;overflow-x:auto;position:relative;z-index:5}.menu-btn{background:none;border:none;color:var(--text-sub);font-size:1.25rem;cursor:pointer;padding:.25rem;transition:color var(--transition);border-radius:4px}.menu-btn:hover{color:var(--text)}.status{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-sub)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:background var(--transition)}.status-dot.connected{background:var(--green);box-shadow:0 0 6px #a6e3a166}.status-dot.connecting{background:var(--yellow);animation:pulse 1s infinite}.status-dot.disconnected{background:var(--red)}.transport-badge{font-size:.6rem;font-weight:600;padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.transport-badge.p2p{background:#a6e3a126;color:var(--green)}.transport-badge.relay{background:#89b4fa26;color:var(--blue)}.header-title{font-size:.85rem;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-bell{position:relative;background:none;border:none;color:var(--text-sub);font-size:1rem;cursor:pointer;padding:.25rem .4rem;line-height:1;transition:color var(--transition),transform var(--transition);border-radius:4px}.notif-bell:hover{color:var(--text);transform:scale(1.1)}.notif-bell:active{transform:scale(.95)}.notif-badge{position:absolute;top:-2px;right:-2px;background:var(--red);color:var(--bg-crust);font-size:.6rem;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px;animation:badge-pop .3s cubic-bezier(.175,.885,.32,1.275)}.notif-panel{position:absolute;top:38px;right:0;width:340px;max-height:420px;background:var(--bg-mantle);border:1px solid var(--bg-surface0);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:20;display:flex;flex-direction:column;overflow:hidden;animation:dropdown .2s ease}.notif-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem .85rem;border-bottom:1px solid var(--bg-surface0);font-size:.8rem;font-weight:600;color:var(--text-sub)}.notif-clear-btn{background:none;border:none;color:var(--text-muted);font-size:.7rem;cursor:pointer;transition:color var(--transition)}.notif-clear-btn:hover{color:var(--text-sub)}.notif-empty{padding:1.5rem;text-align:center;color:var(--text-muted);font-size:.8rem}.notif-list{overflow-y:auto;flex:1}.notif-item{display:block;width:100%;padding:.6rem .85rem;border:none;border-bottom:1px solid rgba(30,30,46,.5);background:transparent;text-align:left;cursor:pointer;font-family:inherit;color:var(--text);transition:background var(--transition)}.notif-item:hover{background:#3132444d}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:#89b4fa0d;border-left:3px solid var(--blue)}.notif-item-title{font-size:.8rem;font-weight:600}.notif-item-sub{font-size:.7rem;color:var(--blue);margin-top:.1rem}.notif-item-body{font-size:.7rem;color:var(--text-sub);margin-top:.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:10px;width:320px;pointer-events:none}.toast{display:flex;gap:.6rem;padding:.75rem .85rem;border:1px solid rgba(69,71,90,.5);border-radius:var(--radius-lg);background:#313244d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);text-align:left;cursor:pointer;font-family:inherit;color:var(--text);box-shadow:var(--shadow-lg);animation:toast-slide-in .4s cubic-bezier(.21,1.02,.73,1);transition:background var(--transition),transform var(--transition);pointer-events:auto;position:relative;overflow:hidden}.toast:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}.toast.toast-info:before{background:var(--blue)}.toast.toast-success:before{background:var(--green)}.toast.toast-warning:before{background:var(--yellow)}.toast.toast-error:before{background:var(--red)}.toast:hover{background:#45475ae6;transform:translate(-2px)}.toast-icon{font-size:1.2rem;line-height:1;flex-shrink:0;margin-top:1px}.toast-content{flex:1;min-width:0}.toast-title{font-size:.8rem;font-weight:600;color:var(--text)}.toast-sub{font-size:.7rem;color:var(--blue);margin-top:2px}.toast-body{font-size:.7rem;color:var(--text-sub);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-close{background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;padding:0;line-height:1;transition:color var(--transition),transform var(--transition);flex-shrink:0}.toast-close:hover{color:var(--text);transform:scale(1.2)}.toast-progress{position:absolute;bottom:0;left:0;height:2px;border-radius:0 0 0 var(--radius-lg);animation:toast-progress 5s linear forwards}.toast.toast-info .toast-progress{background:var(--blue)}.toast.toast-success .toast-progress{background:var(--green)}.toast.toast-warning .toast-progress{background:var(--yellow)}.toast.toast-error .toast-progress{background:var(--red)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-progress{0%{width:100%}to{width:0%}}@keyframes badge-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes dropdown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.app-body{display:flex;flex:1;overflow:hidden}.sidebar{width:200px;background:var(--bg-crust);border-right:1px solid var(--bg-surface0);overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column;transition:width var(--transition)}.terminal-area{flex:1;overflow:hidden}.workspace-group{border-bottom:1px solid rgba(30,30,46,.6)}.workspace-group:last-child{border-bottom:none}.workspace-label{display:flex;align-items:center;gap:.4rem;width:100%;padding:.55rem .75rem;border:none;background:transparent;font-size:.8rem;font-weight:500;color:var(--text-sub);cursor:pointer;text-align:left;font-family:inherit;transition:background var(--transition),color var(--transition),border-color var(--transition);border-left:3px solid transparent}.workspace-label:hover{background:#18182599;color:var(--text)}.workspace-label.active{color:var(--blue);background:#89b4fa0f;border-left-color:var(--blue);font-weight:600}.workspace-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace-count{font-size:.65rem;font-weight:400;color:var(--text-muted);background:var(--bg-base);padding:.1rem .4rem;border-radius:10px}.pane-container{position:relative;width:100%;height:100%}.pane{border:1px solid var(--bg-surface0);display:flex;flex-direction:column;background:var(--bg-base);transition:border-color var(--transition),box-shadow var(--transition)}.pane.focused{border-color:var(--blue);box-shadow:0 0 0 1px #89b4fa1a,0 0 12px #89b4fa14}.pane-tabs{display:flex;background:var(--bg-crust);border-bottom:1px solid var(--bg-surface0);overflow-x:auto;min-height:28px;flex-shrink:0}.pane-tab{padding:.35rem .65rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.7rem;white-space:nowrap;font-family:inherit;transition:color var(--transition),background var(--transition);border-bottom:2px solid transparent}.pane-tab:hover{color:var(--text-sub);background:#18182566}.pane-tab.active{color:var(--text);background:#1e1e2e66;border-bottom-color:var(--blue)}.pane-terminal{flex:1;overflow:auto;min-height:0}.no-pane-hint{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.85rem}.surface-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:0;width:100%;height:100%}.surface-grid>.pane{position:relative;min-height:0}.sidebar-empty{padding:2rem 1rem;text-align:center;color:var(--text-sub)}.sidebar-empty .hint{font-size:.8rem;margin-top:.5rem;color:var(--text-muted)}.xterm-viewport{-webkit-overflow-scrolling:touch}@media(hover:none)and (pointer:coarse){.xterm-viewport{overflow-y:hidden!important}}.mobile-app{display:flex;flex-direction:column;height:100%;height:100dvh;background:var(--bg-base)}.mobile-header{display:flex;align-items:center;gap:.4rem;padding:0 .4rem;padding-top:env(safe-area-inset-top,0px);background:var(--bg-crust);border-bottom:1px solid var(--bg-surface0);min-height:44px;flex-shrink:0}.mobile-header-title{flex:1;font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-ws-counter{font-size:.7rem;color:var(--text-muted);background:var(--bg-surface0);padding:.15rem .45rem;border-radius:10px;flex-shrink:0}.mobile-nav-btn{background:none;border:none;color:var(--text-sub);font-size:1.5rem;line-height:1;cursor:pointer;padding:.2rem .5rem;transition:color var(--transition),opacity var(--transition);flex-shrink:0}.mobile-nav-btn:disabled{opacity:.2;cursor:default}.mobile-nav-btn:not(:disabled):hover{color:var(--blue)}.mobile-tab-bar{display:flex;background:var(--bg-mantle);border-bottom:1px solid var(--bg-surface0);overflow-x:auto;min-height:36px;flex-shrink:0;-webkit-overflow-scrolling:touch}.mobile-tab-bar::-webkit-scrollbar{display:none}.mobile-tab{padding:.5rem .75rem;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.8rem;white-space:nowrap;font-family:inherit;transition:color var(--transition),background var(--transition);border-bottom:2px solid transparent;flex-shrink:0}.mobile-tab:hover{color:var(--text-sub);background:#3132444d}.mobile-tab.active{color:var(--text);border-bottom-color:var(--blue)}.mobile-terminal-area{flex:1;overflow:hidden;-webkit-overflow-scrolling:touch;min-height:0}@media(max-width:768px){.sidebar{position:absolute;z-index:10;width:240px;height:calc(100% - 44px);top:44px;left:0}.sidebar:not(:empty){box-shadow:4px 0 16px #00000080}.toast-container{width:calc(100% - 32px);right:16px;left:16px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-surface1);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--bg-surface2)}.github-login-btn{width:100%;padding:.75rem 1rem;border:1px solid var(--bg-surface0);border-radius:var(--radius);background:var(--bg-surface0);color:var(--text);font-size:1rem;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.github-login-btn:hover{background:var(--bg-surface1);border-color:var(--blue)}.dashboard-card{max-width:600px;width:100%;padding:2rem;background:#18182599;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(49,50,68,.6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}.dashboard-card h1{font-size:1.5rem;background:linear-gradient(135deg,var(--blue),var(--mauve));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dashboard-user{display:flex;align-items:center;gap:.75rem;color:var(--text-sub);font-size:.85rem}.logout-btn{padding:.4rem .75rem;border:1px solid var(--bg-surface1);border-radius:var(--radius);background:transparent;color:var(--text-sub);font-size:.8rem;cursor:pointer;transition:color var(--transition),border-color var(--transition)}.logout-btn:hover{color:var(--red);border-color:var(--red)}.dashboard-section{margin-bottom:1.5rem}.dashboard-section h2{font-size:1rem;color:var(--text);margin-bottom:.5rem}.dashboard-hint{color:var(--text-muted);font-size:.8rem;margin-bottom:.75rem}.dashboard-empty{color:var(--text-muted);font-size:.85rem;padding:.5rem 0}.dashboard-error{color:var(--red);font-size:.85rem;margin:.5rem 0}.token-create{display:flex;gap:.5rem;margin-bottom:.75rem}.token-create input{flex:1;padding:.5rem .75rem;border:1px solid var(--bg-surface0);border-radius:var(--radius);background:var(--bg-surface0);color:var(--text);font-size:.9rem;outline:none}.token-create input:focus{border-color:var(--blue)}.token-create button{padding:.5rem 1rem;border:none;border-radius:var(--radius);background:var(--blue);color:var(--bg-crust);font-size:.9rem;font-weight:600;cursor:pointer}.token-create button:hover{opacity:.9}.token-reveal{background:#89b4fa1a;border:1px solid rgba(137,180,250,.2);border-radius:var(--radius);padding:.75rem;margin-bottom:.75rem}.token-reveal p{color:var(--text-sub);font-size:.8rem;margin-bottom:.4rem}.token-reveal code{display:block;padding:.5rem;background:var(--bg-crust);border-radius:4px;font-size:.8rem;color:var(--green);word-break:break-all}.token-usage{margin-top:.5rem!important}.token-usage code{font-size:.7rem!important;color:var(--peach)!important}.token-list,.session-list{list-style:none}.token-list li{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--bg-surface0)}.token-list li:last-child{border-bottom:none}.token-list strong{font-size:.9rem;font-weight:500}.token-date{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.delete-btn{padding:.3rem .6rem;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text-muted);font-size:.75rem;cursor:pointer}.delete-btn:hover{color:var(--red);border-color:var(--red)}.session-list li{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--bg-surface0);gap:1rem}.session-item{background:var(--bg-surface0);border-radius:8px;margin-bottom:.5rem;border:none;padding:1rem}.session-info{display:flex;flex-direction:column;gap:.25rem}.session-id{font-family:monospace;font-size:.9rem;color:var(--text)}.session-label{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:var(--text)}.session-status-dot{width:8px;height:8px;border-radius:50%;background:var(--green);display:inline-block}.session-meta{font-size:.8rem;color:var(--text-muted)}.terminal-open-btn{display:block;width:100%;padding:1rem;margin:1rem 0;background:var(--green);color:var(--bg-base);border:none;border-radius:8px;font-size:1.1rem;font-weight:700;text-align:center;text-decoration:none;cursor:pointer}.terminal-open-btn:hover{opacity:.9;text-decoration:none}.viewer-info{display:flex;align-items:baseline;gap:.5rem}.viewer-count{font-size:2rem;font-weight:700;color:var(--text)}.viewer-label{font-size:.9rem;color:var(--text-muted)}.viewer-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:var(--bg-base);font-size:.75rem;font-weight:700;min-width:1.5rem;height:1.5rem;border-radius:999px;padding:0 .4rem;vertical-align:middle;margin-left:.5rem}.viewer-list{list-style:none;padding:0;margin:0}.viewer-item{display:flex;justify-content:space-between;align-items:center;padding:.6rem .8rem;background:var(--bg-surface0);border-radius:6px;margin-bottom:.4rem}.viewer-device{font-size:.85rem;color:var(--text)}.viewer-ip{font-family:monospace;font-size:.8rem;color:var(--text-muted)}.dashboard-btn{background:none;border:none;color:var(--text);font-size:1.3rem;text-decoration:none;cursor:pointer;padding:0 .5rem;line-height:1}.dashboard-btn:hover{opacity:.7}.notif-enable-btn{color:#f0ad4e!important;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.install-banner-overlay{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:0 1rem 1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px))}.install-banner{background:var(--bg-crust);border:1px solid var(--bg-surface1);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 -4px 24px #0006;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-banner-icon{font-size:2rem;flex-shrink:0}.install-banner-content{flex:1;min-width:0}.install-banner-title{font-weight:600;font-size:.95rem;color:var(--text)}.install-banner-desc{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.install-banner-close{position:absolute;top:.5rem;right:.5rem;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;line-height:1}.install-banner-btn{background:var(--blue);color:var(--bg-base);border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;flex-shrink:0}.session-connect-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--blue);color:var(--bg-base);border:none;border-radius:6px;font-size:.85rem;font-weight:600;text-decoration:none;cursor:pointer;white-space:nowrap}.session-connect-btn:hover{opacity:.9;text-decoration:none}.session-link{color:var(--blue);font-size:.85rem;text-decoration:none}.session-link:hover{text-decoration:underline}.session-clients{color:var(--text-muted);font-size:.75rem}.connection-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#1e1e2eeb;display:flex;align-items:center;justify-content:center;z-index:10;animation:connFadeIn .2s ease}@keyframes connFadeIn{0%{opacity:0}to{opacity:1}}.connection-overlay-content{text-align:center;max-width:320px;width:100%;padding:0 1rem}.connection-spinner{margin-bottom:1.25rem;animation:connSpin 1.5s linear infinite}.connection-spinner svg{display:block;margin:0 auto}@keyframes connSpin{to{transform:rotate(360deg)}}.connection-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600}.connection-detail{color:var(--text-sub);font-size:.8rem;margin:0 0 1.25rem}.connection-progress-track{background:var(--bg-surface0);border-radius:999px;height:3px;width:100%;margin-bottom:.75rem;overflow:hidden}.connection-progress-bar{height:100%;border-radius:999px;transition:width .5s ease}.connection-steps{text-align:left;font-size:.72rem;line-height:1.9}.connection-step{color:var(--text-muted)}.connection-step.complete{color:var(--green)}.connection-step.current{color:var(--blue);font-weight:600}.connection-step.failed{color:var(--red);font-weight:600}.connection-attempt{color:var(--text-muted);font-size:.65rem;margin-top:.75rem}.status-text{font-size:.7rem;color:var(--text-muted)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.view-tabs{display:flex;gap:0;background:var(--bg-crust, #11111b);border-bottom:1px solid var(--bg-surface0, #313244);flex-shrink:0}.view-tab{flex:1;padding:8px 0;border:none;background:transparent;color:var(--text-muted, #6c7086);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;font-family:inherit}.view-tab.active{color:var(--text-primary, #cdd6f4);border-bottom-color:var(--blue, #89b4fa)}
