.session-invalid-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f172aa6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:session-invalid-fade-in .22s ease}:root[data-theme=light] .session-invalid-modal-overlay{background:#0f172a73}.session-invalid-modal-card{width:100%;max-width:380px;padding:28px 24px 24px;border-radius:16px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);box-shadow:0 24px 48px #00000059,0 0 0 1px #ffffff0a inset;text-align:center;animation:session-invalid-slide-up .28s cubic-bezier(.22,1,.36,1)}:root[data-theme=light] .session-invalid-modal-card{box-shadow:0 20px 40px #0f172a1f,0 0 0 1px #0f172a0f inset}.session-invalid-modal-icon-wrap{width:64px;height:64px;margin:0 auto 18px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#3390ec38,#2563eb1f);border:1px solid rgba(51,144,236,.35)}.session-invalid-modal-icon-wrap svg{width:32px;height:32px;color:var(--primary-light, #60a5fa)}.session-invalid-modal-title{margin:0 0 10px;font-size:19px;font-weight:600;color:var(--text-primary, #f8fafc);letter-spacing:-.02em;line-height:1.25}.session-invalid-modal-text{margin:0 0 24px;font-size:14px;line-height:1.55;color:var(--text-secondary, #cbd5e1)}.session-invalid-modal-btn{width:100%;padding:13px 18px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;color:#fff;background:linear-gradient(180deg,var(--primary-color, #3390ec) 0%,var(--primary-dark, #2563eb) 100%);box-shadow:0 4px 14px #2563eb59;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease}.session-invalid-modal-btn:hover{filter:brightness(1.05);box-shadow:0 6px 18px #2563eb6b}.session-invalid-modal-btn:active{transform:scale(.98)}.session-invalid-modal-btn:focus-visible{outline:2px solid var(--primary-light, #60a5fa);outline-offset:2px}@keyframes session-invalid-fade-in{0%{opacity:0}to{opacity:1}}@keyframes session-invalid-slide-up{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.app-brand-icon{display:inline-flex;align-items:center;justify-content:center;padding:7px;box-sizing:content-box;background:transparent;overflow:visible;flex-shrink:0}.app-brand-icon__svg{display:block;overflow:visible;pointer-events:none;-webkit-user-select:none;user-select:none}.app-brand-icon--splash .app-brand-icon__svg{width:var(--app-brand-splash-size, 96px);height:var(--app-brand-splash-size, 96px);max-width:min(96px,28vw);max-height:min(96px,28vw)}.app-brand-icon--auth .app-brand-icon__svg{width:70%;max-width:300px;height:auto;aspect-ratio:1}.auth-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;width:100%;min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom));padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));background:#fff;box-sizing:border-box;overflow-y:auto;-webkit-overflow-scrolling:touch}.auth-page-inner{width:100%;max-width:500px;flex-shrink:0;margin:auto;display:flex;flex-direction:column;align-items:center;justify-content:center}.auth-card{width:100%;max-width:500px;flex-shrink:0;margin-left:auto;margin-right:auto;display:flex;flex-direction:column;align-items:center}@media (orientation: landscape) and (min-width: 600px){.auth-page{align-items:center;justify-content:center;padding:max(12px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.auth-page-inner{max-width:500px;width:100%;flex:0 1 auto;min-height:0}.auth-card{max-width:500px;width:100%}}.auth-logo{display:flex;justify-content:center;align-items:center}.auth-title{text-align:center;font-size:1.25rem;font-weight:600;width:100%;color:#9ca3af;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:12px;width:100%;align-self:stretch}.auth-page--login .auth-form--login{max-width:300px;width:100%;align-self:center}.auth-page--login .auth-error--login{max-width:300px;width:100%;align-self:center;box-sizing:border-box}.auth-input{background:#f5f5f5;border:none;border-radius:12px;padding:14px 16px;font-size:16px;color:#000;outline:none}.auth-input::placeholder{color:#707579}.auth-input:focus{box-shadow:0 0 0 2px #3390ec59}.auth-input:-webkit-autofill,.auth-input:-webkit-autofill:hover,.auth-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px #f5f5f5 inset!important;box-shadow:0 0 0 1000px #f5f5f5 inset!important;-webkit-text-fill-color:#000000!important;caret-color:#000}.auth-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px #f5f5f5 inset,0 0 0 2px rgba(51,144,236,.35)!important;box-shadow:0 0 0 1000px #f5f5f5 inset,0 0 0 2px #3390ec59!important;-webkit-text-fill-color:#000000!important;caret-color:#000}.auth-input:autofill{box-shadow:0 0 0 1000px #f5f5f5 inset}.auth-button{margin-top:8px;min-height:48px;border:none;border-radius:12px;background:#3390ec;color:#fff;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-error{padding:12px;background:#fee2e2;color:#b91c1c;border-radius:12px;font-size:14px;margin-bottom:8px}.auth-link{text-align:center;margin-top:24px;font-size:15px;color:#707579;width:100%;align-self:stretch}.auth-link a{color:#3390ec;text-decoration:none;font-weight:500}.auth-link a:hover{text-decoration:underline}.chat-sidebar{width:450px;min-width:450px;max-width:450px;flex:0 0 450px;background:var(--bg-secondary, #1e293b);border-right:1px solid var(--border-color, #334155);display:flex;flex-direction:column;align-self:stretch;min-height:0;height:100%;max-height:100%;overflow:hidden;transition:background-color .3s ease,border-color .3s ease;flex-shrink:0}.sidebar-header,.sidebar-search-row{flex-shrink:0}.sidebar-header{padding:12px 16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;gap:12px;transition:border-color .3s ease}.user-info{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.sidebar-header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.sidebar-icon-btn{width:38px;height:38px;border:none;border-radius:19px;background:transparent;color:var(--text-secondary, #94a3b8);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,color .2s ease;padding:0}.sidebar-icon-btn:hover:not(:disabled){background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.sidebar-icon-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-icon-btn__svg{width:18px;height:18px}.sidebar-icon-btn--loading .rooms-refresh-icon{animation:rooms-refresh-spin .85s linear infinite}.sidebar-search-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color, #334155);background:var(--bg-secondary, #1e293b);transition:border-color .3s ease}.sidebar-search-row__lead-icon{width:18px;height:18px;flex-shrink:0;color:var(--text-tertiary, #94a3b8)}.sidebar-search-row__input{flex:1;min-width:0;border:none;background:transparent;font-size:16px;color:var(--text-primary, #f8fafc);padding:4px 0}.sidebar-search-row__input::placeholder{color:var(--text-secondary, #94a3b8)}.sidebar-search-row__input:focus{outline:none}.sidebar-search-row__close{flex-shrink:0;width:36px;height:36px;border:none;border-radius:10px;background:transparent;color:var(--text-primary, #f8fafc);font-size:18px;font-weight:600;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s ease}.sidebar-search-row__close:hover{background:var(--sidebar-hover, #334155)}.sidebar-search-hint{padding:24px 20px;text-align:center;font-size:14px;color:var(--text-secondary, #94a3b8);line-height:1.45}.sidebar-search-hint--loading{color:var(--text-tertiary, #64748b)}.sidebar-menu-btn{width:38px;height:38px;border:none;border-radius:19px;background:transparent;color:var(--text-secondary, #94a3b8);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,color .2s ease}.sidebar-menu-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.sidebar-menu-btn__icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}.user-avatar,.user-avatar-img{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.user-avatar{background:var(--accent-color);color:#fff}.user-avatar-img{object-fit:cover}.user-name{font-weight:700;color:var(--text-primary);transition:color .3s ease}.user-status{font-size:12px;color:var(--text-secondary);transition:color .3s ease}.user-status--self{color:var(--status-online, #10b981)}.user-status--offline.user-status--self{color:var(--status-offline, #f59e0b)}.user-status-speed{font-size:11px;color:var(--text-secondary, #94a3b8);line-height:1.2}.logout-btn{padding:5px 10px;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:5px;cursor:pointer;font-size:12px;color:var(--text-primary);transition:background-color .3s ease,border-color .3s ease,color .3s ease}.logout-btn:hover{background:var(--sidebar-hover)}.sidebar-rooms-scroll-area{position:relative;flex:1 1 0%;min-height:0;display:flex;flex-direction:column}.rooms-refresh-icon{width:18px;height:18px}@keyframes rooms-refresh-spin{to{transform:rotate(360deg)}}.rooms-list,.users-list{flex:1 1 0%;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.rooms-list--scroll,.users-list--scroll{flex:1 1 0%;min-height:0}.rooms-list::-webkit-scrollbar,.users-list::-webkit-scrollbar{width:0;height:0;display:none}.room-item,.user-item{padding:15px 20px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:background-color .3s ease}.room-item:hover,.user-item:hover{background:var(--sidebar-hover)}.room-item.active{background:var(--sidebar-active)}.room-avatar-container{position:relative;display:inline-block;flex-shrink:0}.room-avatar,.user-avatar-small{width:50px;height:50px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden}.room-avatar-img{width:100%;height:100%;object-fit:cover}.user-avatar-small{position:relative;width:40px;height:40px}.user-avatar-small-img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}.status-indicator{position:absolute;bottom:0;right:0;width:14px;height:14px;border-radius:50%;border:2px solid white;background:#95a5a6}.status-indicator.online{background:#4caf50}.status-indicator.offline{background:#e74c3c}.status-indicator.away{background:#ff9800}.status-indicator.busy{background:#f44336}.room-info,.user-info-small{flex:1 1 0%;min-width:0;display:flex;flex-direction:column;gap:2px}.room-header{display:flex;justify-content:space-between;align-items:center;gap:10px;min-width:0}.room-title-row{display:flex;align-items:center;gap:4px;min-width:0;flex:1}.room-title-row .room-name{flex:0 1 auto;min-width:0}.room-geo-share-wrap{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;margin-top:1px}.room-geo-share-icon{width:12px;height:12px;display:block;color:var(--accent-color, #3390ec);opacity:.9}.room-geo-share-icon path{fill:currentColor}.room-header-meta{display:inline-flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:2px;flex-shrink:0}.room-name,.user-name-small{font-weight:500;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:color .3s ease}.user-name-small{flex:1}.user-head-small{display:flex;align-items:baseline;justify-content:space-between;gap:8px;width:100%;min-width:0}.user-status-small{font-size:11px;color:var(--text-secondary);margin-left:auto;text-align:right;flex-shrink:0;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-push-counts{display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:nowrap}.subscription-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border:1px solid currentColor;border-radius:999px;font-size:11px;font-weight:600;line-height:1.2;background:transparent;white-space:nowrap}.subscription-badge--active{color:#16a34a;background:#16a34a1f}.subscription-badge--inactive{color:#dc2626;background:#dc26261a}.subscription-badge__label,.subscription-badge__count{display:inline-flex;align-items:center}.subscription-badge__count{font-variant-numeric:tabular-nums}.room-time{font-size:11px;color:var(--text-secondary);flex-shrink:0;transition:color .3s ease}.room-network-status{font-size:11px;color:var(--text-secondary, #94a3b8)}.room-network-status--online{color:var(--status-online, #10b981)}.room-footer{display:flex;justify-content:space-between;align-items:center;gap:8px;min-width:0}.room-footer-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.room-pin-btn{display:none}.room-last-message--typing{color:var(--primary-color, #3390ec)!important;font-weight:500}.room-last-message-secondary{color:var(--text-tertiary, #94a3b8);font-weight:400}.room-delivery{margin-left:6px;font-size:11px;color:var(--text-secondary);letter-spacing:-3px}.room-delivery--meta{margin-left:0}.room-delivery--read{color:var(--primary-color, #3390ec)}.room-last-message{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;transition:color .3s ease}.room-last-message-text{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.room-item.has-unread .room-name{font-weight:600}.room-item.has-unread .room-last-message{color:var(--text-primary);font-weight:500}.room-badges{display:flex;gap:5px;flex-shrink:0}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:600;line-height:1}.badge-message{background:var(--accent-color);color:#fff}.badge-call{background:#f44336;color:#fff;font-size:10px;padding:0 4px}.user-status-small{font-size:12px;color:var(--text-secondary);margin-left:auto;text-align:right;transition:color .3s ease}@media (max-width: 699px){.chat-sidebar{width:100%!important;max-width:100%!important;min-width:100%!important;position:absolute!important;top:0!important;left:0!important;z-index:22000;transition:transform .3s ease-in-out;flex-shrink:0}.chat-sidebar.hidden{transform:translate(-100%)}.chat-window{width:100%!important;max-width:100%!important}.users-list{padding-top:10px}}.empty-state{padding:40px 20px;text-align:center;color:var(--text-secondary);transition:color .3s ease}.message{display:flex;gap:6px;margin-bottom:15px;align-items:flex-start;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.message.message--geo-share-event{flex-direction:column;align-items:center;justify-content:center;text-align:center;margin-bottom:12px;max-width:100%}.message-geo-share-event__pill{display:flex;flex-direction:column;align-items:center;padding:6px 12px;background:var(--bg-tertiary);border-radius:12px;max-width:min(420px,92%);transition:background-color .3s ease,color .3s ease}.message-geo-share-event__text{font-size:12px;font-weight:500;line-height:1.45;color:var(--text-secondary, #94a3b8);text-align:center}.message-geo-share-event__time{margin-top:4px;font-size:11px;font-weight:500;color:var(--text-secondary, #94a3b8);opacity:.9}.message.own{flex-direction:row-reverse}@keyframes message-reaction-picker-in{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:translate(0)}}.message-reaction-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10058;pointer-events:auto;overscroll-behavior:none}.message-reaction-picker{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;box-shadow:0 12px 40px #00000059;padding:8px;box-sizing:border-box;display:flex;flex-direction:column;min-height:0;overflow:hidden;animation:message-reaction-picker-in .22s ease-out}.message-reaction-picker__scroll{flex:1;min-height:0;max-height:100%;overflow-x:hidden;overflow-y:auto;display:flex;flex-wrap:wrap;align-content:flex-start;justify-content:center;gap:2px 4px;padding:2px 0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.message-reaction-picker__btn{margin:0;padding:6px;border:none;border-radius:0;background:transparent;color:inherit;font-size:26px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;-webkit-tap-highlight-color:transparent}.message-reaction-picker__btn:hover,.message-reaction-picker__btn:focus-visible{opacity:.85;outline:none}.message-reactions-row{position:static;margin:8px 0 0;flex-shrink:0;flex-grow:0;display:flex;flex-wrap:wrap;gap:6px;row-gap:6px;align-self:stretch;width:100%;max-width:100%;min-width:0;box-sizing:border-box;justify-content:flex-start;align-content:flex-start;align-items:center;overflow:visible;min-height:min-content}.message-reaction-chip{border:1px solid var(--border-color, #334155);border-radius:999px;background:#0f172a40;color:var(--text-primary, #f8fafc);font-size:12px;padding:4px 8px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;flex:0 0 auto}.message-reaction-chip--mine{border-color:#3390ec8c;background:#3390ec29}.message-reaction-count{font-weight:700;font-variant-numeric:tabular-nums;opacity:.95}.message.message--media-top-menu{flex-direction:column;align-items:stretch}.message.message--media-top-menu.own{align-items:flex-end}.message.message--media-top-menu:not(.own){align-items:flex-start}.message.message--media-top-menu:not(.own) .message-context-bar:not(.message-context-bar--video),.message.message--media-top-menu:not(.own) .message-context-bar:not(.message-context-bar--video) .message-context-bar-wrap{justify-content:flex-start}.message-media-stack{display:flex;flex-direction:column;align-items:stretch;min-width:0}.message-media-stack.message-media-stack--text-menu-below{gap:8px}.message-media-stack .message-content{max-width:100%;width:100%}.message--media-top-menu .message-media-stack:has(.message-bubble.has-media .message-media--image){width:min(60%,350px);max-width:min(60%,350px);min-width:0}.message--media-top-menu .message-media-stack:has(.message-bubble.has-media .video-wrapper){width:min(60%,350px);max-width:min(60%,350px);min-width:0}.message.own .message--media-top-menu .message-media-stack:has(.message-bubble.has-media .message-media--image),.message.own .message--media-top-menu .message-media-stack:has(.message-bubble.has-media .video-wrapper){margin-left:auto}.message--media-top-menu .message-media-stack:has(.message-bubble--audio){width:min(70%,350px);max-width:min(70%,350px);min-width:0}.message.own .message--media-top-menu .message-media-stack:has(.message-bubble--audio){margin-left:auto}.message--media-top-menu .message-media-stack:has(.message-bubble--document){width:min(70%,350px);max-width:min(70%,350px);min-width:0}.message.own .message--media-top-menu .message-media-stack:has(.message-bubble--document){margin-left:auto}.message--media-top-menu .message-media-stack:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)){width:min(80%,350px);max-width:min(80%,350px);min-width:0}.message.own .message--media-top-menu .message-media-stack:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)){margin-left:auto}.message--media-top-menu .message-media-stack:has(.message-bubble--with-link-preview){width:min(80%,350px);max-width:min(80%,350px);min-width:0}.message.own .message--media-top-menu .message-media-stack:has(.message-bubble--with-link-preview){margin-left:auto}.message-context-bar{display:flex;justify-content:flex-end;align-items:center;width:100%;flex-shrink:0;margin-bottom:2px;padding:0;min-height:34px}.message-context-bar--video{justify-content:space-between;flex-direction:row;gap:8px}.message-context-bar__side{display:flex;align-items:center;min-height:34px;flex:0 0 auto}.message-context-bar__side--start .message-context-bar-wrap{justify-content:flex-start}.message-context-bar__side--end .message-context-bar-wrap{justify-content:flex-end}.message-context-bar-wrap{flex-shrink:0;display:flex;justify-content:flex-end}.message-video-fullscreen-icon{display:block;pointer-events:none}.message-media-overflow--top{position:relative;top:auto;right:auto}.message.message--selected .message-bubble{outline:2px solid var(--primary-color, #3390ec);outline-offset:2px;transition:background-color .2s ease,color .2s ease,outline .2s ease}.message.message--selected .message-bubble:not(.has-media){background:var(--message-selected-bubble-bg, var(--bg-tertiary));color:var(--message-selected-bubble-text, var(--text-primary))}.message.message--selected .message-bubble.has-media{background:var(--bg-tertiary, #334155);color:var(--text-primary)}.message-content{max-width:100%;min-width:0;display:flex;flex-direction:column}.message-content:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)){width:min(80%,350px);max-width:min(80%,350px);min-width:0}.message.own .message-content:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)){margin-left:auto}.message-content:has(.message-bubble.has-media .message-media--image){width:min(60%,350px);max-width:min(60%,350px);min-width:0}.message-content:has(.message-bubble.has-media .video-wrapper){width:min(60%,350px);max-width:min(60%,350px);min-width:0}.message.own .message-content:has(.message-bubble.has-media .message-media--image),.message.own .message-content:has(.message-bubble.has-media .video-wrapper){margin-left:auto}.message-content:has(.message-bubble--audio){width:min(70%,350px);max-width:min(70%,350px);min-width:0}.message.own .message-content:has(.message-bubble--audio){margin-left:auto}.message-content:has(.message-bubble--document){width:min(70%,350px);max-width:min(70%,350px);min-width:0}.message.own .message-content:has(.message-bubble--document){margin-left:auto}.message-content:has(.message-bubble--with-link-preview){width:min(80%,350px);max-width:min(80%,350px);min-width:0}.message.own .message-content:has(.message-bubble--with-link-preview){margin-left:auto}.message-media-stack .message-content:has(.message-bubble.has-media .message-media--image),.message-media-stack .message-content:has(.message-bubble.has-media .video-wrapper),.message-media-stack .message-content:has(.message-bubble--audio),.message-media-stack .message-content:has(.message-bubble--document){width:100%;max-width:100%;min-width:0}.message.own .message-media-stack .message-content:has(.message-bubble.has-media .message-media--image),.message.own .message-media-stack .message-content:has(.message-bubble.has-media .video-wrapper),.message.own .message-media-stack .message-content:has(.message-bubble--audio),.message.own .message-media-stack .message-content:has(.message-bubble--document){margin-left:0}.message-media-stack .message-content:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)),.message-media-stack .message-content:has(.message-bubble--with-link-preview){width:100%;max-width:100%;min-width:0}.message.own .message-media-stack .message-content:has(.message-bubble:not(.has-media):not(.message-bubble--audio):not(.message-bubble--document):not(.message-bubble--with-link-preview)),.message.own .message-media-stack .message-content:has(.message-bubble--with-link-preview){margin-left:0}.message:not(.own) .message-content{align-items:flex-start}.message.own .message-content{align-items:flex-end}.message-bubble-wrap{display:flex;flex-direction:column;align-items:stretch;min-width:0;width:fit-content;max-width:100%;align-self:flex-start;overflow:visible}.message.own .message-bubble-wrap{align-self:flex-end}.message-bubble-wrap--link{max-width:100%}.message-content .message-bubble-wrap:has(.message-bubble--document),.message-content .message-bubble-wrap:has(.message-bubble--audio){width:100%;max-width:100%;align-self:stretch}.message-media-stack .message-bubble-wrap{align-self:flex-start}.message.own .message-media-stack .message-bubble-wrap{align-self:flex-end}.message-username-container{display:flex;align-items:center;gap:5px;margin-bottom:5px;padding:0 10px}.message-username{font-size:12px;color:var(--text-secondary);transition:color .3s ease}.message-username-status{font-size:8px;line-height:1}.message-bubble{display:flex;flex-direction:column;align-items:stretch;padding:10px 15px;border-radius:15px;background:var(--message-bg);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;min-width:0;max-width:100%;box-sizing:border-box;position:relative;overflow:visible}.message.own .message-bubble{background:var(--message-own-bg);color:#fff}[data-theme=light] .message:not(.own) .message-bubble:not(.has-media),:root[data-theme=light] .message:not(.own) .message-bubble:not(.has-media){background:#fff;border:none;outline:none;box-shadow:none}.message-text{color:inherit;overflow-wrap:break-word;word-break:normal;word-wrap:break-word}.message-forwarded-from{display:inline-flex;align-items:center;max-width:100%;margin-bottom:7px;padding:0;border:none;background:transparent;color:var(--primary-color, #3390ec);font-size:12px;font-weight:700;line-height:1.25;cursor:pointer;text-align:left;text-decoration:none}.message-forwarded-from:hover{text-decoration:none}.message-forwarded-block{padding:8px;border-radius:10px;background:#d9f7d8}.message-forwarded-content{min-width:0;padding:8px;border-radius:10px;background:#e5e7eb}.message-forwarded-content .message-bubble,.message.own .message-forwarded-content .message-bubble{background:#e5e7eb!important;color:#0f172a!important}.message.own .message-forwarded-content{background:#d9f7d8;color:#0f172a}:root[data-theme=dark] .message-forwarded-content,[data-theme=dark] .message-forwarded-content,:root[data-theme=dark] .message.own .message-forwarded-content,[data-theme=dark] .message.own .message-forwarded-content{background:var(--message-other-bg, #334155);color:var(--message-other-text, #f8fafc)}:root[data-theme=dark] .message-forwarded-content .message-bubble,[data-theme=dark] .message-forwarded-content .message-bubble,:root[data-theme=dark] .message.own .message-forwarded-content .message-bubble,[data-theme=dark] .message.own .message-forwarded-content .message-bubble{background:var(--message-other-bg, #334155)!important;color:var(--message-other-text, #f8fafc)!important}.message-forwarded-content .message-bubble.has-media{background:#e5e7eb;padding:8px;border-radius:12px}.message.own .message-forwarded-content .message-bubble.has-media{background:#d9f7d8}:root[data-theme=dark] .message-forwarded-content .message-bubble.has-media,[data-theme=dark] .message-forwarded-content .message-bubble.has-media,:root[data-theme=dark] .message.own .message-forwarded-content .message-bubble.has-media,[data-theme=dark] .message.own .message-forwarded-content .message-bubble.has-media{background:var(--message-other-bg, #334155)}.message-forwarded-content .message-bubble.has-media:has(.video-wrapper){background:transparent!important;padding:0}.message-forwarded-block .message-forwarded-from{display:inline-flex;margin:0 0 7px;padding:0;border-radius:0;background:transparent;color:#166534}.message.own .message-forwarded-block .message-forwarded-from{background:#d9f7d8;color:#166534}.message-bubble.message-bubble--forwarded{background:transparent!important;box-shadow:none;border:none;padding:0}.message-forwarded-block:has(.video-wrapper){background:transparent;padding:0}.message-forwarded-block:has(.video-wrapper) .message-forwarded-from{padding:4px 8px;border:1px solid #22c55e;border-radius:8px;background:transparent;color:#166534}.message-forwarded-block:has(.video-wrapper) .message-forwarded-content{background:transparent!important;padding:0;border-radius:0}.message-media{margin:0;background:transparent;position:relative;display:block}.message-media--image{width:100%;max-width:100%;border-radius:16px;overflow:hidden;background:#0b0b0b;align-self:flex-start;line-height:0;position:relative}.message.own .message-media--image{align-self:flex-end}.message-media--openable{cursor:pointer;border-radius:inherit}.message-media--image.message-media--openable{border-radius:16px}.message-text-upload-wrap{position:relative;min-width:0;align-self:stretch}.message-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;display:flex;align-items:center;justify-content:center;padding:8px;box-sizing:border-box;background:#0000006b;border-radius:inherit;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:auto;cursor:wait}.message-upload-overlay--text{border-radius:12px;min-height:56px}.message-bubble.has-media{background:transparent;padding:0;box-shadow:none}.message-bubble.has-media .message-bubble-media-wrap{flex-shrink:0}.message-bubble>*:first-child{flex-shrink:0;min-width:0}.message.own .message-bubble.has-media{background:transparent}.message-bubble-media-wrap{position:relative;display:block;width:100%;min-width:0;overflow:visible}.message-bubble.message-bubble--audio .message-bubble-media-wrap,.message-bubble.message-bubble--document .message-bubble-media-wrap{width:100%}.message-media-overflow{position:relative;top:auto;right:auto;z-index:1;width:34px;height:34px;border:none;border-radius:17px;background:#0000006b;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;font-size:1.05rem;font-weight:700;box-shadow:0 1px 4px #00000059;transition:background .15s ease,transform .1s ease}.message-media-overflow:hover{background:#00000094}.message-media-overflow:active{transform:scale(.96)}.message-media-dropdown{min-width:180px;padding:6px 0;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;box-shadow:0 12px 40px #00000073}.message-media-dropdown__item{display:block;width:100%;padding:12px 16px;border:none;background:none;color:var(--text-primary, #f8fafc);font-size:15px;text-align:left;cursor:pointer}.message-media-dropdown__item:hover,.message-media-dropdown__item:focus-visible{background:var(--bg-tertiary, #334155);outline:none}.message-media-dropdown__item--danger{color:#f87171}.message-media-dropdown__item--danger:hover,.message-media-dropdown__item--danger:focus-visible{background:#f871711f}.message-media-dropdown.message-media-dropdown--inline{position:relative;width:max-content;max-width:100%;min-width:0;box-sizing:border-box}.message-context-bar.message-context-bar--inline-menu{justify-content:flex-start;align-items:flex-start;min-height:0;margin-top:0;margin-bottom:0;width:100%;padding:0}.message.own .message-context-bar.message-context-bar--inline-menu{justify-content:flex-end}.message-share-toast{position:fixed;bottom:max(24px,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:10060;padding:10px 18px;background:#0f172af2;color:#fff;border-radius:10px;font-size:14px;box-shadow:0 4px 24px #00000059;pointer-events:none}.message-bubble.message-bubble--audio{display:flex;flex-direction:column;align-items:flex-start;align-self:flex-start;width:100%;max-width:100%;min-width:0;margin-left:0;margin-right:auto;padding-top:15px}.message.own .message-bubble.message-bubble--audio{align-items:flex-end;align-self:flex-end;margin-left:auto;margin-right:0}.message-bubble.message-bubble--document{align-self:flex-start;width:100%;max-width:100%;min-width:0}.message.own .message-bubble.message-bubble--document{align-self:flex-end}.message-image{width:100%;max-width:100%;height:auto;max-height:min(70vh,520px);border-radius:16px;display:block;object-fit:contain;object-position:center;background:#000;transition:opacity .15s ease;vertical-align:top}.message-image.loaded{opacity:1}.message-image-placeholder{width:100%;max-width:100%;aspect-ratio:4 / 3;min-height:150px;border-radius:16px;background:linear-gradient(90deg,#d8d8d8 25%,#c8c8c8,#d8d8d8 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}.message-image-error{width:100%;max-width:100%;min-height:150px;aspect-ratio:4 / 3;border-radius:16px;background:#1a1a1a;display:flex;align-items:center;justify-content:center;font-size:32px;color:#666}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.message-audio{width:100%;min-width:0}.message-footer{display:flex;align-items:center;gap:8px;margin-top:4px;justify-content:flex-end;padding:0 10px;width:100%;max-width:100%;box-sizing:border-box}.message-footer--in-bubble{position:static;width:100%;max-width:100%;padding:0;margin:6px 0 0;align-self:stretch;justify-content:flex-start;box-sizing:border-box}.message.own .message-footer.message-footer--in-bubble{justify-content:flex-start}.message-bubble.has-media .message-reactions-row{margin-top:8px;padding-left:10px;padding-right:10px}.message-bubble.has-media .message-footer--in-bubble{padding-left:10px;padding-right:10px;padding-bottom:2px;gap:8px}.message-bubble.has-media .message-footer--in-bubble .message-media-file-size{margin-right:0}.message-bubble.message-bubble--forwarded .message-reactions-row,.message-bubble.message-bubble--forwarded .message-footer--in-bubble{padding-left:10px;padding-right:10px}.message-bubble:has(.message-text--single-emoji) .message-reactions-row,.message-bubble:has(.message-text--single-emoji) .message-footer--in-bubble{padding-left:6px;padding-right:6px}.message-media-file-size{font-size:11px;color:var(--text-secondary);flex-shrink:0;margin-right:8px;line-height:1;align-self:center}:root[data-theme=light] .message-footer--in-bubble .message-media-file-size{color:#64748b}:root[data-theme=dark] .message-footer--in-bubble .message-media-file-size{color:#94a3b8}:root[data-theme=dark] .message.own .message-footer--in-bubble .message-media-file-size{color:#fff}.message-footer-end{display:flex;align-items:center;gap:5px;flex-shrink:0;margin-left:auto;background:transparent;border-radius:0;padding:0}.message-footer-end .message-time,.message-footer-end .message-status,.message-footer-end .message-status.read{color:inherit}.message.own .message-footer{justify-content:flex-end}.message-time{font-size:11px;color:var(--text-secondary);text-align:right;transition:color .3s ease;line-height:1}.message.own .message-time{color:var(--text-secondary)}.message.own .message-footer{opacity:1}.message-status{font-size:13px;display:inline-block;color:var(--text-secondary);transition:color .3s ease;font-weight:500;letter-spacing:-3px;line-height:1;margin-left:2px;text-shadow:0 0 0 currentColor,.15px 0 currentColor}.message.own .message-status{opacity:1}.message-status.sent{opacity:.6}.message-status.delivered{opacity:.7;letter-spacing:-3px}.message-status.read{color:var(--accent-color);opacity:1;letter-spacing:-3px}:root[data-theme=light] .message.own .message-bubble{background:#d9f7d8;color:#0f172a}:root[data-theme=light] .message:not(.own) .message-bubble{background:#fff;color:#0f172a}:root[data-theme=light] .message-footer--in-bubble .message-footer-end{background:transparent!important}:root[data-theme=light] .message .message-time,:root[data-theme=light] .message-footer--in-bubble .message-time{color:#64748b!important}:root[data-theme=light] .message.own .message-status.sent{color:#94a3b8!important;opacity:.9!important}:root[data-theme=light] .message.own .message-status.delivered{color:#64748b!important;opacity:1!important}:root[data-theme=light] .message.own .message-status.read{color:#1e3a8a!important;opacity:1!important}:root[data-theme=light] .message.own .message-reaction-chip{background:#fff;border-color:#e2e8f0;color:#0f172a}:root[data-theme=light] .message:not(.own) .message-reaction-chip{background:#d9f7d8;border-color:#16a34a40;color:#0f172a}:root[data-theme=dark] .message.own .message-bubble{background:#3390ecd9;color:#fff}:root[data-theme=dark] .message:not(.own) .message-bubble{background:#0b1f3a;color:#fff}:root[data-theme=dark] .message-footer--in-bubble .message-footer-end{background:transparent!important}:root[data-theme=dark] .message .message-time,:root[data-theme=dark] .message-footer--in-bubble .message-time{color:#94a3b8!important}:root[data-theme=dark] .message.own .message-time,:root[data-theme=dark] .message.own .message-footer--in-bubble .message-time{color:#fff!important}:root[data-theme=dark] .message.own .message-status.sent,:root[data-theme=dark] .message.own .message-status.delivered{color:#fff!important;opacity:1!important}:root[data-theme=dark] .message.own .message-status.read{color:#00ff1c!important;opacity:1!important}:root[data-theme=dark] .message.own .message-reaction-chip{background:#fff;border-color:#e2e8f073;color:#0f172a}:root[data-theme=dark] .message:not(.own) .message-reaction-chip{background:#3390ec38;border-color:#3390ec40;color:#fff}:root[data-theme=light] .message.own .message-bubble.has-media,:root[data-theme=light] .message:not(.own) .message-bubble.has-media,:root[data-theme=dark] .message.own .message-bubble.has-media,:root[data-theme=dark] .message:not(.own) .message-bubble.has-media{background:transparent!important;box-shadow:none!important}.message-bubble.message-bubble--video-circle.has-media .video-circle{background:transparent}:root[data-theme=light] .message.own .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-footer-end,:root[data-theme=light] .message.own .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-footer-end{background:#d9f7d8!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=dark] .message.own .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-footer-end,:root[data-theme=dark] .message.own .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-footer-end{background:#3390ecd9!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=light] .message.own .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-media-file-size,:root[data-theme=light] .message.own .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-media-file-size{background:#d9f7d8!important;border-radius:10px;padding:3px 8px;box-sizing:border-box;color:#64748b!important}:root[data-theme=dark] .message.own .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-media-file-size,:root[data-theme=dark] .message.own .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-media-file-size{background:#3390ecd9!important;border-radius:10px;padding:3px 8px;box-sizing:border-box;color:#fff!important}:root[data-theme=light] .message:not(.own) .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-footer-end,:root[data-theme=light] .message:not(.own) .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-footer-end{background:#fff!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=dark] .message:not(.own) .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-footer-end,:root[data-theme=dark] .message:not(.own) .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-footer-end{background:#0b1f3a!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=light] .message:not(.own) .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-media-file-size,:root[data-theme=light] .message:not(.own) .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-media-file-size{background:#fff!important;border-radius:10px;padding:3px 8px;box-sizing:border-box;color:#64748b!important}:root[data-theme=dark] .message:not(.own) .message-bubble.has-media:has(.message-media--image) .message-footer--in-bubble .message-media-file-size,:root[data-theme=dark] .message:not(.own) .message-bubble.has-media:has(.video-wrapper) .message-footer--in-bubble .message-media-file-size{background:#0b1f3a!important;border-radius:10px;padding:3px 8px;box-sizing:border-box;color:#94a3b8!important}:root[data-theme=light] .message.own .message-bubble:has(.message-text--single-emoji) .message-footer--in-bubble .message-footer-end{background:#d9f7d8!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=dark] .message.own .message-bubble:has(.message-text--single-emoji) .message-footer--in-bubble .message-footer-end{background:#3390ecd9!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=light] .message:not(.own) .message-bubble:has(.message-text--single-emoji) .message-footer--in-bubble .message-footer-end{background:#fff!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}:root[data-theme=dark] .message:not(.own) .message-bubble:has(.message-text--single-emoji) .message-footer--in-bubble .message-footer-end{background:#0b1f3a!important;border-radius:10px;padding:3px 8px;box-sizing:border-box}.video-wrapper{position:relative;cursor:pointer;display:block;width:100%;max-width:100%}.video-wrapper.video-wrapper--fullscreen-active{visibility:hidden;pointer-events:none}.video-circle{border-radius:50%;overflow:hidden;width:100%;aspect-ratio:1;height:auto;line-height:0;background:#000}.video-square{border-radius:20px;overflow:hidden;width:100%;aspect-ratio:1;height:auto}.video-heart{clip-path:path("M12,21.35l-1.45-1.32C5.4,15.36,2,12.28,2,8.5 C2,5.42,4.42,3,7.5,3c1.74,0,3.41,0.81,4.5,2.09C13.09,3.81,14.76,3,16.5,3 C19.58,3,22,5.42,22,8.5c0,3.78-3.4,6.86-8.55,11.54L12,21.35z");overflow:hidden;width:100%;aspect-ratio:1;height:auto}.message-video{width:100%;height:100%;display:block;object-fit:cover;object-position:center;background:#000}.progress-ring{position:absolute;top:0;left:0;width:100%;height:100%;display:block;pointer-events:none;z-index:10}.video-duration{position:absolute;bottom:10px;right:10px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700;z-index:20;pointer-events:none}.message-video-duration-badge{position:absolute;bottom:14px;right:14px;z-index:12;pointer-events:none;padding:2px 6px;border-radius:8px;background:#00000080;color:#fff;font-size:11px;font-weight:600;letter-spacing:.2px;font-variant-numeric:tabular-nums}.message-delete-btn{background:transparent;border:none;cursor:pointer;font-size:14px;opacity:.5;transition:opacity .2s;padding:0;line-height:1}.message-delete-btn:hover{opacity:1}.message-deleted{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-style:italic;padding:10px 0;transition:color .3s ease}.deleted-icon{font-size:16px;opacity:.6}.deleted-text{font-size:14px}.message-text-link{color:var(--text-secondary, #707579);text-decoration:underline;text-underline-offset:2px;overflow-wrap:break-word;word-break:normal}.message.own .message-text-link{color:#ffffffe6}:root[data-theme=light] .message.own .message-text-link{color:#475569;text-decoration:none}.message-text--rich{display:flex;flex-direction:column;gap:8px;min-width:0;max-width:100%}.message-content:has(.message-text--single-emoji){width:fit-content;max-width:fit-content;min-width:0}.message.own .message-content:has(.message-text--single-emoji){margin-left:auto}.message-bubble:has(.message-text--single-emoji){background:transparent!important;box-shadow:none;border:none;padding:0}.message.message--selected .message-bubble:has(.message-text--single-emoji){background:transparent!important}.message-text--single-emoji{display:inline-flex;align-items:center;line-height:1;font-size:5em}.message-content:has(.message-text--single-emoji) .message-footer{margin-top:6px}.message-link-preview{display:block;overflow:hidden;border-radius:12px;border:1px solid var(--border-color, rgba(0, 0, 0, .08));background:var(--bg-secondary, rgba(0, 0, 0, .04));text-decoration:none;color:inherit;max-width:100%;margin-top:2px;transition:opacity .15s ease}.message-link-preview:hover{opacity:.95}.message-link-preview--own{border-color:#ffffff47;background:#ffffff1f}.message-link-preview__image-wrap{max-height:180px;overflow:hidden;background:#0b0b0b}.message-link-preview__image{width:100%;height:auto;max-height:180px;object-fit:cover;display:block}.message-link-preview__body{padding:8px 10px}.message-link-preview__site{font-size:12px;color:var(--text-secondary, #707579);margin-bottom:4px}.message.own .message-link-preview__site{color:#ffffffb8}.message-link-preview__title{font-size:14px;font-weight:600;margin-bottom:4px;line-height:1.35}.message-link-preview__desc{font-size:13px;color:var(--text-secondary, #707579);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.message.own .message-link-preview__desc{color:#ffffffd9}:root[data-theme=light] .message.own .message-link-preview--own{background:#0000000d;border-color:#0000001a}:root[data-theme=light] .message.own .message-link-preview__title{color:#0f172a}:root[data-theme=light] .message.own .message-link-preview__site{color:#475569}:root[data-theme=light] .message.own .message-link-preview__desc{color:#475569}:root[data-theme=light] .message.own .message-link-preview--loading .message-link-preview__skeleton{background:linear-gradient(90deg,#0000000d 25%,#0000001a,#0000000d 75%);background-size:200% 100%}.message-link-preview--loading .message-link-preview__skeleton{height:100px;border-radius:12px;background:linear-gradient(90deg,#0000000d 25%,#0000001a,#0000000d 75%);background-size:200% 100%;animation:message-link-preview-shimmer 1.1s ease-in-out infinite}.message.own .message-link-preview--loading .message-link-preview__skeleton{background:linear-gradient(90deg,#ffffff14 25%,#ffffff29,#ffffff14 75%);background-size:200% 100%}@keyframes message-link-preview-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.message-upload-progress-bubble{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px 8px;min-width:0;max-width:100%;pointer-events:none}.message-upload-progress-bubble__ring-wrap{position:relative;width:48px;height:48px;flex-shrink:0}.message-upload-progress-bubble__svg{width:48px;height:48px;display:block}.message-upload-progress-bubble__track{stroke:#ffffff40}.message-upload-progress-bubble__bar{stroke:#fff;transition:stroke-dashoffset .12s ease}.message-upload-progress-bubble__pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}.message-upload-progress-bubble__bytes{font-size:9px;font-variant-numeric:tabular-nums;color:#ffffffeb;text-shadow:0 1px 2px rgba(0,0,0,.55);text-align:center;line-height:1.2;max-width:120px;word-break:break-all}.message-upload-overlay--failed{background:#0000008c;cursor:default}.message-upload-failed-inner{display:flex;flex-direction:column;align-items:center;gap:8px;padding:4px;max-width:140px;text-align:center}.message-upload-failed-text{font-size:11px;font-weight:600;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.5);line-height:1.25}.message-upload-retry-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;color:#0f172a;background:#fff;box-shadow:0 2px 8px #00000040;transition:filter .15s ease,transform .1s ease}.message-upload-retry-btn:hover{filter:brightness(1.05)}.message-upload-retry-btn:active{transform:scale(.98)}.voice-message-container{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background-color:transparent;position:relative;box-sizing:border-box;width:100%;max-width:100%;min-width:0}.voice-message-container--other{align-self:flex-start}.voice-message-container--own{align-self:flex-end}.voice-message-block{position:relative;display:flex;flex-direction:column;align-items:flex-start;border-radius:12px;padding:0;gap:4px;overflow:hidden;width:100%;transition:color .2s ease;background:transparent;border:none;box-shadow:none;color:inherit;--voice-bar-played: var(--primary-color)}.voice-message-block--other,.voice-message-block--own{background-color:transparent;color:inherit;border:none;box-shadow:none}:root[data-theme=light] .voice-message-container .voice-message-block{--voice-bar-idle: rgba(15, 23, 42, .22)}:root[data-theme=dark] .voice-message-container .voice-message-block{--voice-bar-idle: rgba(255, 255, 255, .4);--voice-bar-played: #ffffff}.voice-top{display:flex;flex-direction:row;align-items:center;gap:8px;width:100%}.voice-expand-button{flex-shrink:0;width:32px;height:32px;border-radius:8px;border:1px solid var(--border-color, rgba(148, 163, 184, .45));background:transparent;color:inherit;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.85}.voice-expand-button:hover{opacity:1}.voice-message-block--other .voice-play-button,.voice-message-block--own .voice-play-button{width:40px;height:40px;border-radius:20px;background-color:var(--primary-color);border:none;display:flex;justify-content:center;align-items:center;cursor:pointer;flex-shrink:0;transition:opacity .2s}.voice-play-button:hover:not(:disabled){opacity:.92}.voice-play-button:disabled{cursor:not-allowed}.voice-message-block--other .voice-play-icon,.voice-message-block--own .voice-play-icon{font-size:16px;color:#fff;margin-left:2px}.voice-error-icon{font-size:18px}.voice-loading-spinner{width:28px;height:28px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:voice-spin 1s linear infinite}.voice-waveform{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:0;height:32px;flex:1;width:100%;padding:0;overflow:hidden;min-width:0}.voice-wave-bar-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:32px;margin:0;padding:0}.voice-wave-bar-top{width:2.5px;border-radius:1.25px;min-height:2px;max-height:12px;margin:0;padding:0}.voice-wave-bar-bottom{width:2.5px;border-radius:1.25px;min-height:2px;max-height:12px;transform:scaleY(-1);margin:-1px 0 0;padding:0}.voice-time-container{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:8px;width:100%}.voice-message-block--other .voice-file-size-text,.voice-message-block--own .voice-file-size-text{font-size:13px;font-weight:500;color:var(--text-secondary);flex-shrink:0}.voice-message-block--other .voice-time-text,.voice-message-block--own .voice-time-text{font-size:13px;font-weight:500;color:var(--text-secondary);line-height:1.35;text-align:right;flex-shrink:0;min-width:40px;margin-left:auto}.voice-footer{display:flex;flex-direction:row;align-items:center;padding:4px 6px;border-radius:8px;gap:4px;align-self:flex-end;margin-left:auto;background-color:#00000080;margin-top:4px}.voice-footer-time{font-size:12px;color:#fff;opacity:.9}.voice-footer-status{display:flex;flex-direction:row;align-items:center;gap:2px;margin-left:4px}.voice-status-icon{font-size:13px;font-weight:500;color:#fff}.document-message-container{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background-color:transparent;position:relative;width:100%;max-width:100%;min-width:0}.document-white-block{position:relative;display:flex;flex-direction:row;align-items:flex-start;background-color:transparent;color:inherit;border-radius:12px;padding:4px 0;gap:12px;overflow:hidden;width:100%;box-sizing:border-box;cursor:pointer;transition:opacity .15s ease;border:none;box-shadow:none}:root[data-theme=light] .document-white-block,:root[data-theme=dark] .document-white-block{border:none;box-shadow:none}.document-white-block:hover{opacity:.92}.document-icon-container{width:48px;height:48px;border-radius:24px;background-color:color-mix(in srgb,currentColor 14%,transparent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.document-icon{font-size:24px}.document-info{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.document-name{font-size:14px;font-weight:500;color:inherit;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.35}.document-meta{font-size:13px;line-height:1.35;word-break:break-word}:root[data-theme=light] .document-meta,:root[data-theme=light] .document-size{color:#64748b}:root[data-theme=dark] .document-meta,:root[data-theme=dark] .document-size{color:#94a3b8}.document-size{font-size:13px}.video-fs-portal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#000;display:flex;flex-direction:column;justify-content:center;align-items:center;animation:video-fs-fade .2s ease}@keyframes video-fs-fade{0%{opacity:0}to{opacity:1}}.video-fs-video{position:absolute;top:0;left:0;width:100%;height:100%;max-width:100vw;max-height:100vh;max-height:100dvh;object-fit:contain;background:#000;display:block}.video-fs-interaction{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;touch-action:none;cursor:default}.video-fs-volume-hud{position:absolute;right:max(24px,env(safe-area-inset-right));top:30%;z-index:4;width:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 12px;background:#00000080;border-radius:16px;pointer-events:none;box-shadow:0 4px 8px #0000004d}.video-fs-volume-icon{font-size:16px;margin-bottom:8px;font-weight:600;color:#fff}.video-fs-volume-bars{display:flex;flex-direction:column-reverse;gap:3px}.video-fs-volume-bar{width:4px;height:6px;border-radius:2px;background:#fff3}.video-fs-volume-bar.is-on{background:#fff;box-shadow:0 0 4px #fffc}.video-fs-volume-pct{font-size:10px;font-weight:500;color:#ffffffb3;margin-top:8px;text-align:center;width:100%;font-variant-numeric:tabular-nums}.video-fs-chrome{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;flex-direction:column;justify-content:space-between;padding:max(20px,env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left));pointer-events:none}.video-fs-top-bar{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;padding:40px 20px 0;box-sizing:border-box;pointer-events:none}.video-fs-time-top{color:#fff;font-size:14px;background:#0009;padding:6px 12px;border-radius:8px;pointer-events:none;max-width:min(70vw,280px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-fs-time-top--placeholder{visibility:hidden;min-width:1px}.video-fs-top-actions{display:flex;align-items:center;gap:8px;pointer-events:auto;margin-left:auto}.video-fs-close-btn{width:40px;height:40px;border:none;border-radius:20px;background:#0009;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.video-fs-close-btn:hover{background:#ffffff26}.video-fs-close-btn-text{font-size:24px;font-weight:700;line-height:1}.video-fs-bottom-area{align-self:stretch;display:flex;align-items:center;justify-content:center;pointer-events:none;margin-top:auto}.video-fs-controls-row{display:flex;flex-direction:row;align-items:center;gap:12px;background:#0009;padding:10px 12px;border-radius:8px;pointer-events:auto}.video-fs-time-main{color:#fff;font-size:12px;min-width:40px;text-align:center;font-variant-numeric:tabular-nums;font-weight:500}.video-fs-play-btn{width:40px;height:40px;margin-left:8px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0}.video-fs-play-btn-text{font-size:24px;color:#fff;line-height:1}.video-fs-sound-btn{position:absolute;right:max(24px,env(safe-area-inset-right));bottom:max(40px,env(safe-area-inset-bottom));width:44px;height:44px;border-radius:22px;border:none;background:#0009;cursor:pointer;display:flex;align-items:center;justify-content:center;pointer-events:auto;z-index:3;transition:background .15s}.video-fs-sound-btn:hover{background:#ffffff1f}.video-fs-sound-btn-text{font-size:24px;line-height:1}.call-message{display:flex;align-items:center;justify-content:center;margin:16px auto;padding:6px 12px;background:var(--bg-tertiary);border-radius:12px;max-width:min(420px,92%);min-width:0;box-sizing:border-box;transition:background-color .3s ease,color .3s ease}.call-message-content{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%;min-width:0}.call-message-text{font-size:12px;font-weight:500;line-height:1.45;text-align:center;overflow-wrap:anywhere;word-break:break-word;color:var(--text-secondary)}.call-message-details{display:flex;align-items:center;justify-content:center}.call-message-time{font-size:11px;font-weight:500;color:var(--text-secondary);text-align:center;opacity:.9;transition:color .3s ease}.typing-indicator{display:flex;align-items:center}.typing-indicator--header{margin-top:2px}.typing-indicator--list{margin-top:0}.typing-indicator--refresh-line{margin-top:20px;justify-content:center}.typing-indicator__text{font-size:12px;color:var(--primary-color, #3390ec);font-weight:500;margin-right:4px}.typing-indicator__dots{display:flex;align-items:center;gap:3px}.typing-indicator__dot{width:4px;height:4px;border-radius:50%;background-color:var(--primary-color, #3390ec);opacity:.4;animation:typing-indicator-dot 1.4s infinite}.typing-indicator__dot:nth-child(2){animation-delay:.2s}.typing-indicator__dot:nth-child(3){animation-delay:.4s}@keyframes typing-indicator-dot{0%,60%,to{opacity:.4;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}}.media-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20000;background:#000000eb;display:flex;align-items:stretch;justify-content:center;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}.media-viewer{display:flex;flex-direction:column;width:100%;max-width:100%;min-height:0;height:100%;position:relative}.media-viewer__top{display:flex;justify-content:flex-end;padding:8px 12px;flex-shrink:0;z-index:2}.media-viewer__icon-btn{width:40px;height:40px;border:none;border-radius:50%;background:#ffffff1f;color:#fff;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease}.media-viewer__icon-btn:hover{background:#ffffff2e}.media-viewer__icon-btn:active{background:#ffffff38}.media-viewer__main{flex:1;min-height:0;display:flex;align-items:stretch;justify-content:center;position:relative;touch-action:pan-y}.media-viewer__stage{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;max-width:100%;padding:0 48px}.media-viewer__stage--image{min-height:0;overflow:hidden}.media-viewer__stage--image-loading{min-height:120px}.media-viewer__image-loading{width:40px;height:40px;border-radius:50%;border:3px solid rgba(255,255,255,.2);border-top-color:#ffffffd9;animation:media-viewer-spin .7s linear infinite}@keyframes media-viewer-spin{to{transform:rotate(360deg)}}.media-viewer__img{max-width:100%;max-height:100%;width:auto;height:auto;min-height:0;object-fit:contain;-webkit-user-select:none;user-select:none}.media-viewer__stage--video{width:100%;max-height:78vh}.media-viewer__video{max-width:100%;max-height:78vh;width:auto;height:auto}.media-viewer__stage--audio{flex-direction:column;gap:20px;padding:24px}.media-viewer__audio-icon{font-size:56px;opacity:.85}.media-viewer__audio{width:min(100%,420px)}.media-viewer__stage--file{flex-direction:column;text-align:center;gap:12px;padding:24px;color:#e2e8f0}.media-viewer__stage--file-preview{flex:1;align-self:stretch;width:100%;max-width:100%;min-height:min(78vh,720px);padding:0 12px}.media-viewer__file-iframe{width:100%;height:min(78vh,720px);min-height:320px;border:none;border-radius:8px;background:#1e293b}.media-viewer__file-open{display:inline-flex;align-items:center;justify-content:center;margin-top:4px;padding:12px 20px;border:none;border-radius:10px;background:var(--primary-color, #3390ec);color:#fff!important;font-size:.95rem;font-weight:600;font-family:inherit;text-decoration:none;cursor:pointer;transition:opacity .15s}.media-viewer__file-open:hover{opacity:.92}.media-viewer__file-icon{font-size:64px}.media-viewer__file-name{font-size:1rem;font-weight:600;word-break:break-word}.media-viewer__file-hint{font-size:.85rem;color:#94a3b8}.media-viewer__file-loading,.media-viewer__file-preview-fallback{color:#ffffffeb;text-align:center;padding:24px 16px;font-size:.95rem}.media-viewer__file-preview-fallback p{margin:0 0 12px}.media-viewer__nav-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:50%;cursor:pointer;color:#ffffffeb;background:#ffffff1f;transition:background-color .15s ease,opacity .15s ease}.media-viewer__nav-arrow:hover:not(:disabled){background:#ffffff2e}.media-viewer__nav-arrow:active:not(:disabled){background:#ffffff38}.media-viewer__nav-arrow:disabled{opacity:.4;cursor:default;background:#ffffff14}.media-viewer__nav-arrow--prev{left:max(10px,env(safe-area-inset-left,0px))}.media-viewer__nav-arrow--next{right:max(10px,env(safe-area-inset-right,0px))}.media-viewer__nav-arrow-svg{width:24px;height:24px;display:block;flex-shrink:0}.media-viewer__footer{flex-shrink:0;padding:12px 16px 20px;display:flex;flex-direction:column;align-items:center;gap:14px;background:linear-gradient(0deg,rgba(0,0,0,.75) 0%,transparent 100%)}.media-viewer--photo-only .media-viewer__main{padding:0 12px}.media-viewer--photo-only .media-viewer__stage--image{padding:0 8px}.media-viewer__footer--photo-only{background:transparent;padding:16px 16px max(20px,env(safe-area-inset-bottom));gap:0}.media-viewer__counter{font-size:.95rem;font-weight:600;color:#ffffffe6;font-variant-numeric:tabular-nums}.media-viewer__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;position:relative}.media-viewer__action{padding:12px 20px;border-radius:12px;border:1px solid rgba(255,255,255,.25);background:#ffffff14;color:#fff;font-size:15px;font-weight:600;cursor:pointer}.media-viewer__action--primary{background:var(--primary-color, #3390ec);border-color:transparent}.media-viewer__action--icon{min-width:48px;padding-left:14px;padding-right:14px;font-size:1.35rem;line-height:1;font-weight:700;letter-spacing:0}.media-viewer__share-more-wrap{position:relative}.media-viewer__share-menu{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;min-width:220px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;box-shadow:0 8px 32px #00000073;overflow:hidden;z-index:10}.media-viewer__share-item{display:block;width:100%;padding:14px 16px;border:none;background:none;color:var(--text-primary, #f8fafc);font-size:15px;text-align:left;cursor:pointer;border-bottom:1px solid var(--border-color, #334155)}.media-viewer__share-item:last-child{border-bottom:none}.media-viewer__share-item:hover,.media-viewer__share-item:active{background:var(--bg-tertiary, #334155)}.media-viewer__toast{position:absolute;bottom:100px;left:50%;transform:translate(-50%);padding:10px 18px;background:#0f172af2;color:#fff;border-radius:10px;font-size:14px;z-index:20;pointer-events:none}.message-list-wrap{flex:1 1 0%;min-height:0;position:relative;display:flex;flex-direction:column}.message-list-scroll-date{position:absolute;left:50%;top:10px;transform:translate(-50%);z-index:8;pointer-events:none;opacity:0;transition:opacity .22s ease;max-width:calc(100% - 32px);text-align:center}.message-list-scroll-date--visible{opacity:1}.message-list-scroll-date__text{display:inline-block;padding:6px 14px;border-radius:12px;font-size:12px;font-weight:600;color:var(--text-secondary, #94a3b8);background:var(--bg-tertiary, #334155);box-shadow:0 4px 14px #0003}.message-list-item-anchor{min-width:0}.message-list{display:flex;flex-direction:column;flex:1 1 0%;min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:12px 16px;background:transparent;transition:background-color .3s ease,background-image .3s ease;scrollbar-width:none;-ms-overflow-style:none;container-type:inline-size;container-name:chat-messages}.message-list::-webkit-scrollbar{width:0;height:0;display:none}.message-list-scroll-fab{position:absolute;right:16px;bottom:12px;z-index:6;width:46px;height:46px;padding:0;border:none;border-radius:50%;background:var(--primary-color, #3390ec);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000059;transition:transform .15s ease,box-shadow .15s ease;animation:message-list-fab-in .22s ease;-webkit-tap-highlight-color:transparent}.message-list-scroll-fab:hover{box-shadow:0 6px 20px #0006}.message-list-scroll-fab:active{transform:scale(.94)}.message-list-scroll-fab__icon{width:22px;height:22px;display:block}@keyframes message-list-fab-in{0%{opacity:0;transform:scale(.85) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.message-list-scroll-fab{right:12px;bottom:8px}}@media (max-width: 768px){.message-list{padding:8px 14px}}.load-more-spinner{display:flex;justify-content:center;padding:8px 0}.load-more-spinner__dot{width:24px;height:24px;border:3px solid var(--border-color, #e0e0e0);border-top-color:var(--accent-color, #3390ec);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message-list-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-height:min(320px,70vh);flex:1;color:var(--text-secondary)}.message-list-loading-text{margin:0;font-size:15px}.message-list-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:min(320px,70vh);flex:1;color:var(--text-secondary);transition:color .3s ease}.message-list-empty-text{margin:0 0 8px;font-size:15px}.first-unread-message{position:relative}.first-unread-message:before{content:"";position:absolute;left:0;right:0;top:-10px;height:2px;background:var(--accent-color);border-radius:1px}.date-divider{display:flex;align-items:center;justify-content:center;margin:16px auto;padding:6px 12px;background:var(--bg-tertiary);border-radius:12px;font-size:12px;font-weight:500;color:var(--text-secondary);max-width:fit-content;transition:background-color .3s ease,color .3s ease}.chat-message-list-typing{display:flex;align-items:center;padding-left:41px;margin-top:-6px;margin-bottom:8px}.chat-message-list-typing--empty{padding-left:0;justify-content:center;margin-top:12px;margin-bottom:0}.emoji-picker-wrapper{margin-bottom:8px;animation:slideUp .2s ease;box-shadow:0 -4px 12px #0003;border-radius:12px;overflow:hidden}@keyframes pulse{0%,to{background-color:#dc26261a}50%{background-color:#dc262633}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.video-record-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20000;background:#000000d1;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s ease}.video-record-modal-overlay--fullscreen{padding:0;background:#000;align-items:stretch;justify-content:stretch}.video-record-fullscreen{flex:1;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;width:100%;background:#000}.video-record-fullscreen-video-wrap{flex:1;min-height:0;position:relative;display:flex;align-items:center;justify-content:center;background:#000}.video-record-fullscreen-video-wrap--preview{padding-bottom:env(safe-area-inset-bottom,0)}.video-record-fullscreen-video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.video-record-fullscreen-video--mirror{transform:scaleX(-1)}.video-record-fullscreen-video--preview{object-fit:contain;max-height:calc(100vh - 120px);max-height:calc(100dvh - 120px)}.video-record-fullscreen-time-badge{position:absolute;top:max(12px,env(safe-area-inset-top));left:50%;transform:translate(-50%);font-size:18px;font-weight:600;font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,.9);z-index:10;pointer-events:none;display:flex;align-items:center;gap:6px;white-space:nowrap}.video-record-rec-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;flex-shrink:0;animation:video-rec-blink 1s ease-in-out infinite}@keyframes video-rec-blink{0%,to{opacity:1}50%{opacity:0}}.video-record-fullscreen-toolbar{flex-shrink:0;position:absolute;bottom:32px;left:0;right:0;padding:0 20px max(8px,env(safe-area-inset-bottom));display:flex;justify-content:center;z-index:10002}.video-record-fullscreen-toolbar__inner{background:#00000040;border-radius:24px;padding:16px 20px;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-around;align-items:center;gap:8px;width:100%;max-width:520px}.video-record-fullscreen-toolbar--preview{flex-wrap:wrap;gap:12px}.video-record-tool-item{flex:1;min-width:56px;max-width:80px;display:flex;flex-direction:column;align-items:center;gap:8px}.video-record-tool-btn{flex:1;min-width:0;max-width:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;border:none;border-radius:12px;background:#ffffff1f;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s,transform .1s}.video-record-tool-btn:hover{background:#fff3}.video-record-tool-btn:active{transform:scale(.97)}.video-record-tool-btn--danger{background:#f44336f2}.video-record-tool-btn--danger:hover{background:#e53935}.video-record-tool-btn--ghost{background:#94a3b840}.video-record-tool-icon-btn{width:56px;height:56px;border-radius:28px;border:none;background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,transform .1s ease;padding:0}.video-record-tool-icon-btn:hover{transform:scale(1.04)}.video-record-tool-icon-btn:active{transform:scale(.98)}.video-record-tool-icon-btn--danger{background:#f44336f2}.video-record-tool-icon-btn--danger:hover{background:#e53935}.video-record-tool-icon-btn--primary{background:#2196f3f2}.video-record-tool-icon-btn--primary:hover:not(:disabled){background:#1976d2}.video-record-tool-icon-btn--mirror-on{background:#7c5cff66;border-color:#ffffff73;color:#fff}.video-record-tool-icon-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.video-record-tool-icon-btn--uniform{background:#ffffff26;color:#fff}.video-record-tool-icon-btn--uniform:hover:not(:disabled){background:#ffffff40}.video-record-tool-icon-btn--uniform:active:not(:disabled){background:#fff3}.video-record-tool-icon-btn--uniform-active{background:#ffffff59}.video-record-tool-icon-btn--send{background:var(--primary-color, #3390ec);color:#fff;box-shadow:0 4px 16px #00000059}.video-record-tool-icon-btn--send:hover:not(:disabled){background:var(--primary-dark, #2563eb)}.video-record-tool-icon-btn--send:active:not(:disabled){transform:scale(.94)}.video-record-red-dot{display:block;width:22px;height:22px;border-radius:50%;background:#ef4444;flex-shrink:0}.video-record-exit-btn{position:absolute;top:max(16px,env(safe-area-inset-top,16px));right:16px;z-index:10003;width:40px;height:40px;border-radius:50%;border:none;background:#00000073;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease}.video-record-exit-btn:hover{background:#000000a6}.video-record-exit-btn:active{transform:scale(.95)}.video-record-exit-btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.video-record-exit-btn--left{right:auto;left:16px}.video-record-tool-icon{font-size:22px;line-height:1}.video-record-tool-label{line-height:1.1;text-align:center;font-size:9px;font-weight:500;color:#fff;text-transform:lowercase}@media (max-width: 420px){.video-record-tool-label{font-size:10px}}.video-record-modal{width:min(100%,420px);max-height:min(90vh,640px);background:var(--bg-secondary, #1e293b);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 48px #00000073}.video-record-modal--compact{width:auto;max-width:none;max-height:none;background:transparent;box-shadow:none;border-radius:0;overflow:visible}.video-record-circle-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;position:relative}.video-record-circle-frame{position:relative;width:min(80vw,80cqw,640px);height:min(80vw,80cqw,640px);border-radius:50%;border:8px solid #f97316;overflow:hidden;box-sizing:border-box;flex-shrink:0;background:#0f172a}.video-record-circle-frame .video-record-live,.video-record-circle-frame .video-record-preview{width:100%;height:100%;object-fit:cover;display:block;max-height:none}.video-record-rec-time{font-size:16px;font-weight:600;font-variant-numeric:tabular-nums;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.95),0 0 16px rgba(0,0,0,.7);line-height:1.2}.video-record-rec-time--outside{position:absolute;top:-30px;left:50%;transform:translate(-50%);z-index:3}.video-record-actions-below{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:0 8px;width:100%;max-width:min(100%,320px)}.video-record-actions-below--preview{max-width:min(100%,360px)}.video-record-stop-btn,.video-record-cancel-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s,opacity .2s}.video-record-stop-btn{background:var(--primary-color, #3390ec);color:#fff}.video-record-stop-btn:hover{background:var(--primary-dark, #2563eb)}.video-record-cancel-btn{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.video-record-cancel-btn:hover{background:var(--border-light, #475569)}.video-record-actions-below--preview .confirm-send-btn,.video-record-actions-below--preview .cancel-send-btn{flex:1;min-width:120px}@media (max-width: 480px){.video-record-circle-frame{width:min(88vw,80cqw,560px);height:min(88vw,80cqw,560px)}.video-record-rec-time{font-size:14px}}@media (max-width: 768px){.text-input-container{padding:6px 10px}.inline-icon-button{width:28px;height:28px}.inline-icon-svg{width:20px;height:20px}.trailing-icon-button{width:30px;height:30px}.trailing-icon-svg{width:20px;height:20px}.message-input-field{font-size:15px}}.message-input-container{width:100%;padding:0;box-sizing:border-box;position:relative}.input-wrapper{display:flex;align-items:center;width:100%}.text-input-container{flex:1;width:100%;min-width:0;box-sizing:border-box;display:flex;align-items:center;padding:8px 12px;gap:8px;background-color:var(--input-bg, var(--bg-tertiary, #334155));border-radius:24px;margin:0 15px}.inline-icon-button{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary, #cbd5e1);transition:all .2s;flex-shrink:0;margin-right:6px}.inline-icon-button:hover{color:var(--text-primary, #f8fafc)}.inline-icon-text{font-size:22px}.inline-icon-svg{width:22px;height:22px;fill:currentColor}.message-input-field{flex:1;min-height:36px;max-height:120px;padding:6px 0;background:transparent;border:none;color:var(--text-primary, #f8fafc);font-size:16px;line-height:1.5;resize:none;overflow-y:auto;font-family:inherit}.message-input-field:focus{outline:none}.message-input-field::placeholder{color:var(--text-muted, #64748b)}.message-input-field::-webkit-scrollbar{width:4px}.message-input-field::-webkit-scrollbar-track{background:transparent}.message-input-field::-webkit-scrollbar-thumb{background:var(--border-color, #334155);border-radius:2px}.trailing-icons{display:flex;align-items:center;gap:6px;margin-left:8px}.trailing-icon-button{width:32px;height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-secondary, #cbd5e1);transition:all .2s;flex-shrink:0;position:relative}.trailing-icon-button:hover:not(:disabled){color:var(--text-primary, #f8fafc);background-color:#ffffff0d}.trailing-icon-button:disabled{opacity:.5;cursor:not-allowed}.trailing-icon-text{font-size:20px}.trailing-icon-svg{width:20px;height:20px;fill:currentColor;pointer-events:none}.trailing-icon-svg--dim{opacity:.45}.upload-progress-overlay{position:fixed;left:50%;bottom:max(96px,calc(env(safe-area-inset-bottom) + 80px));transform:translate(-50%);z-index:21050;pointer-events:none}.upload-progress-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;border-radius:16px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);box-shadow:0 8px 32px #00000059}.upload-progress-ring-wrap{position:relative;width:56px;height:56px}.upload-progress-svg{width:56px;height:56px;display:block}.upload-progress-track{stroke:var(--border-color, #334155);opacity:.55}.upload-progress-bar{stroke:var(--primary-color, #3390ec);transition:stroke-dashoffset .15s ease}.upload-progress-pct{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-primary, #f8fafc);pointer-events:none}.upload-progress-bytes{font-size:11px;font-variant-numeric:tabular-nums;color:var(--text-secondary, #cbd5e1);white-space:nowrap}.video-record-button{touch-action:none;user-select:none;-webkit-user-select:none}.record-circle-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#dc2626}.send-inline-button{padding:4px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--primary-color, #3390EC);transition:all .2s;min-width:32px;margin-left:8px}.send-inline-button:hover:not(:disabled){color:var(--primary-dark, #2563eb);transform:scale(1.1)}.send-inline-button:disabled{opacity:.5;cursor:not-allowed}.send-inline-icon{width:22px;height:22px;font-weight:700}.emoji-picker-wrapper{position:absolute;bottom:60px;left:0;z-index:100;animation:slideUp .2s ease;box-shadow:0 -4px 12px #0003;border-radius:12px 12px 0 0;overflow:hidden}.recording-indicator{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background-color:#dc26261a;border-radius:12px;margin:0;position:absolute;left:15px;right:15px;bottom:calc(100% + 8px);z-index:120;animation:pulse 1.5s ease-in-out infinite}.recording-dot{width:10px;height:10px;border-radius:50%;background-color:#dc2626;animation:blink 1s ease-in-out infinite}.recording-time{font-size:14px;font-weight:600;color:var(--text-primary, #f8fafc)}.video-preview{width:100%;max-height:300px;border-radius:12px;margin-bottom:8px}.confirm-video-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.confirm-video-modal{background-color:var(--bg-secondary, #1e293b);border-radius:16px;padding:20px;max-width:90%;max-height:90%;display:flex;flex-direction:column;gap:16px}.confirm-video-preview{max-width:100%;max-height:60vh;border-radius:12px}.confirm-video-buttons{display:flex;gap:12px}.confirm-send-btn,.cancel-send-btn{flex:1;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.confirm-send-btn{background-color:var(--primary-color, #3390EC);color:#fff}.confirm-send-btn:hover{background-color:var(--primary-dark, #2563eb)}.cancel-send-btn{background-color:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.cancel-send-btn:hover{background-color:var(--border-light, #475569)}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.attach-media-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:24000;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));box-sizing:border-box}.attach-media-modal{width:min(420px,100%);max-height:min(88vh,640px);display:flex;flex-direction:column;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:16px;box-shadow:0 20px 50px #00000073;overflow:hidden}.attach-media-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border-color, #334155)}.attach-media-modal__title{margin:0;font-size:17px;font-weight:600;color:var(--text-primary, #f8fafc)}.attach-media-modal__close{border:none;background:transparent;color:var(--text-secondary, #94a3b8);font-size:26px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:8px}.attach-media-modal__close:hover{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.attach-media-modal__tabs{display:flex;gap:6px;padding:10px 12px;border-bottom:1px solid var(--border-color, #334155)}.attach-media-modal__tab{flex:1;padding:10px 8px;border:1px solid transparent;border-radius:10px;background:var(--bg-tertiary, #334155);color:var(--text-secondary, #94a3b8);font-size:14px;font-weight:600;cursor:pointer}.attach-media-modal__tab--active{border-color:var(--primary-color, #3390ec);color:var(--text-primary, #f8fafc);background:#3390ec26}.attach-media-modal__input-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.attach-media-modal__actions{padding:12px 16px 0}.attach-media-modal__pick{width:100%;padding:12px 16px;border-radius:12px;border:1px dashed var(--border-color, #475569);background:transparent;color:var(--text-primary, #f8fafc);font-size:15px;font-weight:500;cursor:pointer}.attach-media-modal__pick:hover{border-color:var(--primary-color, #3390ec);background:#3390ec14}.attach-media-modal__previews{display:flex;flex-wrap:wrap;gap:10px;padding:14px 16px;overflow-y:auto;max-height:42vh;-webkit-overflow-scrolling:touch}.attach-media-modal__preview-card{position:relative;width:96px;height:96px;border-radius:12px;overflow:hidden;background:var(--bg-tertiary, #334155);flex-shrink:0}.attach-media-modal__preview-media{width:100%;height:100%;object-fit:cover;display:block}.attach-media-modal__preview-file{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;box-sizing:border-box;gap:6px}.attach-media-modal__preview-file-icon{font-size:28px}.attach-media-modal__preview-file-name{font-size:10px;color:var(--text-secondary, #94a3b8);text-align:center;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.attach-media-modal__preview-remove{position:absolute;top:4px;right:4px;width:26px;height:26px;border:none;border-radius:50%;background:#0000008c;color:#fff;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.attach-media-modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 16px 16px;border-top:1px solid var(--border-color, #334155);margin-top:auto}.attach-media-modal__btn{padding:10px 18px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;border:none}.attach-media-modal__btn--ghost{background:transparent;color:var(--text-secondary, #94a3b8)}.attach-media-modal__btn--ghost:hover{color:var(--text-primary, #f8fafc)}.attach-media-modal__btn--primary{background:var(--primary-color, #3390ec);color:#fff}.attach-media-modal__btn--primary:disabled{opacity:.45;cursor:not-allowed}:root[data-theme=light] .attach-media-modal{background:#fff;border-color:#e2e8f0}:root[data-theme=light] .attach-media-modal__header,:root[data-theme=light] .attach-media-modal__tabs,:root[data-theme=light] .attach-media-modal__footer{border-color:#e2e8f0}:root[data-theme=light] .attach-media-modal__title{color:#0f172a}:root[data-theme=light] .attach-media-modal__tab{background:#f1f5f9;color:#64748b}:root[data-theme=light] .attach-media-modal__tab--active{background:#3390ec1f;color:#0f172a}:root[data-theme=light] .attach-media-modal__pick{color:#0f172a;border-color:#cbd5e1}.chat-window{display:flex;flex-direction:column;flex:1 1 0%;min-width:0;min-height:0;height:100%;max-height:100%;overflow:hidden;background-color:var(--bg-secondary, #1e293b);position:relative;transition:padding-right .3s ease-in-out}@media (min-width: 900px){.chat-window--with-peer-profile{padding-right:300px}}.chat-messages-container{flex:1 1 0%;min-height:0;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-primary, #0f172a);background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;z-index:1;isolation:isolate}.chat-messages-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff3;pointer-events:none;z-index:0}.chat-messages-container>*{position:relative;z-index:1}.chat-header{flex-shrink:0;padding:12px 20px;background-color:var(--bg-secondary, #1e293b);border-bottom:1px solid var(--border-color, #334155);box-shadow:0 1px 2px #0000000d;position:relative;z-index:25;overflow:visible}.chat-header-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;gap:8px;min-width:0;overflow:hidden}.chat-header-back{display:flex;align-items:center;justify-content:center;flex:0 0 auto;width:40px;height:40px;margin-right:4px;padding:0;background:none;border:none;border-radius:50%;cursor:pointer;color:var(--text-primary, #f8fafc);transition:background-color .2s,opacity .2s}.chat-header-back:hover{background-color:#ffffff0f}.chat-header-back:active{opacity:.85}.chat-header-back-svg{width:24px;height:24px;display:block}.chat-header-user-info{display:flex;align-items:center;flex:1;min-width:0;margin-right:12px}.chat-header-avatar-container{position:relative;margin-right:12px;flex-shrink:0}.chat-header-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background-color:var(--bg-tertiary, #334155)}.chat-header-avatar-placeholder{width:40px;height:40px;border-radius:50%;background-color:var(--primary-color, #3390EC);display:flex;align-items:center;justify-content:center}.chat-header-avatar-text{color:#fff;font-size:16px;font-weight:600}.chat-header-online-indicator{position:absolute;bottom:0;right:0;width:12px;height:12px;border-radius:50%;background-color:var(--status-online, #10b981);border:2px solid var(--bg-secondary, #1e293b)}.chat-header-text-container{flex:1 1 0%;min-width:min(140px,40vw);max-width:100%}.chat-header-title{font-size:16px;font-weight:600;color:var(--text-primary, #f8fafc);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-status{display:flex;align-items:center;margin-top:2px}.chat-header-status-text{font-size:12px;color:var(--text-secondary, #cbd5e1)}.chat-header-actions{display:flex;align-items:center;gap:6px;flex:0 0 auto}.chat-header-button{padding:8px;border-radius:50%;background:none;border:none;cursor:pointer;color:var(--text-secondary, #cbd5e1);transition:all .2s;display:flex;align-items:center;justify-content:center}.chat-header-button:hover,.chat-header-button--profile.chat-header-button--active{background-color:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.chat-header-button:disabled{opacity:.45;cursor:not-allowed}.chat-header-button:disabled:hover{background:none;color:var(--text-secondary, #cbd5e1)}.chat-header-button-icon{width:20px;height:20px}.chat-header-title-row{display:flex;align-items:center;gap:6px;min-width:0}.chat-header-geo-share-icon{width:16px;height:16px;flex-shrink:0;display:block;color:var(--accent-color, #3390ec);opacity:.95}.chat-header-geo-share-icon path{fill:currentColor}.chat-context-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:28000}.chat-context-menu{position:absolute;top:calc(100% + 4px);right:8px;width:220px;background-color:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;box-shadow:0 4px 12px #0003;overflow:hidden;z-index:15001;animation:slideDown .2s ease}.chat-context-menu--portal{position:fixed;left:auto;margin:0;z-index:28001;animation:none}.chat-context-menu-item{display:flex;align-items:center;width:100%;padding:14px 16px;background:none;border:none;border-bottom:1px solid var(--border-color, #334155);cursor:pointer;color:var(--text-primary, #f8fafc);transition:background-color .2s;text-align:left}.chat-context-menu-item:last-child{border-bottom:none}.chat-context-menu-item:hover{background-color:var(--bg-tertiary, #334155)}.chat-context-menu-item--danger{color:#dc2626}.chat-context-menu-item--danger:hover{background-color:#dc262626}.chat-context-menu-icon{width:20px;height:20px;margin-right:12px;flex-shrink:0}.chat-context-menu-icon--svg{color:var(--text-secondary, #94a3b8)}.chat-context-menu-icon--svg path{fill:currentColor}.chat-context-menu-text{font-size:14px;font-weight:500}.clear-history-buttons button{padding:10px 20px;border:none;border-radius:6px;font-size:16px;cursor:pointer;transition:background .2s}.chat-input-container{flex-shrink:0;padding:10px 0 max(12px,env(safe-area-inset-bottom,0px));background-color:var(--bg-primary, #0f172a);border-top:none;position:relative;z-index:5}:root[data-theme=light] .chat-input-container{background-color:var(--bg-tertiary, #f1f5f9)}.chat-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.chat-modal-content{width:90%;max-width:400px;background-color:var(--bg-secondary, #1e293b);border-radius:12px;padding:24px;box-shadow:0 10px 40px #0000004d;animation:slideUp .2s ease}.chat-modal-title{font-size:18px;font-weight:600;color:var(--text-primary, #f8fafc);margin-bottom:12px;text-align:center}.chat-modal-text{font-size:14px;color:var(--text-secondary, #cbd5e1);margin-bottom:24px;text-align:center;line-height:1.5}.chat-modal-buttons{display:flex;gap:12px}.chat-modal-button{flex:1;padding:12px;border-radius:8px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.chat-modal-button-cancel{background-color:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.chat-modal-button-cancel:hover{background-color:var(--border-light, #475569)}.chat-modal-button-confirm{background-color:#dc2626;color:#fff}.chat-modal-button-confirm:hover{background-color:#b91c1c}.peer-profile-panel{position:absolute;top:0;right:0;bottom:0;width:300px;min-width:300px;max-width:300px;display:flex;flex-direction:column;background:var(--bg-secondary, #1e293b);border-left:1px solid var(--border-color, #334155);z-index:36;transform:translate(100%);transition:transform .3s ease-in-out}.peer-profile-panel.visible{transform:translate(0)}.peer-profile-header{display:flex;justify-content:flex-start;padding:12px 16px}.peer-profile-back-btn{margin-right:0;background:#00000073;color:#fff}.peer-profile-back-btn:hover{background:#000000a6}.peer-profile-close-btn{width:38px;height:38px;border:none;border-radius:19px;background:transparent;color:var(--text-secondary, #94a3b8);font-size:22px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.peer-profile-close-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.peer-profile-top{padding:0 16px 16px}.peer-profile-hero{display:flex;flex-direction:row;align-items:center;gap:10px;width:100%;min-width:0}.peer-profile-avatar-wrap{width:88px;height:88px;border-radius:50%;overflow:hidden;border:none;padding:0;background:transparent;cursor:pointer;flex-shrink:0}.peer-profile-avatar{width:100%;height:100%;object-fit:cover;display:block}.peer-profile-avatar--placeholder{background:var(--primary-color, #3390ec);color:#fff;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center}.peer-profile-name{font-size:16px;font-weight:600;color:var(--text-primary, #f8fafc);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.peer-profile-name-row{display:flex;align-items:center;gap:6px;min-width:0;width:100%;max-width:100%}.peer-profile-name-row .peer-profile-name{flex:1 1 auto;min-width:0}.peer-profile-alias-edit-btn{flex-shrink:0;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:var(--bg-primary, #0f172a);color:var(--text-secondary, #94a3b8);font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.peer-profile-alias-edit-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.peer-profile-alias-editor{display:flex;flex-direction:column;gap:10px;min-width:0;max-width:100%;width:100%}.peer-profile-alias-input{width:100%;height:42px;min-height:42px;margin:0;box-sizing:border-box;padding:10px 12px;border:1px solid var(--input-border, var(--border-color, #334155));border-radius:10px;background:var(--input-bg, var(--bg-tertiary, #334155));color:var(--text-primary, #f8fafc);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.peer-profile-alias-input:hover:not(:disabled){border-color:var(--border-light, #475569)}.peer-profile-alias-input:focus,.peer-profile-alias-input:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}.peer-profile-alias-input::placeholder{color:var(--text-muted, #64748b)}.peer-profile-alias-input:-webkit-autofill,.peer-profile-alias-input:-webkit-autofill:hover,.peer-profile-alias-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;-webkit-text-fill-color:var(--text-primary, #f8fafc)!important;caret-color:var(--text-primary, #f8fafc);border:1px solid var(--input-border, var(--border-color, #334155))}.peer-profile-alias-input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset,0 0 0 2px rgba(51,144,236,.3)!important;border-color:var(--accent-color, #3390ec)}.peer-profile-alias-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:2px}.peer-profile-alias-btn{min-height:40px;padding:0 18px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--border-color, #334155);background:transparent;color:var(--text-primary, #f8fafc);transition:background .15s ease,filter .15s ease}.peer-profile-alias-btn:hover:not(:disabled){background:#94a3b814}.peer-profile-alias-btn--primary{border-color:transparent;background:var(--accent-color, #3390ec);color:#fff}.peer-profile-alias-btn--primary:hover:not(:disabled){filter:brightness(1.06)}.peer-profile-meta{min-width:0;display:flex;flex-direction:column;gap:4px}.peer-profile-status{font-size:11px;color:var(--text-secondary, #94a3b8);line-height:1.35}.peer-profile-status--online{color:var(--status-online, #10b981)}.peer-profile-section{margin-top:6px;padding:14px 16px;border-top:1px solid var(--border-color, #334155);display:flex;flex-direction:column;flex:1 1 auto;min-height:0;gap:12px}.peer-profile-section-title{font-size:14px;font-weight:600;color:var(--text-primary, #f8fafc)}.peer-profile-tabs{display:flex;flex-wrap:wrap;gap:6px}.peer-profile-tab{border:1px solid var(--border-color, #334155);border-radius:8px;background:transparent;color:var(--text-secondary, #94a3b8);font-size:12px;padding:6px 10px;cursor:pointer}.peer-profile-tab--active{border-color:var(--primary-color, #3390ec);color:var(--text-primary, #f8fafc);background:#3390ec26}.peer-profile-content-list{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:max-content;align-content:start;gap:8px;flex:1 1 auto;min-height:0;overflow:auto}.peer-profile-date-section{grid-column:1 / -1;display:flex;flex-direction:column;align-self:start;gap:8px}.peer-profile-date-section--list{gap:4px}.peer-profile-date-divider{display:inline-flex;align-items:center;justify-content:center;width:fit-content;margin:4px auto 0;padding:4px 10px;border-radius:10px;background:var(--bg-primary, #0f172a);color:var(--text-secondary, #94a3b8);font-size:12px}.peer-profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.peer-profile-media-card{border:1px solid var(--border-color, #334155);border-radius:12px;overflow:hidden;display:block;background:var(--bg-primary, #0f172a);padding:0;cursor:pointer;aspect-ratio:1 / 1}.peer-profile-media-thumb{width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:var(--bg-primary, #0f172a)}.peer-profile-media-thumb--video{object-fit:contain;object-position:center;background:#000}.peer-profile-link-item{grid-column:1 / -1;display:block;border:1px solid var(--border-color, #334155);border-radius:8px;padding:9px 10px;color:var(--primary-color, #3390ec);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:transparent;text-align:left;cursor:pointer}.peer-profile-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #94a3b8);font-size:13px;pointer-events:none}.peer-profile-audio-row{width:100%;display:flex;align-items:center;gap:6px;margin:0;padding:0}.peer-profile-audio-player{min-width:0;flex:1}.peer-profile-audio-player .voice-message-container{gap:0}.peer-profile-audio-player .voice-message-block{padding:8px}.peer-profile-audio-row+.peer-profile-audio-row{margin-top:2px}.peer-profile-audio-actions-btn{width:30px;height:30px;border:1px solid var(--border-color, #334155);border-radius:8px;background:transparent;color:var(--text-secondary, #94a3b8);cursor:pointer;flex-shrink:0}.peer-profile-audio-actions-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.peer-profile-document-row{width:100%;display:flex;align-items:center;gap:6px;margin:0;padding:0}.peer-profile-document-player{min-width:0;flex:1}.peer-profile-document-player .document-message-container{gap:0}.peer-profile-document-player .document-white-block{padding:8px 10px}.peer-profile-document-actions-btn{width:30px;height:30px;border:1px solid var(--border-color, #334155);border-radius:8px;background:transparent;color:var(--text-secondary, #94a3b8);cursor:pointer;flex-shrink:0}.peer-profile-document-actions-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.peer-item-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25000}.peer-item-menu{position:fixed;z-index:25001;min-width:210px;border:1px solid var(--border-color, #334155);border-radius:10px;background:var(--bg-secondary, #1e293b);box-shadow:0 8px 24px #0000004d;transform:translate(-50%,-10%);overflow:hidden}.peer-item-menu__btn{width:100%;border:none;border-bottom:1px solid var(--border-color, #334155);background:transparent;color:var(--text-primary, #f8fafc);padding:10px 12px;text-align:left;cursor:pointer}.peer-item-menu__btn:last-child{border-bottom:none}.peer-item-menu__btn:hover{background:var(--sidebar-hover, #334155)}.message-jump-target{animation:message-jump-pulse 1.2s ease}@keyframes message-jump-pulse{0%{background:#3390ec47}to{background:transparent}}@media (max-width: 768px){.chat-header{padding:10px 16px}.chat-messages-container{padding:0}.chat-input-container{padding:10px 0 max(12px,env(safe-area-inset-bottom,0px))}.chat-modal-content{width:95%;padding:20px}.peer-profile-panel{width:100%;min-width:100%;max-width:100%}}@media (max-width: 699px){.peer-profile-panel{width:100%;min-width:100%;max-width:100%}.peer-profile-header{position:absolute;top:0;right:0;left:0;justify-content:flex-start;padding:max(8px,env(safe-area-inset-top,0px)) 12px 16px;z-index:3;pointer-events:none;background:linear-gradient(to bottom,rgba(15,23,42,.72) 0%,rgba(15,23,42,.35) 55%,transparent 100%)}.peer-profile-close-btn,.peer-profile-back-btn{pointer-events:auto}.peer-profile-top{padding:0}.peer-profile-hero{position:relative;display:block;width:100%}.peer-profile-avatar-wrap{width:100%;height:40vh;min-height:148px;max-height:55vh;border-radius:0;flex-shrink:0;display:block}.peer-profile-avatar{object-fit:cover;object-position:center;width:100%;height:100%}.peer-profile-avatar--placeholder{width:100%;height:100%;min-height:0;border-radius:0;font-size:clamp(1.75rem,11vw,3.25rem)}.peer-profile-meta{position:absolute;left:max(12px,env(safe-area-inset-left,0px));bottom:12px;right:auto;max-width:calc(100% - 24px);margin:0;padding:0;background:none;display:flex;flex-direction:column;align-items:flex-start;gap:6px;pointer-events:none;z-index:2;text-align:left}.peer-profile-meta .peer-profile-name-row,.peer-profile-meta .peer-profile-alias-editor{pointer-events:auto;max-width:100%}.peer-profile-meta .peer-profile-name-row{align-items:stretch;gap:8px}.peer-profile-meta .peer-profile-name,.peer-profile-meta .peer-profile-name-row .peer-profile-name{font-size:14px;font-weight:600;line-height:1.3;color:var(--text-primary, #f8fafc);padding:6px 12px;background:var(--bg-tertiary);border-radius:12px;box-shadow:0 2px 10px #00000059;white-space:normal;overflow:visible;text-overflow:unset;max-width:100%;transition:background-color .3s ease}.peer-profile-meta .peer-profile-alias-edit-btn{align-self:center;background:var(--bg-tertiary);box-shadow:0 2px 10px #00000059}.peer-profile-meta .peer-profile-alias-editor{padding:8px 10px;background:var(--bg-tertiary);border-radius:12px;box-shadow:0 2px 10px #00000059}.peer-profile-meta .peer-profile-status{font-size:10px;font-weight:500;line-height:1.4;color:var(--text-secondary, #cbd5e1);padding:4px 8px;background:#0f172ae0;border:1px solid var(--border-color, #334155);border-radius:10px;box-shadow:0 2px 10px #0000004d;max-width:100%;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.peer-profile-meta .peer-profile-status--online{color:var(--status-online, #10b981);border-color:#10b98159;background:#0f172aeb}.peer-profile-section{margin-top:0;border-top:1px solid var(--border-color, #334155)}}@media (max-width: 699px){:root[data-theme=light] .peer-profile-meta .peer-profile-name,:root[data-theme=light] .peer-profile-meta .peer-profile-name-row .peer-profile-name{background:#00000073;color:#fff;box-shadow:0 2px 10px #00000040}:root[data-theme=light] .peer-profile-meta .peer-profile-alias-edit-btn{background:#00000073;color:#fff;box-shadow:0 2px 10px #00000040}:root[data-theme=light] .peer-profile-meta .peer-profile-status{background:#00000073;color:#ffffffd9;border-color:#ffffff2e;box-shadow:0 2px 10px #00000040}:root[data-theme=light] .peer-profile-meta .peer-profile-status--online{color:#6ee7b7;border-color:#6ee7b766;background:#00000073}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.peer-location-panel{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;background:var(--bg-primary, #0f172a)}.peer-location-panel__tile-bar{flex-shrink:0;padding:8px 12px 10px 64px;border-bottom:1px solid var(--border-color, #334155);background:var(--bg-secondary, #1e293b);z-index:5}.peer-location-panel__tile-label{display:block;margin-bottom:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary, #94a3b8)}.peer-location-panel__tile-select{width:100%;box-sizing:border-box;padding:8px 10px;border-radius:8px;border:1px solid var(--input-border, var(--border-color, #334155));background:var(--input-bg, var(--bg-tertiary, #334155));color:var(--text-primary, #f8fafc);font-size:13px;font-family:inherit;cursor:pointer;outline:none}.peer-location-panel__tile-select:focus,.peer-location-panel__tile-select:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}.peer-location-panel__top-bar{position:absolute;top:calc(env(safe-area-inset-top,0px) + 10px);left:0;right:0;z-index:1100;padding-left:max(8px,env(safe-area-inset-left,0px));padding-right:max(12px,env(safe-area-inset-right,0px));box-sizing:border-box;pointer-events:none}.peer-location-panel__top-row{position:relative;display:flex;align-items:center;justify-content:flex-start;width:100%;min-width:0;min-height:44px;pointer-events:none}.peer-location-panel__top-row .peer-location-panel__fab-back{position:relative;z-index:2;flex-shrink:0;pointer-events:auto}.peer-location-panel__fab-back{width:44px;height:44px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(251,191,36,.45);border-radius:50%;cursor:pointer;color:#fcd34d;background:#0f172ad1;box-shadow:0 2px 12px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.peer-location-panel__fab-back:hover{background:#1e293beb;color:#fef3c7}.peer-location-panel__fab-back-arrow{display:inline-flex;align-items:center;justify-content:center;font-size:22px;line-height:0;font-weight:600;color:inherit;height:1em;transform:translateY(-.08em)}.peer-location-panel__data-age{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:1;box-sizing:border-box;display:block;max-width:min(72vw,calc(100% - 64px));padding:6px 10px;border-radius:10px;font-size:11px;font-weight:500;line-height:1.35;color:#fff;background:#1a3350;border:none;box-shadow:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;pointer-events:auto}.peer-location-panel__data-age--muted{color:#fffc;background:var(--bg-tertiary, #334155)}.peer-location-panel__data-age--online{background:#166534;color:#dcfce7}.peer-location-panel__data-age--offline{background:#9a3412;color:#ffedd5}:root[data-theme=light] .peer-location-panel__data-age{background:#1e3a8a;color:#fff}:root[data-theme=light] .peer-location-panel__data-age--muted{background:#475569;color:#ffffffd9}.peer-location-panel__map-wrap{flex:1;min-height:0;position:relative}.peer-location-panel__map{position:absolute;top:0;right:0;bottom:0;left:0}.peer-location-panel__map-crosshair{position:absolute;left:50%;top:50%;width:22px;height:22px;margin:-11px 0 0 -11px;pointer-events:none;z-index:650;box-shadow:0 0 0 1px #00000059}.peer-location-panel__map-crosshair:before,.peer-location-panel__map-crosshair:after{content:"";position:absolute;background:#94a3b8f2;border-radius:1px}.peer-location-panel__map-crosshair:before{left:50%;top:0;width:2px;height:100%;margin-left:-1px}.peer-location-panel__map-crosshair:after{top:50%;left:0;height:2px;width:100%;margin-top:-1px}.peer-location-panel__map-crosshair--green:before,.peer-location-panel__map-crosshair--green:after{background:#22c55eeb}.peer-location-panel__map-crosshair-label{position:absolute;left:50%;top:10px;transform:translate(-50%);z-index:650;pointer-events:none;font-size:11px;font-weight:600;color:#cbd5e1;text-shadow:0 0 6px rgba(0,0,0,.85),0 1px 2px rgba(0,0,0,.9);max-width:88%;text-align:center;line-height:1.25}.peer-location-panel__map-crosshair-label--green{color:#bbf7d0}.peer-location-panel__map-tile-float{position:absolute;left:max(6px,env(safe-area-inset-left,0px));bottom:calc(max(12px,env(safe-area-inset-bottom,0px)) + 25px);z-index:1200;max-width:min(200px,52vw);pointer-events:auto}.peer-location-panel__tile-select--map{width:100%;min-width:0;font-size:12px;padding:6px 8px}.peer-location-panel__add-hud{position:absolute;left:50%;bottom:calc(max(12px,env(safe-area-inset-bottom,0px)) + 25px);transform:translate(-50%);width:min(60%,400px);max-width:400px;box-sizing:border-box;z-index:1250;padding:10px 12px;border-radius:10px;background:#0f172aeb;border:1px solid var(--border-color, #334155);box-shadow:0 4px 16px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.peer-location-panel__add-hud-radius{margin:0 0 4px;font-size:14px;font-weight:600;color:var(--text-primary, #f8fafc)}.peer-location-panel__add-hud-hint{margin:0 0 10px;font-size:11px;line-height:1.35;color:var(--text-secondary, #94a3b8)}.peer-location-panel__add-hud-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.peer-location-panel__hud-btn{padding:8px 14px;border-radius:8px;border:1px solid var(--border-color, #475569);background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc);font-size:13px;cursor:pointer}.peer-location-panel__hud-btn--primary{background:#4f46e5;border-color:#6366f1}.peer-location-panel__map-fabs{position:absolute;right:calc(10px + env(safe-area-inset-right,0px));bottom:calc(max(12px,env(safe-area-inset-bottom,0px)) + 25px);top:auto;transform:none;z-index:1100;display:flex;flex-direction:column;gap:10px;pointer-events:auto}.peer-location-panel__fab-track{width:44px;height:44px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(251,191,36,.45);border-radius:50%;cursor:pointer;color:#fcd34d;background:#0f172ad1;box-shadow:0 2px 12px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.peer-location-panel__fab-track--off{border-color:#fbbf2447;color:#facc1573}.peer-location-panel__fab-track--off:hover{color:#fcd34dbf}.peer-location-panel__fab-track:hover{background:#1e293beb;color:#fef3c7}.peer-location-panel__fab-places,.peer-location-panel__fab-add{width:44px;height:44px;padding:0;margin:0;display:flex;align-items:center;justify-content:center;border:1px solid rgba(251,191,36,.45);border-radius:50%;cursor:pointer;color:#fcd34d;background:#0f172ad1;box-shadow:0 2px 12px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.peer-location-panel__fab-places:hover,.peer-location-panel__fab-add:hover{background:#1e293beb;color:#fef3c7}.peer-location-panel__fab-add:disabled,.peer-location-panel__fab-places:disabled{opacity:.45;cursor:not-allowed}.peer-location-panel__fab-add--active{background:#f59e0b59;border-color:#fbbf24;color:#fff}.peer-location-panel__state{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:24px 48px 24px 24px;text-align:center;color:var(--text-secondary, #94a3b8);font-size:14px;line-height:1.5}.peer-location-panel .leaflet-container{font-family:inherit;background:var(--bg-primary, #0f172a)}.peer-location-panel .leaflet-top.leaflet-right{top:50%;transform:translateY(-50%);bottom:auto!important;margin-top:0!important;padding-top:0!important}.peer-location-panel .leaflet-tooltip-pane{z-index:800!important}.leaflet-tooltip.map-address-tooltip{background:#0f172af0;color:#e2e8f0;border:1px solid #475569;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:500;max-width:min(280px,72vw);white-space:normal;line-height:1.35;box-shadow:0 2px 12px #00000059}.leaflet-tooltip.map-address-tooltip--muted{color:#94a3b8;font-size:11px;font-weight:400}.peer-location-panel__map-section{flex:1;min-height:0;display:flex;flex-direction:column}.peer-location-panel__map-section .peer-location-panel__map-wrap{flex:1;min-height:200px}.map-places-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20050;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px}.map-places-modal{display:flex;flex-direction:column;overflow:hidden;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:14px;box-shadow:0 12px 40px #00000059}.map-places-modal--add{width:min(440px,94vw);max-width:440px;max-height:min(88vh,620px)}.map-places-modal--list{width:min(400px,80vw);max-width:400px;max-height:min(72vh,480px)}.map-places-modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border-color, #334155);flex-shrink:0}.map-places-modal__title{margin:0;font-size:16px;font-weight:600;color:var(--text-primary, #f8fafc)}.map-places-modal__close{flex-shrink:0;border:none;background:transparent;color:var(--text-primary, #f8fafc);font-size:18px;line-height:1;cursor:pointer;padding:6px 8px;border-radius:8px}.map-places-modal__close:hover{background:var(--sidebar-hover, #334155)}.map-places-modal__body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;min-height:0;flex:1}.map-places-modal__body--list{padding-top:8px;gap:0}.map-places-modal__help{margin:0;font-size:12px;line-height:1.45;color:var(--text-secondary, #94a3b8)}.map-places-modal__help--warn{color:#fbbf24}.map-places-modal__radius{margin:0;padding:10px 12px;border-radius:10px;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);font-size:13px;line-height:1.4;color:var(--text-secondary, #94a3b8)}.map-places-modal__radius strong{font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-primary, #e2e8f0)}.map-places-modal__input{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:10px;border:1px solid var(--input-border, var(--border-color, #334155));background:var(--input-bg, var(--bg-tertiary, #334155));color:var(--text-primary, #f8fafc);font-size:14px;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.map-places-modal__input:hover:not(:disabled){border-color:var(--border-light, #475569);background:var(--input-bg, var(--bg-tertiary, #334155))}.map-places-modal__input:focus,.map-places-modal__input:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d;background:var(--input-bg, var(--bg-tertiary, #334155))}.map-places-modal__input:disabled{opacity:.5}.map-places-modal__input:-webkit-autofill,.map-places-modal__input:-webkit-autofill:hover,.map-places-modal__input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;-webkit-text-fill-color:var(--text-primary, #f8fafc)!important;caret-color:var(--text-primary, #f8fafc);border:1px solid var(--input-border, var(--border-color, #334155))}.map-places-modal__input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset,0 0 0 2px rgba(51,144,236,.3)!important;box-shadow:0 0 0 1000px var(--input-bg, #334155) inset,0 0 0 2px #3390ec4d!important;border-color:var(--accent-color, #3390ec)}.map-places-modal__actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:4px}.map-places-modal__btn{min-height:40px;padding:0 16px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent}.map-places-modal__btn:disabled{opacity:.5;cursor:not-allowed}.map-places-modal__btn--secondary{background:transparent;border-color:var(--border-color, #334155);color:var(--text-primary, #f8fafc)}.map-places-modal__btn--secondary:hover:not(:disabled){background:#94a3b814}.map-places-modal__btn--primary{background:var(--accent-color, #3390ec);color:#fff}.map-places-modal__btn--primary:hover:not(:disabled){filter:brightness(1.06)}.map-places-modal__empty{margin:0;padding:20px 8px;text-align:center;font-size:13px;color:var(--text-secondary, #94a3b8);line-height:1.45}.map-places-modal__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.map-places-modal__row{display:flex;align-items:stretch;gap:8px}.map-places-modal__row-main{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border-color, #334155);border-radius:10px;background:var(--input-bg, var(--bg-tertiary, #334155));color:var(--text-primary, #f8fafc);font-size:14px;cursor:pointer;text-align:left;transition:border-color .15s ease,background-color .15s ease}.map-places-modal__row-main:hover:not(:disabled){border-color:#3390ec73;background:var(--sidebar-hover, #334155)}.map-places-modal__row-main:disabled{cursor:default;opacity:.85}.map-places-modal__row-main--static{cursor:default;pointer-events:none}.map-places-modal__row-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.map-places-modal__row-meta{flex-shrink:0;font-size:12px;color:var(--text-secondary, #94a3b8)}.map-places-modal__row-delete{flex-shrink:0;width:42px;border:1px solid var(--border-color, #334155);border-radius:10px;background:transparent;color:#f87171;font-size:20px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.map-places-modal__row-delete:hover:not(:disabled){background:#f871711f}.map-places-modal__row-delete:disabled{opacity:.4;cursor:not-allowed}.map-places-modal__caption{margin:0 0 6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary, #94a3b8)}.leaflet-tooltip.map-place-zone-label{background:#064e3be6;color:#ecfdf5;border:1px solid rgba(74,222,128,.65);border-radius:8px;padding:6px 10px;font-size:12px;font-weight:600;max-width:min(220px,48vw);white-space:normal;text-align:center;line-height:1.3;box-shadow:0 2px 12px #0000004d}.leaflet-tooltip.map-place-zone-label:before{display:none}.map-user-marker-wrap{background:transparent!important;border:none!important}.map-user-marker{display:flex;flex-direction:column;align-items:center;gap:3px}.map-user-marker__img{display:block;box-sizing:border-box;border-radius:50%;object-fit:cover;object-position:center;border:2px solid #fff;box-shadow:0 1px 5px #00000059;flex-shrink:0;aspect-ratio:1}.leaflet-container .map-user-marker__img{max-width:none;max-height:none}.map-user-marker__letter{display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:13px;font-weight:600;color:#0f172a;background:#e2e8f0;border:2px solid #fff;box-shadow:0 1px 5px #00000040;flex-shrink:0}.map-user-marker__dot{width:11px;height:11px;border-radius:50%;border:2px solid #fff;box-shadow:0 1px 4px #0000004d;flex-shrink:0}.call-window-overlay{position:fixed;top:0;right:0;bottom:0;left:0;min-height:100dvh;min-height:100svh;min-height:-webkit-fill-available;background:#000;z-index:23000;display:flex;align-items:center;justify-content:center;overflow:hidden}.call-window{width:100%;max-width:100%;flex:1;min-height:0;height:100%;max-height:100%;display:flex;flex-direction:column;overflow:hidden;position:relative;background:#000}.call-screen-header{position:absolute;top:0;left:0;right:0;z-index:10000;padding:calc(12px + env(safe-area-inset-top,0px)) 20px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;pointer-events:none;transition:opacity .25s ease}.call-screen-header--hidden{opacity:0}.call-screen-header__name-wrap{width:100%;display:flex;justify-content:center}.call-screen-header__name-pill{background:#0009;padding:10px 14px;border-radius:8px;color:#fff;font-size:18px;font-weight:600;max-width:90%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.call-screen-header__name-pill--screen-sharing{display:flex;align-items:center;justify-content:center;gap:10px}.screen-share-pulse-dot{width:10px;height:10px;border-radius:50%;background:#f97316;box-shadow:0 0 #f9731680;animation:screenSharePulse 1.2s ease-in-out infinite;flex-shrink:0}@keyframes screenSharePulse{0%{transform:scale(1);box-shadow:0 0 #f9731673;opacity:1}50%{transform:scale(1.35);box-shadow:0 0 0 10px #f9731600;opacity:.85}to{transform:scale(1);box-shadow:0 0 #f9731673;opacity:1}}.call-screen-header__duration-pill{position:absolute;top:calc(12px + env(safe-area-inset-top,0px));right:20px;background:#0009;padding:6px 10px;border-radius:6px;color:#fff;font-size:12px;font-weight:600;font-variant-numeric:tabular-nums;z-index:10001}.call-screen-header__status{margin:0;font-size:12px;color:#fffc}.call-video-container{flex:1;min-height:0;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0f172a}.remote-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;background:#000;z-index:1}.remote-video--mirror{transform:scaleX(-1)}.call-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff;background:#0f172aeb;padding:24px;text-align:center}.call-preview-overlay__avatar{width:min(50vmin,200px);height:min(50vmin,200px);aspect-ratio:1 / 1;flex-shrink:0;border-radius:50%;border:3px solid rgba(255,255,255,.35);overflow:hidden;display:flex;align-items:center;justify-content:center;background:#ffffff14;font-size:clamp(2rem,10vmin,3.5rem);font-weight:700}.call-preview-overlay__avatar img{width:100%;height:100%;object-fit:cover}.call-preview-overlay__name{font-size:20px;font-weight:700}.call-preview-overlay__title{margin:0;font-size:16px;opacity:.95}.call-preview-overlay__subtitle{margin:0;font-size:14px;opacity:.75}.call-preview-overlay__spinner{width:40px;height:40px;margin-top:8px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:call-spin .9s linear infinite}@keyframes call-spin{to{transform:rotate(360deg)}}.call-pip{position:absolute;z-index:10001;border-radius:10px;overflow:hidden;border:2px solid #fff;background:#000;box-shadow:0 2px 8px #00000080;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.call-pip--dragging{cursor:grabbing}.call-pip__video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.call-pip__video--mirror{transform:scaleX(-1)}.call-pip__placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:8px;background:#0f172af2;text-align:center}.call-pip__placeholder-avatar{width:50px;height:50px;border-radius:25px;overflow:hidden;background:#667eea;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:#fff}.call-pip__placeholder-avatar img{width:100%;height:100%;object-fit:cover}.call-pip__placeholder-name{font-size:14px;font-weight:600;color:#fff;max-width:100%;overflow:hidden;text-overflow:ellipsis}.call-pip__placeholder-hint{font-size:10px;color:#fffc}.call-remote-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;z-index:8;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#0f172a;color:#fff}.call-remote-placeholder__avatar{width:min(40vmin,200px);height:min(40vmin,200px);aspect-ratio:1 / 1;flex-shrink:0;border-radius:50%;overflow:hidden;background:var(--bg-tertiary, #334155);display:flex;align-items:center;justify-content:center;font-size:clamp(2.5rem,12vmin,4rem);font-weight:700}.call-remote-placeholder__avatar img{width:100%;height:100%;object-fit:cover}.call-remote-placeholder__name{font-size:1.2rem;font-weight:600}.call-remote-placeholder__hint{font-size:.9rem;color:#ffffffa6}.audio-call-screen{display:flex;flex-direction:column;align-items:center;gap:20px;color:#fff;padding:24px}.audio-call-avatar{width:min(48vmin,220px);height:min(48vmin,220px);aspect-ratio:1 / 1;flex-shrink:0;border-radius:50%;background:linear-gradient(145deg,var(--primary-color, #3390ec),#1e40af);display:flex;align-items:center;justify-content:center;font-size:80px;overflow:hidden}.audio-call-avatar-img{width:100%;height:100%;object-fit:cover}.audio-call-avatar-fallback{font-size:clamp(3rem,18vmin,5rem);font-weight:700;color:#fff}.audio-call-name{font-size:1.35rem;font-weight:700}.audio-call-sub{font-size:.95rem;color:#ffffffb3}.call-control-dock{position:absolute;bottom:32px;left:0;right:0;padding:0 20px calc(8px + env(safe-area-inset-bottom,0px));z-index:10002;display:flex;justify-content:center;pointer-events:none;transition:opacity .25s ease}.call-control-dock--hidden{opacity:0;pointer-events:none}.call-control-dock__inner{pointer-events:auto;background:#00000040;border-radius:24px;padding:16px 20px;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-around;align-items:center;gap:8px;width:100%;max-width:520px}.call-control-item{flex:1;min-width:56px;max-width:80px;display:flex;flex-direction:column;align-items:center;gap:8px}.call-control-icon{width:56px;height:56px;border-radius:28px;border:none;background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,transform .1s ease;padding:0}.call-control-icon:hover{transform:scale(1.04)}.call-control-icon:active{transform:scale(.98)}.call-control-icon:disabled{opacity:.45;cursor:not-allowed;transform:none}.call-control-icon:disabled:hover{transform:none}.call-control-icon--active{background:#22c55eb3}.call-control-icon--danger{background:#f44336f2}.call-control-icon--danger:hover{background:#e53935}.call-control-icon__phone-svg{color:#fff}.call-control-label{color:#fff;font-size:9px;font-weight:500;text-align:center;line-height:11px;text-transform:lowercase;padding:0 4px;max-width:72px}.call-control-label--no-transform{text-transform:none;white-space:normal;line-height:12px;max-width:92px}.call-control-item--settings{position:relative}.call-settings-menu{box-sizing:border-box;min-width:200px;padding:6px 0;background:#0f172af5;border-radius:12px;border:1px solid rgba(255,255,255,.18);box-shadow:0 10px 32px #0000008c}.call-settings-menu__item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border:none;background:none;color:#f1f5f9;font-size:15px;font-weight:500;text-align:left;cursor:pointer;transition:background .12s ease}.call-settings-menu__item:hover,.call-settings-menu__item:focus-visible{background:#ffffff14;outline:none}.call-settings-menu__item:disabled{opacity:.4;cursor:not-allowed}.call-settings-menu__check{flex-shrink:0;width:1.25em;text-align:center;font-size:16px;color:#4ade80}.call-settings-menu__item-content{display:flex;flex-direction:column;gap:2px}.call-settings-menu__hint{font-size:11px;font-weight:400;color:#f1f5f973;line-height:1.2}.call-video-mirror-btn{position:absolute;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;border-radius:50%;background:#00000040;color:#fff;transition:background .15s ease,transform .1s ease;padding:0}.call-video-mirror-btn:hover{background:#00000073}.call-video-mirror-btn:active{transform:scale(.96)}.call-video-mirror-btn--remote{top:calc(110px + env(safe-area-inset-top,0px));right:12px;width:32px;height:32px;z-index:10003}.call-video-mirror-btn--pip{top:4px;right:4px;width:24px;height:24px;z-index:2}.incoming-call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:23000;display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.incoming-call-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0f172a,#020617 45%,#0f172a);opacity:.98}.incoming-call-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:420px;width:100%;padding:24px 20px}.incoming-call-avatar-wrap{width:min(56vw,220px);height:min(56vw,220px);border-radius:50%;overflow:hidden;background:linear-gradient(145deg,var(--bg-tertiary, #334155),var(--bg-secondary, #1e293b));display:flex;align-items:center;justify-content:center;margin-bottom:20px;box-shadow:0 12px 40px #00000073;animation:incoming-pulse 2.2s ease-in-out infinite}@keyframes incoming-pulse{0%,to{box-shadow:0 12px 40px #00000073}50%{box-shadow:0 12px 48px #3390ec40}}.incoming-call-avatar-img{width:100%;height:100%;object-fit:cover}.incoming-call-avatar-fallback{font-size:clamp(3rem,18vw,5rem);font-weight:700;color:var(--text-primary, #f8fafc)}.incoming-call-name{font-size:1.35rem;font-weight:600;color:var(--text-primary, #f8fafc);margin:0 0 8px}.incoming-call-type{font-size:.95rem;color:var(--text-secondary, #94a3b8);margin:0 0 4px}.incoming-call-sub{font-size:.85rem;color:var(--text-muted, #64748b);margin:0 0 36px}.incoming-call-actions{display:flex;flex-direction:row;align-items:flex-end;justify-content:center;gap:clamp(32px,12vw,56px)}.incoming-call-btn{display:flex;flex-direction:column;align-items:center;gap:10px;border:none;background:none;cursor:pointer;padding:8px;color:#fff;-webkit-tap-highlight-color:transparent}.incoming-call-btn__icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}.incoming-call-btn:active .incoming-call-btn__icon{transform:scale(.94)}.incoming-call-btn--reject .incoming-call-btn__icon{background:#dc2626;box-shadow:0 4px 16px #dc262673}.incoming-call-btn--reject .incoming-call-btn__icon--phone{transform:rotate(135deg)}.incoming-call-btn--accept .incoming-call-btn__icon{background:#16a34a;box-shadow:0 4px 16px #16a34a73}.incoming-call-btn__label{font-size:.75rem;font-weight:600;color:var(--text-secondary, #cbd5e1)}@media (max-width: 380px){.incoming-call-btn__icon{width:64px;height:64px}}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;display:flex;align-items:stretch;justify-content:flex-start;z-index:23000;pointer-events:none}.profile-overlay--open{pointer-events:auto}.profile-modal{width:450px;min-width:450px;max-width:450px;height:100%;display:flex;flex-direction:column;background:var(--bg-secondary, #1e293b);border-right:1px solid var(--border-color, #334155);overflow-y:auto;overflow-x:hidden;scrollbar-width:none;position:relative;transform:translate3d(-100%,0,0);transition:transform .3s ease-in-out}.profile-modal::-webkit-scrollbar{display:none}.profile-confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:inherit;animation:fadeIn .18s ease}.profile-confirm-modal{background:var(--bg-secondary, #1e293b);border-radius:16px;padding:28px 24px 20px;max-width:300px;width:90%;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 8px 32px #00000059;animation:slideUp .2s cubic-bezier(.22,.78,.2,1)}.profile-confirm-icon{font-size:36px;line-height:1;display:flex;align-items:center;justify-content:center}.profile-confirm-geo-icon{width:40px;height:40px;display:block;color:var(--accent-color, #3390ec)}.profile-confirm-geo-icon path{fill:currentColor}:root[data-theme=dark] .profile-confirm-geo-icon{color:#fff}.profile-confirm-text{font-size:15px;color:var(--text-primary, #f8fafc);text-align:center;line-height:1.5;margin:0}.profile-confirm-actions{display:flex;gap:10px;width:100%;margin-top:4px}.profile-confirm-btn{flex:1;padding:10px 0;border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .15s ease,transform .1s ease}.profile-confirm-btn:active{transform:scale(.97);opacity:.85}.profile-confirm-btn--cancel{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f8fafc)}.profile-confirm-btn--danger{background:#ef4444;color:#fff}.profile-confirm-btn--cancel:hover{background:var(--sidebar-hover, #3f546a)}.profile-confirm-btn--danger:hover{background:#dc2626}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-modal--open{transform:translateZ(0)}.profile-modal--closing{transform:translate3d(-100%,0,0)}.profile-header{position:absolute;top:20px;right:20px;z-index:20;padding:0;border:none;display:flex;align-items:center;gap:6px}.profile-theme-btn{position:relative;width:38px;height:38px;background:transparent!important;outline:none;-webkit-tap-highlight-color:transparent}.profile-theme-btn:hover,.profile-theme-btn:focus,.profile-theme-btn:active{background:transparent!important}.profile-theme-icon{font-size:18px;line-height:1;transition:opacity .25s ease;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.profile-theme-icon--sun{filter:saturate(2) brightness(1.1)}.close-btn{background:transparent;border:none;font-size:22px;cursor:pointer;color:var(--text-secondary, #94a3b8);width:38px;height:38px;border-radius:19px;display:inline-flex;align-items:center;justify-content:center;transition:background-color .2s ease,color .2s ease}.close-btn:hover{background:var(--sidebar-hover, #334155);color:var(--text-primary, #f8fafc)}.profile-content{display:flex;flex-direction:column;gap:16px;padding:16px;flex:1}.profile-top{display:flex;align-items:center;justify-content:flex-start;width:100%}.avatar-section{display:flex;flex-direction:column;align-items:flex-start;gap:8px;width:100%}.avatar-section-top{display:flex;align-items:flex-start;gap:16px}.avatar-preview{position:relative;width:88px;height:88px;border-radius:50%;cursor:pointer;overflow:hidden;background:var(--bg-primary, #0f172a);margin-bottom:15px}.avatar-preview img{position:absolute;top:0;right:0;bottom:0;left:0;display:block;width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.08);transform-origin:center}.avatar-placeholder{width:100%;height:100%;background:var(--accent-color, #3390ec);color:#fff;display:flex;align-items:center;justify-content:center;font-size:34px;font-weight:700}.avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.avatar-preview:hover .avatar-overlay{opacity:1}.profile-username-row{display:flex;align-items:center;gap:8px;min-height:42px;width:100%;padding-bottom:15px;margin-bottom:6px;border-bottom:1px solid var(--border-color, #334155)}.profile-username-row input{flex:1;width:100%;height:42px;min-height:42px;margin:0;box-sizing:border-box;padding:10px 12px;border:1px solid var(--input-border, #334155);border-radius:10px;background:var(--input-bg, #334155);color:var(--text-primary, #f8fafc);font-size:inherit;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.profile-username-row input:hover:not(:disabled){border-color:var(--border-light, #475569)}.profile-username-row input:focus,.profile-username-row input:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}.profile-username-row input:-webkit-autofill,.profile-username-row input:-webkit-autofill:hover,.profile-username-row input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;-webkit-text-fill-color:var(--text-primary, #f8fafc)!important;caret-color:var(--text-primary, #f8fafc)}.profile-username-row input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset,0 0 0 2px rgba(51,144,236,.3)!important;border-color:var(--accent-color, #3390ec)}.profile-username-text{flex:1;height:42px;min-height:42px;display:flex;align-items:center;padding:10px 12px;border:1px solid var(--input-border, #334155);border-radius:10px;background:var(--input-bg, #334155);color:var(--text-primary, #f8fafc);box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-username-edit-btn{width:34px;height:34px;border-radius:999px;border:1px solid var(--border-color, #334155);background:var(--bg-primary, #0f172a);color:var(--text-primary, #f8fafc);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px}.profile-username-edit-btn:disabled{opacity:.55;cursor:not-allowed}.profile-menu{border:none;border-radius:0;overflow:visible}.profile-menu-row{min-height:46px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:none;color:var(--text-primary, #f8fafc);background:transparent}.profile-menu-row:disabled{opacity:.55;cursor:not-allowed}.profile-menu-main{display:inline-flex;align-items:center;gap:12px}.profile-menu-side{display:inline-flex;align-items:center;gap:8px}.profile-menu-icon{width:18px;height:18px;color:var(--text-secondary, #94a3b8);flex-shrink:0}.profile-menu-row:last-child{border-bottom:none}.profile-menu-row--button{width:100%;border:none;cursor:pointer;text-align:left}.profile-menu-note{font-size:12px;color:var(--text-secondary, #94a3b8)}.profile-select{background:var(--input-bg, #334155);color:var(--text-primary, #f8fafc);border:1px solid var(--input-border, #334155);border-radius:8px;font-size:12px;padding:6px 8px;font-family:inherit;outline:none;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.profile-select:hover{border-color:var(--border-light, #475569)}.profile-select:focus,.profile-select:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}.profile-wallpaper-preview{width:36px;height:36px;border-radius:10px;border:1px solid var(--border-color, #334155)}.profile-status-chip{border-radius:999px;padding:4px 10px;font-size:12px;color:#10b981;background:#10b9811f}.profile-status-chip--offline{color:#f59e0b;background:#f59e0b26}.profile-toggle{width:44px;height:26px;border-radius:999px;border:1px solid var(--border-color, #334155);background:#94a3b833;display:inline-flex;align-items:center;padding:2px;cursor:pointer}.profile-toggle:disabled{opacity:.45;cursor:not-allowed}.profile-toggle__thumb{width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s ease}.profile-toggle--on{background:var(--primary-color, #3390ec);border-color:var(--primary-color, #3390ec)}.profile-toggle--on .profile-toggle__thumb{transform:translate(18px)}.profile-geo-audience{margin:4px 0 8px;padding:12px;border-radius:10px;background:transparent;border:1px solid rgba(148,163,184,.2)}.profile-geo-audience__title{font-size:13px;font-weight:600;color:var(--text-primary, #e2e8f0);margin:0 0 10px}.profile-geo-audience__loading,.profile-geo-audience__empty{margin:0;font-size:12px;color:var(--text-secondary, #94a3b8)}.profile-geo-switch-group{display:inline-flex;align-items:center;gap:14px}.profile-geo-info-icon-btn{padding:2px;margin:0;border:none;border-radius:4px;background:transparent;color:var(--text-secondary, #94a3b8);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;line-height:0;transition:color .15s ease,opacity .15s ease}.profile-geo-info-icon-btn:hover:not(:disabled){color:var(--text-primary, #f8fafc)}.profile-geo-info-icon{width:18px;height:18px;display:block}.profile-geo-info-icon path,.profile-geo-info-icon circle{fill:currentColor}.profile-geo-info-icon-btn:disabled{opacity:.45;cursor:not-allowed}.profile-geo-scope{display:flex;flex-direction:row;align-items:stretch;gap:8px;margin-bottom:14px}.profile-geo-scope__card{display:flex;align-items:center;justify-content:center;gap:8px;flex:1 1 0;min-width:0;padding:10px 8px;border-radius:12px;border:1px solid rgba(148,163,184,.22);background:#0f172a59;color:inherit;text-align:left;cursor:pointer;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.profile-geo-scope__card:hover:not(:disabled){border-color:#3390ec73;background:#0f172a8c}.profile-geo-scope__card:disabled{opacity:.55;cursor:not-allowed}.profile-geo-scope__card--active{border-color:var(--primary-color, #3390ec);background:#3390ec1f;box-shadow:0 0 0 1px #3390ec33}.profile-geo-scope__card-dot{width:16px;height:16px;border-radius:50%;border:2px solid rgba(148,163,184,.55);flex-shrink:0;position:relative}.profile-geo-scope__card--active .profile-geo-scope__card-dot{border-color:var(--primary-color, #3390ec)}.profile-geo-scope__card--active .profile-geo-scope__card-dot:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:50%;background:var(--primary-color, #3390ec)}.profile-geo-scope__card-title{font-size:13px;font-weight:600;color:var(--text-primary, #e2e8f0);line-height:1.2;white-space:nowrap}.profile-geo-allowed{padding-top:4px;border-top:1px solid rgba(148,163,184,.12)}.profile-geo-accordion__trigger{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:8px 4px 8px 0;margin:0;border:none;border-radius:8px;background:transparent;color:inherit;text-align:left;cursor:pointer;transition:background-color .15s ease}.profile-geo-accordion__trigger:hover{background:#94a3b812}.profile-geo-accordion__trigger-text{flex:1;min-width:0}.profile-geo-allowed__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary, #94a3b8)}.profile-geo-allowed__label--trigger{margin-bottom:0;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:8px;min-width:0}.profile-geo-accordion__hint{font-size:12px;font-weight:500;text-transform:none;letter-spacing:normal;color:var(--text-secondary, #94a3b8);white-space:nowrap;flex-shrink:0}.profile-geo-accordion__chevron{flex-shrink:0;color:var(--text-secondary, #94a3b8);transition:transform .22s ease}.profile-geo-accordion__chevron--open{transform:rotate(180deg)}.profile-geo-accordion__panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .22s ease}.profile-geo-accordion__panel--open{grid-template-rows:1fr}.profile-geo-accordion__panel-inner{overflow:hidden;min-height:0}.profile-geo-accordion__panel--open .profile-geo-accordion__panel-inner{padding-bottom:6px}.profile-geo-allowed__none{margin:0;font-size:12px;color:var(--text-secondary, #94a3b8);line-height:1.4}.profile-geo-allowed__chips{display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-start;gap:10px;padding-top:2px;overflow-x:visible}.profile-geo-allowed__chip{display:inline-flex;align-items:center;gap:6px;max-width:100%}.profile-geo-allowed__chip-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid rgba(148,163,184,.25)}.profile-geo-allowed__chip-avatar--letter{display:inline-flex;align-items:center;justify-content:center;background:var(--accent-color, #3390ec);color:#fff;font-size:12px;font-weight:700}.profile-geo-allowed__chip-name{font-size:12px;color:var(--text-primary, #e2e8f0);white-space:normal;word-break:break-word;max-width:100%}.profile-menu-icon--geo{width:20px;height:20px;flex-shrink:0;color:var(--text-secondary, #94a3b8)}.profile-menu-icon--geo path{fill:currentColor}.profile-geo-pick-row .profile-geo-pick-row__check{margin-left:auto;width:28px;height:28px;border-radius:8px;border:1.5px solid rgba(148,163,184,.4);display:flex;align-items:center;justify-content:center;color:transparent;flex-shrink:0;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.profile-geo-pick-row.active .profile-geo-pick-row__check{background:var(--accent-color, #3390ec);border-color:transparent;color:#fff}.profile-inner-modal--geo-pick .profile-inner-modal__content.profile-geo-pick-modal{max-height:min(85vh,540px);display:flex;flex-direction:column;overflow:hidden;padding:0}.profile-geo-pick-modal .profile-inner-modal__header{flex-shrink:0}.profile-geo-pick-modal__listwrap{flex:1;min-height:0;border-top:1px solid var(--border-color, #334155);border-bottom:1px solid var(--border-color, #334155);background:#0f172a40}.profile-geo-pick-modal__scroll{max-height:min(42vh,320px);overflow-y:auto;-webkit-overflow-scrolling:touch}.profile-geo-pick-modal__empty{padding:24px 16px;text-align:center;font-size:13px;color:var(--text-secondary, #94a3b8)}.profile-geo-pick-modal__footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 14px;flex-shrink:0}.profile-geo-pick-modal__btn{min-height:40px;padding:0 18px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:1px solid transparent}.profile-geo-pick-modal__btn:disabled{opacity:.55;cursor:not-allowed}.profile-geo-pick-modal__btn--secondary{background:transparent;border-color:var(--border-color, #334155);color:var(--text-primary, #f8fafc)}.profile-geo-pick-modal__btn--secondary:hover:not(:disabled){background:#94a3b814}.profile-geo-pick-modal__btn--primary{background:var(--accent-color, #3390ec);color:#fff}.profile-geo-pick-modal__btn--primary:hover:not(:disabled){filter:brightness(1.06)}.profile-inner-modal--geo-info .profile-inner-modal__content.profile-geo-info-modal{max-width:420px}.profile-geo-info-modal__header{align-items:flex-start}.profile-geo-info-modal__body{padding:14px 16px 16px}.profile-geo-info-modal__lead{margin:0 0 14px;font-size:13px;line-height:1.5;color:var(--text-secondary, #94a3b8)}.profile-geo-info-modal__list{margin:0 0 16px;padding-left:18px;display:flex;flex-direction:column;gap:12px;font-size:13px;line-height:1.45;color:var(--text-primary, #e2e8f0)}.profile-geo-info-modal__list strong{color:var(--text-primary, #f1f5f9)}.profile-geo-info-modal__ok{width:100%;min-height:44px;border:none;border-radius:10px;background:var(--accent-color, #3390ec);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.profile-geo-info-modal__ok:hover{filter:brightness(1.06)}.profile-app-update-section{padding-top:6px;border-top:1px solid var(--border-color, #334155);display:flex;flex-direction:column;margin-top:auto}.profile-app-update-hint{margin:15px 0;color:var(--text-secondary, #94a3b8);font-size:12px;line-height:1.35;text-align:center}.profile-app-update-btn{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border-color, #334155);background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9);font-size:14px;cursor:pointer;margin-top:8px}.profile-app-update-btn:disabled{opacity:.65;cursor:not-allowed}.profile-footer{display:flex;flex-direction:column;gap:10px;padding:14px 16px 18px;border-top:1px solid var(--border-color, #334155);align-items:center;justify-content:center}.profile-logout-btn{width:100%;min-height:42px;border:none;border-radius:12px;background:#ef4444;color:#fff;font-size:14px;font-weight:600;text-align:center;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:10px 14px}.profile-logout-btn:hover{background:#dc2626}.profile-version-btn{margin:0;border:none;background:transparent;color:var(--text-secondary, #94a3b8);font-size:12px;cursor:pointer;text-align:center}.save-btn{padding:10px 14px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;background:var(--accent-color, #3390ec);color:#fff}.profile-inner-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;z-index:23500}.profile-inner-modal__content{width:min(460px,100%);max-height:70vh;overflow:auto;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:14px}.profile-inner-modal__header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-color, #334155)}.profile-inner-modal__header h3{margin:0;font-size:16px}.profile-inner-modal__header button{border:none;background:transparent;color:var(--text-primary, #f8fafc);font-size:18px;cursor:pointer}.profile-inner-modal__body{padding:12px;display:flex;flex-direction:column;gap:10px}.profile-user-row{width:100%;border:1px solid var(--border-color, #334155);border-radius:10px;background:transparent;color:var(--text-primary, #f8fafc);padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .15s ease,background-color .15s ease}.profile-user-row__avatar,.profile-user-row__avatar-img,.profile-user-row__avatar-fallback{width:32px;height:32px;border-radius:50%;flex:0 0 32px}.profile-user-row__avatar{display:inline-flex;align-items:center;justify-content:center;overflow:hidden;background:var(--accent-color, #3390ec);color:#fff}.profile-user-row__avatar-img{display:block;object-fit:cover}.profile-user-row__avatar-fallback{display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;line-height:1}.profile-user-row__content{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:12px}.profile-user-row__meta{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0}.profile-user-row__name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-user-row__badges{display:flex;align-items:center;gap:6px;min-width:0;flex-wrap:nowrap}.profile-user-row__presence{flex-shrink:0;margin-left:auto;text-align:right;min-width:0}.profile-user-row:hover{background:var(--sidebar-hover, #334155);border-color:var(--border-light, #475569)}.profile-dev-input{width:100%;padding:10px 12px;border:1px solid var(--input-border, #334155);border-radius:10px;background:var(--input-bg, #334155);color:var(--text-primary, #f8fafc);font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.profile-dev-input:hover:not(:disabled){border-color:var(--border-light, #475569)}.profile-dev-input:focus,.profile-dev-input:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}.profile-dev-input:-webkit-autofill,.profile-dev-input:-webkit-autofill:hover,.profile-dev-input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px var(--input-bg, #334155) inset!important;-webkit-text-fill-color:var(--text-primary, #f8fafc)!important;caret-color:var(--text-primary, #f8fafc)}.profile-option-row{width:auto;flex:1 1 0;border:1px solid var(--border-color, #334155);border-radius:10px;background:transparent;color:var(--text-primary, #f8fafc);padding:10px 12px;text-align:center;cursor:pointer}.profile-inner-modal__body>.profile-option-row{display:inline-flex;align-items:center;justify-content:center}.profile-option-row--active{border-color:var(--primary-color, #3390ec);background:#3390ec24}.profile-options-row{display:flex;align-items:stretch;gap:8px}.profile-media-toggle-row{width:100%;min-height:46px;padding:8px 2px;display:flex;align-items:center;justify-content:space-between;gap:10px}.profile-map-tile-label{display:block;margin-bottom:6px;font-size:13px;color:var(--text-secondary, #94a3b8)}.profile-map-tile-save-hint{margin:0 0 8px;font-size:12px;line-height:1.4;color:var(--text-secondary, #94a3b8)}.profile-map-tile-select{width:100%;box-sizing:border-box;margin-bottom:14px;padding:10px 12px;border-radius:10px;border:1px solid var(--input-border, #334155);background:var(--input-bg, #334155);color:var(--text-primary, #f8fafc);font-size:14px;font-family:inherit;cursor:pointer;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.profile-map-tile-select:hover{border-color:var(--border-light, #475569)}.profile-map-tile-select:focus,.profile-map-tile-select:focus-visible{border-color:var(--accent-color, #3390ec);box-shadow:0 0 0 2px #3390ec4d}@media (max-width: 599px){.profile-modal{width:100vw;min-width:100vw;max-width:100vw;border-right:none}}.wallpaper-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:23600;background:#0000009e;display:flex;align-items:center;justify-content:center;padding:16px}.wallpaper-modal{width:min(980px,100%);max-height:min(92vh,860px);overflow:auto;border-radius:20px;border:1px solid var(--border-color, #334155);background:var(--bg-secondary, #1e293b);color:var(--text-primary, #f8fafc)}.wallpaper-modal__header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border-color, #334155)}.wallpaper-modal__header h3{margin:0;font-size:18px}.wallpaper-modal__header button{border:none;background:transparent;color:var(--text-primary, #f8fafc);font-size:20px;cursor:pointer}.wallpaper-modal__preview{height:clamp(240px,46vh,420px);border-bottom:1px solid var(--border-color, #334155);position:relative;background-size:cover;background-position:center}.wallpaper-modal__preview:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff3;pointer-events:none}.wallpaper-modal__preview-chat{position:absolute;left:16px;right:16px;top:16px;bottom:16px;display:flex;flex-direction:column;justify-content:center;gap:12px;z-index:1}.wallpaper-modal__bubble{display:inline-flex;align-self:flex-start;max-width:72%;padding:10px 14px;border-radius:16px;background:#ffffffe0;color:#111827;font-size:14px}.wallpaper-modal__bubble--own{align-self:flex-end;background:#3390eceb;color:#fff}.wallpaper-modal__carousel{display:flex;gap:12px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;padding:16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.wallpaper-modal__carousel::-webkit-scrollbar{width:0;height:0;display:none}.wallpaper-card{flex:0 0 110px;scroll-snap-align:start;border:1px solid var(--border-color, #334155);border-radius:12px;background:transparent;color:var(--text-primary, #f8fafc);cursor:pointer;padding:8px;display:flex;flex-direction:column;gap:8px}.wallpaper-card.is-selected{border-color:var(--primary-color, #3390ec);box-shadow:0 0 0 1px var(--primary-color, #3390ec) inset}.wallpaper-card__swatch{width:100%;height:116px;border-radius:8px;border:1px solid rgba(255,255,255,.08);background-size:cover;background-position:center}.wallpaper-card__label{font-size:12px}.wallpaper-modal__actions{display:flex;gap:10px;justify-content:flex-end;padding:14px 16px 16px}.wallpaper-modal__btn{border-radius:10px;border:1px solid var(--border-color, #334155);background:transparent;color:var(--text-primary, #f8fafc);padding:10px 14px;cursor:pointer}.wallpaper-modal__btn--primary{border-color:var(--primary-color, #3390ec);background:var(--primary-color, #3390ec);color:#fff}@media (max-width: 599px){.wallpaper-modal{width:100%;max-height:100%;border-radius:14px}.wallpaper-card{flex-basis:96px}.wallpaper-card__swatch{height:104px}}.chat-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;display:flex;flex-direction:row;align-items:stretch;width:100%;height:100%;max-height:100vh;max-height:100dvh;overflow:hidden;background:var(--bg-secondary, #1e293b);box-sizing:border-box;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);transition:background-color .3s ease}.chat-container>:not(.chat-sidebar){flex:1 1 0%;min-width:0;min-height:0}.chat-container>.chat-window{display:flex;flex-direction:column}.chat-container>.chat-slide-wrapper{display:flex;flex-direction:column;flex:1 1 0%;min-width:0;min-height:0}.chat-placeholder{flex:1;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary, #0f172a);transition:background-color .3s ease;overflow:hidden}.chat-placeholder h2{color:var(--text-secondary);font-weight:300;transition:color .3s ease}@media (max-width: 699px){.chat-container{flex-wrap:nowrap}.chat-placeholder{display:none}.chat-slide-wrapper{position:absolute!important;top:0!important;right:0!important;bottom:0!important;left:0!important;z-index:21999;flex:none!important;animation:mobile-chat-slide-in .3s ease-in-out}@keyframes mobile-chat-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-slide-wrapper--exiting{transform:translate(100%);transition:transform .3s ease-in-out;animation:none;pointer-events:none}}@media (min-width: 700px){.chat-container{flex-direction:row;flex-wrap:nowrap;align-items:stretch}.chat-sidebar{position:relative!important;width:300px!important;max-width:300px!important;min-width:300px!important;flex:0 0 300px!important;transform:none!important;flex-shrink:0}.chat-window{flex:1 1 0%;min-width:0;width:auto!important;max-width:none!important}}.push-permission-bar{position:fixed;left:0;right:0;bottom:0;z-index:200;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));background:var(--sidebar-bg, #1e293b);border-top:1px solid var(--border-color, #334155);box-shadow:0 -4px 20px #00000040}.push-permission-bar__text{flex:1 1 200px;font-size:14px;color:var(--text-secondary, #cbd5e1);line-height:1.35}.push-permission-bar__actions{display:flex;gap:8px;flex-shrink:0}.push-permission-bar__btn{padding:10px 16px;border-radius:10px;border:1px solid var(--border-color, #334155);background:transparent;color:var(--text-primary, #f8fafc);font-size:14px;font-weight:500;cursor:pointer;-webkit-tap-highlight-color:transparent}.push-permission-bar__btn--primary{border-color:var(--primary-color, #3390ec);background:var(--primary-color, #3390ec);color:#fff}.chat-container>.app-fullscreen-brand-overlay{z-index:23000}.offline-banner-row{flex-shrink:0;display:flex;justify-content:center;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border-color, #334155);background:var(--bg-primary, #0f172a)}.offline-banner-chip{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;margin:0 auto;padding:6px 12px;max-width:min(100%,440px);background:#3390ec24;border-radius:12px;font-size:12px;font-weight:500;color:var(--primary-color, #3390ec);text-align:center;line-height:1.35;transition:background-color .3s ease,color .3s ease}.offline-banner-chip__line{display:block}.offline-banner-chip__line--sub{font-size:11px;font-weight:500;color:var(--primary-color, #3390ec);opacity:.88}*{margin:0;padding:0;box-sizing:border-box}:root[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-chat: #f9fafb;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-light: #cbd5e1;--primary-color: #3390EC;--primary-dark: #2563eb;--accent-color: #3390EC;--accent-hover: #2563eb;--sidebar-bg: #ffffff;--sidebar-hover: #f9f9f9;--sidebar-active: #e3e8ff;--message-bg: #ffffff;--message-own-bg: #3390EC;--message-other-bg: #ffffff;--message-own-text: #ffffff;--message-other-text: #0f172a;--input-bg: #ffffff;--input-border: #e2e8f0;--status-online: #10b981;--message-selected-bubble-bg: #cbd5e1;--message-selected-bubble-text: #0f172a}:root[data-theme=dark],:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-chat: #1a1a1a;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-light: #475569;--primary-color: #3390EC;--primary-dark: #2563eb;--accent-color: #3390EC;--accent-hover: #2563eb;--sidebar-bg: #1e293b;--sidebar-hover: #334155;--sidebar-active: #3d5a80;--message-bg: #334155;--message-own-bg: #2563eb;--message-other-bg: #334155;--message-own-text: #ffffff;--message-other-text: #f8fafc;--input-bg: #334155;--input-border: #334155;--status-online: #10b981;--message-selected-bubble-bg: #64748b;--message-selected-bubble-text: #f8fafc}html{background-color:var(--bg-primary);color-scheme:dark light;height:100%;height:-webkit-fill-available}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;margin:0;min-height:100%;min-height:100vh;min-height:100dvh;min-height:100svh;min-height:-webkit-fill-available;overscroll-behavior:none}body:has(.chat-container){overflow:hidden;height:100vh;height:100dvh}#root{width:100%;min-height:100%;min-height:100vh;min-height:100dvh;min-height:100svh;min-height:-webkit-fill-available;display:flex;flex-direction:column;background:var(--bg-primary);box-sizing:border-box;padding-bottom:env(safe-area-inset-bottom,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px)}@media (display-mode: standalone){html,body,#root{background-color:var(--bg-primary)}html{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar{width:0;height:0;display:none}body{scrollbar-width:none;-ms-overflow-style:none}body::-webkit-scrollbar{width:0;height:0;display:none}#root{scrollbar-width:none;-ms-overflow-style:none}#root::-webkit-scrollbar{width:0;height:0;display:none}}.app-fullscreen-brand-overlay,.app-splash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;width:100%;background:var(--bg-primary, #0f172a);transition:background-color .3s ease;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0);box-sizing:border-box}.app-fullscreen-brand-overlay .app-brand-icon--splash .app-brand-icon__svg,.app-splash .app-brand-icon--splash .app-brand-icon__svg{width:var(--app-brand-splash-size, 96px);height:var(--app-brand-splash-size, 96px);max-width:min(96px,28vw);max-height:min(96px,28vw)}#messager-update-banner{position:fixed;top:0;left:0;right:0;z-index:2147483000;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top,0));font-family:system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.35;color:var(--message-own-text, #fff);background:var(--primary-color, #3390ec);box-shadow:0 2px 12px #0003}#messager-update-banner .messager-update-banner__text{flex:1;min-width:0}#messager-update-banner .messager-update-banner__actions{display:flex;gap:8px;flex-shrink:0}#messager-update-banner button{cursor:pointer;border:none;border-radius:8px;padding:8px 14px;font-size:14px;font-weight:600;background:#fffffff2;color:var(--primary-dark, #2563eb)}#messager-update-banner button.messager-update-banner__dismiss{background:transparent;color:#ffffffe6;border:1px solid rgba(255,255,255,.45)}:root{--primary-color: #3390EC;--primary-dark: #2563eb;--primary-light: #60a5fa;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-chat: #1a1a1a;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--text-muted: #64748b;--message-own-bg: #2563eb;--message-other-bg: #334155;--message-own-text: #ffffff;--message-other-text: #f8fafc;--border-color: #334155;--border-light: #475569;--status-online: #10b981;--status-offline: #6b7280;--status-typing: #3390EC;--notification-bg: #dc2626;--notification-text: #ffffff;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--border-radius-sm: 8px;--border-radius-md: 12px;--border-radius-lg: 16px;--border-radius-xl: 20px;--border-radius-full: 9999px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-base: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 24px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 1000;--z-modal: 1100;--z-popover: 1200;--z-tooltip: 1300;--z-notification: 1400}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-chat: #f9fafb;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-muted: #94a3b8;--message-own-bg: #3390EC;--message-other-bg: #ffffff;--message-own-text: #ffffff;--message-other-text: #0f172a;--border-color: #e2e8f0;--border-light: #cbd5e1;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-size:var(--font-size-base);line-height:1.5}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-muted{color:var(--text-muted)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.border{border:1px solid var(--border-color)}.border-light{border:1px solid var(--border-light)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded-md{border-radius:var(--border-radius-md)}.rounded-lg{border-radius:var(--border-radius-lg)}.rounded-xl{border-radius:var(--border-radius-xl)}.rounded-full{border-radius:var(--border-radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.transition-fast{transition:all var(--transition-fast)}.transition-base{transition:all var(--transition-base)}.transition-slow{transition:all var(--transition-slow)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;border:none;transition:all var(--transition-base)}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-light)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--border-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn var(--transition-base)}.slide-up{animation:slideUp var(--transition-base)}.slide-down{animation:slideDown var(--transition-base)}
