:root,[data-theme=dark]{--bg-primary: #0f1117;--bg-secondary: #1a1d27;--bg-tertiary: #242836;--bg-hover: #2a2e3d;--border: #2e3347;--text-primary: #e4e7ef;--text-secondary: #a3a9bc;--text-muted: #7a8199;--accent: #4f8ff7;--accent-hover: #3a7ae0;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--danger-hover: #ef4444;--overlay-bg: rgba(0, 0, 0, .6);--radius: 8px;--radius-sm: 4px;--sidebar-width: 242px}[data-theme=light]{--bg-primary: #f5f6f8;--bg-secondary: #ffffff;--bg-tertiary: #e9ebf0;--bg-hover: #dfe1e8;--border: #d1d5de;--text-primary: #1a1d27;--text-secondary: #383d4a;--text-muted: #5d6270;--accent: #2563eb;--accent-hover: #1d4ed8;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--danger-hover: #b91c1c;--overlay-bg: rgba(0, 0, 0, .3)}[data-theme=ocean]{--bg-primary: #0a1929;--bg-secondary: #0d2137;--bg-tertiary: #122a45;--bg-hover: #1a3a5c;--border: #1a3a5c;--text-primary: #c5dbe8;--text-secondary: #74a5c0;--text-muted: #4d87a9;--accent: #38bdf8;--accent-hover: #0ea5e9;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--danger-hover: #ef4444;--overlay-bg: rgba(0, 0, 0, .6)}[data-theme=forest]{--bg-primary: #0a1a0f;--bg-secondary: #0f261a;--bg-tertiary: #143022;--bg-hover: #1a3a2a;--border: #1a3a2a;--text-primary: #c5e0c5;--text-secondary: #74a585;--text-muted: #4d875f;--accent: #4ade80;--accent-hover: #22c55e;--success: #34d399;--warning: #fbbf24;--danger: #f87171;--danger-hover: #ef4444;--overlay-bg: rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);font-size:14px;line-height:1.5}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-layout{display:flex;height:100%}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:20px 16px 12px;border-bottom:1px solid var(--border)}.sidebar-header h1{font-size:16px;font-weight:600;color:var(--text-primary)}.sidebar-header .subtitle{font-size:11px;color:var(--text-muted);margin-top:2px}.sidebar-nav{padding:8px;display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto;min-height:0}.sidebar-nav a{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.sidebar-nav a:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none}.sidebar-nav a.active{background:var(--bg-tertiary);color:var(--text-primary)}.sidebar-footer{margin-top:auto;padding:8px 16px;border-top:1px solid var(--border);display:flex;align-items:center;min-height:48px;box-sizing:border-box}.sidebar-user{display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-user-info{min-width:0}.sidebar-user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.top-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.theme-select{appearance:none;-webkit-appearance:none;background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;font-family:inherit;padding:3px 24px 3px 8px;cursor:pointer;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235c6378'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.theme-select:hover{border-color:var(--text-muted)}.theme-select:focus{border-color:var(--accent)}.theme-select option{background:var(--bg-secondary);color:var(--text-primary)}.clock{font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:12px;color:var(--text-muted)}.main-content{flex:1;overflow-y:auto;min-width:0}.page-padding{padding:24px}.login-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:150%}.login-topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;flex-shrink:0}.login-env-badge{font-size:11px;font-weight:700;letter-spacing:.08em;padding:4px 10px;border-radius:4px;border:1px solid}.login-style-switcher{display:flex;gap:4px}.login-style-btn{background:none;border:none;border-bottom:2px solid transparent;padding:4px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.login-style-btn:hover{opacity:.8}.login-style-btn.active{border-bottom-color:currentColor}.login-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;width:100%;padding:0 24px 24px;flex:1;min-height:0;align-items:stretch}.login-center,.login-right{display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto;scrollbar-width:thin}.login-card{border:1px solid;border-radius:10px;padding:32px}.login-card h1{font-size:36px;font-weight:700;margin-bottom:4px}.login-card h2{font-size:24px;font-weight:600;margin-bottom:4px}.login-card p{font-size:20px;margin-bottom:20px}.login-card .form-group{margin-bottom:14px}.login-card .form-group label{display:block;font-size:18px;font-weight:500;margin-bottom:4px}.login-card .form-group input{width:100%;padding:10px 12px;border:1px solid;border-radius:6px;font-size:21px;outline:none;box-sizing:border-box}.login-card .form-group input:focus{box-shadow:0 0 0 2px #38bdf840}.login-btn-primary{width:100%;padding:14px;border:none;border-radius:6px;font-size:21px;font-weight:600;cursor:pointer;transition:opacity .15s}.login-btn-primary:hover:not(:disabled){opacity:.9}.login-btn-primary:disabled{opacity:.5;cursor:not-allowed}.login-btn-secondary{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:transparent;border:1px solid;border-radius:6px;font-size:21px;font-weight:500;cursor:pointer;transition:opacity .15s}.login-btn-secondary:hover:not(:disabled){opacity:.8}.login-btn-secondary:disabled{opacity:.4;cursor:not-allowed}.login-panel{border:1px solid;border-radius:10px;padding:20px;font-size:21px;line-height:1.7}.login-panel h3{font-size:21px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.login-panel ul{list-style:none;padding:0;margin:0}.login-panel li{padding:6px 0;border-bottom:1px solid;font-size:21px}.login-panel li:last-child{border-bottom:none}.login-meta{font-size:16px;margin-top:2px}.login-panel-terms{padding:16px 20px}.login-panel-changelog{overflow-y:auto;scrollbar-width:thin;flex:1;display:flex;flex-direction:column}.login-panel-changelog::-webkit-scrollbar{width:4px}.login-panel-changelog::-webkit-scrollbar-thumb{background:#8080804d;border-radius:2px}.login-changelog-scroll{padding-right:4px;flex:1;overflow-y:auto;scrollbar-width:thin}.login-changelog-scroll::-webkit-scrollbar{width:4px}.login-changelog-scroll::-webkit-scrollbar-thumb{background:#8080804d;border-radius:2px}.login-faq-scroll{flex:1;overflow-y:auto;scrollbar-width:thin}.login-faq-scroll::-webkit-scrollbar{width:4px}.login-faq-scroll::-webkit-scrollbar-thumb{background:#8080804d;border-radius:2px}.login-changelog-group{margin-bottom:16px}.login-changelog-group:last-child{margin-bottom:0}.login-changelog-date{font-size:12px;font-weight:600;font-family:monospace;margin-bottom:2px}.login-changelog-title{font-size:14px;font-weight:600;margin-bottom:6px}.login-changelog-group ul{list-style:none;padding:0;margin:0}.login-changelog-group li{font-size:13px;padding:3px 0 3px 12px;position:relative;border:none}.login-changelog-group li:before{content:"";position:absolute;left:0;top:9px;width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.4}.login-panel-faq{overflow-y:auto;scrollbar-width:thin;flex:1;display:flex;flex-direction:column}.login-panel-faq::-webkit-scrollbar{width:4px}.login-panel-faq::-webkit-scrollbar-thumb{background:#8080804d;border-radius:2px}.login-faq-item{border-bottom:1px solid}.login-faq-item:last-child{border-bottom:none}.login-faq-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 0;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;text-align:left;gap:8px}.login-faq-chevron{font-size:10px;transition:transform .2s;flex-shrink:0}.login-faq-chevron.open{transform:rotate(180deg)}.login-faq-answer{font-size:13px;line-height:1.7;padding:0 0 10px}@media(max-width:1100px){.login-grid{grid-template-columns:1fr 1fr;max-width:750px}.login-panel-changelog{display:none}}@media(max-width:768px){.login-grid{grid-template-columns:1fr;max-width:420px;padding:0 16px 16px}.login-panel-changelog,.login-right{display:none}.login-card{padding:24px}.login-topbar{padding:12px 16px}}.auth-page{display:contents}.auth-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:32px;max-width:400px}.page-header{margin-bottom:24px}.page-header h2{font-size:20px;font-weight:600}.page-header p{color:var(--text-secondary);font-size:13px;margin-top:4px}.card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:16px;overflow:hidden}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.vnc-preview{height:160px;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;cursor:pointer;margin:0 -16px;border-top:1px solid var(--border)}.vnc-preview:hover{color:var(--text-secondary)}.vnc-preview-disabled{cursor:default}.vnc-preview-disabled:hover{border-color:var(--border);color:var(--text-muted)}.vnc-preview canvas{margin:0!important;width:100%!important;height:auto!important}.vnc-canvas-container canvas{margin:0!important}.diagnostics-panel{position:absolute;top:0;right:0;bottom:0;width:380px;background:var(--bg-secondary);border-left:1px solid var(--border);z-index:100;display:flex;flex-direction:column;transform:translate(100%);transition:transform .2s ease}.diagnostics-panel.open{transform:translate(0)}.diagnostics-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.diagnostics-panel-body{flex:1;overflow-y:auto}.diagnostics-section{padding:12px 16px;border-bottom:1px solid var(--border)}.diagnostics-section-title{font-weight:600;font-size:13px;margin-bottom:8px}.stat-bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.active{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.stopped{background:var(--text-muted)}.status-dot.error{background:var(--danger);box-shadow:0 0 6px var(--danger)}.status-dot.provisioning{background:var(--warning);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.type-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:11px}.type-badge.solo,.type-badge.personal{background:#4f8ff726;color:var(--accent)}.type-badge.home,.type-badge.admin{background:#eab30826;color:#ca8a04}.type-badge.team{background:#a855f726;color:#a855f7}.type-badge.standard{background:var(--bg-tertiary);color:var(--text-secondary)}.table-container{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.table-header h3{font-size:14px;font-weight:600}table{width:100%;border-collapse:collapse}th{text-align:left;padding:8px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);font-weight:600}td{padding:10px 16px;border-bottom:1px solid var(--border);font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:4px 8px;font-size:11px}.btn-group{display:flex;gap:4px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.form-group input,.form-group select{width:100%;padding:8px 10px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;outline:none;font-family:inherit}.form-group input:focus,.form-group select:focus{border-color:var(--accent)}.role-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.role-badge.admin{background:#4f8ff726;color:var(--accent)}.role-badge.member{background:var(--bg-tertiary);color:var(--text-secondary)}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-weight:500}.status-badge.active{background:#34d39926;color:var(--success)}.status-badge.stopped{background:var(--bg-tertiary);color:var(--text-secondary)}.status-badge.error{background:#f8717126;color:var(--danger)}.status-badge.provisioning,.status-badge.installing{background:#fbbf2426;color:var(--warning)}.installing-status{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fbbf2414;border:1px solid rgba(251,191,36,.25);border-radius:var(--radius-sm);font-size:13px;color:var(--warning)}.installing-status .status-dot{background:var(--warning);animation:pulse 2s ease-in-out infinite}.modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:24px;min-width:400px;max-width:560px;max-height:80vh;overflow-y:auto}.modal h3{font-size:16px;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.loading{color:var(--text-muted);padding:40px;text-align:center}.error-msg{color:var(--danger);padding:12px 16px;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-sm);font-size:13px}.success-msg{color:var(--success);padding:12px 16px;background:#34d3991a;border:1px solid rgba(52,211,153,.2);border-radius:var(--radius-sm);font-size:13px}.empty-state{color:var(--text-muted);text-align:center;padding:32px 16px;font-size:13px}.mono{font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:12px}.text-muted{color:var(--text-secondary)}.gear-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:color .15s}.gear-btn:hover{color:var(--text-primary)}.sidebar-nav-ws{display:flex!important;justify-content:space-between}.sidebar-add-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;font-weight:600;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1;transition:color .15s,border-color .15s,background .15s}.sidebar-add-btn:hover{color:var(--text-primary);border-color:var(--accent);background:var(--bg-hover)}.sidebar-add-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-sub-items{display:flex;flex-direction:column;padding:2px 0 4px}.sidebar-sub-item{display:flex;align-items:center;gap:8px;padding:3px 8px;font-size:12px;color:var(--text-secondary);text-decoration:none;cursor:pointer;transition:color .15s}.sidebar-sub-item:hover{color:var(--accent)}.sidebar-sub-item-static{cursor:default}.sidebar-sub-item-static:hover{color:var(--text-secondary)}.sidebar-gear-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:var(--radius-sm);flex-shrink:0;display:flex;align-items:center}.sidebar-gear-btn:hover{color:var(--text-primary)}.sidebar-select-row{display:flex;align-items:center;gap:4px;padding:6px 12px 2px}.sidebar-select-row .sidebar-add-btn{flex-shrink:0}.sidebar-view-select{appearance:none;-webkit-appearance:none;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:11px;font-weight:500;font-family:inherit;padding:4px 22px 4px 8px;margin:0;cursor:pointer;outline:none;flex:1;min-width:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%235c6378'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.sidebar-view-select:hover{border-color:var(--text-muted)}.sidebar-view-select:focus{border-color:var(--accent)}.sidebar-view-select option{background:var(--bg-secondary);color:var(--text-primary)}.ws-user-select{appearance:none;-webkit-appearance:none;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-weight:500;font-family:inherit;padding:6px 28px 6px 10px;cursor:pointer;outline:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235c6378'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.ws-user-select:hover{border-color:var(--text-muted)}.ws-user-select:focus{border-color:var(--accent)}.ws-user-select option{background:var(--bg-secondary);color:var(--text-primary)}.color-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;position:relative;transition:border-color .15s}.color-swatch:hover{border-color:var(--text-muted)}.color-swatch.active{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--text-muted)}.invite-url{margin-top:12px;padding:12px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);word-break:break-all;font-family:SF Mono,Fira Code,Fira Mono,Menlo,Consolas,monospace;font-size:12px;color:var(--accent);user-select:all}.chat-layout{display:flex;height:100%;min-height:0}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}.chat-workspace-area{flex:1;overflow-y:auto;padding:16px}.chat-messages-area{flex:1;overflow-y:auto;min-height:0}.chat-sidebar{width:200px;flex-shrink:0;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}.chat-sidebar-list{flex:1;overflow-y:auto}.chat-channel{display:flex;flex-direction:column;width:100%;padding:8px 14px;background:transparent;border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text-primary);transition:background .15s}.chat-channel:hover{background:var(--bg-hover)}.chat-channel.active{background:var(--bg-tertiary)}.chat-channel-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-channel-preview{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.chat-status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);flex-shrink:0}.chat-status-dot.connected{background:var(--success);box-shadow:0 0 4px var(--success)}.chat-input-bar{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-secondary);border-top:1px solid var(--border);min-height:48px;box-sizing:border-box;flex-shrink:0}.chat-my-id{font-family:var(--font-mono, monospace);font-size:11px;color:var(--text-muted);flex-shrink:0}.chat-channel-buttons{display:flex;gap:4px;flex-shrink:0}.chat-input-field{flex:1;resize:none;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);font-size:13px;font-family:inherit;padding:6px 10px;outline:none;min-height:32px;max-height:80px}.chat-input-field:focus{border-color:var(--accent)}.chat-input-field:disabled{opacity:.5}.sidebar-nav .chat-input-bar{padding:4px 0;border-top:none;min-height:0;background:transparent}.sidebar-nav .chat-input-field{min-height:28px;font-size:12px}.sidebar-nav .chat-messages{padding:4px 0;gap:4px}.sidebar-nav .chat-message{font-size:12px;padding:4px 8px;max-width:100%}.sidebar-nav .chat-messages-empty{font-size:11px;padding:8px 0;height:auto}.sidebar-nav .chat-my-id{display:none}.chat-messages{display:flex;flex-direction:column;gap:8px;padding:16px}.chat-messages-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:13px}.chat-message{max-width:80%;padding:8px 12px;border-radius:var(--radius);background:var(--bg-tertiary);font-size:13px}.chat-message.mine{align-self:flex-end;background:var(--accent);color:#fff}.chat-message-header{display:flex;align-items:center;gap:8px;margin-bottom:2px}.chat-message-from{font-size:11px;font-weight:600;color:var(--text-secondary)}.chat-message.mine .chat-message-from{color:#ffffffb3}.chat-message-time{font-size:10px;color:var(--text-muted)}.chat-message.mine .chat-message-time{color:#ffffff80}.chat-message-content{white-space:pre-wrap;word-break:break-word}.chat-message-error{color:var(--danger);font-size:12px}.connect-chat-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--bg-secondary);border-left:1px solid var(--border)}
