*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f5f5f5;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.container{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.card{text-align:center;background:#fff;border-radius:8px;width:100%;max-width:400px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}h1{margin-bottom:.25rem;font-size:1.5rem}.subtitle{color:#666;margin-bottom:1.5rem;font-size:.875rem}.field{margin-bottom:1rem}input[type=text]{border:1px solid #ddd;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}input[type=password]{border:1px solid #ddd;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}input[type=text]:focus{border-color:#4a90d9;outline:none}input[type=password]:focus{border-color:#4a90d9;outline:none}button{color:#fff;cursor:pointer;background:#4a90d9;border:none;border-radius:4px;width:100%;margin-top:.5rem;padding:.75rem;font-size:1rem;transition:background .2s}button:hover:not(:disabled){background:#357abd}button:disabled{cursor:not-allowed;background:#a0c4e8}.error{color:#d32f2f;margin-bottom:.5rem;font-size:.875rem}.success{color:#2e7d32;margin-bottom:.5rem;font-size:.875rem}.toggle{color:#666;margin-top:1rem;margin-bottom:0;font-size:.875rem}.toggle a{color:#4a90d9;text-decoration:none}.toggle a:hover{text-decoration:underline}p{margin-bottom:1.5rem;line-height:1.5}.auth-overlay{background:#1a1a2e;justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{text-align:center;background:#fff;border-radius:8px;width:100%;max-width:360px;padding:2.5rem 2rem;box-shadow:0 4px 24px rgba(0,0,0,.3)}.auth-card-checking{color:#cdd6f4;background:#1e1e2e;box-shadow:0 4px 24px rgba(0,0,0,.5)}.auth-card-checking h1{color:#cdd6f4}.auth-card-checking .subtitle{color:#a6adc8}.ssh-page{width:100vw;height:100vh;overflow:hidden}.ssh-layout{width:100%;height:100vh;display:flex}.ssh-sidebar{background:#1e1e2e;border-right:1px solid #333;flex-direction:column;width:260px;min-width:260px;height:100vh;display:flex}.sidebar-header{border-bottom:1px solid #333;justify-content:space-between;align-items:center;padding:1rem;display:flex}.sidebar-header h2{color:#cdd6f4;font-size:1rem;font-weight:600}.logout-btn{color:#a6adc8;cursor:pointer;background:0 0;border:1px solid #555;border-radius:4px;margin-top:0;padding:.25rem .75rem;font-size:.85rem;transition:all .15s}.logout-btn:hover{color:#fff;background:#d32f2f;border-color:#d32f2f}.sidebar-list{flex:1;padding:.5rem;overflow-y:auto}.sidebar-loading,.sidebar-empty{color:#6c7086;text-align:center;padding:1rem;font-size:.875rem}.connection-item{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;margin-bottom:.25rem;padding:.75rem 1rem;transition:background .15s}.connection-item:hover{background:#313244}.connection-item.active{background:#45475a;border-left:3px solid #89b4fa;padding-left:calc(1rem - 3px)}.conn-name{color:#cdd6f4;margin-bottom:.2rem;font-size:.9rem;font-weight:500}.conn-host{color:#6c7086;font-family:monospace;font-size:.75rem}.ssh-terminal-area{background:#000;flex-direction:column;flex:1;display:flex}.terminal-placeholder{color:#6c7086;background:#11111b;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.placeholder-icon{color:#45475a;margin-bottom:1rem;font-size:3rem}.terminal-placeholder p{color:#585b70;font-size:.9rem}#terminal-bar{color:#ccc;background:#1e1e1e;flex-shrink:0;justify-content:space-between;align-items:center;padding:.5rem 1rem;font-family:monospace;font-size:.875rem;display:flex}.terminal-bar-right{align-items:center;gap:.75rem;display:flex}.connecting-indicator{color:#f9e2af;font-size:.8rem}#disconnect-btn{background:#d32f2f;border-radius:4px;width:auto;margin:0;padding:.35rem .75rem;font-size:.8rem}#disconnect-btn:hover{background:#b71c1c}#terminal-container{background:#000;flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden}.tab-bar-container{background:#1a1a1a;border-bottom:1px solid #333;flex-shrink:0;min-height:36px;display:flex;overflow-x:auto}.tab-item{color:#888;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:#1e1e1e;border-right:1px solid #333;align-items:center;gap:.5rem;padding:.4rem .75rem;font-size:.8rem;transition:background .15s;display:flex}.tab-item:hover{color:#ccc;background:#2a2a2a}.tab-item.active{color:#e0e0e0;background:#000;border-bottom:2px solid #4a90d9}.tab-label{text-overflow:ellipsis;max-width:160px;overflow:hidden}.tab-close{color:#666;border-radius:2px;padding:0 .15rem;font-size:.75rem;line-height:1}.tab-close:hover{color:#fff;background:#d32f2f}#terminal-container .xterm-viewport{padding:0}