.welcome{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:16px}.welcome__container{width:100%;max-width:448px}.welcome__branding{text-align:center;margin-bottom:32px}.welcome__logo{width:80px;height:auto;margin-bottom:12px;display:block;margin-left:auto;margin-right:auto}.landing-logo{width:100px;height:auto;margin-bottom:16px;display:block;margin-left:auto;margin-right:auto;filter:drop-shadow(0 0 20px rgba(76,110,245,.3))}.welcome__title{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.welcome__subtitle{font-size:14px;color:var(--text-secondary)}.welcome__card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.welcome__card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.welcome__server-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.welcome__server-url{color:var(--text-muted);font-size:13px;margin-bottom:16px}.welcome__tabs{display:flex;gap:8px;margin-bottom:16px}.welcome__tab{flex:1;padding:8px 0;border-radius:var(--radius-md);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all .15s ease;background:var(--bg-tertiary);color:var(--text-secondary)}.welcome__tab--active{background:var(--bg-active);color:var(--text-primary)}.welcome__input-spacer{margin-bottom:12px}.welcome__back-btn{width:100%;text-align:center;padding:8px 0;margin-top:8px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:13px;transition:color .15s ease}.welcome__back-btn:hover{color:var(--text-secondary)}.welcome__saved-header{font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px;margin-top:24px}.welcome__saved-server{width:100%;text-align:left;padding:8px 12px;border-radius:var(--radius-md);font-size:13px;border:none;background:none;cursor:pointer;color:var(--text-secondary);transition:background .15s ease}.welcome__saved-server:hover{background:var(--bg-hover)}.welcome__saved-server-url{color:var(--text-muted);margin-left:8px}.welcome__error{margin-top:16px;color:var(--red);font-size:13px;text-align:center}.welcome--dashboard{flex-direction:column;gap:24px}.welcome__dashboard-grid{width:100%;max-width:56rem;display:grid;grid-template-columns:1fr 1fr;gap:16px}.welcome__dashboard-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 16px #0000004d}.welcome__dashboard-panel-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.welcome__dashboard-panel-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.welcome__dashboard-panel-count{margin-left:auto;font-size:12px;color:var(--text-muted)}.welcome__dashboard-panel-body{padding:12px}.welcome__server-item{width:100%;text-align:left;padding:8px 12px;border-radius:var(--radius-md);border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:12px;color:var(--text-secondary);transition:background .15s ease}.welcome__server-item:hover{background:var(--bg-hover)}.welcome__server-icon{width:32px;height:32px;border-radius:var(--radius-md);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-secondary);flex-shrink:0;overflow:hidden;position:relative}.welcome__server-icon-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.welcome__server-info{flex:1;min-width:0}.welcome__server-name{font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:0}.welcome__server-url{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:0}.welcome__server-connect-label{font-size:11px;color:var(--text-muted);flex-shrink:0}.welcome__dashboard-empty{text-align:center;padding:24px 0}.welcome__dashboard-empty-text{font-size:13px;color:var(--text-muted)}.welcome__dashboard-empty-sub{font-size:11px;color:var(--text-muted);margin-top:4px}.welcome__dm-group-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:4px 8px;margin-bottom:0}.welcome__dm-item{display:flex;align-items:center;gap:8px;padding:4px 8px}.welcome__dm-avatar{width:24px;height:24px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-secondary);flex-shrink:0}.welcome__dm-name{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.welcome__dm-username{font-size:11px;color:var(--text-muted)}.welcome__status-row{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;font-size:13px}.welcome__status-label{color:var(--text-muted)}.welcome__status-value{color:var(--text-primary)}.welcome__status-value--good{color:var(--green)}.welcome__status-value--warn{color:var(--yellow)}.welcome__status-value--danger{color:var(--red)}.welcome__tech-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.welcome__tech-tag{font-size:10px;padding:2px 6px;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-muted)}.welcome__dashboard-cta{padding:12px 24px;background:var(--brand);color:var(--text-primary);font-size:13px;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.welcome__dashboard-cta:hover{background:var(--brand-hover)}.welcome__dev-toggle{margin-top:8px;padding:4px 12px;background:var(--bg-tertiary);color:var(--text-muted);font-size:11px;border:1px dashed var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.welcome__dev-toggle:hover{color:var(--text-secondary);border-color:var(--text-muted)}.welcome--landing{flex-direction:column;align-items:center;justify-content:flex-start;padding:48px 32px;overflow:auto;gap:32px}.landing-hero{text-align:center}.landing-title{font-size:clamp(40px,6vw,64px);font-weight:700;color:var(--text-primary);letter-spacing:-.03em;line-height:1}.landing-tagline{font-size:15px;color:var(--text-muted);margin-top:8px}.landing-official{width:100%;max-width:28rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 16px #0000004d}.landing-official__header{padding:12px 20px;border-bottom:1px solid var(--border-color)}.landing-official__label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.landing-official__body{padding:20px;display:flex;flex-direction:column;align-items:center;gap:8px}.landing-official__desc{font-size:15px;color:var(--text-muted);margin-bottom:8px}.landing-links{display:flex;gap:8px}.landing-link{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:500;text-decoration:none;cursor:pointer;transition:all .15s ease;border:1px solid var(--border-color);color:var(--text-secondary);background:transparent}.landing-link:hover{border-color:var(--text-muted);color:var(--text-primary)}.landing-dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:52rem}.landing-dashboard-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 4px 16px #0000004d}.landing-dashboard-panel__header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.landing-dashboard-panel__label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.landing-dashboard-panel__count{margin-left:auto;font-size:12px;color:var(--text-muted)}.landing-dashboard-panel__body{padding:12px 16px 16px}.landing-dev-toggle{position:fixed;bottom:16px;right:16px;z-index:100}@media (max-width: 768px){.welcome--landing{padding:32px 16px;gap:24px}.landing-dashboard-grid{grid-template-columns:1fr}.landing-links{flex-wrap:wrap;justify-content:center}}.export-modal{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:380px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;transition:opacity .2s,transform .2s}.export-modal--closing{opacity:0;transform:scale(.95)}.export-modal__header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border-color)}.export-modal__title{font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.export-modal__close-btn{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;font-family:var(--font-mono);transition:color .15s ease}.export-modal__close-btn:hover{color:var(--text-primary)}.export-modal__tabs{display:flex;gap:4px;padding:8px 20px;border-bottom:1px solid var(--border-color)}.export-modal__tab{flex:1;padding:6px 0;font-size:10px;font-weight:600;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);background:transparent;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;transition:background .15s,color .15s}.export-modal__tab:hover,.export-modal__tab--active{background:var(--bg-hover);color:var(--text-primary)}.export-modal__body{padding:16px 20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.export-modal__qr{margin:0 auto;border-radius:var(--radius-sm);border:1px solid var(--border-color);image-rendering:pixelated}.export-modal__empty-text{color:var(--text-muted);font-size:11px;text-align:center;font-family:var(--font-mono)}.export-modal__copy-btn,.export-modal__import-btn{width:100%;padding:4px 16px;font-size:11px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);background:var(--bg-tertiary);color:var(--text-muted);transition:background .15s,color .15s,border-color .15s}.export-modal__copy-btn:hover,.export-modal__import-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-color)}.export-modal__import-btn:disabled{opacity:.4;cursor:default}.export-modal__label{font-size:10px;font-weight:600;color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;margin-bottom:0}.export-modal__textarea{width:100%;height:120px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px;font-size:11px;font-family:var(--font-mono);resize:vertical}.export-modal__textarea:focus{outline:none;border-color:var(--brand)}.export-modal__status{font-size:11px;text-align:center;font-family:var(--font-mono);padding:6px 10px;border-radius:var(--radius-sm)}.export-modal__status--ok{color:#22c55e;background:#22c55e11}.export-modal__status--err{color:#ef4444;background:#ef444411}.export-modal__footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.export-modal__done-btn{padding:4px 16px;font-size:11px;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);background:var(--brand);color:var(--text-primary);transition:background .15s ease}.export-modal__done-btn:hover{background:var(--brand-hover)}.server-panel{width:68px;background:var(--bg-secondary);display:flex;flex-direction:column;align-items:center;border:1px solid var(--border-color);border-radius:var(--radius-xl);flex-shrink:0;align-self:flex-start;max-height:100%;margin:8px;padding:10px 0;gap:6px;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.server-panel__list{display:flex;flex-direction:column;align-items:center;gap:6px;overflow-y:auto;flex:1 1 auto;min-height:0;padding:0 2px}.server-panel__icon{width:48px;height:48px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-tertiary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-secondary);position:relative;transition:border-radius .15s,background .15s,color .15s,border-color .15s;flex-shrink:0}.server-panel__icon:hover{border-radius:var(--radius-sm);color:var(--text-primary);background:var(--bg-hover);border-color:var(--accent-color)}.server-panel__icon--active{border-radius:var(--radius-sm);border-color:var(--accent-color);background:var(--accent-color);color:#fff}.server-panel__icon--home{font-size:18px}.server-panel__icon--action{border-style:dashed;font-size:20px;color:var(--text-muted)}.server-panel__icon--action:hover{color:#22c55e;border-color:#22c55e}.server-panel__icon-img{width:100%;height:100%;border-radius:calc(var(--radius-md) - 1px);-o-object-fit:cover;object-fit:cover}.server-panel__icon:hover .server-panel__icon-img,.server-panel__icon--active .server-panel__icon-img{border-radius:calc(var(--radius-sm) - 1px)}.server-panel__divider{width:32px;height:2px;background:var(--border-color);border-radius:1px;margin:4px 0}.server-panel__dot{position:absolute;top:3px;right:3px;width:7px;height:7px;border-radius:50%;border:2px solid var(--bg-secondary);background:var(--text-muted)}.server-panel__dot--online{background:#22c55e}.server-panel__badge{position:absolute;bottom:-2px;right:-4px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:8px;min-width:16px;text-align:center;line-height:1.2;border:2px solid var(--bg-secondary)}.server-panel__remove-badge{position:absolute;top:0;right:0;width:18px;height:18px;border-radius:50%;background:#ef4444;color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--bg-secondary);transform:translate(5px,-5px);z-index:1}.screenshare-overlay{position:fixed;bottom:100px;right:16px;z-index:100;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 8px 32px #0006;min-width:320px;max-width:640px;width:400px;resize:both;display:flex;flex-direction:column}.screenshare-overlay__header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none}.screenshare-overlay__title{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.screenshare-overlay__title-icon{width:12px;height:12px;color:var(--green)}.screenshare-overlay__actions{display:flex;gap:4px}.screenshare-overlay__btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm);display:flex;align-items:center}.screenshare-overlay__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.screenshare-overlay__btn--close:hover{color:var(--red)}.screenshare-overlay__body{position:relative;background:#000;aspect-ratio:16 / 10;display:flex;align-items:center;justify-content:center}.screenshare-overlay__video{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.screenshare-overlay__empty{color:var(--text-muted);font-size:12px;text-align:center;padding:24px}.monitor-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--modal-backdrop);display:flex;align-items:center;justify-content:center}.monitor-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;width:360px;max-height:80vh;overflow-y:auto}.monitor-picker__title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.monitor-picker__list{display:flex;flex-direction:column;gap:8px}.monitor-picker__item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:background .15s;color:var(--text-primary);font-size:13px}.monitor-picker__item:hover{background:var(--bg-hover);border-color:var(--brand)}.monitor-picker__item-icon{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.monitor-picker__item-info{display:flex;flex-direction:column;gap:2px}.monitor-picker__item-name{font-size:13px;color:var(--text-primary)}.monitor-picker__item-res{font-size:11px;color:var(--text-muted)}.monitor-picker__cancel{margin-top:16px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:13px;width:100%}.monitor-picker__cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.voice-header__btn--screenshare{color:var(--green)}.voice-header__btn--screenshare:hover{background:#22c55e26}.voice-header__btn--screenshare-active{color:var(--red);animation:screenshare-pulse 1.5s ease-in-out infinite}@keyframes screenshare-pulse{0%,to{opacity:1}50%{opacity:.5}}.voice-header__btn--screenshare:disabled{opacity:.4;cursor:not-allowed}@keyframes voiceExpandIn{0%{opacity:0;max-height:0;transform:scaleY(.95)}to{opacity:1;max-height:400px;transform:scaleY(1)}}@keyframes voiceExpandOut{0%{opacity:1;max-height:400px;transform:scaleY(1)}to{opacity:0;max-height:0;transform:scaleY(.95)}}.voice-overlay{background:var(--bg-tertiary);border-top:1px solid var(--border-color);overflow:hidden;animation:voiceExpandIn .3s ease-out;transform-origin:top}.voice-overlay--closing{animation:voiceExpandOut .25s ease-in forwards;pointer-events:none}.voice-error{background:var(--red-dim);border-bottom:1px solid var(--red-dim-border);padding:8px 12px}.voice-error__label{font-size:11px;font-weight:500;color:var(--red);margin-bottom:4px}.voice-error__message{font-size:11px;color:var(--red);opacity:.8;margin-bottom:8px}.voice-error__actions{display:flex;gap:6px}.voice-error__btn{padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;font-family:var(--font-mono);border:none;cursor:pointer;transition:background .15s ease}.voice-error__btn--retry{background:var(--red-dim);color:var(--red)}.voice-error__btn--retry:hover{background:#ff4d4d4d}.voice-error__btn--leave{background:var(--bg-tertiary);color:var(--text-secondary)}.voice-error__btn--leave:hover{background:var(--bg-hover)}.voice-error__debug{margin-bottom:8px}.voice-error__debug-summary{font-size:10px;color:var(--text-tertiary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.voice-error__debug-summary:hover{color:var(--text-secondary)}.voice-error__debug-log{margin-top:4px;padding:6px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);line-height:1.5;max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.voice-header{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--green-dim);border-bottom:1px solid var(--green-dim-border);flex-wrap:wrap}.voice-header__icon{color:var(--green);flex-shrink:0}.voice-header__name{color:var(--green);font-size:12px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-header__status{color:var(--green);font-size:10px;font-family:var(--font-mono)}.voice-header__status--error{color:var(--red)}.voice-header__btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:none;cursor:pointer;transition:all .15s ease;flex-shrink:0}.voice-header__btn--mute{color:var(--text-secondary)}.voice-header__btn--mute:hover{border-color:var(--brand);color:var(--brand)}.voice-header__btn--unmute{border-color:var(--red-dim-border);color:var(--red)}.voice-header__btn--unmute:hover{background:var(--red-dim)}.voice-header__btn--leave{border-color:var(--red-dim-border);color:var(--red)}.voice-header__btn--leave:hover{background:var(--red-dim)}.voice-body{padding:6px 12px;display:flex;flex-direction:column;gap:3px;max-height:140px;overflow-y:auto}.voice-peer{display:flex;align-items:center;gap:8px}.voice-peer__avatar-wrap{position:relative;flex-shrink:0}.voice-peer__speaking-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-sm);background:#40c05766;animation:ping 1s ease-out infinite;pointer-events:none}.voice-peer__avatar{width:20px;height:20px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.voice-peer__avatar--muted{background:var(--red-dim);color:var(--red)}.voice-peer__avatar--speaking{background:var(--green-dim);color:var(--green)}.voice-peer__avatar--idle{background:var(--brand-dim);color:var(--brand)}.voice-peer__avatar--peer-idle{background:var(--bg-tertiary);color:var(--text-secondary)}.voice-peer__avatar--peer-muted{background:var(--bg-tertiary);color:var(--text-muted)}.voice-peer__avatar--peer-speaking{background:var(--green-dim);color:var(--green)}.voice-peer__name{font-size:11px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .15s ease}.voice-peer__name--default{color:var(--text-secondary)}.voice-peer__name--speaking{color:var(--green);font-weight:600}.voice-peer__name--peer{color:var(--text-secondary)}.voice-peer__name--peer-speaking{color:var(--green);font-weight:600}.voice-peer__mute-label{font-size:12px;color:var(--text-muted)}.voice-peer__peer-muted{font-size:10px;color:var(--red)}.voice-connection-bars{display:flex;align-items:flex-end;gap:2px;flex-shrink:0}.voice-connection-bar{width:3px;border-radius:2px;background:var(--bg-tertiary)}.voice-connection-bar--good{background:var(--green)}.voice-connection-bar--fair{background:var(--yellow)}.voice-connection-bar--poor{background:var(--red)}.voice-connection-bar--h-sm{height:4px}.voice-connection-bar--h-md{height:6px}.voice-connection-bar--h-lg{height:8px}.voice-bitrate{display:flex;align-items:center;gap:6px;padding:6px 12px;border-top:1px solid var(--border-color)}.voice-bitrate__label{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);flex-shrink:0}.voice-bitrate__value{font-size:10px;font-family:var(--font-mono);color:var(--text-secondary)}@keyframes ping{75%,to{transform:scale(1.3);opacity:0}}@keyframes sidebarSlideInLeft{0%{opacity:0;transform:translate(-32px)}to{opacity:1;transform:translate(0)}}.sidebar{width:240px;background:var(--modal-bg);display:flex;flex-direction:column;border:1px solid var(--border-color);border-radius:var(--radius-xl);flex-shrink:0;margin:8px;overflow:hidden;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;animation:sidebarSlideInLeft .25s ease-out}.sidebar__header{padding:12px 16px;border-bottom:1px solid var(--border-color)}.sidebar__header-name{font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__header-username{font-size:11px;color:var(--text-muted)}.sidebar__content{flex:1;overflow-y:auto;padding:8px}.sidebar__section{margin-bottom:16px}.sidebar__section-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:0 8px;margin-bottom:4px}.sidebar__channel{width:100%;text-align:left;padding:6px 8px;border-radius:var(--radius-sm);font-size:13px;border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:8px;color:var(--text-secondary);transition:background .15s ease,color .15s ease}.sidebar__channel:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__channel--active{background:var(--bg-active);color:var(--text-primary)}.sidebar__channel--voice-active{background:var(--green-dim);color:var(--green)}.sidebar__channel-icon{color:var(--text-muted);display:flex;align-items:center;flex-shrink:0}.sidebar__channel-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__unread-badge{margin-left:auto;background:var(--red);color:var(--text-primary);font-size:11px;border-radius:var(--radius-full);padding:2px 6px;min-width:18px;text-align:center;line-height:1}.sidebar__voice-indicator{margin-left:auto;width:8px;height:8px;border-radius:var(--radius-full);background:var(--green);animation:pulse 1.5s ease-in-out infinite}.sidebar__dm-avatar{width:24px;height:24px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-secondary);flex-shrink:0}.sidebar__footer{padding:8px;border-top:1px solid var(--border-color)}.sidebar__logout{width:100%;text-align:left;padding:6px 8px;border-radius:var(--radius-sm);font-size:13px;border:none;background:none;cursor:pointer;color:var(--text-secondary);transition:background .15s ease,color .15s ease}.sidebar__logout:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__user-row{display:flex;align-items:center;gap:8px}.sidebar__user-avatar{width:24px;height:24px;border-radius:var(--radius-full);background:var(--brand);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-primary);flex-shrink:0;overflow:hidden;position:relative}.sidebar__user-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sidebar__user-info{flex:1;min-width:0}.sidebar__user-displayname{font-size:12px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__user-subtitle{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__create-form{padding-top:12px;margin-top:12px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:6px}.sidebar__create-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sidebar__create-input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 8px;color:var(--text-primary);font-size:12px;outline:none;transition:border-color .15s ease}.sidebar__create-input::-moz-placeholder{color:var(--text-muted)}.sidebar__create-input::placeholder{color:var(--text-muted)}.sidebar__create-input:focus{border-color:var(--brand)}.sidebar__create-type-row{display:flex;gap:6px}.sidebar__create-type-toggle{flex:1;display:flex;background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);overflow:hidden}.sidebar__create-type-btn{flex:1;padding:4px 0;font-size:10px;border:none;background:none;cursor:pointer;color:var(--text-secondary);transition:all .15s ease}.sidebar__create-type-btn--active{background:var(--brand);color:var(--text-primary)}.sidebar__create-submit{padding:4px 12px;font-size:11px;border:none;border-radius:var(--radius-sm);background:var(--brand);color:var(--text-primary);cursor:pointer;transition:background .15s ease}.sidebar__create-submit:hover{background:var(--brand-hover)}.sidebar__create-submit:disabled{opacity:.5;cursor:not-allowed}.sidebar__dm-avatar{overflow:hidden;position:relative}.sidebar__dm-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.chat-area{flex:1;display:flex;flex-direction:column;min-width:0}.chat-area__empty{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.chat-area__empty-content{text-align:center;color:var(--text-muted)}.chat-area__empty-title{font-size:20px;margin-bottom:8px}.chat-area__empty-subtitle{font-size:13px}.chat-area__header{height:48px;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.chat-area__header-prefix{color:var(--text-muted);margin-right:8px}.chat-area__header-title{font-size:13px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-area__messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}.chat-area__loading{color:var(--text-muted);font-size:13px;text-align:center}.chat-area__message-row{display:flex;gap:12px}.chat-area__message-row--own{justify-content:flex-end}.chat-area__message-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-secondary);flex-shrink:0}.chat-area__message-bubble{max-width:448px;padding:8px 12px;border-radius:var(--radius-md)}.chat-area__message-bubble--other{background:var(--bg-tertiary);border-top-left-radius:4px}.chat-area__message-bubble--own{background:var(--brand);border-top-right-radius:4px}.chat-area__message-author{font-size:12px;font-weight:500;color:var(--brand);margin-bottom:2px}.chat-area__message-text{font-size:13px;color:var(--text-primary);word-break:break-word}.chat-area__message-meta{display:flex;align-items:center;gap:4px;margin-top:4px}.chat-area__message-time{font-size:10px;color:var(--text-secondary)}.chat-area__message-edited{font-size:10px;color:var(--text-muted)}.chat-area__input-bar{padding:12px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.chat-area__input-row{display:flex;gap:8px}.chat-area__input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 12px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s ease}.chat-area__input::-moz-placeholder{color:var(--text-muted)}.chat-area__input::placeholder{color:var(--text-muted)}.chat-area__input:focus{border-color:var(--brand)}.chat-area__send-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:var(--brand);color:var(--text-primary);font-weight:500;font-size:14px;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.chat-area__send-btn:hover{background:var(--brand-hover)}.chat-area__send-btn:disabled{opacity:.5;cursor:not-allowed}.chat-area__mention-suggestions{margin:0 16px 8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;max-height:144px;overflow-y:auto}.chat-area__mention-suggestion{width:100%;text-align:left;padding:6px 12px;font-size:12px;color:var(--text-primary);border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s ease}.chat-area__mention-suggestion:hover,.chat-area__mention-suggestion--selected{background:var(--brand-dim)}.chat-area__mention-prefix{color:var(--brand);font-size:11px}.chat-area__mention-group-tag{margin-left:auto;color:var(--text-muted);font-size:10px}.chat-area__typing{padding:4px 16px;color:var(--text-muted);font-size:12px;font-style:italic;animation:pulse 1.5s ease-in-out infinite}.chat-area__upload-preview{margin:8px 16px 0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 12px;display:flex;align-items:center;gap:8px}.chat-area__upload-info{flex:1;min-width:0}.chat-area__upload-name{font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-area__upload-size{font-size:10px;color:var(--text-muted)}.chat-area__upload-cancel{color:var(--text-secondary);font-size:12px;padding:4px 8px;border:none;background:none;cursor:pointer}.chat-area__upload-cancel:hover{color:var(--red)}.chat-area__attach-btn{color:var(--text-muted);font-size:14px;padding:4px 8px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);transition:color .15s ease,background .15s ease}.chat-area__attach-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.chat-area__attach-btn:disabled{opacity:.5;cursor:not-allowed}.chat-area__message-delete{color:var(--red);font-size:11px;padding:2px 8px;border-radius:var(--radius-sm);border:none;background:none;cursor:pointer;opacity:0;transition:opacity .15s ease,background .15s ease}.chat-area__message-row:hover .chat-area__message-delete{opacity:1}.chat-area__message-delete:hover{background:var(--red-dim)}.chat-area__delete-confirm{display:flex;align-items:center;gap:4px}.chat-area__delete-confirm-btn{font-size:11px;padding:2px 6px;border-radius:var(--radius-sm);border:none;cursor:pointer}.chat-area__delete-confirm-btn--yes{background:var(--red-dim);color:var(--red)}.chat-area__delete-confirm-btn--yes:hover{background:#ff4d4d4d}.chat-area__delete-confirm-btn--no{background:var(--bg-tertiary);color:var(--text-muted)}.chat-area__delete-confirm-btn--no:hover{background:var(--bg-hover)}.chat-area__mention--self{background:var(--brand-dim);color:var(--brand);border-radius:var(--radius-sm);padding:0 2px;font-weight:600}.chat-area__mention--group{background:#fab00526;color:var(--yellow);border-radius:var(--radius-sm);padding:0 2px;font-weight:600}.chat-area__mention--user{background:var(--bg-hover);border-radius:var(--radius-sm);padding:0 2px}.chat-area__attachment-link{display:inline-flex;align-items:center;gap:6px;background:var(--bg-hover);border-radius:var(--radius-sm);padding:4px 8px;cursor:pointer;transition:background .15s ease;text-decoration:none;margin-top:4px}.chat-area__attachment-link:hover{background:var(--bg-active)}.chat-area__attachment-filename{font-size:12px;color:var(--brand)}.chat-area__attachment-filename:hover{text-decoration:underline}.chat-area__attachment-image{margin-top:4px;max-width:320px;border-radius:var(--radius-md);cursor:pointer;max-height:192px;-o-object-fit:cover;object-fit:cover}.chat-area__attachment-image--expanded{max-width:100%;max-height:none}.chat-area__attachment-expand-hint{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000004d;opacity:0;transition:opacity .15s ease;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-primary);font-size:12px}.chat-area__attachment-image-wrap:hover .chat-area__attachment-expand-hint{opacity:1}.chat-area__attachment-image-wrap{position:relative;display:inline-block;cursor:pointer}.chat-area__attachment-video{margin-top:4px;max-width:320px;max-height:192px;border-radius:var(--radius-md)}.chat-area__attachment-audio{margin-top:4px;max-width:320px}.chat-area__input-hint{font-size:10px;color:var(--text-muted);padding:4px 16px}.chat-area__input-hint--error{color:var(--red)}.chat-area__message-avatar{overflow:hidden;position:relative}.chat-area__message-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-area__header-topic{margin-left:8px;font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:1px solid var(--border-color);padding-left:8px}.chat-area__encrypted-badge{margin-left:8px;font-size:13px;cursor:default;opacity:.6}.chat-area__encrypted-badge--warn{opacity:.4}@keyframes memberSlideInRight{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}@keyframes memberSlideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(32px)}}.member-list{width:208px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);flex-shrink:0;display:flex;flex-direction:column;margin:8px;overflow:hidden;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;animation:memberSlideInRight .25s ease-out}.member-list--closing{animation:memberSlideOutRight .2s ease-in forwards;pointer-events:none}.member-list__header{padding:12px;border-bottom:1px solid var(--border-color)}.member-list__title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.member-list__search{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 8px;color:var(--text-primary);font-size:11px;outline:none;transition:border-color .15s ease}.member-list__search::-moz-placeholder{color:var(--text-muted)}.member-list__search::placeholder{color:var(--text-muted)}.member-list__search:focus{border-color:var(--brand)}.member-list__body{overflow-y:auto;flex:1;padding:4px 0}.member-list__section-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:8px 12px 4px}.member-list__member{display:flex;align-items:center;gap:8px;padding:6px 12px;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:background .15s ease,color .15s ease;border:none;background:none;width:100%;text-align:left}.member-list__member:hover{background:var(--bg-hover);color:var(--text-primary)}.member-list__member-avatar-wrap{position:relative;flex-shrink:0}.member-list__member-avatar{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-primary);overflow:hidden;position:relative}.member-list__member-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.member-list__online-dot{position:absolute;bottom:0;right:0;width:8px;height:8px;background:var(--green);border-radius:var(--radius-full);border:2px solid var(--bg-secondary)}.member-list__member-info{flex:1;min-width:0}.member-list__member-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:var(--text-secondary)}.member-list__member-role{font-size:9px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-list__member-role--admin{color:var(--yellow)}.member-list__admin-badge{font-size:10px;color:var(--yellow);font-weight:600;flex-shrink:0}.member-list__self-tag{font-size:9px;color:var(--text-muted);flex-shrink:0}.member-list__dm-icon{font-size:10px;color:var(--text-muted);flex-shrink:0;transition:color .15s ease}.member-list__member:hover .member-list__dm-icon{color:var(--brand)}.member-list__empty-text{font-size:12px;color:var(--text-muted);text-align:center;padding:16px 0}.settings-modal{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:440px;max-width:calc(100vw - 32px);max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.settings-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-color)}.settings-modal__header-title{font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.settings-modal__close-btn{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);border:none;background:none;cursor:pointer;transition:color .15s ease}.settings-modal__close-btn:hover{color:var(--text-primary)}.settings-modal__body{padding:16px 20px;display:flex;flex-direction:column;gap:16px}.settings-modal__section-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono);margin-bottom:8px}.settings-modal__select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font-size:11px;font-family:var(--font-mono);outline:none;cursor:pointer;transition:border-color .15s ease}.settings-modal__select:focus{border-color:var(--brand)}.settings-modal__select option{background:var(--bg-secondary);color:var(--text-primary)}.settings-modal__hint{font-size:9px;color:var(--text-muted);font-family:var(--font-mono);margin-top:4px}.settings-modal__permission-warning{font-size:10px;color:var(--red);background:var(--red-dim);border:1px solid var(--red-dim-border);border-radius:var(--radius-sm);padding:8px 12px;font-family:var(--font-mono)}.settings-modal__version-row{display:flex;align-items:center;justify-content:space-between}.settings-modal__version-text{font-size:11px;color:var(--text-primary);font-family:var(--font-mono)}.settings-modal__version-tag{font-size:9px;color:var(--text-muted);font-family:var(--font-mono);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color)}.settings-modal__alert{font-size:11px;color:var(--text-muted);font-family:var(--font-mono);text-align:center;padding:8px 0}.settings-modal__footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.settings-modal__done-btn{padding:4px 16px;background:var(--brand);color:var(--text-primary);font-size:11px;font-family:var(--font-mono);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.settings-modal__done-btn:hover{background:var(--brand-hover)}.settings-modal__section-divider{border:none;border-top:1px solid var(--border-color);margin:0}.settings-modal__radio-group{display:flex;flex-direction:column;gap:6px}.settings-modal__radio-option{display:flex;align-items:center;gap:8px;font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);border:1px solid transparent;transition:color .15s ease,border-color .15s ease,background .15s ease}.settings-modal__radio-option:hover{color:var(--text-primary);background:var(--bg-tertiary)}.settings-modal__radio-option--active{color:var(--text-primary);border-color:var(--brand);background:var(--brand-dim)}.settings-modal__radio-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--text-muted);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s ease}.settings-modal__radio-option--active .settings-modal__radio-dot{border-color:var(--brand)}.settings-modal__radio-dot:after{content:"";width:6px;height:6px;border-radius:50%;background:var(--brand);opacity:0;transform:scale(0);transition:opacity .15s ease,transform .15s ease}.settings-modal__radio-option--active .settings-modal__radio-dot:after{opacity:1;transform:scale(1)}.settings-modal__toggle-row{display:flex;align-items:center;justify-content:space-between}.settings-modal__toggle-label{font-size:11px;font-family:var(--font-mono);color:var(--text-primary)}.settings-modal__toggle{position:relative;width:40px;height:22px;flex-shrink:0}.settings-modal__toggle input{opacity:0;width:0;height:0;position:absolute}.settings-modal__toggle-track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:background .2s ease,border-color .2s ease}.settings-modal__toggle input:checked+.settings-modal__toggle-track{background:var(--brand);border-color:var(--brand)}.settings-modal__toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--text-primary);border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0000004d}.settings-modal__toggle input:checked+.settings-modal__toggle-track .settings-modal__toggle-thumb{transform:translate(18px)}.settings-modal__slider-section{display:flex;flex-direction:column;gap:6px}.settings-modal__slider-row{display:flex;align-items:center;gap:10px}.settings-modal__slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:3px;outline:none;cursor:pointer}.settings-modal__slider::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:linear-gradient(to right,var(--brand) 0%,var(--brand) var(--slider-pct, 50%),var(--bg-tertiary) var(--slider-pct, 50%),var(--bg-tertiary) 100%)}.settings-modal__slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--text-primary);border:2px solid var(--brand);border-radius:50%;margin-top:-4px;cursor:pointer;-webkit-transition:transform .1s ease;transition:transform .1s ease}.settings-modal__slider::-webkit-slider-thumb:active{transform:scale(1.15)}.settings-modal__slider-value{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);min-width:36px;text-align:right;flex-shrink:0}.settings-modal__meter-bar{width:100%;height:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;overflow:hidden;position:relative}.settings-modal__meter-fill{height:100%;border-radius:3px;transition:width 60ms linear,background .3s ease}.settings-modal__meter-fill--low{background:var(--brand)}.settings-modal__meter-fill--mid{background:var(--yellow)}.settings-modal__meter-fill--high{background:var(--red)}.settings-modal__meter-threshold{position:absolute;top:0;bottom:0;width:2px;background:var(--text-muted);opacity:.6;pointer-events:none}.settings-modal__keybind-row{display:flex;align-items:center;justify-content:space-between}.settings-modal__keybind-label{font-size:10px;font-family:var(--font-mono);color:var(--text-muted)}.settings-modal__keybind-btn{padding:4px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:11px;font-family:var(--font-mono);cursor:pointer;min-width:80px;text-align:center;transition:border-color .15s ease,background .15s ease}.settings-modal__keybind-btn:hover{border-color:var(--brand)}.settings-modal__keybind-btn--listening{border-color:var(--brand);background:var(--brand-dim);color:var(--brand);animation:keybind-pulse 1s ease infinite}@keyframes keybind-pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalOverlayFadeOut{0%{opacity:1}to{opacity:0}}@keyframes modalSlideDown{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalSlideUp{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-20px) scale(.98)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:var(--modal-backdrop);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modalOverlayFadeIn .2s ease-out}.modal-overlay--closing{animation:modalOverlayFadeOut .2s ease-in forwards;pointer-events:none}.server-menu{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:500px;max-width:calc(100vw - 32px);max-height:85vh;overflow-y:auto;animation:modalSlideDown .25s ease-out;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.server-menu--closing{animation:modalSlideUp .2s ease-in forwards;pointer-events:none}.server-menu__header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-color)}.server-menu__header-title{font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.server-menu__close-btn{color:var(--text-muted);font-size:11px;font-family:var(--font-mono);border:none;background:none;cursor:pointer;transition:color .15s ease}.server-menu__close-btn:hover{color:var(--text-primary)}.server-menu__body{padding:16px 20px;display:flex;flex-direction:column;gap:16px}.server-menu__section-title{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono);margin-bottom:8px}.server-menu__avatar-row{display:flex;align-items:center;gap:12px}.server-menu__avatar{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-primary);background:var(--brand);flex-shrink:0;overflow:hidden;position:relative;cursor:pointer;border:1px solid var(--border-color);transition:border-color .15s ease}.server-menu__avatar:hover{border-color:var(--brand)}.server-menu__avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.server-menu__avatar-actions{display:flex;flex-direction:column;gap:6px}.server-menu__upload-btn{font-size:11px;padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;font-family:var(--font-mono)}.server-menu__upload-btn:hover{border-color:var(--brand);color:var(--text-primary)}.server-menu__remove-btn{font-size:10px;color:var(--text-muted);background:none;border:none;cursor:pointer;transition:color .15s ease;font-family:var(--font-mono)}.server-menu__remove-btn:hover{color:var(--red)}.server-menu__tab-bar{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:2px}.server-menu__tab{flex:1;padding:6px 0;font-size:10px;font-family:var(--font-mono);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);background:none;transition:all .15s ease}.server-menu__tab:hover{color:var(--text-primary)}.server-menu__tab--active{background:var(--bg-hover);color:var(--text-primary)}.server-menu__field{margin-bottom:8px}.server-menu__label{display:block;font-size:9px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-family:var(--font-mono);margin-bottom:4px}.server-menu__input{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font-size:12px;outline:none;font-family:var(--font-mono);transition:border-color .15s ease}.server-menu__input::-moz-placeholder{color:var(--text-muted)}.server-menu__input::placeholder{color:var(--text-muted)}.server-menu__input:focus{border-color:var(--brand)}.server-menu__select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font-size:12px;outline:none;font-family:var(--font-mono);transition:border-color .15s ease;cursor:pointer}.server-menu__select:focus{border-color:var(--brand)}.server-menu__save-row{display:flex;align-items:center;gap:12px;margin-top:12px}.server-menu__hint{font-size:9px;color:var(--text-muted);font-family:var(--font-mono);margin-top:4px}.server-menu__save-btn{padding:4px 16px;background:var(--brand);color:var(--text-primary);font-size:11px;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-mono);transition:background .15s ease}.server-menu__save-btn:hover{background:var(--brand-hover)}.server-menu__save-btn:disabled{opacity:.5;cursor:not-allowed}.server-menu__save-msg{font-size:10px;font-family:var(--font-mono)}.server-menu__save-msg--ok{color:var(--green)}.server-menu__save-msg--err{color:var(--red)}.server-menu__member{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);margin-bottom:6px}.server-menu__member-avatar{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-primary);background:var(--brand-dim);border:1px solid rgba(76,110,245,.3);flex-shrink:0;overflow:hidden;position:relative}.server-menu__member-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.server-menu__member-info{flex:1;min-width:0}.server-menu__member-name{font-size:11px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.server-menu__member-role{font-size:9px;font-family:var(--font-mono);color:var(--text-muted)}.server-menu__member-role--admin{color:var(--brand)}.server-menu__member-badge{font-size:9px;padding:1px 6px;border-radius:var(--radius-full);border:1px solid;font-family:var(--font-mono)}.server-menu__member-self{font-size:8px;color:var(--brand);margin-left:4px}.server-menu__member-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}.server-menu__member-action-btn{font-size:9px;font-family:var(--font-mono);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-hover);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.server-menu__member-action-btn:hover{border-color:var(--brand);color:var(--brand)}.server-menu__member-action-btn--danger:hover{border-color:var(--red);color:var(--red)}.server-menu__member-msg{font-size:9px;font-family:var(--font-mono);color:var(--green);flex-shrink:0}.server-menu__loading{font-size:11px;color:var(--text-muted);text-align:center;padding:16px 0;font-family:var(--font-mono)}.server-menu__invite-create{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;margin-bottom:16px}.server-menu__invite-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.server-menu__invite-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);margin-bottom:4px}.server-menu__invite-code{font-size:11px;font-weight:700;color:var(--text-primary);font-family:var(--font-mono);letter-spacing:.05em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.server-menu__invite-stats{font-size:9px;color:var(--text-muted);font-family:var(--font-mono);flex-shrink:0;text-align:right}.server-menu__invite-revoke{font-size:9px;font-family:var(--font-mono);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-hover);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.server-menu__invite-revoke:hover{border-color:var(--red);color:var(--red)}.server-menu__role-create{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;margin-bottom:16px}.server-menu__role-create-row{display:flex;gap:8px;margin-bottom:8px}.server-menu__role-create-input{flex:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 8px;color:var(--text-primary);font-size:11px;font-family:var(--font-mono);outline:none}.server-menu__role-create-input:focus{border-color:var(--brand)}.server-menu__color-input{width:36px;height:28px;border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;padding:0;background:none}.server-menu__perm-toggles{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.server-menu__perm-toggle{font-size:9px;font-family:var(--font-mono);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-hover);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.server-menu__perm-toggle--on{background:var(--brand-dim);border-color:var(--brand);color:var(--brand)}.server-menu__role-create-btn{padding:4px 12px;background:var(--brand);color:var(--text-primary);font-size:10px;font-family:var(--font-mono);border:none;border-radius:var(--radius-sm);cursor:pointer;width:100%}.server-menu__role-create-btn:hover{background:var(--brand-hover)}.server-menu__role-create-btn:disabled{opacity:.5;cursor:not-allowed}.server-menu__role-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px;margin-bottom:6px}.server-menu__role-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.server-menu__role-name{font-size:11px;font-weight:600;color:var(--text-primary)}.server-menu__role-actions{margin-left:auto;display:flex;gap:4px}.server-menu__role-action-btn{font-size:9px;font-family:var(--font-mono);padding:2px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-hover);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.server-menu__role-action-btn:hover{border-color:var(--brand);color:var(--brand)}.server-menu__role-action-btn--danger:hover{border-color:var(--red);color:var(--red)}.server-menu__footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.server-menu__done-btn{padding:4px 16px;background:var(--brand);color:var(--text-primary);font-size:11px;font-family:var(--font-mono);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease}.server-menu__done-btn:hover{background:var(--brand-hover)}.server-menu__qr-panel{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--bg-hover);border:1px solid var(--accent-color);border-radius:8px;padding:12px;margin:12px 0}.server-menu__qr-img{border-radius:4px;image-rendering:pixelated}.server-menu__qr-code-row{display:flex;align-items:center;gap:8px}.server-menu__qr-code{font-size:11px;font-family:monospace;font-weight:600;letter-spacing:1px;background:var(--bg-primary);padding:4px 10px;border-radius:4px;border:1px solid var(--border-color);color:var(--text-primary)}.server-menu__qr-copy-btn{font-size:10px;font-family:monospace;color:var(--text-muted);background:none;border:1px solid var(--border-color);border-radius:3px;padding:2px 8px;cursor:pointer;transition:color .15s,border-color .15s}.server-menu__qr-copy-btn:hover{color:var(--text-primary);border-color:var(--text-primary)}.server-menu__qr-hint{font-size:9px;font-family:monospace;color:var(--text-muted);text-align:center}.server-menu__qr-dismiss-btn{font-size:10px;font-family:monospace;color:var(--text-muted);background:none;border:none;cursor:pointer}.server-menu__qr-dismiss-btn:hover{color:var(--text-primary)}.server-menu__invite-actions{display:flex;gap:4px;align-items:center}.server-menu__invite-qr-btn{font-size:9px;font-family:monospace;padding:2px 8px;background:transparent;border:1px solid var(--border-color);border-radius:3px;color:var(--text-muted);cursor:pointer;transition:all .15s}.server-menu__invite-qr-btn:hover{color:var(--text-primary);border-color:var(--accent-color)}.server-menu__invite-qr-btn--active{color:var(--accent-color);border-color:var(--accent-color);background:var(--accent-color)11}.server-menu__bg-row{display:flex;align-items:center;gap:12px}.server-menu__bg-preview{width:72px;height:48px;border-radius:var(--radius-sm);background-size:cover;background-position:center;border:1px solid var(--border-color);flex-shrink:0}.server-menu__bg-actions{display:flex;flex-direction:column;gap:6px}.server-menu__range{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:var(--bg-tertiary);border-radius:3px;outline:none;cursor:pointer}.server-menu__range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--brand);cursor:pointer;border:2px solid var(--bg-secondary)}.server-menu__toggle{font-size:10px;font-family:var(--font-mono);padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.server-menu__toggle:hover{border-color:var(--brand);color:var(--text-primary)}.server-menu__toggle--on{background:var(--brand-dim);border-color:var(--brand);color:var(--brand)}.server-menu__css-editor{width:100%;min-height:280px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text-primary);font-size:11px;font-family:var(--font-mono);line-height:1.6;resize:vertical;outline:none;-moz-tab-size:2;-o-tab-size:2;tab-size:2;transition:border-color .15s ease}.server-menu__css-editor:focus{border-color:var(--brand)}.server-menu__css-editor::-moz-placeholder{color:var(--text-muted);opacity:.6}.server-menu__css-editor::placeholder{color:var(--text-muted);opacity:.6}.server-menu__css-hint{font-size:9px;color:var(--text-muted);font-family:var(--font-mono);margin-bottom:8px}.server-menu__css-char-count{font-size:9px;font-family:var(--font-mono);color:var(--text-muted)}.chat-layout{flex:1;display:flex;height:100%;overflow:hidden;padding:8px;gap:8px;position:relative}.chat-layout--has-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background-image:var(--bg-image);background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(var(--bg-blur, 0px));pointer-events:none}.chat-layout--has-bg>*{position:relative;z-index:1}.chat-main{flex:1;position:relative;min-width:0;border-radius:var(--radius-xl);overflow:hidden;margin:8px}@keyframes chatModalOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes chatModalOverlayFadeOut{0%{opacity:1}to{opacity:0}}@keyframes chatModalSlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes chatModalSlideDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(24px) scale(.97)}}.chat-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;animation:chatModalOverlayFadeIn .2s ease-out}.chat-modal-overlay--closing{animation:chatModalOverlayFadeOut .2s ease-in forwards;pointer-events:none}.chat-modal{width:100%;height:100%;background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;animation:chatModalSlideUp .25s ease-out}.chat-modal--closing{animation:chatModalSlideDown .2s ease-in forwards;pointer-events:none}.chat-modal__close-btn{position:absolute;top:12px;right:16px;z-index:10;color:var(--text-muted);font-size:11px;font-family:var(--font-mono);border:none;background:var(--bg-tertiary);border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;transition:color .15s ease,background .15s ease}.chat-modal__close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.login{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:16px}.login__card{width:100%;max-width:448px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.login__server-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.login__server-url{color:var(--text-muted);font-size:13px;margin-bottom:16px}.login__tabs{display:flex;gap:8px;margin-bottom:16px}.login__tab{flex:1;padding:8px 0;border-radius:var(--radius-md);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all .15s ease;background:var(--bg-tertiary);color:var(--text-secondary)}.login__tab--active{background:var(--bg-active);color:var(--text-primary)}.login__input-spacer{margin-bottom:12px}.login__back-btn{width:100%;text-align:center;padding:8px 0;margin-top:8px;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:13px;transition:color .15s ease}.login__back-btn:hover{color:var(--text-secondary)}.login__error{margin-top:16px;color:var(--red);font-size:13px;text-align:center}.login__not-found{flex:1;display:flex;align-items:center;justify-content:center}.login__not-found-text{color:var(--text-secondary);margin-bottom:16px}.update-banner{width:100%;min-height:28px;padding:4px 12px;font-size:11px;font-family:monospace;display:flex;align-items:center;justify-content:space-between;gap:8px;flex-shrink:0}.update-banner--checking{background:var(--accent-color, #6366f1)18;border-bottom:1px solid var(--accent-color, #6366f1)44;color:var(--text-muted)}.update-banner--downloading{background:var(--accent-color, #6366f1)18;border-bottom:1px solid var(--accent-color, #6366f1)44;color:var(--text-normal);flex-direction:column;align-items:stretch;padding:4px 12px 8px}.update-banner--ready{background:#22c55e18;border-bottom:1px solid #22c55e44;color:#22c55e}.update-banner--error{background:#ef444418;border-bottom:1px solid #ef444444;color:#ef4444}.update-banner__row{display:flex;justify-content:space-between;align-items:center}.update-banner__progress{width:100%;height:3px;background:var(--bg-hover);border-radius:2px;overflow:hidden;margin-top:3px}.update-banner__progress-fill{height:100%;background:var(--accent-color, #6366f1);transition:width .3s ease}.update-banner__restart-btn{background:#22c55e;color:var(--bg-primary);border:none;border-radius:3px;padding:2px 10px;font-size:11px;font-family:monospace;cursor:pointer;transition:opacity .15s}.update-banner__restart-btn:hover{opacity:.85}:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-tertiary: #1a1a1a;--bg-hover: #262626;--bg-active: #2d2d2d;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #6b6b6b;--border-color: #2a2a2a;--brand: #4c6ef5;--brand-hover: #4263eb;--brand-dim: rgba(76, 110, 245, .15);--accent-color: #6366f1;--bg-surface: #1a1a1a;--modal-bg: rgba(17, 17, 17, .94);--modal-backdrop: rgba(0, 0, 0, .6);--red: #ff4d4d;--red-hover: #ff3333;--red-dim: rgba(255, 77, 77, .15);--red-dim-border: rgba(255, 77, 77, .3);--green: #40c057;--green-dim: rgba(64, 192, 87, .15);--green-dim-border: rgba(64, 192, 87, .2);--yellow: #fab005;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}*::-webkit-scrollbar{width:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;background:var(--brand);color:var(--text-primary);font-weight:500;font-size:14px;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.btn-primary:hover{background:var(--brand-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;background:var(--bg-tertiary);color:var(--text-secondary);font-weight:500;font-size:14px;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease,color .15s ease}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:var(--text-primary);font-weight:500;font-size:14px;padding:8px 16px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.btn-danger:hover{background:var(--red-hover)}.input-field{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 12px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .15s ease}.input-field::-moz-placeholder{color:var(--text-muted)}.input-field::placeholder{color:var(--text-muted)}.input-field:focus{border-color:var(--brand)}.avatar{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:600;color:var(--text-primary);flex-shrink:0;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:12px}.avatar-xs{width:24px;height:24px;font-size:10px}.icon-xs{width:14px;height:14px}.icon-sm{width:16px;height:16px}.icon-md{width:20px;height:20px}.app-shell{height:100vh;width:100vw;display:flex;flex-direction:row;background:var(--bg-primary);color:var(--text-primary);overflow:hidden}.app-shell__content{flex:1;display:flex;overflow:hidden;min-width:0}
