*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e6edf3;height:var(--app-vh,100dvh);background:#0d1117;flex-direction:column;font-family:system-ui,sans-serif;display:flex}.hidden{display:none!important}#auth-view{background:#0d1117;flex:1;justify-content:center;align-items:center;display:none}.auth-card{background:#161b22;border:1px solid #30363d;border-radius:12px;width:340px;max-width:90vw;padding:2rem}.auth-card h2{text-align:center;color:#58a6ff;margin-bottom:1.5rem;font-size:1.3rem}.auth-card input{color:#e6edf3;background:#0d1117;border:1px solid #30363d;border-radius:6px;outline:none;width:100%;margin-bottom:.8rem;padding:.6rem .8rem;font-size:.9rem;display:block}.auth-card input:focus{border-color:#58a6ff}.auth-card button[type=submit]{color:#fff;cursor:pointer;background:#238636;border:none;border-radius:6px;width:100%;margin-top:.4rem;padding:.6rem;font-size:.9rem;font-weight:600}.auth-card button:hover{background:#2ea043}#auth-error{color:#f85149;text-align:center;min-height:1.2rem;margin-bottom:.5rem;font-size:.8rem}#auth-toggle{text-align:center;color:#8b949e;margin-top:1rem;font-size:.8rem}#auth-toggle a{color:#58a6ff;text-decoration:none}#app-view{flex-direction:column;flex:1;display:none;overflow:hidden}header{background:#161b22;border-bottom:1px solid #30363d;flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}header h1{color:#58a6ff;font-size:1rem;font-weight:600}#sidebar-toggle{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:6px;justify-content:center;align-items:center;padding:.3rem .55rem;font-size:1rem;line-height:1;display:inline-flex}#sidebar-toggle:hover{color:#58a6ff;border-color:#58a6ff}#sidebar-toggle svg{display:block}.header-right{align-items:center;gap:.75rem;margin-left:auto;display:flex}#user-display{color:#3fb950;font-size:.8rem}#logout-btn{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:6px;padding:.25rem .6rem;font-size:.75rem}#logout-btn:hover{color:#f85149;border-color:#f85149}#invites-btn{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:6px;padding:.25rem .6rem;font-size:.75rem}#invites-btn:hover{color:#58a6ff;border-color:#58a6ff}.modal{z-index:100;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal.open{display:flex}.modal-backdrop{background:#0009;position:absolute;inset:0}.modal-card{background:#161b22;border:1px solid #30363d;border-radius:12px;flex-direction:column;width:480px;max-width:92vw;max-height:80vh;padding:1.25rem 1.25rem 1rem;display:flex;position:relative;box-shadow:0 12px 40px #00000080}.modal-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.modal-header h2{color:#e6edf3;font-size:1rem;font-weight:600}.modal-close{color:#8b949e;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:0 .4rem;font-size:1.4rem;line-height:1}.modal-close:hover{color:#e6edf3;background:#ffffff14}.modal-hint{color:#8b949e;margin-bottom:.85rem;font-size:.78rem;line-height:1.45}#invite-create-btn{color:#fff;cursor:pointer;background:#238636;border:none;border-radius:6px;align-self:flex-start;margin-bottom:.85rem;padding:.45rem .75rem;font-size:.82rem}#invite-create-btn:hover{background:#2ea043}#invite-create-btn:disabled{opacity:.6;cursor:progress}.invite-list{border-top:1px solid #21262d;flex-direction:column;flex:1;gap:.4rem;padding-top:.5rem;display:flex;overflow-y:auto}.invite-row{background:#0d1117;border:1px solid #21262d;border-radius:6px;align-items:center;gap:.6rem;padding:.45rem .6rem;font-size:.8rem;display:flex}.invite-row.used{opacity:.55}.invite-code{color:#e6edf3;white-space:nowrap;flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;overflow-x:auto}.invite-status{text-transform:uppercase;letter-spacing:.04em;color:#8b949e;font-size:.7rem}.invite-status.unused{color:#3fb950}.invite-action-btn{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:4px;padding:.2rem .5rem;font-size:.72rem}.invite-action-btn:hover{color:#e6edf3;border-color:#58a6ff}.invite-action-btn.revoke:hover{color:#f85149;border-color:#f85149}.invite-empty{text-align:center;color:#8b949e;padding:1rem 0;font-size:.8rem}main{flex:1;grid-template-columns:0 1fr;transition:grid-template-columns .2s;display:grid;position:relative;overflow:hidden}main.sidebar-open{grid-template-columns:260px 1fr}main:not([data-sidebar-ready]),main:not([data-sidebar-ready]) #sidebar{transition:none!important}#sidebar{background:#161b22;border-right:1px solid #30363d;flex-direction:column;min-width:0;display:flex;overflow:hidden}#sidebar-backdrop{display:none;position:absolute;inset:0}#sidebar-header{border-bottom:1px solid #30363d;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}#sidebar-header h2{text-transform:uppercase;letter-spacing:.05em;color:#8b949e;font-size:.75rem;font-weight:600}#show-terminated-label{color:#8b949e;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.35rem;font-size:.7rem;display:flex}#show-terminated-label input{accent-color:#58a6ff;cursor:pointer}#new-session-form{border-bottom:1px solid #30363d;gap:.5rem;padding:.75rem 1rem;display:flex}#new-session-form input{color:#e6edf3;background:#0d1117;border:1px solid #30363d;border-radius:6px;outline:none;flex:1;padding:.35rem .6rem;font-size:.8rem}#new-session-form input:focus{border-color:#58a6ff}#new-session-form button{color:#fff;cursor:pointer;white-space:nowrap;background:#238636;border:none;border-radius:6px;padding:.35rem .65rem;font-size:.8rem}#new-session-form button:hover{background:#2ea043}#session-list{flex:1;padding:.5rem;overflow-y:auto}.session-item{cursor:pointer;border-radius:6px;align-items:center;gap:.5rem;margin-bottom:2px;padding:.5rem .6rem;transition:background .1s;display:flex}.session-item:hover{background:#21262d}.session-item.active{background:#1f3348}.session-item.terminated .session-name{color:#8b949e;font-style:italic}.session-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.session-dot.running{background:#3fb950}.session-dot.stopped{background:#e3b341}.session-dot.terminated{background:#f85149}.session-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.82rem;overflow:hidden}.session-actions{opacity:0;gap:2px;display:flex}.session-item:hover .session-actions{opacity:1}.session-action-btn,.session-kill{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.75rem}.session-action-btn.start{color:#3fb950}.session-action-btn.stop{color:#e3b341}.session-kill{color:#f85149}.session-action-btn:hover{background:#ffffff1a}.session-kill:hover{background:#f8514926}#terminal-area{flex-direction:column;display:flex;position:relative;overflow:hidden}#terminal-toolbar{color:#8b949e;background:#161b22;border-bottom:1px solid #30363d;flex-shrink:0;align-items:center;gap:.75rem;padding:.5rem 1rem;font-size:.78rem;display:none}#terminal-session-name{color:#e6edf3;font-weight:500}#terminal-status-badge{text-transform:uppercase;border-radius:10px;padding:1px 8px;font-size:.7rem;font-weight:600}#terminal-status-badge.running{color:#3fb950;background:#3fb95033}#terminal-status-badge.stopped{color:#e3b341;background:#e3b34133}#terminal-status-badge.disconnected{color:#8b949e;background:#8b949e33}#font-size-btn{color:#8b949e;cursor:pointer;background:0 0;border:1px solid #30363d;border-radius:6px;margin-left:auto;padding:.2rem .55rem;font-size:.75rem;line-height:1}#font-size-btn:hover{color:#58a6ff;border-color:#58a6ff}#terminal-tabs{scrollbar-width:thin;background:#0d1117;border-bottom:1px solid #30363d;flex-shrink:0;align-items:stretch;gap:4px;padding:4px 8px 0;display:none;overflow-x:auto}.tab-chip{color:#8b949e;cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#161b22;border:1px solid #30363d;border-bottom:none;border-radius:6px 6px 0 0;align-items:center;gap:.4rem;max-width:200px;padding:.3rem .55rem;font-size:.78rem;display:inline-flex}.tab-chip:hover{color:#e6edf3;background:#1c222b}.tab-chip.active{color:#e6edf3;background:#0d1117;border-color:#30363d;position:relative;top:1px}.tab-chip-label{text-overflow:ellipsis;min-width:0;overflow:hidden}.tab-close{color:#8b949e;cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem;line-height:1}.tab-chip:hover .tab-close,.tab-chip.active .tab-close{opacity:1}.tab-close:hover{color:#f85149;background:#f8514933}.tab-close:disabled{cursor:not-allowed;opacity:.2!important}#tab-add{color:#8b949e;cursor:pointer;background:0 0;border:1px dashed #30363d;border-bottom:none;border-radius:6px 6px 0 0;flex-shrink:0;padding:.2rem .55rem;font-size:.9rem}#tab-add:hover{color:#58a6ff;border-color:#58a6ff}#tab-add:disabled{cursor:progress;opacity:.6}#terminal-container{background:#0d1117;flex:1;padding:4px;display:none;position:relative;overflow:hidden}.tab-pane{display:none;position:absolute;inset:4px}.tab-pane.active{display:block}#terminal-container .xterm{height:100%}#terminal-container .xterm,#terminal-container .xterm-viewport,#terminal-container .xterm-screen{touch-action:none}#empty-state{color:#8b949e;flex:1;justify-content:center;align-items:center;font-size:.9rem;display:flex}#toast{opacity:0;pointer-events:none;background:#21262d;border:1px solid #30363d;border-radius:8px;max-width:360px;padding:.6rem 1rem;font-size:.82rem;transition:opacity .2s;position:fixed;bottom:1.5rem;right:1.5rem}#toast.visible{opacity:1}#toast.error{color:#f85149;border-color:#f85149}@media (width<=768px){main,main.sidebar-open{grid-template-columns:1fr}#sidebar{z-index:20;width:min(280px,85vw);transition:transform .2s;position:absolute;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 16px #0006}main.sidebar-open #sidebar{transform:translate(0)}main.sidebar-open #sidebar-backdrop{z-index:15;background:#00000080;display:block}}.xterm{cursor:text;-webkit-user-select:none;user-select:none;position:relative}.xterm.focus,.xterm:focus{outline:none}.xterm .xterm-helpers{z-index:5;position:absolute;top:0}.xterm .xterm-helper-textarea{opacity:0;z-index:-5;white-space:nowrap;resize:none;border:0;width:0;height:0;margin:0;padding:0;position:absolute;top:0;left:-9999em;overflow:hidden}.xterm .composition-view{color:#fff;white-space:nowrap;z-index:1;background:#000;display:none;position:absolute}.xterm .composition-view.active{display:block}.xterm .xterm-viewport{cursor:default;background-color:#000;position:absolute;inset:0;overflow-y:scroll}.xterm .xterm-screen{position:relative}.xterm .xterm-screen canvas{position:absolute;top:0;left:0}.xterm .xterm-scroll-area{visibility:hidden}.xterm-char-measure-element{visibility:hidden;line-height:normal;display:inline-block;position:absolute;top:0;left:-9999em}.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{z-index:10;color:#0000;pointer-events:none;position:absolute;inset:0}.xterm .xterm-accessibility-tree:not(.debug) ::selection{color:#0000}.xterm .xterm-accessibility-tree{-webkit-user-select:text;user-select:text;white-space:pre}.xterm .live-region{width:1px;height:1px;position:absolute;left:-9999px;overflow:hidden}.xterm-dim{opacity:1!important}.xterm-underline-1{text-decoration:underline}.xterm-underline-2{-webkit-text-decoration:underline double;text-decoration:underline double}.xterm-underline-3{-webkit-text-decoration:underline wavy;text-decoration:underline wavy}.xterm-underline-4{-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.xterm-underline-5{-webkit-text-decoration:underline dashed;text-decoration:underline dashed}.xterm-overline{text-decoration:overline}.xterm-overline.xterm-underline-1{text-decoration:underline overline}.xterm-overline.xterm-underline-2{-webkit-text-decoration:overline double underline;text-decoration:overline double underline}.xterm-overline.xterm-underline-3{-webkit-text-decoration:overline wavy underline;text-decoration:overline wavy underline}.xterm-overline.xterm-underline-4{-webkit-text-decoration:overline dotted underline;text-decoration:overline dotted underline}.xterm-overline.xterm-underline-5{-webkit-text-decoration:overline dashed underline;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;pointer-events:none;position:absolute;top:0;right:0}.xterm-decoration-top{z-index:2;position:relative}
