.auth-form__server-header{text-align:center;margin-bottom:20px}.auth-form__server-icon{width:48px;height:48px;border-radius:var(--radius-md);-o-object-fit:cover;object-fit:cover;display:block;margin:0 auto 12px}.auth-form__server-icon--fallback{background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-secondary)}.auth-form__server-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.auth-form__server-description{font-size:13px;color:var(--text-secondary);margin-bottom:4px;line-height:1.4}.auth-form__server-url{color:var(--text-muted);font-size:13px;margin-bottom:0}.auth-form__tabs{display:flex;gap:8px;margin-bottom:16px}.auth-form__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)}.auth-form__tab--active{background:var(--bg-active);color:var(--text-primary)}.auth-form__input-spacer{margin-bottom:12px}.auth-form__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}.auth-form__back-btn:hover{color:var(--text-secondary)}.auth-form__error{margin-top:16px;color:var(--red);font-size:13px;text-align:center}.auth-form__forgot-btn{width:100%;text-align:center;padding:6px 0;margin-top:4px;background:none;border:none;cursor:pointer;color:var(--accent);font-size:13px;transition:opacity .15s ease}.auth-form__forgot-btn:hover{opacity:.8}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper__input{padding-right:36px}.password-input-wrapper__toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:color .15s ease}.password-input-wrapper__toggle:hover{color:var(--text-secondary)}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.spinner-icon{animation:spinner-rotate .7s linear infinite;margin-right:6px;flex-shrink:0}.backuptoken-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000bf;padding:16px}.backuptoken-modal{width:100%;max-width:480px;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000080}.backuptoken-modal__title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.backuptoken-modal__warning{background:var(--bg-tertiary);border-left:3px solid var(--accent);padding:10px 12px;border-radius:var(--radius-sm);margin-bottom:12px;font-size:13px;color:var(--text-secondary);line-height:1.5}.backuptoken-modal__warning--danger{border-left-color:var(--red)}.backuptoken-modal__warning strong{color:var(--text-primary)}.backuptoken-modal__token-box{display:flex;align-items:center;gap:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;margin-bottom:12px}.backuptoken-modal__token{flex:1;font-size:12px;color:var(--accent);word-break:break-all;font-family:monospace;line-height:1.6;-webkit-user-select:all;-moz-user-select:all;user-select:all}.backuptoken-modal__copy-btn{display:flex;align-items:center;gap:4px;flex-shrink:0;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;padding:6px 10px;cursor:pointer;transition:all .15s ease}.backuptoken-modal__copy-btn:hover{background:var(--bg-active);color:var(--text-primary)}.backuptoken-modal__hint{color:var(--text-muted);font-size:12px;line-height:1.5;margin-bottom:4px}.backuptoken-modal__confirm-input{width:100%;font-family:monospace;font-size:12px}.backuptoken-modal__checkbox{display:flex;gap:8px;align-items:flex-start;font-size:13px;color:var(--text-secondary);line-height:1.5;cursor:pointer}.backuptoken-modal__checkbox input{margin-top:3px;flex-shrink:0;accent-color:var(--accent)}@keyframes landingFadeUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.landing{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg-primary);color:var(--text-primary);scroll-behavior:smooth}.landing-nav{position:sticky;top:0;z-index:50;background:#0a0a0ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color)}.landing-nav__inner{max-width:1200px;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.landing-nav__brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-primary)}.landing-nav__logo{width:28px;height:28px}.landing-nav__name{font-size:18px;font-weight:700;letter-spacing:-.02em}.landing-nav__cta{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;background:var(--brand);color:#fff;font-size:13px;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.landing-nav__cta:hover{background:var(--brand-hover)}.landing-hero{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;padding:80px 24px 88px;overflow:hidden}.landing-hero__glow{position:absolute;top:-40%;left:50%;transform:translate(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(76,110,245,.12) 0%,transparent 70%);pointer-events:none}.landing-hero__logo{width:96px;height:auto;margin-bottom:28px;filter:drop-shadow(0 0 32px rgba(76,110,245,.35));position:relative;z-index:1}.landing-hero__title{font-size:clamp(40px,8vw,72px);font-weight:800;line-height:1.05;letter-spacing:-.03em;color:var(--text-primary);position:relative;z-index:1}.landing-hero__title-accent{background:linear-gradient(135deg,var(--brand) 0%,#818cf8 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero__desc{max-width:540px;margin-top:20px;font-size:16px;line-height:1.6;color:var(--text-secondary);position:relative;z-index:1}.landing-hero__actions{display:flex;gap:12px;margin-top:32px;flex-wrap:wrap;justify-content:center;position:relative;z-index:1}.landing-hero__btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:all .15s ease;white-space:nowrap}.landing-hero__btn--primary{background:var(--brand);color:#fff}.landing-hero__btn--primary:hover{background:var(--brand-hover);transform:translateY(-1px);box-shadow:0 4px 16px #4c6ef559}.landing-hero__btn--secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.landing-hero__btn--secondary:hover{background:var(--bg-hover);border-color:var(--text-muted)}.landing-hero__hint{margin-top:20px;font-size:13px;color:var(--text-muted);position:relative;z-index:1}.landing-hero__link{background:none;border:none;color:var(--brand);cursor:pointer;font-size:inherit;text-decoration:underline;text-underline-offset:2px;padding:0}.landing-hero__link:hover{color:var(--brand-hover)}.landing-section__title{font-size:clamp(24px,4vw,32px);font-weight:700;color:var(--text-primary);text-align:center;letter-spacing:-.02em}.landing-section__subtitle{margin-top:8px;font-size:15px;color:var(--text-muted);text-align:center;max-width:480px;margin-left:auto;margin-right:auto}.landing-features{padding:80px 24px 96px;max-width:1100px;margin:0 auto}.landing-features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}.landing-feature-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:28px 24px;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease,border-radius .2s ease;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;animation:landingFadeUp .5s ease both}.landing-feature-card:nth-child(1){animation-delay:.1s}.landing-feature-card:nth-child(2){animation-delay:.15s}.landing-feature-card:nth-child(3){animation-delay:.2s}.landing-feature-card:nth-child(4){animation-delay:.25s}.landing-feature-card:nth-child(5){animation-delay:.3s}.landing-feature-card:nth-child(6){animation-delay:.35s}.landing-feature-card:hover{border-color:var(--brand);transform:translateY(-2px);box-shadow:0 12px 40px #4c6ef526,0 4px 16px #00000080}.landing-feature-card__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--radius-md);background:var(--brand-dim);border:1px solid rgba(76,110,245,.2);color:var(--brand);margin-bottom:16px;transition:border-radius .2s ease,background .2s ease,border-color .2s ease}.landing-feature-card:hover .landing-feature-card__icon{border-radius:var(--radius-sm);background:var(--brand);color:#fff;border-color:var(--brand)}.landing-feature-card__title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.landing-feature-card__desc{font-size:14px;line-height:1.55;color:var(--text-muted)}.landing-how{padding:80px 24px 96px;max-width:1100px;margin:0 auto;border-top:1px solid var(--border-color)}.landing-how__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}.landing-how-card{text-align:center;padding:24px 20px}.landing-how-card__step{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-full);background:var(--brand);color:#fff;font-size:16px;font-weight:700;margin-bottom:16px}.landing-how-card__title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.landing-how-card__desc{font-size:14px;line-height:1.5;color:var(--text-muted);max-width:260px;margin:0 auto}.landing-download{padding:80px 24px 96px;max-width:700px;margin:0 auto;border-top:1px solid var(--border-color)}.landing-download__card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;margin-top:32px;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.landing-download__tabs{display:flex;border-bottom:1px solid var(--border-color)}.landing-download__tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:500;border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease;white-space:nowrap}.landing-download__tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.landing-download__tab--active{background:var(--bg-tertiary);color:var(--text-primary)}.landing-download__tab:not(:last-child){border-right:1px solid var(--border-color)}.landing-download__code{display:flex;background:var(--bg-primary)}.landing-download__cmd{flex:1;padding:14px 18px;font-family:var(--font-mono);font-size:13px;color:var(--text-secondary);line-height:1.6;word-break:break-all;-webkit-user-select:all;-moz-user-select:all;user-select:all}.landing-download__copy{display:flex;align-items:center;gap:4px;padding:10px 18px;font-size:13px;font-weight:500;border:none;border-left:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.landing-download__copy:hover{background:var(--bg-hover);color:var(--text-primary)}.landing-download__gh-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:8px 0;font-size:13px;color:var(--text-muted);text-decoration:none;transition:color .15s ease}.landing-download__gh-link:hover{color:var(--brand)}.landing-selfhost{padding:80px 24px 96px;max-width:780px;margin:0 auto;border-top:1px solid var(--border-color)}.landing-selfhost__card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;margin-top:32px;box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d}.landing-selfhost__code{position:relative}.landing-selfhost__code-header{display:flex;align-items:center;gap:8px;padding:12px 18px;border-bottom:1px solid var(--border-color);font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.landing-selfhost__pre{margin:0;padding:18px;background:var(--bg-primary);overflow-x:auto}.landing-selfhost__pre code{font-family:var(--font-mono);font-size:13px;line-height:1.7;color:var(--text-secondary);white-space:pre;-webkit-user-select:all;-moz-user-select:all;user-select:all}.landing-selfhost__copy{position:absolute;top:10px;right:12px;display:flex;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:500;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;transition:all .15s ease}.landing-selfhost__copy:hover{background:var(--bg-hover);color:var(--text-primary)}.landing-selfhost__more{margin-top:16px;text-align:center}.landing-selfhost__link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);text-decoration:none;transition:color .15s ease}.landing-selfhost__link:hover{color:var(--brand)}.landing-footer{border-top:1px solid var(--border-color);padding:32px 24px}.landing-footer__inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.landing-footer__brand{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-secondary)}.landing-footer__logo{width:20px;height:20px;opacity:.6}.landing-footer__links{display:flex;align-items:center;gap:16px}.landing-footer__links a{color:var(--text-muted);transition:color .15s ease;display:flex}.landing-footer__links a:hover{color:var(--text-primary)}.landing-footer__copy{max-width:1100px;margin:12px auto 0;font-size:12px;color:var(--text-muted)}.landing-footer__copy a{color:var(--text-muted);text-underline-offset:2px}.landing-footer__copy a:hover{color:var(--text-secondary)}.landing-dev-toggle{position:fixed;bottom:16px;right:16px;z-index:100;padding:6px 14px;background:var(--bg-tertiary);color:var(--text-muted);font-size:12px;border:1px dashed var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.landing-dev-toggle:hover{color:var(--text-secondary);border-color:var(--text-muted)}@media (max-width: 768px){.landing-hero{padding:56px 20px 64px}.landing-hero__glow{width:300px;height:300px}.landing-hero__logo{width:72px;margin-bottom:20px}.landing-hero__actions{flex-direction:column;width:100%;max-width:300px}.landing-hero__btn{justify-content:center}.landing-features{padding:56px 20px 64px}.landing-features__grid{grid-template-columns:1fr;margin-top:32px}.landing-how{padding:56px 20px 64px}.landing-how__grid{grid-template-columns:1fr;margin-top:32px;gap:8px}.landing-download,.landing-selfhost{padding:56px 20px 64px}.landing-footer__inner{flex-direction:column;gap:12px;text-align:center}.landing-footer__copy{text-align:center}}@media (max-width: 480px){.landing-nav__inner{padding:0 16px}.landing-hero__title{font-size:36px}.landing-hero__desc{font-size:14px}.landing-download__code{flex-direction:column}.landing-download__copy{border-left:none;border-top:1px solid var(--border-color);justify-content:center;padding:10px}}.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}.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__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__settings-btn{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s,background .15s;box-shadow:0 4px 12px #0000004d}.welcome__settings-btn:hover{color:var(--text-primary);border-color:var(--brand);background:var(--bg-tertiary)}.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:var(--text-primary)}.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:var(--green);border-color:var(--green)}.server-panel__icon-img{width:100%;height:100%;border-radius:calc(var(--radius-md) - 1px);-o-object-fit:cover;object-fit:cover;transition:border-radius .15s ease}.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:var(--green)}.server-panel__badge{position:absolute;bottom:-2px;right:-4px;background:var(--red);color:var(--text-primary);font-size:9px;font-weight:700;padding:1px 4px;border-radius:var(--radius-sm);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:var(--red);color:var(--text-primary);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}@media (max-width: 600px){.server-panel{width:100%;height:52px;flex-direction:row;align-items:center;flex-shrink:0;margin:0;border-radius:0;padding:0 8px;gap:4px;border:none;border-bottom:1px solid var(--border-color);box-shadow:none}.server-panel__list{flex-direction:row;gap:4px;overflow-x:auto;overflow-y:hidden;flex:0 1 auto;padding:0}.server-panel__icon{width:36px;height:36px;font-size:12px}.server-panel__settings-btn{width:36px;height:36px}}.update-banner-card{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin:0 0 8px;position:relative;flex-shrink:0}.update-banner-card__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}.update-banner-card__close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.update-banner-card__content{padding:16px 20px;font-size:12px;font-family:var(--font-mono);display:flex;align-items:center;justify-content:space-between;gap:12px}.update-banner-card__content--checking{color:var(--text-secondary)}.update-banner-card__content--downloading{flex-direction:column;align-items:stretch}.update-banner-card__content--ready{color:var(--green)}.update-banner-card__content--error{color:var(--red)}.update-banner-card__row{display:flex;justify-content:space-between;align-items:center}.update-banner-card__progress{width:100%;height:4px;background:var(--bg-hover);border-radius:2px;overflow:hidden}.update-banner-card__progress-fill{height:100%;background:var(--accent-color);transition:width .3s ease;border-radius:2px}.update-banner-card__restart-btn{background:var(--green);color:var(--bg-primary);border:none;border-radius:var(--radius-sm);padding:4px 14px;font-size:11px;font-family:var(--font-mono);font-weight:500;cursor:pointer;transition:opacity .15s;flex-shrink:0}.update-banner-card__restart-btn:hover{opacity:.85}.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 voiceSlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes voiceSlideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}.voice-overlay{background:var(--bg-tertiary);border-top:1px solid var(--border-color);display:flex;flex-direction:column;animation:voiceSlideUp .15s ease-out;flex-shrink:0}.voice-overlay--closing{animation:voiceSlideDown .12s 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-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:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.voice-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--green-dim);border-bottom:1px solid var(--green-dim-border)}.voice-header__icon{color:var(--green);flex-shrink:0}.voice-header__name{color:var(--green);font-size:12px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-header__status{color:var(--green);font-size:10px;font-family:var(--font-mono);flex-shrink:0}.voice-header__status--error{color:var(--red)}.voice-header__controls{display:flex;align-items:center;gap:4px;flex-shrink:0}.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);color:var(--text-primary)}.voice-header__btn--screenshare{color:var(--text-secondary)}.voice-header__btn--screenshare:hover{border-color:var(--brand);color:var(--brand)}.voice-header__btn--screenshare-active{border-color:var(--red-dim-border);color:var(--red)}.voice-body{padding:4px 8px;display:flex;flex-direction:column;gap:2px;max-height:160px;overflow-y:auto}.voice-peer{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:var(--radius-sm);transition:background .12s ease}.voice-peer:hover{background:var(--bg-hover)}.voice-peer__avatar-wrap{position:relative;flex-shrink:0}.voice-peer__speaking-ring{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:var(--radius-full);border:2px solid var(--green);animation:ping 1s ease-out infinite;pointer-events:none}.voice-peer__avatar{width:24px;height:24px;border-radius:var(--radius-full);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);color:var(--text-primary)}.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);color:var(--text-primary)}.voice-peer__avatar--dmcall{width:28px;height:28px;border-radius:50%;background:var(--color-accent, #7289da);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:6px;flex-shrink:0}.voice-peer__name{font-size:11px;flex:1;min-width:0;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:10px;color:var(--text-muted)}.voice-peer__peer-muted{font-size:10px;color:var(--red)}.voice-peer__volume{width:0;overflow:hidden;transition:width .15s ease;display:flex;align-items:center}.voice-peer:hover .voice-peer__volume{width:72px}.voice-peer__volume input[type=range]{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;outline:none}.voice-peer__volume input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:var(--radius-full);background:var(--text-primary);cursor:pointer}.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-footer{display:flex;align-items:center;gap:8px;padding:4px 12px;border-top:1px solid var(--border-color);font-size:10px;font-family:var(--font-mono);color:var(--text-muted)}@keyframes ping{75%,to{transform:scale(1.4);opacity:0}}.status-picker{position:relative;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-full);border:2px solid transparent;cursor:pointer;flex-shrink:0;transition:border-color .15s ease}.status-picker:hover{filter:brightness(1.1)}.status-picker--online{border-color:var(--green)}.status-picker--idle{border-color:var(--yellow)}.status-picker--busy{border-color:var(--red)}.status-picker--offline{border-color:var(--gray)}.status-picker__dropdown{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px;min-width:140px;z-index:9999;box-shadow:0 4px 16px #00000080;animation:statusFadeIn .12s ease-out}@keyframes statusFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.status-picker__option{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;background:none;color:var(--text-secondary);font-size:12px;cursor:pointer;border-radius:4px;text-align:left;transition:background .1s ease,color .1s ease}.status-picker__option:hover{background:var(--bg-hover);color:var(--text-primary)}.status-picker__option--active{color:var(--text-primary)}.status-picker__dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.status-picker__dot--online{background:var(--green)}.status-picker__dot--idle{background:var(--yellow)}.status-picker__dot--busy{background:var(--red)}.status-picker__dot--offline{background:var(--gray)}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu{z-index:1100;background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px;min-width:188px;max-width:260px;display:flex;flex-direction:column;gap:0;box-shadow:0 4px 16px #00000080;animation:contextMenuFadeIn .12s ease-out}.context-menu__title{padding:6px 10px 8px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-menu__item{display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:12px;padding:6px 10px;border-radius:var(--radius-xs);text-align:left;transition:background .12s ease,color .12s ease;white-space:nowrap;width:100%}.context-menu__item:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.context-menu__item--danger{color:var(--red)}.context-menu__item--danger:hover:not(:disabled){background:#ef44441a;color:var(--red)}.context-menu__item--disabled{opacity:.35;cursor:not-allowed}.context-menu__shortcut{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);margin-left:24px;flex-shrink:0}.context-menu__divider{height:1px;background:var(--border-color);margin:4px 8px}.channel-settings{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:560px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column;animation:serverMenuFadeIn .2s ease;overflow:hidden}.channel-settings--closing{animation:serverMenuFadeOut .15s ease forwards}.channel-settings__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.channel-settings__header-title{font-size:13px;font-family:var(--font-mono);font-weight:600;color:var(--text-primary)}.channel-settings__close-btn{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);background:none;border:none;cursor:pointer}.channel-settings__body{padding:0 20px 20px;overflow-y:auto;flex:1}.channel-settings__tab-bar{display:flex;gap:0;margin-top:16px;border-bottom:1px solid var(--border-color)}.channel-settings__tab{font-size:10px;font-family:var(--font-mono);padding:6px 14px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease}.channel-settings__tab--active{color:var(--brand);border-bottom-color:var(--brand)}.channel-settings__tab:hover{color:var(--text-primary)}.channel-settings__field{margin-bottom:12px}.channel-settings__label{font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;display:block}.channel-settings__value{font-size:12px;color:var(--text-primary);font-family:var(--font-mono)}.channel-settings__section-title{font-size:11px;font-family:var(--font-mono);color:var(--text-primary);margin-bottom:6px;font-weight:600}.channel-settings__hint{font-size:9px;color:var(--text-muted);margin-bottom:12px;font-family:var(--font-mono);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.channel-settings__legend-item{display:inline-flex;align-items:center;gap:3px}.channel-settings__legend-dot{width:8px;height:8px;border-radius:2px}.channel-settings__legend-dot--inherit{background:var(--bg-hover);border:1px solid var(--border-color)}.channel-settings__legend-dot--allow{background:var(--green);border:1px solid var(--green)}.channel-settings__legend-dot--deny{background:var(--red);border:1px solid var(--red)}.channel-settings__loading{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);text-align:center;padding:20px}.channel-settings__perm-matrix{border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.channel-settings__perm-header{display:flex;align-items:center;background:var(--bg-tertiary);padding:6px 10px;border-bottom:1px solid var(--border-color)}.channel-settings__perm-header-role{width:120px;flex-shrink:0;font-size:9px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase}.channel-settings__perm-header-col{flex:1;text-align:center;font-size:8px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase}.channel-settings__perm-row{display:flex;align-items:center;padding:4px 10px;border-bottom:1px solid var(--border-color)}.channel-settings__perm-row:last-child{border-bottom:none}.channel-settings__perm-role{width:120px;flex-shrink:0;display:flex;align-items:center;gap:6px}.channel-settings__perm-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.channel-settings__perm-role-name{font-size:10px;font-family:var(--font-mono);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-settings__perm-cell{flex:1;display:flex;justify-content:center}.channel-settings__perm-btn{width:24px;height:24px;border-radius:4px;border:1px solid var(--border-color);cursor:pointer;transition:all .15s ease}.channel-settings__perm-btn--inherit{background:var(--bg-hover)}.channel-settings__perm-btn--allow{background:var(--green-dim);border-color:var(--green)}.channel-settings__perm-btn--deny{background:var(--red-dim);border-color:var(--red)}.channel-settings__perm-btn:hover{opacity:.8}.channel-settings__footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.channel-settings__done-btn{padding:4px 16px;background:var(--brand);color:var(--text-primary);font-size:10px;font-family:var(--font-mono);border:none;border-radius:var(--radius-sm);cursor:pointer}.channel-settings__done-btn:hover{background:var(--brand-hover)}@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;scrollbar-gutter:stable}.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__unread-dot{margin-left:auto;width:8px;height:8px;border-radius:var(--radius-full);background:var(--text-muted);flex-shrink:0}.sidebar__channel--unread .sidebar__channel-name{color:var(--text-primary);font-weight:500}.sidebar__mute-icon{color:var(--text-muted);flex-shrink:0;opacity:.5;margin-left:2px}.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__disconnect-confirm{padding:6px 8px;display:flex;flex-direction:column;gap:4px}.sidebar__disconnect-label{font-size:12px;color:var(--red);font-weight:500}.sidebar__disconnect-actions{display:flex;gap:4px}.sidebar__disconnect-btn{flex:1;padding:4px 8px;border:none;border-radius:var(--radius-xs);font-size:12px;cursor:pointer;background:var(--bg-tertiary);color:var(--text-secondary);transition:background .15s,color .15s}.sidebar__disconnect-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__disconnect-btn--confirm{background:var(--red-dim);color:var(--red)}.sidebar__disconnect-btn--confirm:hover{background:var(--red-dim-border);color:var(--red)}.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}}.sidebar__channel-wrap{position:relative;display:flex;align-items:center}.sidebar__channel-wrap .sidebar__channel{flex:1}.sidebar__lock-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:2px 4px;border-radius:3px;margin-left:2px;transition:all .15s ease;flex-shrink:0}.sidebar__lock-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__lock-btn--active{color:var(--yellow);background:#fab00526}.sidebar__lock-menu{position:absolute;right:0;top:100%;z-index:20;background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px;min-width:160px;display:flex;flex-direction:column;gap:4px;box-shadow:0 4px 12px #0006;animation:lockMenuFadeIn .15s ease}.sidebar__lock-menu-label{font-size:10px;color:var(--text-muted);padding:2px 4px}.sidebar__lock-menu-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:11px;padding:4px 8px;border-radius:4px;text-align:left;transition:background .15s ease}.sidebar__lock-menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__lock-menu-btn--active{color:var(--brand)}@keyframes lockMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sidebar__voice-users{padding:2px 0 2px 28px;display:flex;flex-direction:column;gap:2px}.sidebar__voice-user{display:flex;align-items:center;gap:6px;padding:1px 0}.sidebar__voice-user-avatar{width:18px;height:18px;border-radius:var(--radius-full);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);color:var(--text-muted);font-size:9px;font-weight:600}.sidebar__voice-user-avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sidebar__voice-user-name{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__voice-user--more{font-size:11px;color:var(--text-muted);opacity:.7;padding-top:1px;cursor:default}@media (max-width: 768px){.sidebar{width:200px}.sidebar__header-name{font-size:12px}}@media (max-width: 600px){.sidebar{width:100%;margin:0;border-radius:0;border:none;border-bottom:1px solid var(--border-color)}}.user-profile-card{width:280px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;z-index:1200;overflow:hidden;animation:profileCardFadeIn .15s ease-out}@keyframes profileCardFadeIn{0%{opacity:0;transform:translateY(-4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.user-profile-card__banner{height:48px;background-size:cover;background-position:center;background-color:var(--bg-tertiary)}.user-profile-card__avatar-wrap{position:relative;display:flex;justify-content:center;margin-top:-24px}.user-profile-card__avatar{width:64px;height:64px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--text-primary);border:4px solid var(--bg-secondary);overflow:hidden}.user-profile-card__avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-profile-card__status{position:absolute;bottom:2px;right:calc(50% - 36px);width:14px;height:14px;border-radius:var(--radius-full);border:3px solid var(--bg-secondary)}.user-profile-card__status--online{background:var(--green)}.user-profile-card__status--idle{background:var(--yellow)}.user-profile-card__status--busy{background:var(--red)}.user-profile-card__status--offline{background:var(--gray)}.user-profile-card__info{text-align:center;padding:8px 16px 4px}.user-profile-card__name{font-size:15px;font-weight:700;color:var(--text-primary)}.user-profile-card__username{font-size:12px;color:var(--text-muted);margin-top:2px}.user-profile-card__roles{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;padding:4px 16px 8px}.user-profile-card__role-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);border:1px solid;white-space:nowrap}.user-profile-card__meta{display:flex;flex-direction:column;gap:6px;padding:8px 16px 12px;border-top:1px solid var(--border-color);margin:0 12px}.user-profile-card__meta-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary)}.user-profile-card__status-dot{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.user-profile-card__status-dot--online{background:var(--green)}.user-profile-card__status-dot--idle{background:var(--yellow)}.user-profile-card__status-dot--busy{background:var(--red)}.user-profile-card__status-dot--offline{background:var(--gray)}.user-profile-card__actions{display:flex;gap:6px;padding:8px 12px 12px;border-top:1px solid var(--border-color)}.user-profile-card__action-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:background .12s ease,color .12s ease}.user-profile-card__action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.embed-card-list{display:flex;flex-direction:column;gap:4px;margin-top:4px}.embed-card{display:flex;align-items:flex-start;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden;max-width:440px;text-decoration:none;transition:background .12s ease}.embed-card:hover{background:var(--bg-hover)}.embed-card__accent{width:4px;align-self:stretch;background:var(--brand);flex-shrink:0}.embed-card__body{flex:1;min-width:0;padding:8px 12px;display:flex;flex-direction:column;gap:4px}.embed-card__header{display:flex;align-items:center;gap:6px}.embed-card__favicon{width:14px;height:14px;border-radius:2px}.embed-card__site{font-size:11px;font-weight:600;color:var(--text-muted)}.embed-card__title{font-size:13px;font-weight:600;color:var(--brand);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.embed-card__desc{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.embed-card__thumb{width:80px;height:80px;-o-object-fit:cover;object-fit:cover;border-radius:0 var(--radius-sm) var(--radius-sm) 0;flex-shrink:0}.msg-bubble__row{display:flex;gap:12px;padding:0 16px;margin-top:12px}.msg-bubble__row:first-child{margin-top:4px}.msg-bubble__row--own{justify-content:flex-end}.msg-bubble__row--grouped{margin-top:4px}.msg-bubble__avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-secondary);flex-shrink:0;overflow:hidden;position:relative;margin-top:2px}.msg-bubble__avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.msg-bubble__avatar-spacer{width:36px;height:0;flex-shrink:0}.msg-bubble__date-separator{display:flex;align-items:center;gap:12px;padding:8px 16px;margin:8px 0}.msg-bubble__date-separator:before,.msg-bubble__date-separator:after{content:"";flex:1;height:1px;background:var(--border-color)}.msg-bubble__date-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:2px 8px;background:var(--bg-primary);border-radius:var(--radius-sm)}.msg-bubble__new-divider{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:4px 0}.msg-bubble__new-divider:before,.msg-bubble__new-divider:after{content:"";flex:1;height:1px;background:var(--red-dim-border)}.msg-bubble__new-divider-label{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes reactionBounce{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.msg-bubble__row--entering{animation:messageSlideIn .2s ease-out}.msg-bubble__reaction-pill--added{animation:reactionBounce .2s ease-out}.msg-bubble__reply-preview{display:flex;align-items:center;gap:6px;margin-bottom:4px;padding:2px 0;font-size:12px;opacity:.7}.msg-bubble__reply-preview-line{width:2px;height:14px;background:var(--text-muted);border-radius:1px;flex-shrink:0}.msg-bubble__reply-preview-username{font-weight:600;color:var(--brand);flex-shrink:0}.msg-bubble__reply-preview-text{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-bubble__bubble{max-width:480px;padding:8px 14px;border-radius:var(--radius-md);position:relative;transition:box-shadow .15s ease,filter .15s ease}.msg-bubble__bubble:hover{filter:brightness(1.06)}.msg-bubble__bubble--other{background:var(--bg-tertiary);border-top-left-radius:4px;box-shadow:0 1px 2px #0003}.msg-bubble__bubble--other.msg-bubble__bubble--grouped{border-top-left-radius:var(--radius-md)}.msg-bubble__bubble--own{background:var(--brand);border-top-right-radius:4px;box-shadow:0 1px 2px #4c6ef540}.msg-bubble__bubble--editing{max-width:600px}.msg-bubble__author{font-size:12px;font-weight:600;color:var(--brand);margin-bottom:2px;line-height:1.3}.msg-bubble__bubble--own .msg-bubble__author{color:#fffc}.msg-bubble__text{font-size:13px;color:var(--text-primary);word-break:break-word;line-height:1.375}.msg-bubble__text p{margin:0}.msg-bubble__text p+p{margin-top:18px}.msg-bubble__text strong{font-weight:700}.msg-bubble__text em{font-style:italic}.msg-bubble__text del{text-decoration:line-through;opacity:.7}.msg-bubble__text a{color:var(--brand);text-decoration:none}.msg-bubble__text a:hover{text-decoration:underline}.msg-bubble__text code{background:var(--bg-hover);padding:2px 5px;border-radius:4px;font-family:var(--font-mono);font-size:12px}.msg-bubble__text pre{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 12px;overflow-x:auto;margin:8px 0}.msg-bubble__text pre code{background:none;padding:0;border-radius:0;font-size:12px;line-height:1.5}.msg-bubble__text blockquote{border-left:3px solid var(--brand);padding-left:10px;margin:8px 0;color:var(--text-secondary)}.msg-bubble__text ul,.msg-bubble__text ol{padding-left:20px;margin:6px 0}.msg-bubble__text li{margin:3px 0}.msg-bubble__text h1,.msg-bubble__text h2,.msg-bubble__text h3,.msg-bubble__text h4,.msg-bubble__text h5,.msg-bubble__text h6{margin:8px 0 4px;font-weight:700;line-height:1.3}.msg-bubble__text h1{font-size:1.4em}.msg-bubble__text h2{font-size:1.2em}.msg-bubble__text h3{font-size:1.1em}.msg-bubble__text hr{border:none;border-top:1px solid var(--border-color);margin:10px 0}.msg-bubble__bubble--own .msg-bubble__text code{background:#ffffff1a;color:#ffffffe6}.msg-bubble__bubble--own .msg-bubble__text pre{background:#0003;border-color:#ffffff26}.msg-bubble__bubble--own .msg-bubble__text pre code{color:#ffffffe6}.msg-bubble__bubble--own .msg-bubble__text blockquote{border-left-color:#ffffff4d;color:#ffffffb3}.msg-bubble__bubble--own .msg-bubble__text a{color:#ffffffe6}.msg-bubble__meta{display:flex;align-items:center;gap:6px;height:24px;margin-top:4px;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none}.msg-bubble__meta--visible{opacity:1;visibility:visible;pointer-events:auto}.msg-bubble__meta--editing{height:auto;max-height:200px;flex-direction:column;align-items:flex-end;opacity:1;visibility:visible}.msg-bubble__time{font-size:10px;color:var(--text-secondary);animation:msg-bubble-time-in .15s ease forwards}@keyframes msg-bubble-time-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.msg-bubble__bubble--own .msg-bubble__time{color:#ffffffa6}.msg-bubble__edited{font-size:10px;color:var(--text-muted)}.msg-bubble__bubble--own .msg-bubble__edited{color:#ffffff80}.msg-bubble__delete-btn{display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);padding:2px;border:none;background:none;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s ease,color .15s ease,background .15s ease}.msg-bubble__bubble:hover .msg-bubble__delete-btn{opacity:1}.msg-bubble__delete-btn:hover{color:var(--red);background:var(--red-dim)}.msg-bubble__bubble--own .msg-bubble__delete-btn{color:#ffffff80}.msg-bubble__bubble--own .msg-bubble__delete-btn:hover{color:#ffffffe6;background:#ffffff1a}.msg-bubble__delete-confirm{display:flex;align-items:center;gap:4px}.msg-bubble__delete-confirm-btn{font-size:10px;padding:2px 6px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:500}.msg-bubble__delete-confirm-btn--yes{background:var(--red-dim);color:var(--red)}.msg-bubble__delete-confirm-btn--yes:hover{background:#ff4d4d4d}.msg-bubble__delete-confirm-btn--no{background:var(--bg-tertiary);color:var(--text-muted)}.msg-bubble__delete-confirm-btn--no:hover{background:var(--bg-hover)}.msg-bubble__edit-btn{display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);padding:2px;border:none;background:none;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s ease,color .15s ease,background .15s ease}.msg-bubble__bubble:hover .msg-bubble__edit-btn{opacity:1}.msg-bubble__edit-btn:hover{color:var(--brand);background:var(--brand-dim)}.msg-bubble__bubble--own .msg-bubble__edit-btn{color:#ffffff80}.msg-bubble__bubble--own .msg-bubble__edit-btn:hover{color:#ffffffe6;background:#ffffff1a}.msg-bubble__edit-input{width:100%;min-height:36px;max-height:300px;overflow-y:auto;font-size:13px;color:var(--text-primary);font-family:inherit;line-height:1.45;padding:6px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-primary);resize:none;outline:none;box-sizing:border-box}.msg-bubble__edit-input:focus{border-color:var(--brand)}.msg-bubble__bubble--own .msg-bubble__edit-input{background:#ffffff1a;border-color:#fff3;color:#fffffff2}.msg-bubble__bubble--own .msg-bubble__edit-input:focus{border-color:#ffffff80}.msg-bubble__edit-actions{display:flex;align-items:center;gap:4px}.msg-bubble__edit-action-btn{font-size:10px;padding:2px 6px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:500}.msg-bubble__edit-action-btn--save{background:var(--brand-dim);color:var(--brand)}.msg-bubble__edit-action-btn--save:hover{background:#4c6ef540}.msg-bubble__edit-action-btn--cancel{background:var(--bg-tertiary);color:var(--text-muted)}.msg-bubble__edit-action-btn--cancel:hover{background:var(--bg-hover)}.msg-bubble__bubble--own .msg-bubble__edit-action-btn--save{background:#ffffff26;color:#ffffffe6}.msg-bubble__bubble--own .msg-bubble__edit-action-btn--save:hover{background:#ffffff40}.msg-bubble__bubble--own .msg-bubble__edit-action-btn--cancel{background:#ffffff14;color:#fff9}.msg-bubble__bubble--own .msg-bubble__edit-action-btn--cancel:hover{background:#ffffff26}.msg-bubble__mention--self{background:var(--brand-dim);color:var(--brand);border-radius:var(--radius-sm);padding:0 2px;font-weight:600}.msg-bubble__mention--group{background:#fab00526;color:var(--yellow);border-radius:var(--radius-sm);padding:0 2px;font-weight:600}.msg-bubble__mention--user{background:var(--bg-hover);border-radius:var(--radius-sm);padding:0 2px}.msg-bubble__attachment-link{display:inline-flex;align-items:center;gap:6px;background:var(--bg-hover);border-radius:var(--radius-sm);padding:6px 10px;cursor:pointer;transition:background .15s ease;text-decoration:none;margin-top:6px}.msg-bubble__attachment-link:hover{background:var(--bg-active)}.msg-bubble__attachment-filename{font-size:12px;color:var(--brand)}.msg-bubble__attachment-filename:hover{text-decoration:underline}.msg-bubble__attachment-image-wrap{position:relative;display:inline-block;cursor:pointer;margin-top:6px}.msg-bubble__attachment-image{max-width:320px;border-radius:var(--radius-md);cursor:pointer;max-height:200px;-o-object-fit:cover;object-fit:cover;display:block}.msg-bubble__attachment-image--expanded{max-width:100%;max-height:none}.msg-bubble__attachment-image--sticker{max-width:100px;max-height:100px}.msg-bubble__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}.msg-bubble__attachment-image-wrap:hover .msg-bubble__attachment-expand-hint{opacity:1}.msg-bubble__attachment-video{margin-top:6px;max-width:320px;max-height:200px;border-radius:var(--radius-md)}.msg-bubble__attachment-audio{margin-top:6px;max-width:320px}.msg-bubble__row--media-only{margin-top:8px}.msg-bubble__bubble--media-only{background:transparent!important;padding:0!important;border-radius:0!important;box-shadow:none!important;max-width:360px}.msg-bubble__bubble--media-only:hover{filter:none}.msg-bubble__attachment-image-wrap--media-only{cursor:default;margin-top:0;border-radius:var(--radius-sm);overflow:hidden}.msg-bubble__attachment-image--media-only{max-width:100%;max-height:280px;border-radius:var(--radius-sm);-o-object-fit:contain;object-fit:contain;cursor:default;display:block}.msg-bubble__attachment-image--media-only.msg-bubble__attachment-image--sticker{max-width:100px;max-height:100px}.msg-bubble__attachment-video--media-only{max-width:360px;max-height:280px;border-radius:var(--radius-sm);margin-top:0}.msg-bubble__bubble--media-only .msg-bubble__meta{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#0009);padding:16px 8px 4px;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.msg-bubble__bubble--media-only .msg-bubble__meta--visible{max-height:40px;margin-top:0}.msg-bubble__bubble--media-only .msg-bubble__time{color:#fffc}.msg-bubble__bubble--media-only .msg-bubble__edited{color:#fff9}.msg-bubble__bubble--media-only .msg-bubble__delete-btn,.msg-bubble__bubble--media-only .msg-bubble__edit-btn{color:#ffffffb3}.msg-bubble__bubble--media-only .msg-bubble__delete-btn:hover,.msg-bubble__bubble--media-only .msg-bubble__edit-btn:hover{color:#fff;background:#ffffff26}.msg-bubble__bubble--media-only .msg-bubble__delete-confirm-btn--yes{background:#ff4d4d66;color:#fff}.msg-bubble__bubble--media-only .msg-bubble__delete-confirm-btn--no{background:#ffffff26;color:#ffffffb3}.msg-bubble__bubble--sticker-only .msg-bubble__meta{position:static;background:none;padding:2px 0 0;border-radius:0}.msg-bubble__bubble--sticker-only .msg-bubble__meta--visible{opacity:1;visibility:visible;pointer-events:auto}.msg-bubble__bubble--sticker-only .msg-bubble__time,.msg-bubble__bubble--sticker-only .msg-bubble__edited{color:var(--text-muted)}.msg-bubble__content{position:relative;max-width:480px;overflow:hidden}.msg-bubble__row--own .msg-bubble__content{display:flex;flex-direction:column;align-items:flex-end}.msg-bubble__row--media-only .msg-bubble__content{max-width:360px}.msg-bubble__reactions{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.msg-bubble__row--own .msg-bubble__reactions{justify-content:flex-end}.msg-bubble__reaction{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-sm, 6px);border:1px solid var(--border-color);background:var(--bg-tertiary);cursor:pointer;transition:background .15s,border-color .15s;font-size:15px;line-height:1.2}.msg-bubble__reaction:hover{background:var(--bg-hover);border-color:var(--brand)}.msg-bubble__reaction--active{border-color:var(--brand);background:var(--brand-dim)}.msg-bubble__reaction-emoji{font-size:18px;line-height:1}.msg-bubble__reaction-sticker{width:24px;height:24px;-o-object-fit:contain;object-fit:contain}.msg-bubble__reaction-count{font-size:13px;color:var(--text-secondary);font-weight:500;min-width:8px;text-align:center}.msg-bubble__reaction--overflow{border-style:dashed;opacity:.7;min-width:36px;justify-content:center}.msg-bubble__reaction--overflow:hover{opacity:1;border-style:solid}.msg-bubble__reaction--overflow-expanded{opacity:.5}.msg-bubble__reaction--overflow-expanded:hover{opacity:.8}.msg-bubble__reaction--overflow .msg-bubble__reaction-emoji{font-size:15px}.msg-bubble__react-bar{opacity:0;transform:translateY(-6px);transition:opacity .15s ease,transform .15s ease;pointer-events:none;white-space:nowrap}.msg-bubble__react-bar--visible{opacity:1;transform:translateY(0);pointer-events:auto;transition-delay:.06s}.msg-bubble__react-bar-inner{display:flex;align-items:center;gap:2px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm, 8px);padding:2px;box-shadow:0 4px 12px #0000004d}.msg-bubble__react-quick{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;border-radius:var(--radius-sm, 6px);cursor:pointer;font-size:16px;line-height:1;transition:background .1s,transform .1s}.msg-bubble__react-quick:hover{background:var(--bg-hover);transform:scale(1.2)}.msg-bubble__react-quick--add{color:var(--text-muted)}.msg-bubble__react-quick--add:hover{color:var(--text-primary)}.msg-bubble__react-quick-sticker{width:20px;height:20px;-o-object-fit:contain;object-fit:contain}.reaction-picker__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300}.reaction-picker{position:fixed;bottom:120px;left:50%;transform:translate(-50%);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md, 12px);box-shadow:0 8px 32px #0006;width:312px;max-height:340px;display:flex;flex-direction:column;overflow:hidden;z-index:310}.reaction-picker__header{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 0}.reaction-picker__tabs{display:flex;gap:4px}.reaction-picker__tab{padding:4px 12px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;border-radius:var(--radius-sm, 4px) var(--radius-sm, 4px) 0 0;transition:background .15s,color .15s}.reaction-picker__tab:hover{color:var(--text-primary)}.reaction-picker__tab--active{color:var(--text-primary);background:var(--bg-primary)}.reaction-picker__close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px;display:flex}.reaction-picker__close:hover{color:var(--text-primary);background:var(--bg-hover)}.reaction-picker__emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;overflow-y:auto;flex:1}.reaction-picker__emoji-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:18px;transition:background .1s,transform .1s}.reaction-picker__emoji-btn:hover{background:var(--bg-hover);transform:scale(1.15)}.reaction-picker__packs{display:flex;gap:4px;padding:4px 8px;overflow-x:auto;flex-shrink:0}.reaction-picker__packs::-webkit-scrollbar{height:3px}.reaction-picker__packs::-webkit-scrollbar-thumb{border-radius:2px}.reaction-picker__pack-btn{padding:3px 10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:10px;border-radius:var(--radius-full, 999px);cursor:pointer;white-space:nowrap;flex-shrink:0}.reaction-picker__pack-btn:hover{border-color:var(--brand)}.reaction-picker__pack-btn--active{background:var(--brand);color:#fff;border-color:var(--brand)}.reaction-picker__sticker-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;overflow-y:auto;flex:1;align-content:start}.reaction-picker__sticker-btn{aspect-ratio:1;padding:0;border:none;background:var(--bg-tertiary);border-radius:4px;cursor:pointer;overflow:hidden;transition:transform .1s}.reaction-picker__sticker-btn:hover{transform:scale(1.08);outline:2px solid var(--brand);outline-offset:-2px}.reaction-picker__sticker-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.reaction-picker__status{grid-column:1 / -1;text-align:center;padding:16px;color:var(--text-muted);font-size:12px}.gif-picker__overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0009;display:flex;align-items:center;justify-content:center}.gif-picker{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);width:420px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0006}.gif-picker__header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 0}.gif-picker__tabs{display:flex;gap:4px}.gif-picker__tab{padding:6px 16px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;border-radius:var(--radius-sm, 6px) var(--radius-sm, 6px) 0 0;transition:background .15s,color .15s}.gif-picker__tab:hover{color:var(--text-primary);background:var(--bg-hover)}.gif-picker__tab--active{color:var(--text-primary);background:var(--bg-primary)}.gif-picker__close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-sm, 4px);display:flex;align-items:center;justify-content:center}.gif-picker__close:hover{color:var(--text-primary);background:var(--bg-hover)}.gif-picker__search{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--bg-primary);margin:4px 12px 8px;border-radius:var(--radius-sm, 6px);border:1px solid var(--border-color)}.gif-picker__search:focus-within{border-color:var(--brand)}.gif-picker__search-icon{color:var(--text-muted);flex-shrink:0}.gif-picker__search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:13px;font-family:inherit}.gif-picker__search-input::-moz-placeholder{color:var(--text-muted)}.gif-picker__search-input::placeholder{color:var(--text-muted)}.gif-picker__filters{display:flex;gap:4px;padding:0 12px 8px;overflow-x:auto;flex-shrink:0}.gif-picker__filters::-webkit-scrollbar{height:3px}.gif-picker__filters::-webkit-scrollbar-thumb{border-radius:2px}.gif-picker__filter{padding:4px 10px;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-secondary);font-size:11px;border-radius:var(--radius-full, 999px);cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.gif-picker__filter:hover{border-color:var(--brand);color:var(--text-primary)}.gif-picker__filter--active{background:var(--brand);color:var(--text-primary);border-color:var(--brand)}.gif-picker__grid{flex:1;overflow-y:auto;padding:0 8px 8px;display:flex;flex-wrap:wrap;gap:4px;align-content:flex-start}.gif-picker__status{width:100%;text-align:center;padding:24px 0;color:var(--text-muted);font-size:13px}.gif-picker__status--error{color:var(--red)}.gif-picker__item{position:relative;overflow:hidden;border-radius:var(--radius-xs);cursor:pointer;background:var(--bg-tertiary);transition:outline .15s ease;flex-shrink:0;max-width:100%}.gif-picker__item:hover{outline:2px solid var(--brand);outline-offset:-2px}.gif-picker__img{display:block;max-width:100%;height:auto;-o-object-fit:contain;object-fit:contain}.gif-picker__img--sticker{width:125px;height:125px}.gif-picker__item-name{position:absolute;bottom:0;left:0;right:0;background:#000000b3;color:var(--text-primary);font-size:10px;padding:3px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}@keyframes skeletonShimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{background:linear-gradient(90deg,var(--bg-hover) 0%,var(--bg-active) 40%,var(--bg-hover) 80%);background-size:800px 100%;animation:skeletonShimmer 1.6s ease-in-out infinite;border-radius:var(--radius-xs);flex-shrink:0}.skeleton--circle{border-radius:var(--radius-full)}.skeleton--text{height:14px;border-radius:var(--radius-xs)}.skeleton--text-last{width:60%!important}.skeleton-text-block{display:flex;flex-direction:column;gap:8px;width:100%}.skeleton--message{display:flex;gap:12px;padding:8px 16px;align-items:flex-start}.skeleton--message-body{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.skeleton--message-name{width:120px;height:14px}.skeleton--channel{display:flex;align-items:center;gap:8px;padding:6px 8px}.skeleton--channel-icon{width:20px;height:20px;border-radius:var(--radius-xs)}.skeleton--channel-name{width:80%;height:13px}.skeleton--member{display:flex;align-items:center;gap:10px;padding:6px 12px}.skeleton--member-name{width:60%;height:13px}.skeleton--gif-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px}.skeleton--gif-item{aspect-ratio:1;border-radius:var(--radius-xs)}.skeleton__app-loading{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-muted);font-size:14px;flex-direction:column;gap:12px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000eb;display:flex;align-items:center;justify-content:center;animation:lightboxFadeIn .15s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox__header{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;z-index:10}.lightbox__counter{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.lightbox__header-actions{display:flex;gap:8px}.lightbox__btn{display:flex;align-items:center;justify-content:center;background:#ffffff1a;color:var(--text-primary);border:none;border-radius:var(--radius-sm);padding:8px;cursor:pointer;transition:background .12s ease}.lightbox__btn:hover{background:#fff3}.lightbox__content{display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden}.lightbox__image{max-width:90vw;max-height:90vh;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);transition:transform .1s ease-out}.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;background:#ffffff14;color:var(--text-primary);border:none;border-radius:var(--radius-full);width:44px;height:44px;cursor:pointer;z-index:10;transition:background .12s ease}.lightbox__nav:hover{background:#ffffff29}.lightbox__nav--prev{left:16px}.lightbox__nav--next{right:16px}.search-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;animation:searchBarSlideIn .12s ease-out}@keyframes searchBarSlideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.search-bar__input-wrap{display:flex;align-items:center;gap:8px;padding:8px 12px}.search-bar__input-icon{color:var(--text-muted);flex-shrink:0}.search-bar__input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font-size:13px;outline:none;font-family:inherit}.search-bar__input:focus{border-color:var(--brand)}.search-bar__spinner{animation:spin 1s linear infinite;color:var(--text-muted)}.search-bar__close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius-xs);display:flex;align-items:center;transition:color .12s ease}.search-bar__close:hover{color:var(--text-primary)}.search-bar__results{max-height:200px;overflow-y:auto;padding:0 12px 8px;display:flex;flex-direction:column;gap:2px}.search-bar__result{display:flex;align-items:center;gap:8px;padding:6px 8px;border:none;border-radius:var(--radius-sm);background:none;text-align:left;cursor:pointer;width:100%;transition:background .1s ease}.search-bar__result:hover{background:var(--bg-hover)}.search-bar__result-user{font-size:12px;font-weight:600;color:var(--brand);flex-shrink:0;min-width:80px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-bar__result-content{flex:1;font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-bar__result-time{font-size:10px;color:var(--text-muted);flex-shrink:0}.search-bar__more{font-size:11px;color:var(--text-muted);text-align:center;padding:8px 0}.search-bar__empty{font-size:12px;color:var(--text-muted);text-align:center;padding:12px 0}.chat-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.chat-area__messages-wrap{flex:1;display:flex;flex-direction:column;min-height:0;animation:chatFadeIn .15s ease-out}@keyframes chatFadeIn{0%{opacity:0}to{opacity:1}}.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;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__call-btn{margin-left:auto;width:32px;height:32px;border-radius:8px;border:none;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease;flex-shrink:0}.chat-area__call-btn:hover{background:var(--color-accent, #7289da);color:#fff}.chat-area__call-btn:disabled{opacity:.5;cursor:not-allowed}.chat-area__call-btn--active{background:#f04747;color:#fff}.chat-area__call-btn--active:hover{background:#d84040}.chat-area__messages{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:8px 0 16px;display:flex;flex-direction:column;gap:0;position:relative;scrollbar-gutter:stable}.chat-area__scroll-bottom{position:sticky;bottom:0;left:50%;transform:translate(-50%);background:var(--brand);color:var(--text-primary);border:none;border-radius:var(--radius-full);padding:6px 16px;font-size:12px;font-weight:600;cursor:pointer;opacity:.92;transition:opacity .15s ease,background .15s ease;z-index:10;white-space:nowrap;width:-moz-fit-content;width:fit-content;box-shadow:0 2px 8px #0006}.chat-area__scroll-bottom:hover{opacity:1;background:var(--brand-hover)}.chat-area__loading{color:var(--text-muted);font-size:13px;text-align:center;padding:24px 16px}.chat-area__input-bar{flex-shrink:0;padding:0 16px 12px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.chat-area__input-row{display:flex;gap:8px;padding-top:12px}.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;font-family:inherit}.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__input--locked{opacity:.5;cursor:not-allowed}.chat-area__send-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:var(--brand);color:var(--text-primary);padding:8px 14px;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease,opacity .15s ease}.chat-area__send-btn:hover{background:var(--brand-hover)}.chat-area__send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-area__attach-btn{color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;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:.4;cursor:not-allowed}.chat-area__gif-btn{color:var(--text-muted);display:inline-flex;align-items:center;justify-content:center;padding:8px 10px;border:none;background:none;cursor:pointer;border-radius:var(--radius-sm);transition:color .15s ease,background .15s ease}.chat-area__gif-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.chat-area__mention-suggestions{margin:0 0 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__reply-bar{margin:0 0 8px;display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-left:3px solid var(--brand);border-radius:var(--radius-sm);padding:6px 10px}.chat-area__reply-bar-content{flex:1;min-width:0;display:flex;align-items:center;gap:6px}.chat-area__reply-bar-label{font-size:11px;color:var(--text-muted);flex-shrink:0}.chat-area__reply-bar-username{font-size:12px;font-weight:600;color:var(--brand);flex-shrink:0}.chat-area__reply-bar-preview{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-area__reply-bar-close{flex-shrink:0;background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:2px 6px;border-radius:var(--radius-xs);transition:color .15s ease,background .15s ease}.chat-area__reply-bar-close:hover{color:var(--text-primary);background:var(--bg-hover)}.chat-area__upload-preview{margin:0 0 8px;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-thumbnail{width:48px;height:48px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);flex-shrink:0}.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__upload-progress{font-size:12px;color:var(--text-muted);padding:4px 8px}.chat-area__input-hint{font-size:10px;color:var(--text-muted);padding:4px 0}.chat-area__input-hint--error{color:var(--red)}.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}.chat-area__locked-badge{margin-left:8px;font-size:10px;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);background:var(--red-dim);color:var(--red);border:1px solid var(--red-dim-border);white-space:nowrap;display:inline-flex;align-items:center;gap:4px}.chat-area__locked-badge-icon{flex-shrink:0}.chat-area__locked-badge--can-write{background:var(--green-dim);color:var(--green);border-color:var(--green-dim-border)}.chat-area__drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;background:#000000b3;border:2px dashed var(--brand);border-radius:var(--radius-lg);margin:4px;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:dropOverlayFadeIn .15s ease-out}@keyframes dropOverlayFadeIn{0%{opacity:0}to{opacity:1}}.chat-area__drop-overlay-content{display:flex;flex-direction:column;align-items:center;gap:8px}.chat-area__drop-overlay-icon{font-size:32px;color:var(--brand)}.chat-area__drop-overlay-text{font-size:14px;font-weight:600;color:var(--brand)}@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);width:0;margin:8px 0}}.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;scrollbar-gutter:stable}.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__online-dot--online{background:var(--green)}.member-list__online-dot--idle{background:var(--yellow)}.member-list__online-dot--busy{background:var(--red)}.member-list__online-dot--offline{background:var(--gray)}.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__host-badge{font-size:10px;color:#f59e0b;font-weight:600;flex-shrink:0}.member-list__self-tag{font-size:9px;color:var(--text-muted);flex-shrink:0}.member-list__group{margin-bottom:4px}.member-list__group-header{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 4px;font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px}.member-list__group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.member-list__group-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-list__group-count{color:var(--text-muted);font-size:9px}.member-list__group-online{color:var(--text-muted);font-size:9px;margin-left:auto}.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}@media (max-width: 768px){.member-list{width:180px}}@media (max-width: 600px){.member-list{position:fixed;top:0;right:0;bottom:0;z-index:100;margin:0;border-radius:0;box-shadow:-4px 0 24px #0006}}@keyframes modalOverlayFadeOut{0%{opacity:1}to{opacity:0}}@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:620px;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__profile-preview{position:relative;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-tertiary)}.server-menu__profile-banner{position:relative;height:100px;cursor:pointer;overflow:hidden;border-radius:var(--radius-md) var(--radius-md) 0 0}.server-menu__profile-banner-empty{height:100%;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-hover) 50%,var(--bg-tertiary) 100%)}.server-menu__profile-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000073;opacity:0;transition:opacity .2s ease}.server-menu__profile-banner:hover .server-menu__profile-banner-overlay{opacity:1}.server-menu__profile-banner-overlay span{font-size:10px;font-weight:500;color:#fff;font-family:var(--font-mono);letter-spacing:.03em;padding:4px 12px;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.server-menu__profile-banner-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.server-menu__profile-avatar-wrap{position:absolute;bottom:-12px;left:16px;z-index:1}.server-menu__profile-avatar{width:64px;height:64px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--text-primary);background:var(--brand);border:4px solid var(--bg-secondary);overflow:hidden;position:relative;cursor:pointer;transition:border-color .15s ease;box-shadow:0 2px 8px #0000004d}.server-menu__profile-avatar:hover{border-color:var(--brand)}.server-menu__profile-avatar-letter{z-index:0}.server-menu__profile-avatar-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-full)}.server-menu__profile-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .2s ease;border-radius:var(--radius-full)}.server-menu__profile-avatar:hover .server-menu__profile-avatar-overlay{opacity:1}.server-menu__profile-avatar-overlay span{font-size:18px;color:#fff;font-weight:300;line-height:1}.server-menu__profile-actions{display:flex;gap:6px;padding:20px 16px 12px;flex-wrap:wrap}.server-menu__profile-action{font-size:10px;font-weight:500;font-family:var(--font-mono);padding:3px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s ease;letter-spacing:.02em}.server-menu__profile-action:hover{border-color:var(--brand);color:var(--text-primary);background:var(--bg-hover)}.server-menu__profile-action--remove:hover{border-color:var(--red);color:var(--red)}.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;position:relative}.server-menu__tab:hover{color:var(--text-primary)}.server-menu__tab--active{background:var(--bg-hover);color:var(--text-primary)}.server-menu__tab--active:after{content:"";position:absolute;bottom:1px;left:50%;transform:translate(-50%);width:60%;height:2px;background:var(--brand);border-radius:1px}.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 32px 6px 10px;color:var(--text-primary);font-size:12px;font-family:var(--font-mono);outline:none;transition:border-color .15s ease;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance: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='%236b6b6b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.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:var(--bg-tertiary)}.server-menu__color-input::-webkit-color-swatch-wrapper{padding:2px}.server-menu__color-input::-webkit-color-swatch{border:none;border-radius:calc(var(--radius-sm) - 2px)}.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-flags{display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap}.server-menu__role-flag{display:flex;align-items:center;gap:4px;font-size:10px;font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.server-menu__role-flag input[type=checkbox]{accent-color:var(--brand);cursor:pointer}.server-menu__role-tag{font-size:8px;font-family:var(--font-mono);padding:1px 5px;border-radius:3px;background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border-color);white-space:nowrap}.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(--brand-dim)}.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:1px solid var(--border-color);border-radius:3px;outline:none;cursor:pointer}.server-menu__range::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:var(--bg-tertiary)}.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);margin-top:-4px}.server-menu__range::-webkit-slider-thumb:active{transform:scale(1.15)}.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)}.server-menu__role-remove-btn{margin-left:3px;font-size:8px;background:none;border:none;color:inherit;cursor:pointer;opacity:.6;padding:0 2px;line-height:1;transition:opacity .15s ease}.server-menu__role-remove-btn:hover{opacity:1}.server-menu__toggle-row{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.server-menu__toggle-switch{position:relative;width:40px;height:22px;flex-shrink:0}.server-menu__toggle-switch input{opacity:0;width:0;height:0;position:absolute}.server-menu__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}.server-menu__toggle-switch input:checked+.server-menu__toggle-track{background:var(--brand);border-color:var(--brand)}.server-menu__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}.server-menu__toggle-switch input:checked+.server-menu__toggle-track .server-menu__toggle-thumb{transform:translate(18px)}.server-menu__member-search{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px 10px;color:var(--text-primary);font-size:11px;font-family:var(--font-mono);outline:none;margin-bottom:12px;transition:border-color .15s ease}.server-menu__member-search::-moz-placeholder{color:var(--text-muted)}.server-menu__member-search::placeholder{color:var(--text-muted)}.server-menu__member-search:focus{border-color:var(--brand)}.server-menu__member-avatar-wrap{position:relative;flex-shrink:0}.server-menu__status-dot{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:50%;border:2px solid var(--bg-secondary)}.server-menu__status-dot--online{background:var(--green)}.server-menu__status-dot--idle{background:var(--yellow)}.server-menu__status-dot--busy{background:var(--red)}.server-menu__member-checkbox{display:flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;cursor:pointer;opacity:0;transition:opacity .15s ease;position:relative}.server-menu__member-checkbox input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.server-menu__member-checkbox-visual{display:block;width:14px;height:14px;border-radius:3px;border:1.5px solid var(--text-muted);background:var(--bg-tertiary);transition:all .15s ease;position:relative}.server-menu__member-checkbox input:checked+.server-menu__member-checkbox-visual{background:var(--brand);border-color:var(--brand)}.server-menu__member-checkbox input:checked+.server-menu__member-checkbox-visual:after{content:"";position:absolute;left:3.5px;top:1px;width:4px;height:8px;border:solid var(--text-primary);border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.server-menu__member:hover .server-menu__member-checkbox,.server-menu__member--selected .server-menu__member-checkbox{opacity:1}.server-menu__member-checkbox:hover .server-menu__member-checkbox-visual{border-color:var(--brand)}.server-menu__member--selected{background:var(--brand-dim);border-color:var(--brand)}.server-menu__bulk-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--brand-dim);border:1px solid var(--brand);border-radius:var(--radius-md);margin-bottom:12px;flex-wrap:wrap}.server-menu__bulk-bar-count{font-size:10px;font-family:var(--font-mono);color:var(--brand);font-weight:600;white-space:nowrap}.server-menu__bulk-bar-actions{display:flex;gap:4px;flex-wrap:wrap}.server-menu__bulk-bar-btn{font-size:9px;font-family:var(--font-mono);padding:3px 8px;border-radius:var(--radius-sm);border:1px solid var(--brand);background:var(--bg-hover);color:var(--brand);cursor:pointer;transition:all .15s ease}.server-menu__bulk-bar-btn:hover{background:var(--brand);color:var(--text-primary)}.server-menu__bulk-bar-btn--danger{border-color:var(--red);color:var(--red)}.server-menu__bulk-bar-btn--danger:hover{background:var(--red);color:var(--text-primary)}.server-menu__member-overflow-wrap{position:relative;flex-shrink:0}.server-menu__member-overflow-btn{display:flex;align-items:center;justify-content:center;color:var(--text-muted);background:none;border:1px solid transparent;border-radius:var(--radius-sm);padding:4px;cursor:pointer;transition:all .15s ease;line-height:1}.server-menu__member-overflow-btn:hover{color:var(--text-primary);border-color:var(--border-color);background:var(--bg-hover)}.server-menu__member-overflow-btn--active{color:var(--brand);border-color:var(--brand);background:var(--brand-dim)}.server-menu__overflow-menu{position:absolute;right:0;top:100%;margin-top:4px;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px;z-index:10;box-shadow:0 8px 24px #0006;animation:overflowMenuIn .12s ease-out}@keyframes overflowMenuIn{0%{opacity:0;transform:translateY(-4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.server-menu__overflow-item{display:block;width:100%;text-align:left;font-size:10px;font-family:var(--font-mono);color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);padding:6px 10px;cursor:pointer;transition:all .12s ease}.server-menu__overflow-item:hover{background:var(--bg-hover);color:var(--text-primary)}.server-menu__overflow-item--danger:hover{background:var(--red-dim);color:var(--red)}.server-menu__overflow-divider{height:1px;background:var(--border-color);margin:4px 0}.server-menu__overflow-section-title{font-size:8px;font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px 2px}.server-menu__overflow-role-item{display:flex;align-items:center;gap:6px;width:100%;font-size:10px;font-family:var(--font-mono);color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;transition:all .12s ease;text-align:left}.server-menu__overflow-role-item:hover{background:var(--bg-hover);color:var(--text-primary)}.server-menu__overflow-role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.server-menu__overflow-role-check{margin-left:auto;font-size:10px;color:var(--green)}.server-menu__confirm-panel{padding:8px 10px;background:var(--red-dim);border:1px solid var(--red-dim-border);border-radius:var(--radius-sm);margin-top:6px}.server-menu__confirm-text{font-size:10px;font-family:var(--font-mono);color:var(--red);margin-bottom:6px}.server-menu__confirm-actions{display:flex;gap:6px}.server-menu__confirm-btn{font-size:9px;font-family:var(--font-mono);padding:3px 10px;border-radius:var(--radius-sm);border:1px solid var(--red);background:var(--red);color:var(--text-primary);cursor:pointer;transition:all .15s ease}.server-menu__confirm-btn:hover{background:var(--red-hover)}.server-menu__confirm-cancel{font-size:9px;font-family:var(--font-mono);padding:3px 10px;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__confirm-cancel:hover{color:var(--text-primary)}.server-menu__role-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px}.server-menu__role-count{font-size:9px;font-family:var(--font-mono);color:var(--text-muted)}.server-menu__role-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.server-menu__perm-tooltip{font-size:8px;font-family:var(--font-mono);color:var(--text-muted);line-height:1.4}.server-menu__info-loading{font-size:10px;font-family:var(--font-mono);color:var(--text-muted);padding:8px 0;text-align:center}.server-menu__css-char-count--warn{color:var(--yellow)}.server-menu__css-char-count--over{color:var(--red)}.server-menu__self-warn{font-size:9px;font-family:var(--font-mono);color:var(--yellow);background:#fab0051a;border:1px solid rgba(250,176,5,.3);border-radius:var(--radius-sm);padding:6px 10px;margin-top:8px}.server-menu__gif-upload{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:12px}.server-menu__gif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:300px;overflow-y:auto}.server-menu__gif-item{position:relative;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);overflow:hidden}.server-menu__gif-thumb{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;display:block}.server-menu__gif-item-info{padding:4px 6px;display:flex;flex-direction:column;gap:1px}.server-menu__gif-item-name{font-size:10px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.server-menu__gif-item-cat{font-size:9px;color:var(--text-muted)}.server-menu__gif-delete{position:absolute;top:4px;right:4px;background:#0009;color:#fff;border:none;border-radius:4px;padding:2px 6px;font-size:10px;cursor:pointer;opacity:0;transition:opacity .15s}.server-menu__gif-item:hover .server-menu__gif-delete{opacity:1}.server-menu__gif-delete:hover{background:var(--red)}@keyframes modalOverlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideDown{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-dialog{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:448px;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}.login-dialog__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px}.login-dialog__header-title{font-size:13px;font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.login-dialog__close-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:12px;font-family:var(--font-mono);padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s ease,background .15s ease}.login-dialog__close-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.login-dialog__body{padding:0 24px 24px}@keyframes notificationSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.notification-container{position:fixed;bottom:16px;right:16px;z-index:1000;display:flex;flex-direction:column;gap:8px;pointer-events:none}.notification-toast{display:flex;align-items:flex-start;gap:10px;background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 12px;min-width:300px;max-width:400px;box-shadow:0 4px 16px #0006;animation:notificationSlideIn .25s ease-out;pointer-events:auto}.notification-toast--clickable{cursor:pointer;transition:border-color .15s ease}.notification-toast--clickable:hover{border-color:var(--brand)}.notification-toast__icon{color:var(--brand);flex-shrink:0;margin-top:1px}.notification-toast__body{flex:1;min-width:0}.notification-toast__title{font-size:12px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-toast__text{font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.notification-toast__close{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:3px;flex-shrink:0;transition:color .15s ease,background .15s ease}.notification-toast__close:hover{color:var(--text-primary);background:var(--bg-hover)}.quick-switcher-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;background:#0009;animation:quickSwitcherFadeIn .12s ease-out}@keyframes quickSwitcherFadeIn{0%{opacity:0}to{opacity:1}}.quick-switcher{width:480px;max-width:90vw;max-height:60vh;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:0 8px 40px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:quickSwitcherSlideDown .15s ease-out}@keyframes quickSwitcherSlideDown{0%{transform:translateY(-12px);opacity:0}to{transform:translateY(0);opacity:1}}.quick-switcher__input-wrap{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-color)}.quick-switcher__input-icon{color:var(--text-muted);font-size:16px;font-family:var(--font-mono);flex-shrink:0}.quick-switcher__input{flex:1;background:none;border:none;color:var(--text-primary);font-size:15px;outline:none;font-family:inherit}.quick-switcher__input::-moz-placeholder{color:var(--text-muted)}.quick-switcher__input::placeholder{color:var(--text-muted)}.quick-switcher__results{flex:1;overflow-y:auto;padding:8px;min-height:0}.quick-switcher__empty{color:var(--text-muted);font-size:13px;text-align:center;padding:24px 0}.quick-switcher__item{width:100%;display:flex;align-items:center;gap:12px;padding:8px 12px;border:none;border-radius:var(--radius-sm);background:none;text-align:left;cursor:pointer;transition:background .1s ease}.quick-switcher__item:hover,.quick-switcher__item--selected{background:var(--brand-dim)}.quick-switcher__item-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.quick-switcher__item-icon--text{background:var(--bg-tertiary);color:var(--text-secondary)}.quick-switcher__item-icon--voice{background:var(--green-dim);color:var(--green)}.quick-switcher__item-icon--dm{background:var(--brand-dim);color:var(--brand)}.quick-switcher__item-info{display:flex;flex-direction:column;min-width:0}.quick-switcher__item-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quick-switcher__item-subtitle{font-size:11px;color:var(--text-muted)}.quick-switcher__footer{display:flex;align-items:center;gap:16px;padding:8px 16px;border-top:1px solid var(--border-color);font-size:11px;color:var(--text-muted)}.quick-switcher__footer kbd{display:inline-block;padding:1px 5px;font-size:10px;font-family:var(--font-mono);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:3px;margin-right:3px}.incoming-call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000080;animation:incomingCallFadeIn .2s ease-out}@keyframes incomingCallFadeIn{0%{opacity:0}to{opacity:1}}.incoming-call-card{background:var(--color-bg-primary, #1e1e2e);border:1px solid var(--color-border, #313244);border-radius:16px;padding:32px 40px;display:flex;flex-direction:column;align-items:center;gap:12px;min-width:280px;box-shadow:0 16px 48px #0006}.incoming-call-avatar{width:64px;height:64px;border-radius:50%;background:var(--color-accent, #7289da);color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;margin-bottom:4px}.incoming-call-title{margin:0;font-size:20px;font-weight:700;color:var(--color-text-primary, #cdd6f4)}.incoming-call-subtitle{margin:0;font-size:14px;color:var(--color-text-secondary, #a6adc8);animation:incomingCallPulse 1.5s ease-in-out infinite}@keyframes incomingCallPulse{0%,to{opacity:.6}50%{opacity:1}}.incoming-call-actions{display:flex;gap:24px;margin-top:12px}.incoming-call-btn{width:52px;height:52px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}.incoming-call-btn:hover{transform:scale(1.1)}.incoming-call-btn--accept{background:#43b581;color:#fff}.incoming-call-btn--accept:hover{box-shadow:0 4px 16px #43b58166}.incoming-call-btn--reject{background:#f04747;color:#fff}.incoming-call-btn--reject:hover{box-shadow:0 4px 16px #f0474766}.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__body{padding:16px 20px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.export-modal__json{width:100%;max-height:200px;overflow:auto;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);white-space:pre-wrap;word-break:break-all;margin:0}.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)}.connect-dialog{width:480px}.connect-dialog__connect{display:flex;flex-direction:column;gap:12px}.connect-dialog__input{width:100%;box-sizing:border-box}.connect-dialog__saved-header{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin:16px 0 8px}.connect-dialog__saved-server{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);font-size:14px;text-align:left;transition:background .15s ease,border-color .15s ease;margin-bottom:6px}.connect-dialog__saved-server:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.connect-dialog__saved-server-info{display:flex;flex-direction:column;gap:2px}.connect-dialog__saved-server-url{font-size:11px;color:var(--text-muted);font-family:var(--font-mono)}.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;display:flex;flex-direction:column;min-width:0;margin:8px;gap:0}.chat-main__content{flex:1;display:flex;flex-direction:column;min-height:0;position:relative;border-radius:var(--radius-xl);overflow:hidden;background:var(--bg-secondary);border:1px solid var(--border-color)}.chat-toolbar{display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.chat-toolbar__left{display:flex;align-items:center;gap:8px}.chat-toolbar__members-btn{display:inline-flex;align-items:center;gap:6px;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.chat-toolbar__members-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-toolbar__members-btn--active{border-color:var(--brand-dim-border);background:var(--brand-dim);color:var(--brand)}.chat-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center}.chat-placeholder__icon{width:72px;height:72px;border-radius:var(--radius-xl);background:var(--brand-dim);border:1px solid var(--brand-dim-border);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--brand);overflow:hidden;margin-bottom:8px}.chat-placeholder__icon-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.chat-placeholder__title{font-size:20px;font-weight:700;color:var(--text-primary)}.chat-placeholder__subtitle{font-size:14px;color:var(--text-muted);max-width:360px}.chat-placeholder__stats{display:flex;gap:24px;margin-top:12px}.chat-placeholder__stat{display:flex;flex-direction:column;align-items:center;gap:2px}.chat-placeholder__stat-value{font-size:22px;font-weight:700;color:var(--text-primary)}.chat-placeholder__stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}@keyframes connectionBannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.connection-banner{position:absolute;top:0;left:0;right:0;z-index:50;background:var(--red);color:var(--text-primary);font-size:13px;font-weight:600;padding:8px 16px;text-align:center;animation:connectionBannerSlideDown .2s ease-out;display:flex;align-items:center;justify-content:center;gap:8px}.connection-banner__spinner{animation:spin 1s linear infinite}.connection-banner__reconnect{background:#ffffff26;color:var(--text-primary);border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;margin-left:12px;transition:background .15s}.connection-banner__reconnect:hover{background:#ffffff40}@media (max-width: 768px){.chat-layout{padding:4px;gap:4px}.chat-main{margin:4px}}@media (max-width: 600px){.chat-layout{padding:0;gap:0}.chat-main{margin:0}.chat-placeholder{padding:32px 16px}.chat-placeholder__title{font-size:16px}.chat-placeholder__stats{gap:16px}}.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__not-found{flex:1;display:flex;align-items:center;justify-content:center}.login__not-found-text{color:var(--text-secondary);margin-bottom:16px}.settings-modal{background:var(--modal-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:560px;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;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.settings-modal__subsection-title{font-size:10px;font-weight:500;color:var(--text-secondary);letter-spacing:.3px}.settings-modal__select{width:100%;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px 32px 8px 12px;color:var(--text-primary);font-size:14px;font-family:var(--font-mono);outline:none;cursor:pointer;transition:border-color .15s ease;-webkit-appearance:none;-moz-appearance:none;appearance: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='%236b6b6b'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.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__alert--success{color:var(--green);background:var(--green-dim);border:1px solid var(--green-dim-border);border-radius:var(--radius-sm);padding:8px 12px}.settings-modal__alert--error{color:var(--red);background:var(--red-dim);border:1px solid var(--red-dim-border);border-radius:var(--radius-sm);padding:8px 12px}.settings-modal__footer{padding:12px 20px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.settings-modal__check-btn{padding:4px 12px;background:var(--bg-tertiary);color:var(--text-secondary);font-size:11px;font-family:var(--font-mono);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.settings-modal__check-btn:hover{border-color:var(--brand);color:var(--text-primary)}.settings-modal__check-btn:disabled{opacity:.5;cursor:not-allowed}.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}}:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-tertiary: #1a1a1a;--bg-hover: #262626;--bg-active: #2d2d2d;--text-primary: #ffffff;--text-secondary: #a0a0a0;--text-muted: #808080;--border-color: #2a2a2a;--brand: #4c6ef5;--brand-hover: #4263eb;--brand-dim: rgba(76, 110, 245, .15);--brand-dim-border: rgba(76, 110, 245, .25);--brand-glow: rgba(76, 110, 245, .2);--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;--gray: #6b7280;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--focus-ring: 0 0 0 2px var(--bg-primary), 0 0 0 3.5px var(--brand)}*,*: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}*::-webkit-scrollbar-thumb:hover{background-color:var(--bg-hover)}*::-webkit-scrollbar-thumb:active{background-color:var(--text-muted)}:focus-visible{outline:none;box-shadow:var(--focus-ring)}button:focus:not(:focus-visible),[tabindex]:focus:not(:focus-visible),input:focus:not(:focus-visible),textarea:focus:not(:focus-visible),select:focus:not(:focus-visible){outline:none;box-shadow:none}.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:focus-visible{outline:none;box-shadow:var(--focus-ring)}.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-secondary:focus-visible{outline:none;box-shadow:var(--focus-ring)}.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)}.btn-danger:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg-primary),0 0 0 3.5px var(--red)}.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}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.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}
