@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Source+Code+Pro:wght@400;500&family=Instrument+Sans:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-0:#111111;--bg-1:#191919;--bg-2:#222222;--bg-3:#2a2a2a;--bg-4:#323232;--bg-5:#3a3a3a;--bg-h:#2a2a2a;--bg-ub:#0f0f0f;--b1:rgba(255,255,255,.06);--b2:rgba(255,255,255,.1);--t0:#e8e8e8;--t1:#a3a3a3;--t2:#737373;--t3:#525252;--primary:#3b82f6;--primary-s:rgba(59,130,246,.1);--primary-m:rgba(59,130,246,.22);--primary-h:#5b9af7;--green:#22c55e;--green-s:rgba(34,197,94,.1);--red:#ef4444;--red-s:rgba(239,68,68,.1);--yellow:#f0b232;--teal:#3b82f6;--secondary:#3b82f6;--secondary-s:rgba(59,130,246,.08);--gradient:linear-gradient(135deg, #111111 0%, #161616 40%, #1a1a1a 100%);--f-ui:"Instrument Sans",sans-serif;--f-d:"Outfit",sans-serif;--f-m:"Source Code Pro",monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--f-ui);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{font-family:inherit}.theme-transitioning *,.theme-transitioning *:before,.theme-transitioning *:after{transition:background-color .35s ease,color .35s ease,border-color .35s ease,fill .35s ease,stroke .35s ease!important}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-5);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--t3)}*{scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent}@keyframes bip{0%,60%,to{transform:translateY(0);opacity:.35}30%{transform:translateY(-2px);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes ring{0%,to{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(1.25)}}@keyframes vpIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.mqvi-app{display:flex;flex-direction:row;height:100vh;background:var(--bg-0);color:var(--t0);font-family:var(--f-ui);-webkit-font-smoothing:antialiased;overflow:hidden}.app-body{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0}.mqvi-app.mobile{flex-direction:column}.mqvi-app.mobile .sidebar,.mqvi-app.mobile .members-panel{display:none}.mobile-drawer .sidebar{display:flex!important;width:100%!important;height:100%!important;border-right:none;overflow:hidden}.mobile-drawer .sidebar-inner{width:100%!important;height:100%!important}.mobile-drawer .resize-handle{display:none}.mobile-drawer .members-panel{display:flex!important;width:100%!important;height:100%!important;border-left:none;overflow:hidden}.mobile-drawer .members-panel .resize-handle{display:none}.mobile-drawer .members-inner{width:100%!important;height:100%!important}.sidebar{background:var(--bg-1);border-right:1px solid var(--b1);display:flex;flex-shrink:0;overflow:hidden;position:relative}.sidebar-inner{height:100%;display:flex;flex-direction:column;overflow:hidden}.sb-header{height:36px;padding:0 8px 0 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b1);flex-shrink:0}.sb-header-brand{display:flex;align-items:center;gap:8px}.sb-logo{width:24px;height:24px;border-radius:5px}.sb-brand-name{font-family:var(--f-d);font-size:16px;font-weight:700;color:var(--t0);letter-spacing:.02em}.sb-header-actions{display:flex;gap:2px}.sb-header-btn{width:30px;height:30px;border:none;background:transparent;color:var(--t2);cursor:pointer;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .1s,color .1s}.sb-header-btn:hover{background:var(--bg-h);color:var(--t0)}.ch-tree{flex:1;overflow-y:auto;padding:6px 0;scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent}.ch-tree-section{margin-bottom:4px}.ch-tree-section-header{display:flex;align-items:center;gap:5px;width:100%;padding:7px 10px;border:none;background:transparent;color:var(--t2);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-family:var(--f-d);cursor:pointer;transition:color .1s}.ch-tree-section-header:hover{color:var(--t0)}.ch-tree-section-body{padding:0 4px}.ch-tree-server-header{display:flex;align-items:center;justify-content:flex-start;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--t0);font-size:15px;font-weight:700;font-family:var(--f-d);cursor:pointer;transition:color .1s;letter-spacing:0;text-align:left}.ch-tree-server-header:hover{color:var(--t0)}.ch-tree-server-icon{width:24px;height:24px;border-radius:6px;flex-shrink:0;object-fit:cover}.ch-tree-server-icon-fallback{width:24px;height:24px;border-radius:6px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.ch-tree-server-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ch-tree-server-badge{background:var(--red);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center;flex-shrink:0;line-height:16px}.ch-tree-chevron{font-size:13px;color:var(--t3);transition:transform .15s;display:inline-block}.ch-tree-chevron.expanded{transform:rotate(90deg)}.ch-tree-category{margin-bottom:2px;padding-left:8px}.ch-tree-cat-row{display:flex;align-items:center}.ch-tree-cat-header{display:flex;align-items:center;gap:5px;flex:1;padding:5px 8px 5px 14px;border:none;background:transparent;color:var(--t3);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-d);cursor:pointer;transition:color .1s}.ch-tree-cat-header:hover{color:var(--t1)}.ch-tree-cat-add{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;color:var(--t3);font-size:16px;font-weight:700;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .1s,color .1s,background .1s;margin-right:6px;flex-shrink:0}.ch-tree-cat-row:hover .ch-tree-cat-add{opacity:1}.ch-tree-cat-add:hover{color:var(--t0);background:var(--bg-h)}.ch-tree-create-form{padding:4px 10px 6px 28px;display:flex;flex-direction:column;gap:4px}.ch-tree-create-input{width:100%;padding:5px 8px;border:1px solid var(--b1);border-radius:4px;background:var(--bg-0);color:var(--t0);font-size:13px;font-family:var(--f-ui);outline:none}.ch-tree-create-input:focus{border-color:var(--primary)}.ch-tree-create-actions{display:flex;align-items:center;gap:4px}.ch-tree-create-btn{padding:3px 8px;border:none;border-radius:4px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;cursor:pointer}.ch-tree-create-btn:disabled{opacity:.5;cursor:not-allowed}.ch-tree-create-cancel{padding:3px 8px;border:none;border-radius:4px;background:transparent;color:var(--t3);font-size:13px;cursor:pointer}.ch-tree-create-cancel:hover{color:var(--t1)}.ch-tree-drag-wrap{position:relative;transition:opacity .15s}.ch-tree-drag-wrap.dragging{opacity:.4}.ch-tree-drag-wrap.drop-above:before,.ch-tree-drag-wrap.drop-below:after{content:"";position:absolute;left:20px;right:8px;height:2px;background:var(--primary);border-radius:1px;pointer-events:none;z-index:2}.ch-tree-drag-wrap.drop-above:before{top:0}.ch-tree-drag-wrap.drop-below:after{bottom:0}.ch-tree-item{display:flex;align-items:center;gap:7px;width:100%;padding:5px 8px 5px 28px;border:none;background:transparent;color:var(--t1);font-size:14px;font-weight:500;font-family:var(--f-ui);cursor:pointer;border-radius:5px;transition:background .08s;text-align:left}.ch-tree-item:hover{background:var(--bg-h);color:var(--t0)}.ch-tree-item.active{background:var(--primary-s);color:var(--t0)}.ch-tree-item.voice{color:var(--t2)}.ch-tree-item.voice.active{background:var(--green-s);color:var(--green)}.ch-tree-item.has-unread{color:var(--t0);font-weight:600}.ch-tree-dm{padding-left:16px}.ch-tree-icon{font-size:15px;color:var(--t3);min-width:16px;text-align:center;flex-shrink:0}.ch-tree-item.active .ch-tree-icon{color:var(--primary)}.ch-tree-item.voice .ch-tree-icon{color:var(--green)}.ch-tree-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ch-tree-badge{min-width:18px;height:18px;padding:0 5px;background:var(--primary);color:#fff;font-size:13px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1}.ch-tree-unread-dot{width:8px;height:8px;border-radius:999px;background:var(--primary);flex-shrink:0;margin-left:auto}.ch-tree-voice-users{padding:2px 0 2px 42px}.ch-tree-voice-user{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:4px;font-size:13px;color:var(--t2)}.ch-tree-voice-user:hover{background:var(--bg-h)}.ch-tree-vu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ch-tree-vu-icons{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.ch-tree-vu-icon{width:14px;height:14px;flex-shrink:0}button.ch-tree-vu-stream{all:unset;display:flex;align-items:center;justify-content:center;width:14px;height:14px;flex-shrink:0;cursor:pointer;color:var(--t2);transition:color .15s}button.ch-tree-vu-stream:hover{color:var(--t0)}button.ch-tree-vu-stream.watching{color:var(--green)}button.ch-tree-vu-stream svg{width:14px;height:14px}.ch-tree-vu-mute,.ch-tree-vu-deafen{color:var(--red);opacity:.7}.ch-tree-vu-dot{width:6px;height:6px;border-radius:999px;background:var(--green);animation:pulse 1.5s ease-in-out infinite;flex-shrink:0}.ch-tree-voice-user.speaking{color:var(--t1)}.ch-tree-voice-user.speaking .avatar{box-shadow:0 0 0 2px var(--green)}.ch-tree-voice-user[draggable=true]{cursor:grab;user-select:none}.ch-tree-voice-user[draggable=true]:active{cursor:grabbing}.ch-tree-voice-user.vu-dragging{opacity:.35}.ch-tree-item.voice.voice-drop-target{background:color-mix(in srgb,var(--primary) 18%,transparent);box-shadow:inset 0 0 0 1.5px var(--primary);border-radius:5px}.ch-tree-placeholder{padding:6px 16px}.ch-tree-placeholder-text{font-size:13px;color:var(--t3);font-style:italic}.user-bar{flex-shrink:0;background:var(--bg-ub);border-top:1px solid var(--b1)}.ub-voice-row{display:flex;flex-direction:column;padding:6px 0;border-bottom:1px solid var(--b1);gap:2px}.ub-voice-info{display:flex;align-items:center;gap:6px;position:relative;padding:0 10px}.ub-voice-pulse{width:8px;height:8px;background:var(--green);border-radius:999px;animation:pulse 2s ease-in-out infinite;flex-shrink:0}.ub-voice-label{font-size:13px;font-weight:600;color:var(--green);font-family:var(--f-d)}.ub-ping-tooltip{position:absolute;bottom:calc(100% + 8px);left:0;display:flex;align-items:center;gap:6px;background:var(--bg-1);border:1px solid var(--b1);border-radius:6px;padding:6px 10px;box-shadow:0 4px 12px #0000004d;opacity:0;pointer-events:none;transition:opacity .15s;white-space:nowrap;z-index:50}.ub-voice-info:hover .ub-ping-tooltip{opacity:1;pointer-events:auto}.ub-ping-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0;background:var(--t3)}.ub-ping-value{font-size:13px;font-weight:600;font-family:var(--f-m);color:var(--t1)}.ub-ping-dot.ub-ping-good{background:var(--green)}.ub-ping-dot.ub-ping-mid{background:var(--yellow)}.ub-ping-dot.ub-ping-bad{background:var(--red)}.ub-voice-btns{display:flex;gap:3px;padding:2px 10px;justify-content:center}.ub-main{display:flex;align-items:center;gap:8px;padding:8px 10px}.ub-user-wrap{position:relative;flex:1;min-width:0}.ub-user{display:flex;align-items:center;gap:8px;flex:1;min-width:0;cursor:pointer;border-radius:6px;padding:2px 4px;margin:-2px -4px;transition:background .1s}.ub-user:hover{background:var(--bg-h)}.ub-avatar-wrap{position:relative;flex-shrink:0}.ub-status-dot{position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-radius:999px;border:2px solid var(--bg-ub)}.ub-dot-online{background:var(--green)}.ub-dot-idle{background:var(--yellow)}.ub-dot-dnd{background:var(--red)}.ub-dot-offline{background:var(--t3)}.ub-info{display:flex;flex-direction:column;min-width:0}.ub-name{font-size:14px;font-weight:600;color:var(--t0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ub-status{font-size:13px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ub-ctrl{width:34px;height:34px;border:none;background:transparent;color:var(--t2);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:15px;transition:background .1s,color .1s}.ub-ctrl:hover{background:var(--bg-h);color:var(--t0)}.ub-ctrl.active{color:var(--primary);background:var(--primary-s)}.ub-end{color:var(--red)!important}.ub-end:hover{background:var(--red-s)!important}.ub-settings{font-size:16px}.ub-sp{position:absolute;bottom:calc(100% + 6px);left:0;width:300px;background:var(--bg-1);border:1px solid var(--b1);border-radius:8px;padding:6px;box-shadow:0 8px 24px #0006;z-index:100;animation:ub-sp-in .12s ease-out}@keyframes ub-sp-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.ub-sp-header{padding:6px 8px 4px;font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.02em}.ub-sp-divider{height:1px;background:var(--b1);margin:2px 0}.ub-sp-item{display:flex;align-items:center;gap:10px;width:100%;border:none;background:transparent;padding:8px;border-radius:6px;cursor:pointer;transition:background .1s;text-align:left}.ub-sp-item:hover{background:var(--bg-h)}.ub-sp-item.active{background:var(--primary-s)}.ub-sp-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.ub-sp-green{background:var(--green)}.ub-sp-yellow{background:var(--yellow)}.ub-sp-red{background:var(--red)}.ub-sp-gray{background:var(--t3)}.ub-sp-text{display:flex;flex-direction:column;flex:1;min-width:0}.ub-sp-label{font-size:14px;font-weight:500;color:var(--t0)}.ub-sp-desc{font-size:13px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ub-sp-check{color:var(--primary);flex-shrink:0}.ub-nr-row{display:flex;align-items:center;justify-content:space-between;padding:4px 10px;gap:8px}.ub-nr-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--t2)}.ub-switch{position:relative;width:36px;height:20px;border:none;border-radius:999px;cursor:pointer;background:var(--bg-5);transition:background .2s;flex-shrink:0;padding:0}.ub-switch:hover{background:var(--t3)}.ub-switch.active{background:var(--green)}.ub-switch.active:hover{background:var(--green-h,var(--green))}.ub-switch-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:999px;background:#fff;transition:transform .2s;pointer-events:none}.ub-switch.active .ub-switch-thumb{transform:translate(16px)}.resize-handle{position:absolute;top:0;width:4px;height:100%;cursor:col-resize;z-index:10;transition:background .15s}.resize-handle:hover{background:var(--primary-m)}.resize-handle.active{background:var(--primary)}.sidebar>.resize-handle{right:0}.members-panel>.resize-handle{left:0}.sb-collapsed{width:52px;background:var(--bg-1);border-right:1px solid var(--b1);display:flex;flex-direction:column;align-items:center;padding:6px 0;gap:6px;flex-shrink:0;transition:width .2s cubic-bezier(.22,1,.36,1)}.sb-collapsed-btn{width:36px;height:36px;border:none;background:var(--bg-3);color:var(--t1);cursor:pointer;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .15s;position:relative}.sb-collapsed-btn:hover{background:var(--bg-4);color:var(--t0)}.sb-collapsed-expand{background:transparent;font-size:13px}.sb-collapsed-icon{width:30px;height:30px;border-radius:6px}.sb-collapsed-dm{font-size:16px}.sb-collapsed-badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;padding:0 4px;background:var(--red);color:#fff;font-size:10px;font-weight:700;border-radius:999px;display:flex;align-items:center;justify-content:center;line-height:1}.sb-collapsed-spacer{flex:1}.sb-collapsed-avatar{padding:4px 0}.tab-icon{font-size:13px;color:var(--t3);display:flex;align-items:center}.tab-label{font-size:13.5px;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.main-area{flex:1;display:flex;min-height:0;position:relative}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-2);min-width:0;min-height:0;position:relative}.channel-bar{height:32px;padding:0 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.03);flex-shrink:0}.ch-hash{color:var(--t3);font-size:14px}.ch-name{font-family:var(--f-d);font-size:13px;font-weight:600;color:var(--t0)}.ch-divider{width:1px;height:12px;background:var(--b1)}.ch-topic{font-size:13px;color:var(--t3)}.ch-actions{margin-left:auto;display:flex;gap:1px}.ch-actions button{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px}.ch-actions button:hover{color:var(--t1);background:var(--bg-h)}.ch-actions button.active{color:var(--primary);background:var(--primary-s)}.messages-scroll{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent;mask-image:linear-gradient(to bottom,transparent,black 3%,black)}.date-divider{display:flex;align-items:center;gap:10px;padding:6px 14px;margin:4px 0}.date-divider:before,.date-divider:after{content:"";flex:1;height:1px;background:var(--b1)}.date-divider span{font-size:13px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.04em;font-family:var(--f-d);white-space:nowrap}.msg{padding:2px 14px;position:relative;transition:background .08s}.msg:hover{background:#00000021}.msg.first-of-group{margin-top:10px}.msg-row{display:flex;gap:9px;align-items:flex-start}.msg.grouped .msg-avatar{visibility:hidden}.msg.grouped .msg-meta{display:none}.msg-gtime{position:absolute;left:14px;width:38px;text-align:center;font-size:13px;color:var(--t3);font-family:var(--f-m);opacity:0;top:50%;transform:translateY(-50%)}.msg.grouped:hover .msg-gtime{opacity:1}.msg-avatar{flex-shrink:0}.msg-body{min-width:0;flex:1}.msg-meta{display:flex;align-items:baseline;gap:6px;margin-bottom:1px}.msg-name{font-size:13px;font-weight:600;cursor:pointer;color:var(--t0)}.msg-name:hover{opacity:.75}.msg-time{font-size:13px;color:var(--t3);font-family:var(--f-m)}.msg-text{font-size:13px;line-height:1.45;color:var(--t0);white-space:pre-wrap;word-break:break-word}.msg-text code{font-family:var(--f-m);font-size:13px;background:var(--bg-0);padding:1px 5px;border-radius:3px;border:1px solid var(--b1);color:var(--teal)}.msg-edited{font-size:13px;color:var(--t3);margin-left:4px}.mention{background:var(--primary-s);color:var(--primary);padding:0 3px;border-radius:3px;font-weight:500;cursor:pointer}.mention:hover{background:var(--primary-m)}.msg-mention{background:var(--primary-s);color:var(--primary);padding:0 3px;border-radius:3px;font-weight:500}.msg-mention:hover{background:var(--primary-m)}.msg-pin-indicator{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--t3);margin-bottom:2px}.msg-pin-indicator svg{color:var(--primary)}.msg-hover-actions{position:absolute;top:-11px;right:14px;display:flex;background:var(--bg-4);border:1px solid var(--b2);border-radius:6px;box-shadow:0 4px 14px #0006;opacity:0;pointer-events:none;transition:opacity .1s}.msg-hover-actions:after{content:"";position:absolute;left:0;right:0;top:100%;height:14px}.msg:hover .msg-hover-actions,.msg.picker-open .msg-hover-actions{opacity:1;pointer-events:auto}.msg-hover-actions button{width:26px;height:24px;border:none;background:transparent;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px}.msg-hover-actions button:hover{color:var(--t0);background:var(--bg-h)}.msg-hover-actions button:first-child{border-radius:5px 0 0 5px}.msg-hover-actions button:last-child{border-radius:0 5px 5px 0}.msg-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.msg-attachment-img{max-height:300px;border-radius:8px;object-fit:contain;cursor:pointer}.msg-attachment-file{display:flex;align-items:center;gap:8px;padding:10px;border-radius:8px;border:1px solid var(--b1);background:var(--bg-1);cursor:pointer;transition:background .1s}.msg-attachment-file:hover{background:var(--bg-h)}.msg-attachment-file-icon{width:28px;height:28px;color:var(--t2);flex-shrink:0}.msg-attachment-file-name{font-size:13px;font-weight:500;color:var(--primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-attachment-file-name:hover{text-decoration:underline}.msg-attachment-file-size{font-size:13px;color:var(--t3)}.msg-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;align-items:center}.msg-reaction-btn{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;border:1px solid var(--b1);background:var(--bg-3);cursor:pointer;transition:all .1s;font-size:13px}.msg-reaction-btn:hover{background:var(--bg-4);border-color:var(--b2)}.msg-reaction-btn.active{border-color:var(--primary);background:var(--primary-s)}.msg-reaction-emoji{font-size:14px;line-height:1}.msg-reaction-count{font-size:13px;color:var(--t1);font-family:var(--f-m);min-width:8px;text-align:center}.msg-reaction-btn.active .msg-reaction-count{color:var(--primary)}.msg-reaction-add-wrap{position:relative}.msg-reaction-add{width:24px;height:24px;border-radius:999px;border:1px solid var(--b1);background:var(--bg-3);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .1s;opacity:0}.msg:hover .msg-reaction-add,.msg.picker-open .msg-reaction-add{opacity:1}.msg-reaction-add:hover{background:var(--bg-4);border-color:var(--b2);color:var(--t0)}.emoji-picker{position:absolute;bottom:100%;left:0;width:320px;background:var(--bg-3);border:1px solid var(--b2);border-radius:10px;box-shadow:0 8px 24px #00000080;z-index:100;overflow:hidden;margin-bottom:6px}.emoji-picker-flipped{bottom:auto;top:100%;margin-bottom:0;margin-top:6px}.msg-hover-actions .emoji-picker,.input-emoji-picker-wrap .emoji-picker{left:auto;right:0}.emoji-picker-tabs{display:flex;border-bottom:1px solid var(--b1);padding:0 4px}.emoji-picker-tab{flex:1;padding:8px 0;border:none;background:transparent;cursor:pointer;font-size:16px;opacity:.5;transition:opacity .1s;position:relative}.emoji-picker-tab:hover{opacity:.8}.emoji-picker-tab.active{opacity:1}.emoji-picker-tab.active:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--primary);border-radius:1px}.emoji-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:8px;max-height:200px;overflow-y:auto}.emoji-picker-btn{width:100%;aspect-ratio:1;border:none;background:transparent;cursor:pointer;font-size:20px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .08s}.emoji-picker-btn:hover{background:var(--bg-h)}.msg-reply-preview{display:flex;align-items:center;gap:6px;padding:2px 0 4px;cursor:pointer;font-size:13px;max-width:400px}.msg-reply-preview:hover{opacity:.8}.msg-reply-bar{width:2px;height:14px;border-radius:1px;background:var(--primary);flex-shrink:0}.msg-reply-author{font-weight:600;color:var(--t1);white-space:nowrap}.msg-reply-content{color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-reply-deleted{color:var(--t3);font-style:italic}.msg-highlight{background:var(--primary-s);transition:background 2s ease-out}.msg-edit-area{margin-top:4px}.msg-edit-textarea{width:100%;resize:none;border-radius:8px;background:var(--bg-3);padding:8px;font-size:13px;color:var(--t0);border:none;outline:none;font-family:var(--f-ui)}.msg-edit-textarea:focus{background:var(--bg-4)}.msg-edit-hint{font-size:13px;color:var(--t3);margin-top:4px}.msg-welcome{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;padding:32px;text-align:center}.msg-welcome-icon{width:76px;height:76px;border-radius:999px;background:var(--bg-3);display:flex;align-items:center;justify-content:center;margin-bottom:16px}.msg-welcome-icon span{font-size:42px;color:var(--t2);line-height:1}.msg-welcome h2{font-size:32px;font-weight:700;color:var(--t0);font-family:var(--f-d);margin-bottom:8px;line-height:1.1}.msg-welcome p{font-size:16px;color:var(--t2);max-width:480px;line-height:1.5}.typing-indicator{height:18px;padding:0 14px;display:flex;align-items:center;gap:4px;flex-shrink:0;position:relative;z-index:2}.typing-dots{display:flex;gap:2px}.typing-dots i{width:3.5px;height:3.5px;background:var(--t3);border-radius:999px;animation:bip 1.4s ease-in-out infinite;display:block}.typing-dots i:nth-child(2){animation-delay:.15s}.typing-dots i:nth-child(3){animation-delay:.3s}.typing-indicator span{font-size:13px;color:var(--t3)}.typing-indicator strong{color:var(--t2);font-weight:600}.input-area{padding:0 10px 10px;flex-shrink:0;position:relative;z-index:2}.reply-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-radius:8px 8px 0 0;border:1px solid var(--b1);border-bottom:none;margin-bottom:-1px}.reply-bar-icon{color:var(--t2);flex-shrink:0}.reply-bar-user{font-size:13px;font-weight:600;color:var(--t0);white-space:nowrap}.reply-bar-text{font-size:13px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.reply-bar-close{width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:4px}.reply-bar-close:hover{color:var(--t1);background:var(--bg-h)}.reply-bar+.input-box{border-radius:0 0 10px 10px}.input-box{background:var(--bg-3);border:1px solid var(--b1);border-radius:10px;display:flex;align-items:flex-end;padding:4px;transition:border-color .15s}.input-box:focus-within{border-color:var(--primary)}.input-action-btn{width:36px;height:36px;border:none;background:transparent;color:var(--t2);cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .1s,background .1s}.input-action-btn:hover{color:var(--t0);background:var(--bg-h)}.input-box button{width:36px;height:36px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}.input-box button:hover{color:var(--t1);background:var(--bg-h)}.send-btn{color:var(--primary)!important}.input-box textarea{flex:1;background:transparent;border:none;outline:none;color:var(--t0);font-family:var(--f-ui);font-size:14px;padding:8px 6px;resize:none;max-height:100px;line-height:1.4}.input-box textarea::placeholder{color:var(--t3)}.input-box-disabled{justify-content:center;padding:10px;cursor:not-allowed;opacity:.6}.input-no-perm{font-size:13px;color:var(--t3);font-style:italic;user-select:none}.mention-popup{position:absolute;bottom:100%;left:10px;right:10px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:4px;margin-bottom:4px;max-height:200px;overflow-y:auto;z-index:10;box-shadow:0 -4px 12px #0000004d}.mention-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;background:transparent;color:var(--t0);cursor:pointer;border-radius:6px;text-align:left;font-family:inherit;font-size:13px}.mention-item:hover,.mention-item.active{background:var(--bg-h)}.mention-item-avatar{flex-shrink:0}.mention-item-name{font-weight:500;color:var(--t0)}.mention-item-username{font-size:13px;color:var(--t3);margin-left:auto}.file-preview{display:flex;flex-wrap:wrap;gap:8px;padding:0 10px 6px}.file-preview-item{position:relative;width:80px;height:80px;border-radius:8px;overflow:hidden;background:var(--bg-3);border:1px solid var(--b1)}.file-preview-item img{width:100%;height:100%;object-fit:cover}.file-preview-name{position:absolute;bottom:0;left:0;right:0;padding:2px 4px;background:#000000b3;font-size:13px;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-remove{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:999px;background:var(--bg-5);border:1.5px solid var(--bg-1);color:var(--t1);font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1}.file-preview-remove:hover{background:var(--red);color:#fff}.file-drop-overlay{position:absolute;inset:0;z-index:50;background:color-mix(in srgb,var(--primary) 12%,transparent);border:2px dashed var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;pointer-events:none}.file-drop-overlay-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--primary);pointer-events:none}.file-drop-overlay-content svg{opacity:.8}.file-drop-overlay-content span{font-size:16px;font-weight:600;font-family:var(--f-d)}.members-panel{width:0;background:var(--bg-1);border-left:1px solid var(--b1);overflow:hidden;flex-shrink:0;position:relative}.members-inner{height:100%;display:flex;flex-direction:column}.members-header{height:38px;padding:0 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b1)}.members-header h3{font-family:var(--f-d);font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em}.members-header button{width:22px;height:22px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px}.members-header button:hover{color:var(--t1);background:var(--bg-h)}.members-list{flex:1;overflow-y:auto;padding:4px 6px;scrollbar-width:thin;scrollbar-color:var(--bg-5) transparent}.member-label{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--t3);padding:9px 6px 3px;font-family:var(--f-d)}.member{display:flex;align-items:center;gap:9px;padding:5px 6px;border-radius:7px;cursor:pointer;transition:background .08s}.member:hover{background:var(--bg-h)}.member-info{display:flex;flex-direction:column;min-width:0}.member-av-wrap{position:relative;flex-shrink:0}.member-status{position:absolute;bottom:-1px;right:-1px;width:9px;height:9px;border-radius:999px;border:2px solid var(--bg-1)}.status-on{background:var(--green)}.status-idle{background:var(--yellow)}.status-dnd{background:var(--red)}.status-off{background:var(--t3)}.member-name{font-size:13px;font-weight:500;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member:hover .member-name{color:var(--t0)}.member-activity{font-size:13px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member.offline{opacity:.4}.member-card-backdrop{position:fixed;inset:0;z-index:50}.member-card{position:fixed;width:288px;background:#000000e0;backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--b2);border-radius:12px;box-shadow:0 12px 48px #0000008c;z-index:51;overflow:hidden}.member-card-banner{height:64px;background:linear-gradient(135deg,var(--primary),var(--secondary))}.member-card-avatar{position:relative;margin-top:-32px;margin-left:16px}.member-card-body{padding:8px 16px 16px}.member-card-name{font-size:18px;font-weight:700;color:var(--t0);font-family:var(--f-d);margin-top:8px}.member-card-username{font-size:13px;color:var(--t2)}.member-card-divider{height:1px;background:var(--b1);margin:10px 0}.member-card-section-title{font-size:13px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.member-card-roles{display:flex;flex-wrap:wrap;gap:4px}.member-card-joined{font-size:13px;color:var(--t2)}.member-card-actions{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}.member-card-btn{height:30px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;font-family:var(--f-ui);display:flex;align-items:center;justify-content:center;background:var(--bg-4);color:var(--t1);transition:background .15s,color .15s}.member-card-btn:hover{background:var(--bg-5);color:var(--t0)}.member-card-btn-kick{background:var(--bg-4);color:var(--t1)}.member-card-btn-kick:hover{background:var(--bg-5);color:var(--t0)}.member-card-btn-ban{background:var(--red-s);color:var(--red)}.member-card-btn-ban:hover{background:var(--red);color:#fff}.role-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--bg-4);border:1px solid var(--b1);font-size:13px;font-weight:500;color:var(--t1)}.role-badge-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.role-editor-popup{position:fixed;z-index:52;width:240px;max-height:360px;background:var(--bg-2);border:1px solid var(--b1);border-radius:10px;box-shadow:0 8px 24px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:vpIn .12s ease-out}.role-editor-title{padding:12px 14px 8px;font-size:14px;font-weight:700;color:var(--t0);font-family:var(--f-ui)}.role-editor-list{flex:1;overflow-y:auto;padding:0 6px 6px}.role-editor-empty{text-align:center;font-size:13px;color:var(--t3);padding:16px 8px}.role-editor-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--t1);font-family:var(--f-ui)}.role-editor-item:hover{background:var(--bg-4)}.role-editor-item.disabled{opacity:.4;cursor:not-allowed}.role-editor-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.role-editor-dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.role-editor-actions{padding:8px;border-top:1px solid var(--b1);display:flex;justify-content:flex-end}.role-editor-save{height:30px;padding:0 16px;border:none;border-radius:6px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;font-family:var(--f-ui);cursor:pointer;transition:opacity .15s}.role-editor-save:hover{opacity:.85}.role-editor-save:disabled{opacity:.4;cursor:not-allowed}.avatar{border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--f-d);font-weight:600;color:#fff;flex-shrink:0}.avatar-round{border-radius:999px}.av-admin{background:linear-gradient(135deg,var(--primary),var(--primary-h))}.av-mod{background:linear-gradient(135deg,#6fb07a,#4d8a5a)}.av-default{background:linear-gradient(135deg,var(--primary),var(--secondary))}.av-u1{background:linear-gradient(135deg,#8a7ab8,#6a5a98)}.av-u2{background:linear-gradient(135deg,#b87a6a,#986050)}.av-u3{background:linear-gradient(135deg,#5ea5a8,#468588)}.av-u4{background:linear-gradient(135deg,#b8a87a,#988a60)}.split-container{display:flex;flex:1;min-height:0;min-width:0}.split-container.vertical{flex-direction:column}.split-pane{display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.split-handle{background:transparent;flex-shrink:0;position:relative;z-index:5;transition:background .15s}.split-handle:hover{background:var(--primary)}.split-handle.horizontal{width:4px;cursor:col-resize}.split-handle.vertical{height:4px;cursor:row-resize}.split-handle-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:4px;height:4px;border-radius:999px;background:var(--t3);opacity:0;transition:opacity .15s}.split-handle:hover .split-handle-dot{opacity:1}.panel-tab-bar{display:flex;align-items:stretch;background:var(--bg-1);border-bottom:1px solid var(--b1);min-height:36px;overflow-x:auto;flex-shrink:0}.panel-tab-bar::-webkit-scrollbar{display:none}.panel-tab-bar.active-panel{background:var(--bg-2)}.panel-tab-bar.drop-hover{border-bottom:2px solid var(--primary)}.panel-tab{display:flex;align-items:center;gap:5px;padding:0 12px;cursor:pointer;font-size:13px;color:var(--t2);position:relative;flex-shrink:0;border-right:1px solid rgba(255,255,255,.03);transition:background .1s;max-width:180px}.panel-tab:hover{background:var(--bg-h)}.panel-tab.active{background:var(--bg-2);color:var(--t0)}.panel-tab.active:after{content:"";position:absolute;bottom:0;left:4px;right:4px;height:2px;background:var(--primary);border-radius:1px 1px 0 0}.panel-tab.active .tab-icon{color:var(--primary)}.panel-tab.active .tab-label{color:var(--t0);font-weight:500}.panel-tab.tab-voice .tab-icon{color:var(--green)}.panel-tab.tab-voice.active:after{background:var(--green)}.panel-tab.tab-screen .tab-icon{color:var(--red)}.panel-tab.tab-screen.active:after{background:var(--red)}.panel-tab-dot{width:5px;height:5px;background:var(--primary);border-radius:999px;flex-shrink:0}.panel-tab-close{width:16px;height:16px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:0;margin-left:auto}.panel-tab:hover .panel-tab-close{opacity:1}.panel-tab-close:hover{color:var(--t0);background:var(--bg-h)}.drop-zone-overlay{position:absolute;inset:0;z-index:20;pointer-events:none}.drop-zone{position:absolute;border-radius:4px;border:2px solid transparent;transition:background .15s,border-color .15s}.drop-zone.highlight{background:var(--primary-m);border-color:var(--primary)}.drop-zone-left{top:10%;left:0;width:25%;bottom:10%}.drop-zone-right{top:10%;right:0;width:25%;bottom:10%}.drop-zone-top{top:0;left:10%;right:10%;height:25%}.drop-zone-bottom{bottom:0;left:10%;right:10%;height:25%}.drop-zone-center{inset:25%}.no-channel{display:flex;align-items:center;justify-content:center;flex:1;color:var(--t3);font-size:13px}.settings-placeholder{flex-direction:column;gap:8px}.settings-placeholder-text{font-size:13px;color:var(--t2)}.channel-settings-list{display:flex;flex-direction:column;gap:4px;margin-top:12px}.channel-settings-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-3);border-radius:6px;transition:background .15s}.channel-settings-item:hover{background:var(--bg-4)}.channel-settings-icon{font-size:16px;color:var(--t2);width:20px;text-align:center;flex-shrink:0}.channel-settings-name{flex:1;font-size:14px;color:var(--t0);font-weight:500}.channel-settings-type{font-size:13px;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}.channel-settings-delete{background:none;border:none;color:var(--t3);font-size:14px;cursor:pointer;padding:4px 6px;border-radius:4px;transition:color .15s,background .15s}.channel-settings-delete:hover{color:var(--red);background:var(--red-s)}.channel-settings-create-form{margin-top:12px;padding:12px;background:var(--bg-3);border-radius:8px}.channel-settings-wrapper{display:flex;height:100%}.channel-settings-header{display:flex;align-items:center;justify-content:space-between;padding:10px 8px}.channel-settings-header-label{font-size:13px;font-weight:600;color:var(--t0)}.channel-settings-header-btn{height:28px;padding:0 10px;font-size:13px}.channel-settings-create-inline{padding:0 8px 8px}.channel-settings-create-inline .settings-input,.channel-settings-create-inline .settings-btn{width:100%;margin-bottom:4px}.channel-settings-create-inline .settings-btn{font-size:13px}.channel-settings-ch-list{flex:1;overflow-y:auto;padding:0 4px}.channel-settings-ch-row .channel-settings-delete{margin-left:auto}.channel-settings-ch-icon{width:16px;text-align:center;font-size:13px;color:var(--t2);flex-shrink:0}.channel-settings-right{padding:24px}.channel-settings-right-title{margin-bottom:16px}.channel-perm-section{max-width:560px}.perm-tri-section-desc{font-size:13px;color:var(--t2);margin-bottom:16px;line-height:1.5}.perm-tri-role-select{display:flex;align-items:center;gap:8px}.perm-tri-role-select .role-list-dot{flex-shrink:0}.perm-tri-role-dropdown{flex:1}.perm-tri-container{background:var(--bg-1);border-radius:8px;overflow:hidden}.perm-tri{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--b1);gap:16px}.perm-tri:last-child{border-bottom:none}.perm-tri-info{flex:1;min-width:0}.perm-tri-label{font-size:13px;font-weight:500;color:var(--t0)}.perm-tri-desc{font-size:13px;color:var(--t3);margin-top:2px}.perm-tri-controls{display:flex;gap:2px;flex-shrink:0}.perm-tri-btn{width:28px;height:28px;border-radius:4px;border:1px solid transparent;background:var(--bg-3);color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;opacity:.4}.perm-tri-btn:hover{opacity:.7}.perm-tri-btn.active{opacity:1}.perm-tri-btn.deny.active{background:var(--red-s);border-color:var(--red);color:var(--red)}.perm-tri-btn.inherit.active{background:var(--bg-4);border-color:var(--t3);color:var(--t2);opacity:.8}.perm-tri-btn.allow.active{background:var(--green-s);border-color:var(--green);color:var(--green)}.voice-settings{max-width:660px;padding:16px 0}.vs-section{margin-bottom:24px}.vs-label{font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.vs-desc{font-size:13px;color:var(--t3);margin-top:4px}.vs-radio-group{display:flex;gap:10px}.vs-radio{flex:1;display:flex;align-items:flex-start;gap:10px;padding:14px 16px;background:var(--bg-3);border:2px solid var(--b1);border-radius:8px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.vs-radio:hover{border-color:var(--t3);background:var(--bg-4)}.vs-radio.active{border-color:var(--primary);background:var(--primary-s)}.vs-radio-dot{width:18px;height:18px;border-radius:999px;border:2px solid var(--t3);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.vs-radio.active .vs-radio-dot{border-color:var(--primary)}.vs-radio.active .vs-radio-dot:after{content:"";width:10px;height:10px;border-radius:999px;background:var(--primary)}.vs-radio-title{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:2px}.vs-slider-row{display:flex;align-items:center;gap:12px}.vs-range{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-5);border-radius:3px;outline:none;cursor:pointer}.vs-range::-webkit-slider-runnable-track{height:6px;border-radius:3px}.vs-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:999px;background:var(--primary);cursor:pointer;margin-top:-6px;box-shadow:0 1px 4px #0006}.vs-range::-moz-range-track{height:6px;border-radius:3px;background:var(--bg-5)}.vs-range::-moz-range-progress{height:6px;border-radius:3px;background:var(--primary)}.vs-range::-moz-range-thumb{width:18px;height:18px;border-radius:999px;background:var(--primary);border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.vs-range:hover::-webkit-slider-thumb{transform:scale(1.15)}.vs-range:hover::-moz-range-thumb{transform:scale(1.15)}.vs-slider-value{font-size:13px;font-weight:500;color:var(--primary);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.vs-select{width:100%;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:13px;font-family:var(--f-ui);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23949BA4' stroke-width='2'%3E%3Cpath d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.vs-select:focus{border-color:var(--primary)}.vs-keybind{display:inline-flex;align-items:center;justify-content:center;min-width:120px;height:38px;padding:0 20px;background:var(--bg-3);border:2px solid var(--b1);border-radius:6px;color:var(--t0);font-size:14px;font-weight:500;font-family:var(--f-m);cursor:pointer;transition:border-color .15s,color .15s}.vs-keybind:hover{border-color:var(--primary);color:var(--primary)}.vs-keybind.listening{border-color:var(--primary);color:var(--primary);animation:pulse 1.5s ease-in-out infinite}.vs-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.vs-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.vs-switch input{opacity:0;width:0;height:0;position:absolute}.vs-switch-slider{position:absolute;inset:0;background:var(--bg-5);border:2px solid var(--t3);border-radius:999px;cursor:pointer;transition:background .2s,border-color .2s}.vs-switch-slider:before{content:"";position:absolute;left:2px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:999px;background:var(--t3);transition:transform .2s,background .2s}.vs-switch input:checked+.vs-switch-slider{background:var(--primary);border-color:var(--primary)}.vs-switch input:checked+.vs-switch-slider:before{transform:translate(20px) translateY(-50%);background:#fff}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-0)}.auth-card{width:100%;max-width:480px;padding:40px;background:var(--bg-2);border:1px solid var(--b1);border-radius:12px}.auth-title{font-family:var(--f-d);font-size:26px;font-weight:700;color:var(--t0);text-align:center;margin-bottom:8px}.auth-subtitle{font-size:14px;color:var(--t2);text-align:center;margin-bottom:28px}.auth-error{background:var(--red-s);border:1px solid var(--red);border-radius:8px;padding:10px 14px;margin-bottom:16px;font-size:13px;color:var(--red)}.auth-email-warning{margin-top:6px;font-size:13px;color:var(--yellow);line-height:1.4}.auth-label{display:block;font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.auth-input{width:100%;height:44px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 14px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;transition:border-color .15s}.auth-input:focus{border-color:var(--primary)}.auth-input::placeholder{color:var(--t3)}.auth-field{margin-bottom:16px}.auth-btn{width:100%;height:44px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--f-ui);transition:background .15s}.auth-btn:hover{background:var(--primary-h)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-link{display:block;text-align:center;margin-top:16px;font-size:13px;color:var(--t2)}.auth-link a{color:var(--primary);text-decoration:none}.auth-link a:hover{text-decoration:underline}.settings-overlay{position:fixed;inset:0;z-index:50;display:flex;background:var(--bg-0)}.settings-nav{width:218px;background:var(--bg-1);border-right:1px solid var(--b1);display:flex;flex-direction:column;padding:16px 10px;overflow-y:auto;flex-shrink:0}.settings-nav-label{font-size:13px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.06em;padding:12px 8px 4px;font-family:var(--f-d)}.settings-nav-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--t2);border:none;background:transparent;width:100%;text-align:left;font-family:var(--f-ui);transition:background .08s}.settings-nav-item:hover{background:var(--bg-h);color:var(--t1)}.settings-nav-item.active{background:var(--bg-4);color:var(--t0)}.settings-nav-divider{height:1px;background:var(--b1);margin:8px 0}.settings-nav-divider-push{margin-top:auto}.settings-nav-logout{color:var(--red)!important}.settings-nav-version{margin-top:8px;padding:0 8px;font-size:13px;color:var(--t3)}.settings-content{flex:1;overflow-y:auto;padding:32px 40px;max-width:740px}.settings-close{position:fixed;top:16px;right:16px;width:36px;height:36px;border:1px solid var(--b1);border-radius:999px;background:var(--bg-3);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;z-index:51;transition:background .1s}.settings-close:hover{background:var(--bg-4);color:var(--t0)}.settings-section{margin-bottom:32px}.settings-section-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--t0);margin-bottom:16px}.settings-label{display:block;font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.settings-input{width:100%;max-width:400px;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;transition:border-color .15s}.settings-input:focus{border-color:var(--primary)}.settings-input::placeholder{color:var(--t3)}.settings-textarea{width:100%;max-width:400px;min-height:80px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:10px 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;resize:vertical;transition:border-color .15s}.settings-textarea:focus{border-color:var(--primary)}.settings-select{width:100%;max-width:400px;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:8px;padding:0 12px;color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;cursor:pointer;appearance:none}.settings-field{margin-bottom:16px}.settings-btn{height:36px;padding:0 20px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--f-ui);transition:background .15s}.settings-btn:hover{background:var(--primary-h)}.settings-btn:disabled{opacity:.5;cursor:not-allowed}.settings-btn-danger{background:var(--red-s);color:var(--red)}.settings-btn-danger:hover{background:var(--red);color:#fff}.settings-btn-secondary{background:var(--bg-4);color:var(--t1)}.settings-btn-secondary:hover{background:var(--bg-5);color:var(--t0)}.settings-btn-row{display:flex;gap:8px;margin-top:16px}.settings-value{font-size:14px;color:var(--t0);margin:0;padding:8px 0}.settings-hint{font-size:13px;color:var(--t2);margin-top:4px}.settings-divider{height:1px;background:var(--b1);margin:24px 0}.dz-separator{height:1px;background:var(--red-s);margin:32px 0 0}.dz-section{margin-top:24px}.dz-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--red);margin-bottom:16px}.dz-card{border:1px solid var(--red-s);border-radius:10px;padding:20px;background:var(--bg-1)}.dz-card-title{font-size:15px;font-weight:600;color:var(--t0);margin:0 0 8px}.dz-card-desc{font-size:13px;color:var(--t2);line-height:1.5;margin:0 0 16px}.dz-confirm-label{display:block;font-size:13px;color:var(--t1);margin-bottom:8px}.dz-confirm-label strong{color:var(--t0);font-weight:700}.dz-input{margin-bottom:16px}.dz-btn{height:36px;padding:0 20px;border:none;border-radius:8px;background:var(--red);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--f-ui);transition:background .15s,opacity .15s}.dz-btn:hover{opacity:.9}.dz-btn:disabled{opacity:.4;cursor:not-allowed}.theme-section-desc{font-size:13px;color:var(--t2);margin-bottom:20px;line-height:1.5}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;max-width:660px}.theme-card{position:relative;display:flex;flex-direction:column;gap:8px;padding:16px;background:var(--bg-3);border:2px solid var(--b1);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;text-align:left;font-family:inherit}.theme-card:hover{background:var(--bg-4);border-color:var(--b2)}.theme-card-active{border-color:var(--primary);background:var(--primary-s)}.theme-card-active:hover{border-color:var(--primary)}.theme-swatches{display:flex;gap:6px}.theme-swatch{width:24px;height:24px;border-radius:999px;border:2px solid rgba(255,255,255,.12);flex-shrink:0}.theme-card-name{font-size:14px;font-weight:600;color:var(--t0);font-family:var(--f-d)}.theme-card-desc{font-size:13px;color:var(--t2);line-height:1.4}.theme-card-check{position:absolute;top:10px;right:10px;width:22px;height:22px;border-radius:999px;background:var(--primary);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center}.avatar-upload{position:relative;cursor:pointer;display:inline-block}.avatar-upload-overlay{position:absolute;inset:0;border-radius:inherit;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;font-size:13px;color:#fff}.avatar-upload:hover .avatar-upload-overlay{opacity:1}.color-picker{display:grid;grid-template-columns:repeat(10,1fr);gap:4px;max-width:280px}.color-swatch{width:24px;height:24px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:border-color .1s}.color-swatch.selected{border-color:var(--t0);box-shadow:0 0 0 2px var(--bg-0)}.color-hex-row{display:flex;align-items:center;gap:8px;margin-top:8px}.color-hex-preview{width:32px;height:32px;border-radius:6px;border:1px solid var(--b1);flex-shrink:0}.color-hex-input{width:100px;height:32px;background:var(--bg-3);border:1px solid var(--b1);border-radius:6px;padding:0 8px;color:var(--t0);font-size:13px;font-family:var(--f-m);outline:none}.color-hex-input:focus{border-color:var(--primary)}.permission-toggle{display:flex;align-items:flex-start;gap:12px;padding:8px 0}.permission-toggle-checkbox{width:20px;height:20px;border-radius:4px;border:2px solid var(--b2);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}.permission-toggle-checkbox.checked{background:var(--primary);border-color:var(--primary)}.permission-toggle-check{width:12px;height:12px;color:#fff}.permission-toggle-label{font-size:13px;font-weight:500;color:var(--t0)}.permission-toggle-desc{font-size:13px;color:var(--t2);margin-top:2px}.permission-toggle-warn{font-size:13px;color:var(--red);margin-top:2px}.role-list{width:200px;border-right:1px solid var(--b1);flex-shrink:0;overflow-y:auto}.role-list-item{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;border-radius:6px;transition:background .08s}.role-list-item:hover{background:var(--bg-h)}.role-list-item.active{background:var(--bg-4)}.role-list-dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.role-list-name{font-size:13px;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-list-item.active .role-list-name{color:var(--t0);font-weight:500}.platform-instance-item{flex-direction:column;align-items:flex-start;gap:2px;padding:8px}.platform-instance-capacity{font-size:13px;color:var(--t3)}.role-list-item.active .platform-instance-capacity{color:var(--t2)}.role-drag-wrap{position:relative;transition:opacity .15s}.role-drag-wrap.dragging{opacity:.4}.role-drag-wrap.drop-above:before,.role-drag-wrap.drop-below:after{content:"";position:absolute;left:8px;right:8px;height:2px;background:var(--primary);border-radius:1px;pointer-events:none;z-index:2}.role-drag-wrap.drop-above:before{top:0}.role-drag-wrap.drop-below:after{bottom:0}.role-drag-handle{color:var(--t3);font-size:14px;cursor:grab;flex-shrink:0;user-select:none}.role-drag-handle:active{cursor:grabbing}.role-hierarchy-warning{background:var(--bg-4);border-radius:8px;padding:12px;font-size:13px;color:var(--t2);margin-bottom:16px}.permission-toggle-checkbox.disabled{opacity:.4;cursor:not-allowed}.member-settings-avatar{width:32px;height:32px;border-radius:999px;border:2px solid var(--t2);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--bg-3);flex-shrink:0}.member-settings-avatar-lg{width:56px;height:56px;border-width:3px}.member-settings-avatar-img{width:100%;height:100%;object-fit:cover}.member-settings-avatar-fallback{font-size:14px;font-weight:600;color:var(--t0)}.member-settings-avatar-lg .member-settings-avatar-fallback{font-size:22px}.member-settings-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.member-settings-name{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-settings-username{font-size:13px;color:var(--t2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-settings-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.member-settings-detail-name{font-size:18px;font-weight:600}.member-settings-detail-username{font-size:13px;color:var(--t2);margin-top:2px}.member-settings-role-tags{display:flex;flex-wrap:wrap;gap:6px}.member-settings-role-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:13px;color:var(--t1);border:1px solid var(--t2);background:var(--bg-3)}.member-settings-no-roles{font-size:13px;color:var(--t2)}.member-settings-role-checkboxes{display:flex;flex-direction:column;gap:6px;background:var(--bg-1);border-radius:8px;padding:8px 12px}.member-settings-role-checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--t1);cursor:pointer;padding:4px 0}.member-settings-role-checkbox input[type=checkbox]{accent-color:var(--primary)}.member-settings-actions{display:flex;align-items:center;gap:12px;margin-top:8px}.member-settings-unsaved{font-size:13px;color:var(--primary)}.member-settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--b1);padding:0 8px}.member-settings-tab{flex:1;padding:10px 0;font-size:13px;font-weight:500;color:var(--t2);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s;text-align:center}.member-settings-tab:hover{color:var(--t0)}.member-settings-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.member-settings-avatar-banned{border-color:var(--red)!important;opacity:.7}.member-settings-name-banned{color:var(--t2)!important}.ban-detail-value{font-size:14px;color:var(--t1);background:var(--bg-1);padding:8px 12px;border-radius:6px;word-break:break-word}.toast-container{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column-reverse;gap:8px}.toast{width:360px;background:var(--bg-3);border:1px solid var(--b1);border-radius:10px;padding:12px 14px;box-shadow:0 8px 32px #0006;display:flex;align-items:flex-start;gap:10px;animation:vpIn .3s cubic-bezier(.22,1,.36,1)}.toast-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px}.toast-success .toast-icon{color:var(--green)}.toast-error .toast-icon{color:var(--red)}.toast-warning .toast-icon{color:var(--primary)}.toast-info .toast-icon{color:var(--teal)}.toast-body{flex:1;min-width:0}.toast-title{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:2px}.toast-message{font-size:13px;color:var(--t2)}.toast-close{width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.toast-close:hover{color:var(--t1);background:var(--bg-h)}.toast-border-success{border-left:3px solid var(--green)}.toast-border-error{border-left:3px solid var(--red)}.toast-border-warning{border-left:3px solid var(--primary)}.toast-border-info{border-left:3px solid var(--teal)}.modal-backdrop{position:fixed;inset:0;background:#0009;z-index:50;display:flex;align-items:center;justify-content:center}.modal-card{background:var(--bg-3);border:1px solid var(--b2);border-radius:12px;max-width:480px;width:100%;padding:24px;box-shadow:0 12px 48px #00000080}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--t0)}.modal-text{font-size:14px;color:var(--t2);margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.voice-room{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--bg-2)}.voice-room-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:13px}.voice-room-grid{flex:1;display:flex;flex-wrap:wrap;gap:16px;padding:24px;align-content:center;justify-content:center;overflow-y:auto}.voice-grid-strip{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 16px;border-top:1px solid var(--b1)}.voice-participant{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px}.voice-participant-avatar{width:64px;height:64px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--secondary));display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;font-family:var(--f-d);transition:box-shadow .15s;position:relative}.voice-participant-avatar.speaking{box-shadow:0 0 0 2px var(--bg-2),0 0 0 4px var(--green)}.voice-participant-name{font-size:13px;font-weight:500;color:var(--t0);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-participant-overlay{position:absolute;bottom:-2px;right:-2px;width:22px;height:22px;border-radius:999px;background:var(--bg-3);display:flex;align-items:center;justify-content:center}.voice-participant-overlay svg{width:13px;height:13px;color:var(--red)}.voice-participant-compact{display:flex;align-items:center;gap:8px}.voice-participant-compact .voice-participant-avatar{width:40px;height:40px;font-size:14px}.voice-participant-compact .voice-participant-avatar.speaking{box-shadow:0 0 0 1.5px var(--bg-2),0 0 0 3px var(--green)}.voice-participant-compact .voice-participant-name{font-size:13px;color:var(--t1);max-width:120px;margin-top:0}.voice-participant-compact .voice-participant-overlay{width:16px;height:16px;bottom:-1px;right:-1px}.voice-participant-compact .voice-participant-overlay svg{width:10px;height:10px}.vp-vol-popup{background:var(--bg-4);border:1px solid var(--b1);border-radius:8px;padding:12px 16px;min-width:200px;box-shadow:0 4px 16px #00000080}.vp-vol-header{font-size:13px;font-weight:600;color:var(--t0);margin-bottom:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vp-vol-slider{display:flex;align-items:center;gap:10px}.vp-vol-slider svg{color:var(--primary)}.vp-vol-range{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-5);border-radius:3px;outline:none;cursor:pointer}.vp-vol-range::-webkit-slider-runnable-track{height:6px;border-radius:3px}.vp-vol-range::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:999px;background:var(--primary);cursor:pointer;margin-top:-5px;box-shadow:0 1px 4px #0006}.vp-vol-range::-moz-range-track{height:6px;border-radius:3px;background:var(--bg-5)}.vp-vol-range::-moz-range-progress{height:6px;border-radius:3px;background:var(--primary)}.vp-vol-range::-moz-range-thumb{width:16px;height:16px;border-radius:999px;background:var(--primary);border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.vp-vol-value{font-size:13px;font-weight:500;color:var(--primary);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.voice-ctx-menu{position:fixed;z-index:9999;min-width:220px;max-width:280px;background:var(--bg-2);border:1px solid var(--b1);border-radius:10px;box-shadow:0 8px 24px #00000080;padding:0;animation:vpIn .12s ease-out;overflow:hidden}.voice-ctx-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-4);border-bottom:1px solid var(--b1)}.voice-ctx-header-name{font-size:14px;font-weight:600;color:var(--t0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-ctx-body{padding:8px}.voice-ctx-label{font-size:13px;font-weight:600;color:var(--t2);padding:2px 8px 0;text-transform:uppercase;letter-spacing:.03em}.voice-ctx-slider{display:flex;align-items:center;gap:10px;padding:6px 8px}.voice-ctx-slider svg{color:var(--primary);flex-shrink:0}.voice-ctx-range{flex:1;height:6px;-webkit-appearance:none;appearance:none;background:var(--bg-5);border-radius:3px;outline:none;cursor:pointer}.voice-ctx-range::-webkit-slider-runnable-track{height:6px;border-radius:3px}.voice-ctx-range::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:999px;background:var(--primary);cursor:pointer;margin-top:-5px;box-shadow:0 1px 4px #0006}.voice-ctx-range::-moz-range-track{height:6px;border-radius:3px;background:var(--bg-5)}.voice-ctx-range::-moz-range-progress{height:6px;border-radius:3px;background:var(--primary)}.voice-ctx-range::-moz-range-thumb{width:16px;height:16px;border-radius:999px;background:var(--primary);border:none;cursor:pointer;box-shadow:0 1px 4px #0006}.voice-ctx-vol-value{font-size:13px;font-weight:500;color:var(--primary);min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.voice-ctx-divider{height:1px;background:var(--b1);margin:4px 8px}.voice-ctx-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--t1);font-size:13px;font-family:var(--f-ui);text-align:left;border-radius:6px;cursor:pointer;transition:background .08s}.voice-ctx-item:hover{background:var(--bg-h);color:var(--t0)}.voice-ctx-item.active{color:var(--red)}.voice-ctx-item.active:hover{background:var(--red-s);color:var(--red)}.voice-ctx-item.danger{color:var(--yellow, #f0b232)}.voice-ctx-item.danger:hover{background:#f0b2321a;color:var(--yellow, #f0b232)}.voice-ctx-item svg{width:16px;height:16px;flex-shrink:0}.voice-ctx-move-wrap{position:relative}.voice-ctx-chevron{transition:transform .15s ease}.voice-ctx-move-list{display:flex;flex-direction:column;gap:2px;padding:4px 0 0;max-height:160px;overflow-y:auto}.voice-ctx-move-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px 6px 26px;border:none;background:transparent;color:var(--t2);font-size:13px;font-family:var(--f-ui);text-align:left;border-radius:6px;cursor:pointer;transition:background .08s}.voice-ctx-move-item:hover{background:var(--bg-h);color:var(--t0)}.voice-ctx-move-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ch-tree-vu-local-mute{color:var(--red);opacity:.8}.ch-tree-vu-server-mute,.ch-tree-vu-server-deafen{color:var(--yellow, #f0b232);opacity:.9}.voice-connection-status{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#0009}.voice-connection-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.voice-connection-dot.connecting{background:var(--primary);animation:pulse 1.5s ease-in-out infinite}.voice-connection-dot.error{background:var(--red)}.voice-connection-text{font-size:13px;font-weight:500}.voice-connection-text.warning{color:var(--primary)}.voice-connection-text.error{color:var(--red)}.voice-connection-text.muted{color:var(--t2)}.screen-share-view{flex:1;display:flex;min-height:0;padding:8px;position:relative}.screen-share-split{display:flex;flex:1;min-height:0;min-width:0;gap:0}.screen-share-split.vertical{flex-direction:column}.screen-share-split.horizontal{flex-direction:row}.screen-share-pane{min-height:0;min-width:0;overflow:hidden}.screen-share-grid{display:grid;grid-template-columns:repeat(2,1fr);flex:1;min-height:0;gap:4px}.screen-share-panel{width:100%;height:100%;position:relative;overflow:hidden;border-radius:8px;background:var(--bg-1)}.screen-share-panel video{width:100%;height:100%;object-fit:contain}.screen-share-panel-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4),transparent 40%);opacity:0;transition:opacity .2s;pointer-events:none}.screen-share-panel:hover .screen-share-panel-overlay{opacity:1}.screen-share-panel-label{position:absolute;bottom:8px;left:8px;background:#0009;border-radius:6px;padding:2px 8px;font-size:13px;font-weight:500;color:var(--t0);pointer-events:auto}.screen-share-panel-btn{position:absolute;bottom:8px;right:8px;width:32px;height:32px;border:none;border-radius:6px;background:#0009;color:var(--t1);cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;transition:background .15s,color .15s}.screen-share-panel-btn:hover{background:var(--bg-h);color:var(--t0)}.screen-share-panel-btn svg{width:16px;height:16px}.screen-share-toggle{position:absolute;top:12px;right:12px;z-index:10;width:32px;height:32px;border:none;border-radius:6px;background:#0009;color:var(--t1);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.screen-share-toggle:hover{background:var(--bg-h);color:var(--t0)}.screen-share-toggle svg{width:16px;height:16px}.screen-share-resize{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center}.screen-share-resize.vertical{height:8px;width:100%;cursor:row-resize}.screen-share-resize.horizontal{width:8px;height:100%;cursor:col-resize}.screen-share-resize-line{border-radius:999px;background:var(--bg-5);transition:background .15s}.screen-share-resize:hover .screen-share-resize-line{background:var(--primary)}.screen-share-resize.vertical .screen-share-resize-line{height:2px;width:48px}.screen-share-resize.horizontal .screen-share-resize-line{width:2px;height:48px}.spinner{width:24px;height:24px;border:2px solid var(--b1);border-top-color:var(--primary);border-radius:999px;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.pinned-panel{position:absolute;top:33px;right:0;width:360px;max-height:420px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;z-index:30;display:flex;flex-direction:column;box-shadow:0 8px 24px #0006}.pinned-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--b1)}.pinned-header-title{font-size:13px;font-weight:600;color:var(--t0)}.pinned-close{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.pinned-close:hover{color:var(--t1);background:var(--bg-h)}.pinned-list{flex:1;overflow-y:auto;padding:8px}.pinned-empty{text-align:center;font-size:13px;color:var(--t2);padding:24px 12px}.pinned-item{position:relative;padding:10px 12px;background:var(--bg-3);border-radius:6px;margin-bottom:6px}.pinned-item:hover{background:var(--bg-4)}.pinned-item-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.pinned-item-author{font-size:13px;font-weight:500;color:var(--t0)}.pinned-item-time{font-size:13px;color:var(--t3);margin-left:auto}.pinned-item-content{font-size:13px;color:var(--t1);line-height:1.4;word-break:break-word}.pinned-item-unpin{position:absolute;top:8px;right:8px;width:20px;height:20px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.pinned-item:hover .pinned-item-unpin{opacity:1}.pinned-item-unpin:hover{color:var(--red);background:var(--red-s)}.search-panel{position:absolute;top:33px;right:0;width:400px;max-height:480px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;z-index:30;display:flex;flex-direction:column;box-shadow:0 8px 24px #0006}.search-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--b1)}.search-header-title{font-size:13px;font-weight:600;color:var(--t0)}.search-close{width:24px;height:24px;border:none;background:transparent;color:var(--t3);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center}.search-close:hover{color:var(--t1);background:var(--bg-h)}.search-input-wrap{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--b1)}.search-input-icon{color:var(--t3);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;color:var(--t0);font-size:13px;font-family:var(--f-ui)}.search-input::placeholder{color:var(--t3)}.search-results{flex:1;overflow-y:auto;padding:8px}.search-empty{text-align:center;font-size:13px;color:var(--t2);padding:24px 12px}.search-count{font-size:13px;color:var(--t2);padding:0 4px 6px;border-bottom:1px solid var(--b1);margin-bottom:6px}.search-result-item{padding:10px 12px;background:var(--bg-3);border-radius:6px;margin-bottom:6px;cursor:pointer}.search-result-item:hover{background:var(--bg-4)}.search-result-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}.search-result-author{font-size:13px;font-weight:500;color:var(--t0)}.search-result-time{font-size:13px;color:var(--t3);margin-left:auto}.search-result-content{font-size:13px;color:var(--t1);line-height:1.4;word-break:break-word;max-height:60px;overflow:hidden;text-overflow:ellipsis}.search-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0 4px}.search-page-btn{border:none;background:var(--bg-4);color:var(--t1);font-size:13px;padding:4px 10px;border-radius:4px;cursor:pointer}.search-page-btn:hover{background:var(--bg-5);color:var(--t0)}.search-page-btn:disabled{opacity:.4;cursor:default}.search-page-info{font-size:13px;color:var(--t2)}.dm-header{display:flex;align-items:center;gap:8px;padding:6px 14px;border-bottom:1px solid var(--b1);background:var(--bg-3);flex-shrink:0;height:33px}.dm-header-name{font-size:13px;font-weight:600;color:var(--t0)}.dm-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:13px}.dm-unread-badge{flex-shrink:0;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;background:var(--red);border-radius:8px;padding:0 4px;font-family:var(--f-ui)}.member-card-btn-dm{background:var(--primary-s);color:var(--primary)}.member-card-btn-dm:hover{background:var(--primary);color:#fff}.member-card-btn-call{background:var(--green-s);color:var(--green)}.member-card-btn-call:hover{background:var(--green);color:#fff}.member-card-btn-danger{background:var(--red-s);color:var(--red)}.member-card-btn-danger:hover{background:var(--red);color:#fff}.quick-switcher-overlay{position:fixed;inset:0;background:#00000080;z-index:60;display:flex;align-items:flex-start;justify-content:center;padding-top:120px}.quick-switcher{width:480px;max-height:420px;background:var(--bg-2);border:1px solid var(--b1);border-radius:10px;box-shadow:0 12px 40px #0009;display:flex;flex-direction:column;overflow:hidden;animation:vpIn .12s ease-out}.qs-input{width:100%;padding:14px 16px;border:none;border-bottom:1px solid var(--b1);background:transparent;color:var(--t0);font-size:15px;font-family:var(--f-ui);outline:none}.qs-input::placeholder{color:var(--t3)}.qs-results{flex:1;overflow-y:auto;padding:6px}.qs-empty{text-align:center;font-size:13px;color:var(--t2);padding:20px 12px}.qs-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-family:var(--f-ui);color:var(--t1);font-size:13px;text-align:left;transition:background .08s}.qs-item:hover,.qs-selected{background:var(--bg-h);color:var(--t0)}.qs-icon{font-size:14px;color:var(--t3);min-width:18px;text-align:center}.qs-selected .qs-icon{color:var(--primary)}.qs-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qs-category{font-size:13px;color:var(--t3);margin-left:auto}.qs-footer{display:flex;gap:16px;padding:8px 14px;border-top:1px solid var(--b1);font-size:13px;color:var(--t3)}.ctx-menu{position:fixed;z-index:70;min-width:160px;max-width:240px;background:var(--bg-2);border:1px solid var(--b1);border-radius:8px;box-shadow:0 8px 24px #00000080;padding:4px;animation:vpIn .1s ease-out}.ctx-item{display:block;width:100%;padding:7px 10px;border:none;background:transparent;color:var(--t1);font-size:13px;font-family:var(--f-ui);text-align:left;border-radius:4px;cursor:pointer;transition:background .08s}.ctx-item:hover{background:var(--bg-h);color:var(--t0)}.ctx-danger{color:var(--red)}.ctx-danger:hover{background:var(--red-s);color:var(--red)}.ctx-disabled{opacity:.4;cursor:default}.ctx-disabled:hover{background:transparent;color:var(--t1)}.ctx-separator{height:1px;background:var(--b1);margin:4px 0}.sk-container{padding:8px}.sk-line{height:10px;border-radius:4px;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.sk-short{width:30%;margin-bottom:6px}.sk-medium{width:60%;margin-top:4px}.sk-long{width:80%}.sk-name{width:50%}.sk-message{display:flex;gap:10px;padding:8px 14px;align-items:flex-start}.sk-avatar{width:30px;height:30px;border-radius:50%;background:var(--bg-4);flex-shrink:0;animation:shimmer 1.5s infinite;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%}.sk-body{flex:1;min-width:0}.sk-member{display:flex;gap:8px;padding:4px 10px;align-items:center}.sk-avatar-sm{width:22px;height:22px;border-radius:50%;flex-shrink:0;background:linear-gradient(90deg,var(--bg-4) 25%,var(--bg-5) 50%,var(--bg-4) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.sk-channel{display:flex;gap:6px;padding:5px 10px;align-items:center}.sk-ch-icon{width:12px;height:12px;border-radius:3px;background:var(--bg-4);flex-shrink:0}.sk-ch-name{width:60px}.friends-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.fv-header{padding:12px 16px 0;border-bottom:1px solid var(--b1)}.fv-title{font-size:16px;font-weight:700;color:var(--t0);margin:0 0 10px;font-family:var(--f-d)}.fv-tabs{display:flex;gap:0}.fv-tab{padding:8px 14px;font-size:13px;color:var(--t2);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;transition:color .15s,border-color .15s}.fv-tab:hover{color:var(--t1)}.fv-tab.active{color:var(--t0);border-bottom-color:var(--primary)}.fv-tab-add,.fv-tab-add:hover{color:var(--green)}.fv-tab-add.active{border-bottom-color:var(--green)}.fv-tab-count{font-size:13px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--bg-4);color:var(--t1);display:flex;align-items:center;justify-content:center}.fv-content{flex:1;overflow-y:auto;padding:12px 16px}.fv-search{margin-bottom:10px}.fv-search-input{width:100%;height:34px;background:var(--bg-3);border:1px solid var(--b1);border-radius:6px;padding:0 12px;color:var(--t0);font-size:13px;outline:none;font-family:inherit}.fv-search-input:focus{border-color:var(--primary)}.fv-search-input::placeholder{color:var(--t3)}.fv-list{display:flex;flex-direction:column;gap:2px}.fv-empty{color:var(--t3);font-size:13px;text-align:center;padding:40px 0}.fv-pending-section{margin-bottom:16px}.fv-pending-title{font-size:13px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.04em;margin:0 0 6px;padding:0 4px}.fi-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:6px;transition:background .1s}.fi-item:hover{background:var(--bg-h)}.fi-info{display:flex;align-items:center;gap:10px;min-width:0}.fi-text{display:flex;flex-direction:column;gap:1px;min-width:0}.fi-name{font-size:13px;font-weight:600;color:var(--t0);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fi-username{font-size:13px;color:var(--t3)}.fi-status{font-size:13px;color:var(--t2)}.fi-status-online{color:var(--green)}.fi-status-idle{color:var(--yellow,#f0b232)}.fi-status-dnd{color:var(--red)}.fi-status-offline{color:var(--t3)}.fi-actions{display:flex;gap:6px;flex-shrink:0}.fi-btn{width:32px;height:32px;border-radius:999px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;background:var(--bg-4);color:var(--t2);transition:background .1s,color .1s,opacity .1s}.fi-btn-accept{background:#3d914026;color:var(--green)}.fi-btn-accept:hover{background:#3d91404d}.fi-btn-decline{background:#dc35451a;color:var(--red)}.fi-btn-decline:hover{background:#dc354533}.fi-btn-msg{opacity:0}.fi-item:hover .fi-btn-msg{opacity:1}.fi-btn-msg:hover{background:var(--primary-s);color:var(--primary)}.fi-btn-remove{opacity:0}.fi-item:hover .fi-btn-remove{opacity:1}.fi-btn-remove:hover{background:#dc354526;color:var(--red)}.frf-container{max-width:460px;padding:20px 0}.frf-title{font-size:16px;font-weight:700;color:var(--t0);margin:0 0 6px;font-family:var(--f-d)}.frf-desc{font-size:13px;color:var(--t2);margin:0 0 16px}.frf-form{display:flex;gap:8px}.frf-input{flex:1;height:40px;background:var(--bg-3);border:1px solid var(--b1);border-radius:6px;padding:0 12px;color:var(--t0);font-size:13px;outline:none;font-family:inherit}.frf-input:focus{border-color:var(--primary)}.frf-btn{height:40px;padding:0 20px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s}.frf-btn:hover:not(:disabled){background:var(--primary-h)}.frf-btn:disabled{opacity:.5;cursor:not-allowed}.frf-result{margin-top:12px;padding:10px 14px;border-radius:6px;font-size:13px}.frf-success{background:#3d91401f;color:var(--green)}.frf-error{background:#dc35451a;color:var(--red)}.ico-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px)}.ico-card{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 48px;background:var(--bg-2);border:1px solid var(--b1);border-radius:16px;box-shadow:0 20px 60px #00000080;animation:vpIn .25s ease}.ico-avatar-wrap{position:relative}.ico-pulse-ring{position:absolute;inset:-8px;border-radius:50%;border:2px solid var(--green);animation:ring 2s ease-in-out infinite}.ico-info{display:flex;flex-direction:column;align-items:center;gap:4px}.ico-caller-name{font-size:20px;font-weight:700;color:var(--t0);font-family:var(--f-d)}.ico-call-type{font-size:14px;color:var(--t2)}.ico-actions{display:flex;gap:24px;margin-top:8px}.ico-btn{width:56px;height:56px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,filter .15s}.ico-btn:hover{transform:scale(1.08)}.ico-btn-accept{background:var(--green);color:#fff}.ico-btn-decline{background:var(--red);color:#fff}.p2p-call-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;background:var(--bg-0);gap:16px;padding:24px;min-height:0}.p2p-empty{color:var(--t2)}.p2p-ringing .p2p-avatar-large{position:relative;margin-bottom:8px}.p2p-ring-anim{position:absolute;inset:-12px;border-radius:50%;border:2px solid var(--primary);animation:ring 2s ease-in-out infinite}.p2p-status-text{font-size:16px;color:var(--t1);font-family:var(--f-d)}.p2p-active{gap:12px}.p2p-media-area{position:relative;flex:1;width:100%;min-height:0;display:flex;align-items:center;justify-content:center;border-radius:12px;overflow:hidden;background:var(--bg-1)}.p2p-avatar-large{display:flex;align-items:center;justify-content:center}.p2p-remote-video{width:100%;height:100%;object-fit:contain;background:var(--bg-0)}.p2p-local-video{position:absolute;right:12px;bottom:12px;width:160px;height:120px;object-fit:cover;border-radius:8px;border:2px solid var(--b2);z-index:1}.p2p-duration{font-size:14px;font-weight:600;color:var(--t1);font-family:var(--f-m);letter-spacing:.05em}.p2p-controls{display:flex;align-items:center;gap:12px;padding:8px 0}.p2p-ctrl-btn{width:44px;height:44px;border-radius:50%;border:none;background:var(--bg-4);color:var(--t0);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,transform .1s}.p2p-ctrl-btn:hover{background:var(--bg-5);transform:scale(1.05)}.p2p-ctrl-btn.active{background:var(--red-s);color:var(--red)}.p2p-ctrl-btn.end-call{width:52px;height:52px;background:var(--red);color:#fff}.p2p-ctrl-btn.end-call:hover{filter:brightness(1.15)}.fi-btn-call{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg-4);color:var(--t1);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.fi-btn-call:hover:not(:disabled){background:var(--green-s);color:var(--green)}.fi-btn-call:disabled{opacity:.3;cursor:not-allowed}.dm-call-actions{display:flex;gap:4px;margin-left:auto}.dm-call-btn{width:30px;height:30px;border-radius:5px;border:none;background:transparent;color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.dm-call-btn:hover{background:var(--bg-h);color:var(--t0)}.sp-overlay{position:fixed;inset:0;background:#0009;z-index:150;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(2px)}.sp-card{width:680px;max-width:90vw;max-height:80vh;background:var(--bg-2);border:1px solid var(--b1);border-radius:14px;box-shadow:0 16px 48px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:vpIn .2s ease-out}.sp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--b1)}.sp-title{font-family:var(--f-d);font-size:18px;font-weight:700;color:var(--t0);margin:0}.sp-close{width:32px;height:32px;border:none;background:transparent;color:var(--t2);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s}.sp-close:hover{background:var(--bg-h);color:var(--t0)}.sp-tabs{display:flex;gap:2px;padding:0 20px;border-bottom:1px solid var(--b1)}.sp-tab{display:flex;align-items:center;gap:6px;padding:10px 14px;border:none;background:transparent;color:var(--t2);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--f-ui);position:relative;transition:color .1s}.sp-tab:hover{color:var(--t1)}.sp-tab-active{color:var(--t0)}.sp-tab-active:after{content:"";position:absolute;bottom:0;left:8px;right:8px;height:2px;background:var(--primary);border-radius:1px}.sp-tab-count{font-size:13px;color:var(--t3);font-weight:400}.sp-grid{flex:1;overflow-y:auto;padding:16px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.sp-empty{grid-column:1/-1;text-align:center;padding:40px 0;font-size:14px;color:var(--t2)}.sp-source{display:flex;flex-direction:column;gap:8px;padding:8px;border:2px solid var(--b1);border-radius:10px;background:var(--bg-3);cursor:pointer;transition:border-color .15s,background .15s}.sp-source:hover{border-color:var(--primary);background:var(--bg-4)}.sp-thumbnail-wrap{width:100%;aspect-ratio:16/9;border-radius:6px;overflow:hidden;background:var(--bg-0)}.sp-thumbnail{width:100%;height:100%;object-fit:contain}.sp-source-name{font-size:13px;color:var(--t1);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 4px}.sp-footer{padding:12px 20px;border-top:1px solid var(--b1)}.sp-audio-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;user-select:none}.sp-audio-label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--t1)}.sp-switch{width:36px;height:20px;border-radius:10px;background:var(--bg-5);position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.sp-switch-on{background:var(--primary)}.sp-switch-thumb{width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform .2s}.sp-switch-on .sp-switch-thumb{transform:translate(16px)}:root{--mobile-header-h: 48px;--mobile-drawer-w: min(85vw, 320px);--mobile-drawer-right-w: min(80vw, 300px);--mobile-touch-target: 44px;--mobile-bottom-sheet-max: 50vh;--mobile-drawer-z: 40;--mobile-backdrop-z: 39}@supports (height: 100dvh){@media(max-width:768px){html,body,#root,.mqvi-app{height:100dvh}}}@media(max-width:768px){html,body{overscroll-behavior:none}}.mobile-drawer-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:var(--mobile-backdrop-z);opacity:0;transition:opacity .3s ease}.mobile-drawer-backdrop.open{display:block;opacity:1}.mobile-drawer{position:fixed;top:0;bottom:0;z-index:var(--mobile-drawer-z);background:var(--bg-1);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-x:hidden;overflow-y:hidden;display:flex;flex-direction:column}.mobile-drawer.left{left:0;width:var(--mobile-drawer-w);transform:translate(-100%);border-right:1px solid var(--b1)}.mobile-drawer.left.open{transform:translate(0)}.mobile-drawer.right{right:0;width:var(--mobile-drawer-right-w);transform:translate(100%);border-left:1px solid var(--b1)}.mobile-drawer.right.open{transform:translate(0)}@media(max-width:768px){.mobile-drawer{padding-top:env(safe-area-inset-top)}}.mobile-header{display:none;height:var(--mobile-header-h);min-height:var(--mobile-header-h);padding:0 8px;align-items:center;gap:8px;background:var(--bg-1);border-bottom:1px solid var(--b1);flex-shrink:0}@media(max-width:768px){.mobile-header{display:flex}}.mobile-header-btn{width:var(--mobile-touch-target);height:var(--mobile-touch-target);border:none;background:transparent;color:var(--t1);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .1s,color .1s}.mobile-header-btn:active{background:var(--bg-h);color:var(--t0)}.mobile-header-title{flex:1;min-width:0;display:flex;align-items:center;gap:6px;font-size:16px;font-weight:600;color:var(--t0);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-hash{color:var(--t2);font-weight:500}.mobile-bottom-sheet-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:50;opacity:0;transition:opacity .25s ease}.mobile-bottom-sheet-backdrop.open{display:block;opacity:1}.mobile-bottom-sheet{position:fixed;left:0;right:0;bottom:0;z-index:51;background:var(--bg-2);border-top:1px solid var(--b1);border-radius:12px 12px 0 0;max-height:var(--mobile-bottom-sheet-max);overflow-y:auto;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-bottom:env(safe-area-inset-bottom)}.mobile-bottom-sheet.open{transform:translateY(0)}.mobile-bottom-sheet-handle{width:36px;height:4px;background:var(--bg-5);border-radius:2px;margin:8px auto 4px}.mobile-bs-action{display:flex;align-items:center;gap:12px;padding:12px 16px;font-size:15px;color:var(--t0);cursor:pointer;transition:background .1s;border:none;background:transparent;width:100%;text-align:left;font-family:var(--f-ui)}.mobile-bs-action:active{background:var(--bg-h)}.mobile-bs-action.destructive{color:var(--red)}.mobile-bs-action-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--t2)}.mobile-bs-action.destructive .mobile-bs-action-icon{color:var(--red)}.panel-tab-bar.mobile{min-height:var(--mobile-touch-target);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.panel-tab-bar.mobile::-webkit-scrollbar{display:none}.panel-tab-bar.mobile .panel-tab{min-height:var(--mobile-touch-target);padding:0 14px;font-size:14px}.panel-tab-bar.mobile .panel-tab-close{opacity:1;width:24px;height:24px}@media(max-width:768px){.ch-tree-item{min-height:var(--mobile-touch-target);padding:8px 8px 8px 24px}.ch-actions button{width:var(--mobile-touch-target);height:var(--mobile-touch-target);font-size:16px}.sb-header-btn,.ub-ctrl{width:var(--mobile-touch-target);height:var(--mobile-touch-target)}.members-header button{width:var(--mobile-touch-target);height:var(--mobile-touch-target);font-size:16px}.member{padding:8px 6px;min-height:var(--mobile-touch-target)}.pinned-close,.search-close{width:var(--mobile-touch-target);height:var(--mobile-touch-target)}.ctx-item{padding:12px 14px;font-size:15px;min-height:var(--mobile-touch-target)}.ch-tree-section-header{min-height:36px;padding:6px 10px}.ch-tree-cat-add{opacity:1!important}.msg-hover-actions{display:none!important}::-webkit-scrollbar{display:none}*{scrollbar-width:none}.input-area{padding-bottom:max(8px,env(safe-area-inset-bottom))}.input-area textarea{font-size:16px}.vc-btn{width:var(--mobile-touch-target);height:var(--mobile-touch-target)}.ch-tree-item:hover,.member:hover,.panel-tab:hover,.sb-header-btn:hover,.ub-ctrl:hover,.ctx-item:hover{background:transparent}.ch-tree-item:active,.member:active,.panel-tab:active,.sb-header-btn:active,.ub-ctrl:active,.ctx-item:active{background:var(--bg-h)}.ch-tree-item.active{background:var(--primary-s)}.ch-tree-item.voice.active{background:var(--green-s)}.panel-tab.active{background:var(--bg-2)}.ub-ctrl.active{background:var(--primary-s)}}.mobile-msg-emoji-bar{display:flex;justify-content:center;gap:8px;padding:12px 16px 8px;border-bottom:1px solid var(--b1)}.mobile-msg-emoji-btn{width:44px;height:44px;border:none;background:var(--bg-3);border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s}.mobile-msg-emoji-btn:active{background:var(--bg-5)}.mobile-bs-actions-list{padding:4px 0}@media(max-width:768px){.emoji-picker{position:fixed!important;inset:auto 0 0!important;width:100%!important;max-height:50vh;border-radius:12px 12px 0 0;margin-bottom:0!important;z-index:51}.qs-overlay .qs-panel{width:95vw;max-width:none;top:16px;border-radius:12px}.settings-overlay{flex-direction:column}.settings-nav{width:100%;flex-direction:row;overflow-x:auto;overflow-y:hidden;border-right:none;border-bottom:1px solid var(--b1);padding:8px 4px;gap:2px;flex-shrink:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings-nav::-webkit-scrollbar{display:none}.settings-nav-label,.settings-nav-divider,.settings-nav-version{display:none}.settings-nav-item{white-space:nowrap;flex-shrink:0;width:auto;padding:8px 14px;font-size:14px;border-radius:20px;background:var(--bg-3)}.settings-nav-item.active{background:var(--bg-5)}.settings-nav-logout{border-left:1px solid var(--b1);margin-left:4px;padding-left:14px}.settings-content{padding:16px;max-width:100%}.settings-close{width:var(--mobile-touch-target);height:var(--mobile-touch-target)}.pinned-panel{position:fixed!important;inset:auto 0 0!important;width:100%!important;max-height:50vh;border-radius:12px 12px 0 0;z-index:51}.search-panel{position:fixed!important;inset:0!important;width:100%!important;max-width:100%;z-index:51;border-radius:0;border:none}.member-card{position:fixed!important;inset:auto 0 0!important;width:100%!important;max-width:100%;border-radius:12px 12px 0 0;z-index:51}.voice-participant-grid{grid-template-columns:repeat(2,1fr)!important}.voice-controls button{min-width:var(--mobile-touch-target);min-height:var(--mobile-touch-target)}.p2p-controls{gap:16px;padding:16px}.p2p-controls button{width:56px;height:56px}.sp-overlay .sp-card{width:95vw;max-width:none;max-height:80vh;border-radius:12px}.toast-container{left:8px!important;right:8px!important;bottom:max(8px,env(safe-area-inset-bottom))!important}.toast{max-width:100%}.ctx-menu{position:fixed!important;inset:auto 8px 8px!important;width:auto!important;max-width:100%;border-radius:12px;z-index:51}.input-area{position:sticky;bottom:0}.confirm-card{width:90vw!important;max-width:400px}.auth-card{width:90vw;max-width:420px}.invite-card{width:90vw!important;max-width:400px}.file-drop-overlay{font-size:16px;padding:24px}.msg-attachment-img{max-width:100%;max-height:240px}.voice-session-bar{padding:8px}}.ch-tree-server-group{margin-bottom:2px;position:relative;transition:opacity .15s;cursor:grab}.ch-tree-server-group:active{cursor:grabbing}.ch-tree-server-group.srv-dragging{opacity:.4}.ch-tree-server-group.srv-drop-above:before,.ch-tree-server-group.srv-drop-below:after{content:"";position:absolute;left:10px;right:8px;height:2px;background:var(--primary);border-radius:1px;pointer-events:none;z-index:2}.ch-tree-server-group.srv-drop-above:before{top:0}.ch-tree-server-group.srv-drop-below:after{bottom:0}.ch-tree-add-server{opacity:.7;transition:opacity .15s ease}.ch-tree-add-server:hover{opacity:1}.ch-tree-add-server .ch-tree-icon{color:var(--green);font-size:16px;font-weight:700}.add-server-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50;animation:vpIn .15s ease}.add-server-modal{background:var(--bg-1);border-radius:10px;width:440px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0006}.add-server-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between}.add-server-title{font-family:var(--f-d);font-size:20px;font-weight:700;color:var(--t0)}.add-server-close{width:28px;height:28px;border:none;background:transparent;color:var(--t2);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background .1s,color .1s}.add-server-close:hover{background:var(--bg-h);color:var(--t0)}.add-server-body{padding:16px 24px 24px}.add-server-steps{display:flex;gap:6px;margin-bottom:20px}.add-server-step{flex:1;height:3px;border-radius:2px;background:var(--bg-4);transition:background .2s}.add-server-step.active{background:var(--primary)}.add-server-step.done{background:var(--green)}.add-server-field{margin-bottom:16px}.add-server-label{display:block;font-size:13px;font-weight:600;color:var(--t1);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.add-server-input{width:100%;padding:10px 12px;border:1px solid var(--b2);border-radius:6px;background:var(--bg-0);color:var(--t0);font-size:14px;font-family:var(--f-ui);outline:none;transition:border-color .15s}.add-server-input:focus{border-color:var(--primary)}.add-server-input::placeholder{color:var(--t3)}.host-type-cards{display:flex;flex-direction:column;gap:10px}.host-type-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid var(--b2);border-radius:8px;cursor:pointer;transition:border-color .15s,background .15s}.host-type-card:hover{background:var(--bg-h)}.host-type-card.selected{border-color:var(--primary);background:var(--primary-s)}.host-type-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--t3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s}.host-type-card.selected .host-type-radio{border-color:var(--primary)}.host-type-radio-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);transform:scale(0);transition:transform .15s}.host-type-card.selected .host-type-radio-dot{transform:scale(1)}.host-type-info{flex:1}.host-type-name{font-size:14px;font-weight:600;color:var(--t0);margin-bottom:2px}.host-type-desc{font-size:13px;color:var(--t2)}.add-server-actions{display:flex;gap:10px;margin-top:20px}.add-server-btn-primary{flex:1;padding:10px;border:none;border-radius:6px;background:var(--primary);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;font-family:var(--f-ui)}.add-server-btn-primary:hover{background:var(--primary-h)}.add-server-btn-primary:disabled{opacity:.5;cursor:not-allowed}.add-server-btn-secondary{flex:1;padding:10px;border:1px solid var(--b2);border-radius:6px;background:transparent;color:var(--t1);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,color .15s;font-family:var(--f-ui)}.add-server-btn-secondary:hover{background:var(--bg-h);color:var(--t0)}.add-server-choice{display:flex;flex-direction:column;gap:12px}.add-server-choice-btn{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--b2);border-radius:8px;background:transparent;cursor:pointer;transition:background .15s,border-color .15s;text-align:left;font-family:var(--f-ui)}.add-server-choice-btn:hover{background:var(--bg-h);border-color:var(--primary)}.add-server-choice-icon{width:42px;height:42px;border-radius:50%;background:var(--primary-s);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.add-server-choice-text{flex:1}.add-server-choice-title{font-size:15px;font-weight:600;color:var(--t0);margin-bottom:2px}.add-server-choice-desc{font-size:13px;color:var(--t2)}.add-server-choice-arrow{color:var(--t3);font-size:18px;flex-shrink:0}.add-server-or{display:flex;align-items:center;gap:12px;color:var(--t3);font-size:13px;font-weight:600;text-transform:uppercase}.add-server-or:before,.add-server-or:after{content:"";flex:1;height:1px;background:var(--b1)}body:has(.landing-page){overflow-y:auto!important}body:has(.landing-page) #root{overflow-y:auto!important;height:auto!important}.landing-page{--lp-bg: #0a0a0a;--lp-surface: #141414;--lp-surface-light: #1c1c1c;--lp-border: rgba(255,255,255,.08);--lp-text: #e8e8e8;--lp-text-muted: #888;--lp-text-dim: #555;--lp-accent: #3b82f6;--lp-accent-dim: rgba(59,130,246,.1);--lp-secondary: #6366f1;--lp-tertiary: #ef4444;--lp-glow: rgba(59,130,246,.12);font-family:Instrument Sans,system-ui,sans-serif;background:var(--lp-bg);color:var(--lp-text);overflow-x:hidden;-webkit-font-smoothing:antialiased;min-height:100vh}@keyframes auroraFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(60px,-40px) scale(1.1)}66%{transform:translate(-40px,30px) scale(.95)}}@keyframes lp-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}@keyframes lp-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}@keyframes lp-fadeUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.lp-reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}.lp-reveal--visible{opacity:1;transform:translateY(0)}.lp-aurora-wrap{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.lp-aurora-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.12;animation:auroraFloat 20s ease-in-out infinite}.lp-aurora-blob--1{width:600px;height:600px;background:var(--lp-accent);top:-200px;left:10%;animation-duration:20s;opacity:.08}.lp-aurora-blob--2{width:500px;height:500px;background:var(--lp-secondary);top:30%;right:-100px;animation-duration:25s;animation-delay:-7s;opacity:.06}.lp-aurora-blob--3{width:400px;height:400px;background:var(--lp-secondary);bottom:10%;left:20%;animation-duration:22s;animation-delay:-14s;opacity:.05}.lp-grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px}.lp-content{position:relative;z-index:2}.lp-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:16px 40px;display:flex;align-items:center;gap:12px;background:#0a0a0acc;backdrop-filter:blur(20px);border-bottom:1px solid rgba(26,48,56,.5)}.lp-nav-logo{width:34px;height:34px;border-radius:9px;background:var(--lp-accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;color:#fff;flex-shrink:0}.lp-nav-brand{font-weight:700;font-size:18px;letter-spacing:-.5px;color:var(--lp-text)}.lp-nav-links{display:flex;gap:32px;margin-left:auto}.lp-nav-link{color:var(--lp-text-muted);font-size:14px;font-weight:500;text-decoration:none;transition:color .2s;cursor:pointer;background:none;border:none;font-family:inherit}.lp-nav-link:hover{color:var(--lp-accent)}.lp-nav-lang{display:flex;margin-left:16px;border:1px solid var(--lp-border);border-radius:8px;overflow:hidden}.lp-nav-lang-btn{padding:6px 12px;border:none;background:transparent;color:var(--lp-text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .2s,color .2s}.lp-nav-lang-btn:first-child{border-right:1px solid var(--lp-border)}.lp-nav-lang-btn--active{background:var(--lp-accent-dim);color:var(--lp-accent)}.lp-nav-login{margin-left:12px;padding:8px 22px;border-radius:8px;border:1px solid var(--lp-accent);background:var(--lp-accent-dim);color:var(--lp-accent);font-weight:600;font-size:13px;cursor:pointer;font-family:inherit;transition:background .2s}.lp-nav-login:hover{background:#20dbb02e}.lp-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px;position:relative}.lp-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 8px;border-radius:20px;background:#f0706814;border:1px solid rgba(240,112,104,.2);font-size:12px;font-weight:600;color:var(--lp-tertiary);margin-bottom:32px;animation:lp-fadeUp .8s ease both}.lp-hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--lp-tertiary);animation:lp-pulse 2s ease-in-out infinite}.lp-hero-user-count{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 8px;border-radius:20px;background:var(--lp-accent-dim);border:1px solid rgba(32,219,176,.2);font-size:12px;font-weight:600;color:var(--lp-accent);margin-bottom:16px;animation:lp-fadeUp .8s ease both}.lp-hero-user-dot{width:7px;height:7px;border-radius:50%;background:var(--lp-accent);animation:lp-pulse 2s ease-in-out infinite}.lp-hero h1{font-size:clamp(36px,5.5vw,64px);font-weight:700;line-height:1.1;letter-spacing:-1.5px;max-width:700px;margin-bottom:24px;animation:lp-fadeUp .8s ease .1s both}.lp-hero-gradient{color:var(--lp-accent)}.lp-hero p{font-size:clamp(16px,2vw,20px);color:var(--lp-text-muted);max-width:560px;line-height:1.7;margin-bottom:48px;animation:lp-fadeUp .8s ease .2s both}.lp-hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;animation:lp-fadeUp .8s ease .3s both}.lp-btn-primary{padding:14px 36px;border-radius:12px;border:none;background:var(--lp-accent);color:var(--lp-bg);font-weight:700;font-size:15px;cursor:pointer;font-family:inherit;transition:opacity .2s}.lp-btn-primary:hover{opacity:.9}.lp-btn-secondary{padding:14px 36px;border-radius:12px;border:1px solid var(--lp-border);background:var(--lp-surface);color:var(--lp-text);font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;transition:border-color .2s}.lp-btn-secondary:hover{border-color:var(--lp-text-dim)}.lp-download-link{display:inline-flex;align-items:center;gap:10px;margin-top:24px;padding:14px 40px;border-radius:12px;border:2px solid var(--lp-accent);background:transparent;color:var(--lp-accent);font-size:16px;font-weight:700;font-family:inherit;text-decoration:none;transition:background .2s,color .2s;animation:lp-fadeUp .8s ease .5s both}.lp-download-link:hover{background:var(--lp-accent);color:var(--lp-bg)}.lp-download-link svg{flex-shrink:0;width:20px;height:20px}.lp-hero-scroll{position:absolute;bottom:40px;animation:lp-bounce 2s ease infinite;color:var(--lp-text-dim)}.lp-section{padding:120px 40px;max-width:1200px;margin:0 auto}.lp-section-label{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--lp-accent);margin-bottom:16px}.lp-section-title{font-size:clamp(26px,3.5vw,38px);font-weight:700;letter-spacing:-.5px;line-height:1.2;margin-bottom:20px}.lp-section-desc{font-size:17px;color:var(--lp-text-muted);line-height:1.7;max-width:560px}.lp-section--center{text-align:center}.lp-section--center .lp-section-desc{margin:0 auto}.lp-problem{display:flex;align-items:center;gap:80px;flex-wrap:wrap}.lp-problem-left,.lp-problem-right{flex:1;min-width:300px}.lp-id-card{background:var(--lp-surface);border:1px solid var(--lp-border);border-radius:16px;padding:32px;position:relative;overflow:hidden}.lp-id-card-bar{position:absolute;top:0;left:0;right:0;height:4px;background:var(--lp-tertiary)}.lp-id-card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;font-size:13px;font-weight:700;color:var(--lp-tertiary)}.lp-id-card-icon{width:36px;height:36px;border-radius:8px;background:#f070681a;display:flex;align-items:center;justify-content:center;font-size:18px;font-family:JetBrains Mono,monospace;font-weight:700;color:var(--lp-tertiary)}.lp-id-card-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;background:#f070680a;border:1px solid rgba(240,112,104,.1);margin-bottom:12px}.lp-id-card-row:last-of-type{margin-bottom:0}.lp-id-card-label{font-size:11px;color:var(--lp-text-dim);min-width:80px}.lp-id-card-redacted{background:repeating-linear-gradient(90deg,var(--lp-tertiary) 0px,var(--lp-tertiary) 6px,transparent 6px,transparent 9px);height:10px;width:100px;border-radius:2px;opacity:.4}.lp-id-card-upload{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--lp-tertiary)}.lp-id-card-stamp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-12deg);font-size:28px;font-weight:800;color:var(--lp-accent);border:4px solid var(--lp-accent);border-radius:8px;padding:8px 24px;letter-spacing:3px;opacity:.8;text-transform:uppercase}.lp-features-header{text-align:center;margin-bottom:64px}.lp-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.lp-feature-card{background:var(--lp-surface);border:1px solid var(--lp-border);border-radius:16px;padding:32px 28px;transition:all .4s;position:relative;overflow:hidden}.lp-feature-card:hover{border-color:var(--lp-accent);transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.lp-feature-card-line{position:absolute;top:0;left:0;right:0;height:2px;background:var(--lp-accent);transform:scaleX(0);transition:transform .4s;transform-origin:left}.lp-feature-card:hover .lp-feature-card-line{transform:scaleX(1)}.lp-feature-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;margin-bottom:12px}.lp-feature-tag--live{background:#22c55e14;color:#4ade80}.lp-feature-tag--beta{background:var(--lp-accent-dim);color:var(--lp-accent)}.lp-feature-card h3{font-size:16px;font-weight:700;margin-bottom:10px}.lp-feature-card p{font-size:13px;color:var(--lp-text-muted);line-height:1.65;margin:0}.lp-comparison-table{border-radius:16px;overflow:hidden;border:1px solid var(--lp-border);margin-top:48px}.lp-comp-header,.lp-comp-row{display:grid;grid-template-columns:1.5fr 1fr 1fr}.lp-comp-header{background:var(--lp-surface-light)}.lp-comp-cell{padding:16px 24px;font-size:14px;font-weight:500;display:flex;align-items:center}.lp-comp-cell--header{font-size:13px;font-weight:700;justify-content:center}.lp-comp-cell--mqvi{color:var(--lp-accent)}.lp-comp-cell--other{color:var(--lp-text-muted)}.lp-comp-cell+.lp-comp-cell{border-left:1px solid var(--lp-border)}.lp-comp-row{border-top:1px solid var(--lp-border)}.lp-comp-check{font-size:18px}.lp-comp-cross{font-size:16px;color:var(--lp-tertiary);opacity:.6}.lp-comp-text-bad{font-size:13px;color:var(--lp-tertiary)}.lp-roadmap-grid{display:flex;gap:20px}.lp-roadmap-col{flex:1}.lp-roadmap-col-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:10px 10px 0 0;font-size:12px;font-weight:700}.lp-roadmap-col-dot{width:8px;height:8px;border-radius:50%}.lp-roadmap-col-body{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--lp-surface);border:1px solid var(--lp-border);border-top:none;border-radius:0 0 10px 10px;min-height:200px}.lp-roadmap-item{padding:12px 14px;border-radius:8px;background:var(--lp-surface-light);border:1px solid var(--lp-border);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px}.lp-selfhost{display:flex;align-items:center;gap:80px;flex-wrap:wrap}.lp-selfhost-left,.lp-selfhost-right{flex:1;min-width:300px}.lp-guide-os-tabs{display:flex;gap:8px;max-width:780px;margin:40px auto 0;padding:6px;border-radius:12px;background:var(--lp-card);border:1px solid var(--lp-border)}.lp-guide-os-tab{display:flex;align-items:center;justify-content:center;gap:10px;flex:1;padding:16px 32px;border:none;border-radius:8px;background:transparent;color:var(--lp-text-dim);font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:color .2s,background .2s}.lp-guide-os-tab svg{width:22px;height:22px}.lp-guide-os-tab:hover{color:var(--lp-text);background:#ffffff0a}.lp-guide-os-tab.active{color:#fff;background:var(--lp-accent)}.lp-terminal{background:#0a0a0a;border:1px solid #222;border-radius:12px;overflow:hidden;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.8}.lp-terminal-bar{height:36px;background:#141414;display:flex;align-items:center;gap:7px;padding:0 14px;border-bottom:1px solid #222}.lp-terminal-dot{width:10px;height:10px;border-radius:50%}.lp-terminal-body{padding:20px;color:#888}.lp-terminal-comment{color:#444}.lp-terminal-cmd{color:var(--lp-accent)}.lp-terminal-flag{color:var(--lp-secondary)}.lp-terminal-url{color:var(--lp-text-muted);text-decoration:underline}.lp-terminal-ok,.lp-terminal-version{color:var(--lp-accent)}.lp-guide{max-width:780px;margin:60px auto 0;display:flex;flex-direction:column;gap:0;position:relative}.lp-guide:before{content:"";position:absolute;left:19px;top:40px;bottom:40px;width:2px;background:linear-gradient(to bottom,var(--lp-accent),var(--lp-border));border-radius:1px}.lp-guide-step{display:flex;gap:24px;padding:24px 0;position:relative}.lp-guide-step-num{width:40px;height:40px;border-radius:50%;background:var(--lp-surface);border:2px solid var(--lp-accent);color:var(--lp-accent);font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}.lp-guide-step-content{flex:1;min-width:0}.lp-guide-step-title{font-size:20px;font-weight:700;color:var(--lp-text);margin-bottom:8px}.lp-guide-step-desc{font-size:15px;color:var(--lp-text-muted);line-height:1.7;margin-bottom:16px}.lp-guide-providers{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.lp-guide-provider-tag{padding:6px 14px;border-radius:8px;background:var(--lp-surface-light);border:1px solid var(--lp-border);color:var(--lp-text);font-size:13px;font-weight:600}.lp-guide-specs{display:flex;flex-direction:column;gap:6px}.lp-guide-spec{display:flex;align-items:center;gap:12px;font-size:14px}.lp-guide-spec-label{color:var(--lp-text-muted);min-width:140px}.lp-guide-spec-val{color:var(--lp-text);font-weight:500}.lp-guide-port-table{border:1px solid var(--lp-border);border-radius:10px;overflow:hidden;margin-bottom:16px;font-size:14px}.lp-guide-port-row{display:grid;grid-template-columns:160px 80px 1fr;padding:10px 16px;border-bottom:1px solid var(--lp-border);color:var(--lp-text-muted)}.lp-guide-port-row:last-child{border-bottom:none}.lp-guide-port-row--header{background:var(--lp-surface-light);font-weight:600;color:var(--lp-text);font-size:13px;text-transform:uppercase;letter-spacing:.04em}.lp-guide-port-num{color:var(--lp-accent);font-weight:600;font-family:JetBrains Mono,monospace}.lp-guide-tip{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 16px;border-radius:8px;background:#20dbb00f;border:1px solid rgba(32,219,176,.15);font-size:14px;color:var(--lp-text-muted);line-height:1.6}.lp-guide-tip-icon{font-size:16px;flex-shrink:0;margin-top:1px;font-family:JetBrains Mono,monospace;font-weight:700;color:var(--lp-accent)}.lp-guide-fields{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.lp-guide-field{display:flex;align-items:center;gap:16px;padding:10px 16px;border-radius:8px;background:var(--lp-surface);border:1px solid var(--lp-border)}.lp-guide-field-label{color:var(--lp-text-muted);font-size:13px;font-weight:600;min-width:100px}.lp-guide-field-val{color:var(--lp-accent);font-family:JetBrains Mono,monospace;font-size:13px}.lp-guide-troubleshoot{margin-top:48px}.lp-guide-troubleshoot-title{font-size:20px;font-weight:700;color:var(--lp-text);margin-bottom:20px;text-align:center}.lp-guide-trouble-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.lp-guide-trouble-card{padding:20px;border-radius:12px;background:var(--lp-surface);border:1px solid var(--lp-border)}.lp-guide-trouble-q{font-size:15px;font-weight:600;color:var(--lp-text);margin-bottom:8px}.lp-guide-trouble-a{font-size:14px;color:var(--lp-text-muted);line-height:1.6}@media(max-width:640px){.lp-guide:before{left:15px}.lp-guide-step{gap:16px}.lp-guide-step-num{width:32px;height:32px;font-size:14px}.lp-guide-port-row{grid-template-columns:120px 60px 1fr;padding:8px 12px;font-size:13px}.lp-guide-trouble-grid{grid-template-columns:1fr}.lp-guide-spec{flex-direction:column;gap:2px;align-items:flex-start}.lp-guide-spec-label{min-width:auto}}.lp-cta{text-align:center;padding:160px 40px;position:relative}.lp-cta-glow{position:absolute;top:0;left:50%;transform:translate(-50%);width:600px;height:600px;border-radius:50%;background:var(--lp-accent);filter:blur(200px);opacity:.06;pointer-events:none}.lp-cta h2{font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-1px;margin-bottom:20px}.lp-cta p{font-size:18px;color:var(--lp-text-muted);margin-bottom:40px;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.7}.lp-cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.lp-footer{padding:40px;border-top:1px solid var(--lp-border);display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;flex-wrap:wrap;gap:16px}.lp-footer-left{display:flex;align-items:center;gap:10px}.lp-footer-logo{width:24px;height:24px;border-radius:6px;background:var(--lp-accent);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;color:#fff}.lp-footer-copy{font-size:13px;color:var(--lp-text-dim)}.lp-footer-links{display:flex;gap:24px}.lp-footer-link{font-size:13px;color:var(--lp-text-muted);text-decoration:none;transition:color .2s}.lp-footer-link:hover{color:var(--lp-accent)}
