:root{--bg-primary:#1a1b23;--bg-secondary:#1e1f2a;--bg-card:#252633;--bg-hover:#2e3044;--bg-active:#2a2b3d;--border:#2e303e;--border-input:#3a3c4e;--text-primary:#e2e4ea;--text-secondary:#8b8fa4;--text-muted:#555872;--accent:#10b981;--accent-hover:#059669;--accent-soft:#10b9811f;--accent-border:#10b98140;--online:#10b981;--offline:#555872;--error:#ef4444;--error-bg:#ef44441a;--error-border:#ef444433;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--bubble-graphite:#2e3040;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--chat-bg:none;--chat-bg-overlay:#121316d1;--input-bg:#1a1b23;--text-strong:#fff;--login-grad-start:#1a1b23;--login-grad-mid:#1e2a24;--login-grad-end:#1a1b23;--message-meta:#ffffff73;--message-subtle:#fff6}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);user-select:none;overflow:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#3a3c4e;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a4d62}.web-restore-splash{background:var(--bg-primary);height:100dvh;color:var(--text-primary);justify-content:center;align-items:center;margin:0;display:flex}.web-restore-splash__text{opacity:.85;margin:0;font-size:1rem}.login-container{background:var(--bg-primary);justify-content:center;align-items:center;height:100dvh;display:flex;position:relative;overflow:hidden}.login-bg-img{object-fit:cover;z-index:0;pointer-events:none;user-select:none;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges;-ms-interpolation-mode:nearest-neighbor;position:absolute;inset:0}.login-container>.login-card{z-index:1;position:relative}.login-card{border-radius:var(--radius-xl);background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:400px;padding:2rem 2.5rem;box-shadow:0 8px 32px #0000004d}.login-logo{object-fit:contain;max-width:120px;max-height:120px;margin-bottom:16px}.login-title{color:var(--text-strong);margin-bottom:.3rem;font-size:1.8rem;font-weight:700}.login-subtitle{color:var(--text-secondary);margin-bottom:1.2rem;font-size:.9rem}.login-error{color:var(--error);background:var(--error-bg);border:1px solid var(--error-border);border-radius:6px;margin-bottom:.8rem;padding:8px 12px;font-size:.85rem}.login-server-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-top:12px;padding:0;font-size:.8rem;transition:color .15s;display:flex}.login-server-toggle:hover{color:var(--text-primary)}.login-server-section{margin-top:8px}.login-server-row{align-items:flex-start;gap:8px;display:flex}.login-server-row .input{flex:1;margin-bottom:0}.input{border-radius:var(--radius-md);border:1px solid var(--border-input);background:var(--input-bg);width:100%;color:var(--text-primary);outline:none;margin-bottom:10px;padding:10px 14px;font-size:.9rem;transition:border-color .15s;display:block}.login-remember{color:var(--text-secondary);align-items:center;gap:8px;margin-top:2px;margin-bottom:8px;font-size:.82rem;display:flex}.login-remember input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent)}.input:focus{border-color:var(--accent)}.btn-primary{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;border:none;width:100%;margin-top:6px;padding:10px;font-size:.95rem;font-weight:600;transition:background .15s;display:block}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{border-radius:var(--radius-md);border:1px solid var(--border-input);color:var(--text-primary);cursor:pointer;background:0 0;padding:8px 18px;font-size:.85rem;transition:border-color .15s,background .15s}.btn-secondary:hover{background:var(--bg-hover);border-color:#555872}.btn-danger{border-radius:var(--radius-md);background:var(--error);color:#fff;cursor:pointer;border:none;padding:8px 18px;font-size:.85rem;font-weight:600;transition:background .15s}.btn-danger:hover{background:#dc2626}.layout{height:100dvh;display:flex}.sidebar{border-right:1px solid var(--border);background:var(--bg-secondary);flex-direction:column;flex-shrink:0;width:280px;display:flex}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.sidebar-header__name{color:var(--text-strong);font-size:.95rem;font-weight:600}.btn-signout{border-radius:var(--radius-sm);border:1px solid var(--border-input);color:var(--text-secondary);cursor:pointer;background:0 0;padding:4px 10px;font-size:.75rem;transition:color .15s,border-color .15s}.btn-signout:hover{color:var(--text-primary);border-color:#555872}.sidebar-tabs{border-bottom:1px solid var(--border);display:flex}.sidebar-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:10px 0;font-size:.85rem;font-weight:500;transition:color .15s,border-color .15s}.sidebar-tab:hover{color:var(--text-primary)}.sidebar-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.sidebar-section-header{justify-content:flex-end;padding:6px 12px;display:flex}.btn-icon{border-radius:var(--radius-md);border:1px solid var(--border-input);width:28px;height:28px;color:var(--text-primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;font-size:1.1rem;transition:background .15s,border-color .15s;display:flex}.btn-icon:hover{background:var(--bg-hover);border-color:#555872}.btn-icon svg{width:16px;height:16px}.tab-badge{background:var(--accent);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;margin-left:6px;padding:0 5px;font-size:.68rem;font-weight:700;display:inline-flex}.tab-badge--unread{background:var(--error)}.friend-requests{border-bottom:1px solid var(--border);margin-bottom:4px;padding-bottom:6px}.friend-requests__title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:6px 16px 4px;font-size:.72rem;font-weight:600}.friend-request-row{align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;display:flex}.friend-request-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;color:var(--text-primary);flex:1;overflow:hidden}.friend-request-actions{flex-shrink:0;gap:4px;display:flex}.btn-tiny--accept{color:var(--online);border-color:var(--accent-border)}.btn-tiny--accept:hover{color:#fff;background:var(--online);border-color:var(--online)}.outgoing-requests{border-top:1px solid var(--border);margin-top:4px;padding-top:6px}.outgoing-requests__title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;padding:4px 12px;font-size:.72rem;font-weight:600}.peer-row--pending{opacity:.5}.peer-name--pending{color:var(--text-secondary);font-style:italic}.add-contact-form{gap:6px;padding:4px 12px 8px;display:flex}.add-contact-input{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--input-bg);color:var(--text-primary);outline:none;flex:1;padding:6px 10px;font-size:.82rem;transition:border-color .15s}.add-contact-input:focus{border-color:var(--accent)}.btn-add-confirm{border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;padding:6px 12px;font-size:.78rem;font-weight:600;transition:background .15s}.btn-add-confirm:hover{background:var(--accent-hover)}.peer-list{flex:1;padding:4px 0;overflow-y:auto}.peer-row{cursor:pointer;border-radius:var(--radius-md);align-items:center;gap:10px;margin:0 6px;padding:8px 12px;font-size:.9rem;transition:background .12s;display:flex;position:relative}.peer-row:hover{background:var(--bg-hover)}.peer-row--active{background:var(--bg-active)}.peer-row--offline{opacity:.6}.contact-status-text{color:#ffffff73;white-space:nowrap;text-overflow:ellipsis;flex-shrink:1;max-width:120px;margin-left:auto;font-size:.75rem;font-style:italic;overflow:hidden}.unread-dot{background:var(--error);width:10px;min-width:10px;height:10px;box-shadow:0 0 6px var(--error);border-radius:50%;margin-left:auto}.peer-dot{background:var(--online);border-radius:50%;flex-shrink:0;width:8px;height:8px}.peer-dot--offline{background:var(--offline)}.peer-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.peer-name--offline{color:var(--text-secondary)}.btn-remove-contact{width:22px;height:22px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:opacity .15s,color .15s;display:flex}.peer-row:hover .btn-remove-contact{opacity:1}.btn-remove-contact:hover{color:var(--error)}.room-icon{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0}.room-icon svg{width:20px;height:20px}.room-info{flex-direction:column;min-width:0;display:flex}.room-name{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;overflow:hidden}.room-members-count{color:var(--text-secondary);font-size:.72rem}.empty-text{color:var(--text-muted);margin:1rem 16px;font-size:.85rem;font-style:italic}.chat-area{flex-direction:column;flex:1;min-width:0;display:flex}.chat-placeholder{flex:1;justify-content:center;align-items:center;display:flex}.chat-placeholder__text{color:var(--text-muted);font-size:1rem}.chat-header{border-bottom:1px solid var(--border);background:var(--bg-secondary);align-items:center;gap:10px;padding:12px 20px;display:flex}.chat-header__avatar{cursor:pointer}.chat-header__name{color:var(--text-strong);cursor:pointer;font-size:1rem;font-weight:600}.chat-header__name:hover{text-decoration:underline}.chat-header__status-dot{background:var(--online);border-radius:50%;flex-shrink:0;width:8px;height:8px}.chat-header__status-dot--offline{background:var(--offline)}.chat-header__badge{color:var(--accent);background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:10px;padding:2px 8px;font-size:.75rem}.chat-header__badge--room{color:var(--text-secondary);background:#8b8fa41a;border-color:#8b8fa433}.chat-header__actions{gap:6px;margin-left:auto;display:flex}.message-list-wrapper{flex:1;min-height:0;position:relative;overflow:hidden}.chat-jump-to-latest{z-index:4;cursor:pointer;width:44px;height:44px;color:var(--text-strong);background:var(--bg-secondary);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:transform .15s,background .15s;animation:.28s ease-out chat-jump-to-latest-in;display:flex;position:absolute;bottom:12px;right:16px;box-shadow:0 2px 12px #0003}.chat-jump-to-latest:hover{background:var(--accent-soft);transform:translateY(-1px)}@keyframes chat-jump-to-latest-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.message-list-wrapper--with-bg{background-image:var(--chat-bg);background-position:50%;background-repeat:no-repeat;background-size:cover}.message-list-wrapper--with-bg:before{content:"";background:var(--chat-bg-overlay);pointer-events:none;z-index:1;position:absolute;inset:0}.message-list{z-index:2;flex-direction:column;gap:4px;height:100%;padding:16px 20px;display:flex;position:relative;overflow-y:auto}.message-list>[data-message-id]{flex-direction:column;animation:.25s ease-out msg-slide-in;display:flex}@keyframes msg-slide-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.message-list__empty{color:var(--text-muted);text-align:center;margin-top:2rem;font-size:.9rem}.message-list__loading{color:var(--text-muted);text-align:center;padding:.5rem 0;font-size:.8rem}.message-row{flex-direction:column;max-width:70%;display:flex}.message-row--mine{align-self:flex-end;align-items:flex-end}.message-row--theirs{align-self:flex-start;align-items:flex-start}.message-row__inner{align-items:flex-end;gap:8px;display:flex}.message-avatar{flex-shrink:0;width:32px;height:32px}.message-avatar--spacer{visibility:hidden}.message-avatar--clickable,.message-sender--clickable{cursor:pointer}.message-sender--clickable:hover{text-decoration:underline}.message-avatar .avatar{width:32px;height:32px;font-size:.7rem}.message-sender--minimal{color:var(--accent);margin-bottom:1px;margin-left:40px;font-size:.68rem;font-weight:500}.message-sender--inline{color:var(--accent);font-size:.75rem;font-weight:600}.message-bubble__header{justify-content:space-between;align-items:center;gap:8px;width:100%;margin-bottom:2px;display:flex}.message-bubble__header--status-only{justify-content:flex-end}.message-sender-status{color:var(--message-subtle);white-space:nowrap;text-overflow:ellipsis;text-align:right;flex-shrink:0;max-width:120px;font-size:.68rem;font-style:italic;overflow:hidden}.message-sender-status--marquee{text-overflow:clip}.message-sender-status--marquee .marquee-inner{padding-left:100%;animation:6s linear infinite marquee-scroll;display:inline-block}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-100%)}}.message-bubble{border-radius:var(--radius-lg);word-wrap:break-word;flex-flow:wrap;align-items:flex-end;gap:10px;padding:8px 14px;font-size:.9rem;line-height:1.45;display:inline-flex;position:relative}.message-bubble--theirs-graphite{background:var(--bubble-graphite);border-bottom-left-radius:4px}.message-row--mine .message-bubble--theirs-graphite{background:var(--bubble-graphite);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:4px}.message-text{white-space:pre-wrap;word-break:break-word;user-select:text}.msg-code{background:#0003;border-radius:3px;padding:1px 4px;font-family:Consolas,Monaco,monospace;font-size:.85em}.msg-codeblock{white-space:pre;user-select:text;background:#00000040;border-radius:6px;margin:4px 0;padding:8px 10px;font-family:Consolas,Monaco,monospace;font-size:.85em;overflow-x:auto}.msg-link{color:var(--accent);cursor:pointer;text-decoration:underline}.msg-link:hover{text-decoration-thickness:2px}.message-meta{flex-shrink:0;align-items:center;gap:4px;display:flex}.message-time{color:var(--message-meta);white-space:nowrap;font-size:.7rem}.delivery-icon{align-items:center;width:14px;height:14px;display:inline-flex}.delivery-icon svg{width:14px;height:14px}.delivery-icon--unread{color:#ffffff73}.delivery-icon--read{color:var(--accent)}.input-bar{border-top:1px solid var(--border);background:var(--bg-secondary);gap:8px;padding:12px 20px;display:flex}.input-bar__field{border-radius:var(--radius-md);border:1px solid var(--border-input);background:var(--input-bg);resize:none;min-height:40px;max-height:150px;color:var(--text-primary);scrollbar-width:none;-ms-overflow-style:none;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;line-height:1.4;transition:border-color .15s;overflow-y:auto}.input-bar__field::-webkit-scrollbar{display:none}.input-bar__field:focus{border-color:var(--accent)}.btn-send{border-radius:var(--radius-md);background:var(--accent);color:#fff;cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s,opacity .15s;display:flex}.btn-send svg{width:18px;height:18px}.btn-send:hover:not(:disabled){background:var(--accent-hover)}.btn-send:disabled{opacity:.4;cursor:not-allowed}.chat-header__call-btn{border:1px solid var(--border-input);border-radius:var(--radius-md);width:34px;height:34px;color:var(--text-primary);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,color .15s;display:flex}.chat-header__call-btn svg{width:18px;height:18px}.chat-header__call-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--accent);border-color:#555872}.chat-header__call-btn:disabled{opacity:.3;cursor:not-allowed}.call-modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.call-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;min-width:320px;padding:2rem 2.5rem;animation:.25s slideUp}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;min-width:340px;max-width:420px;max-height:80vh;padding:1.5rem 2rem;animation:.25s slideUp;overflow-y:auto}.modal-card--wide{max-width:520px}.modal-card--tabs{flex-direction:column;align-self:center;max-width:650px;height:calc(100dvh - 40px);min-height:200px;padding-top:.75rem;display:flex;position:relative;overflow:hidden}.modal-card--tabs .modal-title{margin-bottom:.5rem}.modal-card__header{flex-shrink:0;justify-content:space-between;align-items:center;margin-right:-1.25rem;padding-right:0;display:flex}.modal-close-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;align-items:center;margin:-3px -3px -3px 0;padding:3px;transition:color .15s,background .15s;display:flex}.modal-close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.settings-modal__body{flex:1;min-height:0;margin:0 -2rem -1.5rem;display:flex}.settings-tabs{border-right:1px solid var(--border);background:var(--bg-secondary);flex-direction:column;flex-shrink:0;width:160px;padding:.5rem 0;display:flex}.settings-version{color:var(--text-secondary);opacity:.85;margin-top:auto;padding:.5rem 1.25rem;font-size:.75rem}.settings-update-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;padding:.2rem .6rem;font-size:.7rem;transition:background .15s,color .15s}.settings-update-btn:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.settings-update-btn:disabled{opacity:.5;cursor:default}.settings-update-btn--available{border-color:var(--accent);color:var(--accent)}.settings-update-btn--ready{color:#22c55e;border-color:#22c55e}.settings-tab--exit{border-top:1px solid var(--border);align-items:center;gap:8px;margin-top:0;margin-left:.5rem;margin-right:.5rem;padding-left:.75rem;display:flex}.settings-tab--exit:hover{color:var(--error)}.settings-tab{text-align:left;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:10px 1.25rem;font-size:.9rem;transition:color .15s,background .15s}.settings-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.settings-tab--active{color:var(--accent);background:var(--accent-soft);font-weight:600}.settings-tab-content{flex:1;padding:0 2rem 1.5rem;overflow-y:auto}.modal-title{color:var(--text-strong);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.modal-subtitle{color:var(--text-secondary);margin-bottom:1rem;font-size:.82rem}.modal-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px;font-size:.78rem;font-weight:600}.modal-actions{justify-content:flex-end;gap:10px;margin-top:1.2rem;display:flex}.modal-btn{width:auto;padding:8px 20px}.member-select-list{border:1px solid var(--border);border-radius:var(--radius-md);max-height:200px;margin-bottom:10px;overflow-y:auto}.member-select-row{cursor:pointer;align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;transition:background .12s;display:flex}.member-select-row:hover{background:var(--bg-hover)}.member-select-row--clickable{cursor:pointer}.member-select-row input[type=checkbox]{accent-color:var(--accent)}.room-settings-header{align-items:flex-start;gap:16px;margin-bottom:8px;display:flex}.room-settings-avatar{cursor:pointer;flex-shrink:0;position:relative}.room-settings-avatar__edit{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;display:flex;position:absolute;bottom:0;right:0}.room-settings-fields{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.member-list{border:1px solid var(--border);border-radius:var(--radius-md);max-height:250px;margin-bottom:10px;overflow-y:auto}.member-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;display:flex}.member-row:last-child{border-bottom:none}.member-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.member-role-badge{background:var(--bg-hover);color:var(--text-secondary);border-radius:8px;flex-shrink:0;padding:2px 6px;font-size:.7rem}.member-actions{gap:4px;margin-left:auto;display:flex}.btn-tiny{border-radius:var(--radius-sm);border:1px solid var(--border-input);color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;padding:3px 8px;font-size:.7rem;transition:color .15s,border-color .15s}.btn-tiny:hover{color:var(--text-primary);border-color:#555872}.btn-tiny--danger{color:var(--error);border-color:#ef44444d}.btn-tiny--danger:hover{color:#fff;background:var(--error);border-color:var(--error)}.add-member-section{margin-top:8px}.toast-error{background:var(--error);color:#fff;border-radius:var(--radius-md);z-index:300;padding:10px 24px;font-size:.85rem;font-weight:500;animation:.25s slideUp;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #0006}.call-modal__icon{color:var(--accent);margin-bottom:.8rem;font-size:2.5rem}.call-modal__icon svg{width:48px;height:48px}.call-modal__title{color:var(--text-strong);margin-bottom:.3rem;font-size:1.1rem;font-weight:600}.call-modal__caller{color:var(--text-secondary);margin-bottom:1.5rem;font-size:1rem}.call-modal__actions{justify-content:center;gap:12px;display:flex}.call-btn{border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 28px;font-size:.9rem;font-weight:600;transition:background .15s}.call-btn--accept{color:#fff;background:#10b981}.call-btn--accept:hover{background:#059669}.call-btn--reject{color:#fff;background:#ef4444}.call-btn--reject:hover{background:#dc2626}.call-overlay{z-index:200;background:#12131c;flex-direction:column;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.call-overlay__bg{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.call-remote-video{object-fit:cover;width:100%;height:100%}.call-audio-placeholder{flex-direction:column;align-items:center;gap:12px;display:flex}.call-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;font-size:2.5rem;font-weight:700;display:flex}.call-remote-name{color:var(--text-strong);font-size:1.4rem;font-weight:600}.call-status-text{color:var(--text-secondary);font-size:.9rem;animation:1.5s ease-in-out infinite pulse}.call-overlay__name{color:#fffc;text-shadow:0 1px 4px #00000080;font-size:1rem;font-weight:600;position:absolute;top:16px;left:20px}.call-local-video{border-radius:var(--radius-lg);object-fit:cover;z-index:10;border:2px solid #ffffff26;width:180px;height:135px;position:absolute;bottom:100px;right:20px;transform:scaleX(-1)}.call-local-bg-video{transform:scaleX(-1)}.call-controls{background:#00000080;justify-content:center;gap:16px;padding:20px;display:flex}.call-control-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:background .15s;display:flex}.call-control-btn svg{width:22px;height:22px}.call-control-btn:hover{background:#fff3}.call-control-btn--active{background:#ffffff40}.call-control-btn--hangup{background:#ef4444}.call-control-btn--hangup:hover{background:#dc2626}.call-mic-level{z-index:15;background:#ffffff1a;border-radius:2px;width:120px;height:4px;position:absolute;bottom:96px;left:50%;overflow:hidden;transform:translate(-50%)}.call-mic-level__bar{background:var(--online);border-radius:2px;height:100%;transition:width 80ms linear}.call-reconnect-banner{color:#fff;z-index:20;text-align:center;white-space:nowrap;background:#c83c3cd9;border-radius:8px;padding:6px 16px;font-size:.85rem;font-weight:600;position:absolute;top:48px;left:50%;transform:translate(-50%)}.call-camera-hint{text-align:center;color:#ffffff80;z-index:15;pointer-events:none;font-size:.8rem;position:absolute;bottom:108px;left:0;right:0}.call-remote--speaking{box-shadow:inset 0 0 0 3px var(--online);transition:box-shadow .15s}.call-avatar--speaking{box-shadow:0 0 0 4px var(--online), 0 0 20px #10b98159;transition:box-shadow .15s}.call-devices-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:20;flex-direction:column;gap:10px;min-width:320px;max-width:420px;padding:14px 18px;animation:.15s slideUp;display:flex;position:absolute;bottom:110px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080}.call-quality-btns{flex:1;gap:6px;display:flex}.call-quality-btn{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;background:0 0;flex:1;padding:4px 8px;font-size:.78rem;transition:background .15s,color .15s}.call-quality-btn:hover{background:#ffffff14}.call-quality-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.call-volume-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:20;min-width:300px;max-width:380px;padding:14px 18px;animation:.15s slideUp;position:absolute;bottom:110px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080}.call-volume-panel__header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:6px;margin-bottom:10px;font-size:.78rem;font-weight:600;display:flex}.call-volume-panel__slider{align-items:center;gap:10px;display:flex}.call-volume-panel__slider input[type=range]{accent-color:var(--accent);cursor:pointer;flex:1;height:4px}.call-volume-panel__value{color:var(--text-primary);text-align:right;font-variant-numeric:tabular-nums;min-width:42px;font-size:.82rem}.call-device-row{flex-direction:column;gap:4px;display:flex}.call-device-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.72rem;font-weight:600}.call-device-select{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--input-bg);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b8fa4' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;outline:none;padding:7px 28px 7px 10px;font-size:.82rem;transition:border-color .15s}.call-device-select:focus{border-color:var(--accent)}.call-device-select option{background:var(--bg-card);color:var(--text-primary)}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex;position:relative}.avatar--sm{width:28px;height:28px;font-size:.72rem}.avatar--md{width:36px;height:36px;font-size:.85rem}.avatar--lg{width:64px;height:64px;font-size:1.5rem}.avatar--xl{width:96px;height:96px;font-size:2.2rem}.avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar__online-dot{background:var(--online);border:2px solid var(--bg-secondary);border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;right:0}.avatar--sm .avatar__online-dot{border-width:1.5px;width:8px;height:8px}.avatar--lg .avatar__online-dot,.avatar--xl .avatar__online-dot{border-width:3px;width:14px;height:14px}.user-panel{border-top:1px solid var(--border);background:#00000026;flex-shrink:0;align-items:center;gap:10px;padding:10px 12px;display:flex}.user-panel__info{cursor:pointer;flex:1;min-width:0}.user-panel__name{color:var(--text-strong);text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:600;overflow:hidden}.user-panel__status{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;overflow:hidden}.user-panel__actions{gap:4px;display:flex}.user-panel__btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.user-panel__btn svg{width:18px;height:18px}.user-panel__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.profile-modal{text-align:center;flex-direction:column;align-items:center;display:flex}.profile-modal__avatar{margin-bottom:16px;position:relative}.profile-modal__avatar-edit{background:var(--accent);border:2px solid var(--bg-card);color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex;position:absolute;bottom:0;right:0}.profile-modal__avatar-edit svg{width:14px;height:14px}.profile-modal__name{color:var(--text-strong);margin-bottom:4px;font-size:1.2rem;font-weight:600}.profile-modal__username{color:var(--text-secondary);margin-bottom:8px;font-size:.82rem}.profile-modal__status{color:var(--text-secondary);margin-bottom:16px;font-size:.88rem;font-style:italic}.profile-modal__online{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:16px;font-size:.82rem;display:flex}.profile-modal__online .peer-dot{width:8px;height:8px}.profile-modal__divider{background:var(--border);width:100%;height:1px;margin:12px 0}.profile-modal__actions{gap:8px;width:100%;display:flex}.profile-modal__actions .btn-primary,.profile-modal__actions .btn-danger,.profile-modal__actions .btn-secondary{flex:1}.edit-profile__field{width:100%;margin-bottom:12px}.edit-profile__label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;font-size:.78rem;font-weight:600;display:block}.settings-section{margin-bottom:20px}.settings-section:last-child{margin-bottom:0}.settings-section__title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px;font-size:.78rem;font-weight:600}.settings-row{flex-direction:column;gap:4px;margin-bottom:10px;display:flex}.settings-row:last-child{margin-bottom:0}.settings-label{color:var(--text-primary);font-size:.82rem}.settings-select{border-radius:var(--radius-sm);border:1px solid var(--border-input);background:var(--input-bg);width:100%;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238b8fa4' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;outline:none;padding:7px 28px 7px 10px;font-size:.82rem;transition:border-color .15s}.settings-select:focus{border-color:var(--accent)}.settings-select option{background:var(--bg-card);color:var(--text-primary)}.settings-server-row{align-items:center;gap:8px;display:flex}.settings-server-row .settings-select{flex:1}.settings-zoom-row{align-items:center;gap:12px;display:flex}.settings-zoom-slider{appearance:none;background:var(--border-input);border-radius:3px;outline:none;flex:1;height:6px}.settings-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px;transition:background .15s}.settings-zoom-slider::-webkit-slider-thumb:hover{background:var(--accent-hover)}.settings-zoom-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.settings-zoom-value{color:var(--text-secondary);min-width:42px;font-size:.9rem}.settings-mic-level{background:var(--input-bg);border:1px solid var(--border-input);border-radius:4px;flex:1;height:8px;overflow:hidden}.settings-mic-level__bar{background:var(--accent);border-radius:4px;min-width:0;height:100%;transition:width 80ms linear}.settings-hint{color:var(--text-muted);margin-top:-4px;font-size:.75rem}.settings-inline-code{word-break:break-all;color:var(--text-secondary);font-family:ui-monospace,monospace;font-size:.7rem}.color-palette{flex-wrap:wrap;gap:8px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.15)}.color-swatch--active{border-color:var(--text-strong);box-shadow:0 0 0 2px var(--bg-card)}.bg-picker{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.bg-option{aspect-ratio:16/10;border-radius:var(--radius-md);cursor:pointer;background-position:50%;background-size:cover;border:2px solid #0000;transition:border-color .15s;position:relative;overflow:hidden}.bg-option:hover{border-color:var(--text-muted)}.bg-option--active{border-color:var(--accent)}.bg-option--none{background:var(--bg-primary);color:var(--text-muted);justify-content:center;align-items:center;font-size:.7rem;display:flex}.bg-option--custom{background:var(--bg-hover);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.bg-option--custom svg{width:20px;height:20px}.confirm-block{border-radius:var(--radius-md);background:var(--error-bg);border:1px solid var(--error-border);margin-top:8px;padding:12px}.confirm-block__text{color:var(--text-primary);margin-bottom:10px;font-size:.85rem}.confirm-block__actions{justify-content:flex-end;gap:8px;display:flex}.btn-attach{border-radius:var(--radius-md);border:1px solid var(--border-input);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.btn-attach:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:#555872}.btn-attach:disabled{opacity:.4;cursor:not-allowed}.message-bubble--file{flex-direction:column;gap:4px;max-width:380px;padding:4px}.message-bubble--file .message-text{padding:4px 10px 0}.message-bubble--file .message-meta{padding:0 10px 4px}.file-attachment{border-radius:var(--radius-md);overflow:hidden}.file-attachment--image{cursor:pointer}.file-attachment__image{border-radius:var(--radius-md);object-fit:contain;max-width:100%;max-height:300px;display:block}.file-attachment--video{max-width:100%}.file-attachment__video{border-radius:var(--radius-md);outline:none;max-width:100%;max-height:300px;display:block}.file-attachment--text{border-radius:var(--radius-md);background:#00000040;overflow:hidden}.file-text-header{color:var(--text-secondary);background:#0003;align-items:center;gap:6px;padding:6px 10px;font-size:.75rem;display:flex}.file-text-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:600;overflow:hidden}.file-text-lang{background:#ffffff1a;border-radius:4px;flex-shrink:0;padding:1px 6px}.file-text-size{flex-shrink:0}.file-text-toggle{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:2px;transition:color .15s;display:flex}.file-text-toggle:hover{color:var(--accent)}.file-text-content{white-space:pre-wrap;word-break:break-all;color:#d4d4d4;user-select:text;max-height:400px;margin:0;padding:8px 10px;font-family:JetBrains Mono,Fira Code,Cascadia Code,Consolas,monospace;font-size:.78rem;line-height:1.5;overflow-y:auto}.file-attachment--generic{cursor:pointer;border-radius:var(--radius-md);align-items:center;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.file-attachment--generic:hover{background:#ffffff0d}.file-attachment--generic svg{color:var(--accent);flex-shrink:0}.file-generic-info{flex-direction:column;min-width:0;display:flex}.file-generic-name{text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;font-weight:500;overflow:hidden}.file-generic-size{color:var(--text-secondary);font-size:.72rem}.image-viewer-overlay{z-index:500;cursor:zoom-out;background:#000000eb;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.image-viewer-close{color:#fff;cursor:pointer;z-index:501;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex;position:absolute;top:16px;right:16px}.image-viewer-close:hover{background:#fff3}.image-viewer-img{object-fit:contain;cursor:default;border-radius:var(--radius-md);max-width:95vw;max-height:95vh;animation:.2s slideUp}.file-video-name{color:var(--text-secondary);text-align:center;padding:4px 10px;font-size:.72rem}.ctx-menu{z-index:600;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);min-width:180px;padding:4px 0;animation:.1s fadeIn;position:fixed;box-shadow:0 8px 24px #00000080}.ctx-menu__item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;padding:8px 14px;font-size:.82rem;transition:background .12s;display:block}.ctx-menu__item:hover{background:var(--bg-hover)}.message-ctx-modal{z-index:600;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);opacity:0;will-change:opacity, transform;min-width:160px;padding:4px 0;transition:opacity .2s,transform .2s;position:fixed;transform:translateY(8px)scale(.98);box-shadow:0 8px 24px #00000080}.message-ctx-modal--visible{opacity:1;transform:translateY(0)scale(1)}.message-ctx-modal--exit{opacity:0;pointer-events:none;transform:translateY(8px)scale(.98)}.message-ctx-modal__item{width:100%;color:var(--text-primary);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 12px;font-size:.82rem;transition:background .12s;display:flex}.message-ctx-modal__item:hover{background:var(--bg-hover)}.message-ctx-modal__item--danger:hover{background:var(--error-bg);color:var(--error)}.message-ctx-modal__reactions{border-bottom:1px solid var(--border);gap:4px;padding:6px 10px;display:flex}.message-ctx-modal__reaction-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;transition:background .12s,transform .12s;display:flex}.message-ctx-modal__reaction-btn:hover{background:var(--bg-hover);transform:scale(1.2)}.message-ctx-modal__reaction-btn--active{background:var(--accent-alpha,#4caf5033)}.message-reactions{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.message-reaction{background:var(--bg-secondary);cursor:default;border-radius:10px;align-items:center;gap:2px;padding:2px 6px;font-size:14px;display:inline-flex}.message-reaction--mine{background:var(--accent-alpha,#4caf5033);outline:1px solid var(--accent)}.message-reaction__emoji{font-size:14px;line-height:1}.message-reaction__count{color:var(--text-muted);font-size:11px}.file-attachment--grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:4px;margin-bottom:4px;display:grid}.file-attachment--grid .file-attachment--image{margin:0}.file-attachment--grid .file-attachment__image{width:100%;height:auto}.paste-modal-overlay{z-index:700;background:#0000008c;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.paste-modal{background:var(--bg-card);border-radius:12px;flex-direction:column;min-width:340px;max-width:560px;max-height:80vh;display:flex;box-shadow:0 8px 32px #0006}.paste-modal__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.paste-modal__title{color:var(--text);font-size:.95rem;font-weight:600}.paste-modal__close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;display:flex}.paste-modal__close:hover{background:var(--bg-hover);color:var(--text)}.paste-modal__grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;max-height:400px;padding:12px 16px;display:grid;overflow-y:auto}.paste-modal__item{background:var(--bg-secondary);aspect-ratio:1;border-radius:8px;position:relative;overflow:hidden}.paste-modal__thumb{object-fit:cover;width:100%;height:100%}.paste-modal__remove{color:#fff;cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;transition:opacity .15s;display:flex;position:absolute;top:4px;right:4px}.paste-modal__item:hover .paste-modal__remove{opacity:1}.paste-modal__name{color:#fff;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(#0000,#0009);padding:2px 6px;font-size:.68rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.paste-modal__add-btn{border:2px dashed var(--border);color:var(--text-muted);cursor:pointer;aspect-ratio:1;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.paste-modal__add-btn:hover{border-color:var(--accent);color:var(--accent)}.paste-modal__hint{text-align:center;color:var(--text-muted);padding:0 16px 8px;font-size:.72rem}.paste-modal__footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:10px 16px 14px;display:flex}.paste-modal__cancel{background:var(--bg-secondary);color:var(--text);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.85rem}.paste-modal__cancel:hover{background:var(--bg-hover)}.paste-modal__send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:.85rem;font-weight:600;display:flex}.paste-modal__send:hover{filter:brightness(1.1)}.paste-modal__send:disabled{opacity:.5;cursor:not-allowed}.input-mode-bar{background:var(--bg-active);border-bottom:1px solid var(--border);color:var(--text-secondary);align-items:center;gap:8px;padding:6px 10px;font-size:.8rem;display:flex}.input-mode-bar__preview{text-overflow:ellipsis;white-space:nowrap;flex:1;max-width:200px;overflow:hidden}.input-mode-bar__preview strong{color:var(--accent);margin-right:4px}.message-reply-ref{border-left:3px solid var(--accent);color:var(--text-secondary);margin-bottom:4px;padding:4px 0 2px 8px;font-size:.78rem;display:block}.message-reply-ref__author{color:var(--accent);margin-right:4px}.message-reply-ref__text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.message-row{cursor:default}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.admin-modal{max-width:780px}.admin-server-info{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:center;gap:16px;padding:8px 16px;animation:.15s fadeIn;display:flex}.admin-server-info__item{flex-direction:column;gap:2px;display:flex}.admin-server-info__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.7rem}.admin-server-info__value{color:var(--text-primary);font-family:Consolas,Courier New,monospace;font-size:.88rem;font-weight:600}.admin-server-info__sep{background:var(--border);width:1px;height:28px}.admin-error{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border);border-radius:var(--radius-sm);margin-bottom:12px;padding:8px 12px;font-size:.82rem;animation:.15s fadeIn}.admin-version-status{border-radius:var(--radius-sm);margin-bottom:8px;padding:6px 10px;font-size:.82rem;animation:.15s fadeIn}.admin-version-status--ok{background:var(--success-bg,#48c7741f);color:var(--success,#48c774);border:1px solid var(--success-border,#48c7744d)}.admin-version-status--err{background:var(--error-bg);color:var(--error);border:1px solid var(--error-border)}.settings-input--sm{max-width:160px}.modal-actions--left{justify-content:flex-start}.admin-toolbar{justify-content:flex-end;margin-bottom:12px;display:flex}.btn-sm{align-items:center;gap:6px;padding:6px 14px;font-size:.8rem;display:inline-flex}.admin-table-wrap{border:1px solid var(--border);border-radius:var(--radius-md);flex:1;margin-bottom:12px;overflow-y:auto}.admin-table{border-collapse:collapse;width:100%;font-size:.82rem}.admin-table th{text-align:left;color:var(--text-secondary);background:var(--bg-secondary);z-index:1;border-bottom:1px solid var(--border);padding:8px 12px;font-weight:600;position:sticky;top:0}.admin-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:8px 12px}.admin-table tbody tr:hover{background:var(--bg-hover)}.admin-table__row--me{background:var(--accent-soft)}.admin-cell-user{color:var(--text-secondary);font-family:Consolas,Courier New,monospace;font-size:.78rem}.admin-cell-status{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.admin-cell-badge{font-size:.78rem}.admin-badge{background:var(--accent);color:#fff;border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:600}.admin-cell-actions{justify-content:flex-end;gap:4px;display:flex}.btn-icon-sm{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.btn-icon-sm:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon-sm--danger:hover{background:var(--error-bg);color:var(--error)}.admin-form{animation:.15s fadeIn}.admin-form__title{color:var(--text-primary);margin-bottom:16px;font-size:.9rem;font-weight:600}.settings-input{background:var(--bg-secondary);border:1px solid var(--border-input);border-radius:var(--radius-sm);color:var(--text-primary);outline:none;flex:1;padding:6px 10px;font-family:inherit;font-size:.82rem;transition:border-color .15s}.settings-input:focus{border-color:var(--accent)}.admin-checkbox{cursor:pointer;color:var(--text-primary);align-items:center;gap:8px;font-size:.82rem;display:flex}.admin-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.admin-confirm-overlay{z-index:10;border-radius:var(--radius-xl);background:#0009;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:absolute;inset:0}.admin-confirm{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:360px;padding:24px;box-shadow:0 8px 32px #0006}.admin-confirm__text{color:var(--text-primary);margin-bottom:8px;font-size:.9rem}.admin-confirm__sub{color:var(--error);margin-bottom:20px;font-size:.8rem}.admin-confirm__actions{justify-content:flex-end;gap:8px;display:flex}.admin-logs-section{flex-direction:column;flex:1;min-height:0;display:flex}.admin-logs-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.admin-logs-header .settings-section__title{margin-bottom:0}.admin-logs{background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);min-height:120px;max-height:100%;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;user-select:text;flex:1;padding:8px 12px;font-family:Consolas,Courier New,monospace;font-size:.75rem;line-height:1.5;overflow-y:auto}.admin-logs__line{padding:1px 0}.admin-logs__line--error{color:var(--error)}.admin-logs__line--warn{color:#e0a030}.admin-logs__empty{color:var(--text-muted);font-style:italic}.user-panel__btn--admin{color:var(--accent)}.user-panel__btn--admin:hover{color:#fff;background:var(--accent)}.connection-toast{flex-direction:column;flex-shrink:0;gap:4px;padding:6px 8px;animation:.25s fadeIn;display:flex}.connection-toast__item{border-radius:var(--radius-sm);color:#fdba74;background:#f9731614;border:1px solid #f9731666;align-items:center;gap:6px;padding:7px 10px;font-size:.78rem;font-weight:500;line-height:1.3;display:flex}.connection-toast__icon{flex-shrink:0;font-size:.85rem}.update-banner{background:var(--bg-secondary);border:1px solid var(--accent);border-radius:var(--radius);z-index:9000;align-items:center;gap:10px;min-width:340px;max-width:560px;padding:10px 16px;animation:.25s fadeIn;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.update-banner__icon{color:var(--accent);flex-shrink:0;font-size:1.1rem}.update-banner__text{color:var(--text-primary);flex:1;font-size:.85rem}.update-banner__btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;flex-shrink:0;padding:.25rem .85rem;font-size:.8rem;transition:background .15s}.update-banner__btn:hover{background:rgba(var(--accent-rgb,16, 185, 129), .12)}.update-banner__btn--install{color:#22c55e;border-color:#22c55e}.update-banner__progress{background:var(--border);border-radius:2px;flex-shrink:0;width:100px;height:4px;overflow:hidden}.update-banner__progress-fill{background:var(--accent);height:100%;transition:width .3s}.update-banner__percent{color:var(--text-secondary);text-align:right;flex-shrink:0;min-width:32px;font-size:.78rem}.update-banner__close{color:var(--text-secondary);cursor:pointer;opacity:.7;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:.85rem;transition:opacity .15s}.update-banner__close:hover{opacity:1}.sync-checkboxes{flex-wrap:wrap;gap:14px;display:flex}.sync-checkbox{cursor:pointer;color:var(--text-primary);align-items:center;gap:6px;font-size:.82rem;display:flex}.sync-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.image-viewer-img--zoomed{image-rendering:auto;cursor:grab!important}.video-viewer-overlay{z-index:500;cursor:default;background:#000000eb;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.video-viewer-container{border-radius:var(--radius-md);background:#000;flex-direction:column;max-width:90vw;max-height:90vh;display:flex;overflow:hidden}.video-viewer-video{object-fit:contain;cursor:pointer;outline:none;max-width:90vw;max-height:calc(90vh - 48px)}.video-viewer-controls{color:#fff;background:#000000d9;align-items:center;gap:8px;padding:8px 12px;display:flex}.video-viewer-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:background .12s;display:flex}.video-viewer-btn:hover{background:#ffffff26}.video-viewer-time{font-variant-numeric:tabular-nums;text-align:center;min-width:40px;color:var(--text-secondary);font-size:.75rem}.video-viewer-progress{cursor:pointer;background:#ffffff26;border-radius:3px;flex:1;height:6px;position:relative}.video-viewer-progress__fill{background:var(--accent);border-radius:3px;height:100%;transition:width .1s linear}.video-viewer-volume-wrap{position:relative}.video-viewer-volume-popup{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;align-items:center;margin-bottom:6px;padding:12px 8px;display:flex;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.video-viewer-volume-slider{writing-mode:vertical-lr;width:6px;height:80px;accent-color:var(--accent);direction:rtl}.file-attachment--video{position:relative}.file-video-overlay{color:#fff;pointer-events:none;border-radius:var(--radius-md);background:#00000059;justify-content:center;align-items:center;height:300px;transition:background .15s;display:flex;position:absolute;inset:0 0 auto}.file-attachment--video:hover .file-video-overlay{background:#0003}.file-attachment--audio{cursor:pointer;border-radius:var(--radius-md);align-items:center;gap:10px;padding:8px 12px;transition:background .15s;display:flex}.file-attachment--audio:hover{background:#ffffff0d}.audio-mini-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .15s;display:flex}.audio-mini-btn--playing{background:var(--accent);opacity:.85}.audio-mini-info{flex-direction:column;flex:1;min-width:0;display:flex}.audio-mini-name{text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:500;overflow:hidden}.audio-mini-size{color:var(--text-secondary);font-size:.7rem}.audio-mini-download{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s;display:flex}.audio-mini-download:hover{color:var(--accent)}.audio-player-bar{background:var(--bg-sidebar);border-bottom:1px solid var(--border);z-index:450;align-items:center;gap:6px;height:36px;padding:0 12px;animation:.2s slideDown;display:flex;position:fixed;top:0;left:0;right:0}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.audio-bar-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .12s;display:flex}.audio-bar-btn:hover,.audio-bar-btn--play{color:var(--accent)}.audio-bar-name{text-overflow:ellipsis;white-space:nowrap;max-width:180px;color:var(--text-primary);font-size:.78rem;font-weight:500;overflow:hidden}.audio-bar-time{font-variant-numeric:tabular-nums;color:var(--accent);text-align:center;min-width:32px;font-size:.72rem}.audio-bar-progress{cursor:pointer;background:#ffffff1a;border-radius:2px;flex:1;height:4px;position:relative}.audio-bar-progress__fill{background:var(--accent);border-radius:2px;height:100%;transition:width .1s linear}.audio-bar-volume{color:var(--text-secondary);align-items:center;gap:4px;display:flex}.audio-bar-volume-slider{width:60px;height:4px;accent-color:var(--accent)}.layout--has-audio{padding-top:36px}.chat-header__back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;margin-right:8px;padding:4px;transition:color .12s;display:none}.chat-header__back-btn:hover{color:var(--text-primary)}@media (width<=768px){.sidebar{border-right:none;width:100%}.chat-area{width:100%;display:none}.layout--has-chat .sidebar{display:none}.layout--has-chat .chat-area,.chat-header__back-btn{display:flex}.chat-header{padding:10px 12px}.chat-header__name{font-size:.95rem}.chat-header__badge{display:none}.input-bar{padding:10px}.input-bar__field{font-size:1rem}.login-card{margin:0 20px;padding:1.5rem}}
