:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #818cf8;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--role-dev: #f59e0b;--role-adm: #ef4444;--role-manager: #10b981;--role-superadmin: #a855f7}:root,[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-hover: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border: #334155;--shadow: rgba(0, 0, 0, .5)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #e2e8f0;--bg-hover: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--border: #e2e8f0;--shadow: rgba(0, 0, 0, .1)}@media (prefers-color-scheme: light){[data-theme=auto]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #e2e8f0;--bg-hover: #e2e8f0;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--border: #e2e8f0;--shadow: rgba(0, 0, 0, .1)}}@media (prefers-color-scheme: dark){[data-theme=auto]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-hover: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border: #334155;--shadow: rgba(0, 0, 0, .5)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow:hidden}.settings-menu{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100vh;background:var(--bg-secondary);z-index:9999;display:none;flex-direction:column;border-left:1px solid var(--border);box-shadow:-4px 0 20px #0000004d;animation:slideInRight .3s ease-out;pointer-events:auto}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.settings-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1999;animation:fadeIn .3s ease-out;pointer-events:auto;cursor:pointer}.settings-menu-content{display:flex;flex-direction:column;height:100%;overflow-y:auto;pointer-events:auto}.settings-menu.show{display:flex;animation:slideInFromRight .3s ease-out;pointer-events:auto}.settings-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:9998;display:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-menu-overlay.show{display:block}.settings-menu-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);position:sticky;top:0;z-index:10}.settings-menu-header h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.settings-menu-close{width:36px;height:36px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.settings-menu-close:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-menu-close svg{width:20px;height:20px}.settings-menu-body{flex:1;overflow-y:auto;padding:.5rem 0}.settings-menu-section{margin-bottom:1.5rem}.settings-menu-item{display:flex;align-items:center;padding:.875rem 1.5rem;cursor:pointer;transition:background .2s;border:none;background:transparent;width:100%;text-align:left;color:var(--text-primary);pointer-events:auto;position:relative;z-index:1}.settings-menu-item:hover{background:var(--bg-hover)}.settings-menu-item.linked{opacity:.7;cursor:not-allowed}.settings-menu-item.linked:hover{background:transparent}.settings-menu-icon{width:40px;height:40px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;margin-right:1rem;flex-shrink:0;transition:all .2s}.settings-menu-item:hover .settings-menu-icon{background:var(--bg-hover);transform:scale(1.05)}.settings-menu-icon.telegram-icon{background:linear-gradient(135deg,#08c,#229ed9)}.settings-menu-icon svg{width:20px;height:20px;color:var(--text-primary)}.settings-menu-icon.telegram-icon svg{color:#fff}.settings-menu-text{flex:1;display:flex;flex-direction:column;gap:.25rem}.settings-menu-title{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.settings-menu-subtitle{font-size:.8125rem;color:var(--text-muted)}.settings-menu-arrow{width:20px;height:20px;color:var(--text-muted);flex-shrink:0;margin-left:.5rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}.screen{display:none;width:100vw;height:100vh;position:relative}.screen.active{display:flex}.server-unavailable-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172af2;display:flex;align-items:center;justify-content:center;padding:2rem}.server-unavailable-card{background:var(--bg-secondary);border-radius:24px;padding:3rem;max-width:420px;width:100%;text-align:center;border:1px solid var(--border);box-shadow:0 20px 60px var(--shadow)}.server-unavailable-icon{font-size:4rem;margin-bottom:1rem}.server-unavailable-card h2{font-size:1.5rem;margin-bottom:.75rem;color:var(--text-primary)}.server-unavailable-desc{color:var(--text-muted);margin-bottom:1.5rem;line-height:1.5}.server-unavailable-card .btn{padding:.75rem 1.5rem}.auth-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);padding:2rem}.auth-card{background:var(--bg-secondary);border-radius:24px;padding:3rem;width:100%;max-width:450px;box-shadow:0 20px 60px var(--shadow);border:1px solid var(--border)}.auth-header{text-align:center;margin-bottom:2rem}.logo{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff}.logo svg{width:50px;height:50px}.auth-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--primary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.auth-header p{color:var(--text-secondary)}.auth-tabs{display:flex;gap:1rem;margin-bottom:2rem;background:var(--bg-primary);padding:.5rem;border-radius:12px}.auth-tab{flex:1;padding:.75rem;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .3s}.auth-tab.active{background:var(--primary);color:#fff}.auth-form{display:none}.auth-form.active{display:block}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.875rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:1rem;transition:all .3s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.btn{width:100%;padding:.875rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff}.btn-primary:hover{transform:translateY(-2px) translateZ(0);box-shadow:0 10px 30px #6366f14d}.error-message{margin-top:1rem;padding:.75rem;background:#ef44441a;border:1px solid var(--danger);border-radius:8px;color:var(--danger);font-size:.875rem;display:none}.error-message.show{display:block}.app-container{display:flex;width:100%;height:100vh;overflow:hidden}.sidebar{width:380px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border)}.user-profile{display:flex;align-items:center;gap:.75rem;position:relative}.avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.2rem;flex-shrink:0}.user-info{flex:1;min-width:0;max-width:150px}.user-info h3{font-size:1rem;font-weight:600;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-selector{position:relative;z-index:1}.status-selector select{background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);padding:.25rem .5rem;font-size:.875rem;cursor:pointer;position:relative;z-index:1}.current-user-bio{font-size:.75rem;color:var(--text-muted);margin-top:.35rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}#settings-link-telegram-btn.linked{background:#2aabee1a;border:1px solid rgba(42,171,238,.3)}#settings-link-telegram-btn.linked .settings-menu-icon svg{color:#2aabee}#settings-link-telegram-btn.linked .settings-menu-title{color:#2aabee}#settings-link-telegram-btn.linked .settings-menu-subtitle:after{content:" ✓";color:#10b981;font-weight:600}.add-members-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:10000;display:flex;align-items:center;justify-content:center}.add-members-content{background:var(--bg-primary);border-radius:16px;padding:2rem;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.add-members-search{margin:1rem 0}.add-members-search input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary)}.add-members-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.add-member-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:8px;cursor:pointer;transition:background .2s}.add-member-item:hover{background:var(--bg-secondary)}.add-members-actions{display:flex;gap:.75rem;margin-top:1rem;justify-content:flex-end}.btn-secondary{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer}.btn-primary{padding:.75rem 1.5rem;border:none;border-radius:8px;background:var(--primary);color:#fff;cursor:pointer}.btn-icon{width:40px;height:40px;border:none;background:var(--bg-primary);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon svg{width:20px;height:20px}.search-bar{padding:1rem 1.5rem;display:flex;gap:.75rem;border-bottom:1px solid var(--border);position:relative;z-index:1}.search-bar .btn-icon{pointer-events:auto;z-index:10}.search-bar input{flex:1;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.95rem;z-index:1}.search-bar input:focus{outline:none;border-color:var(--primary)}.conversations-nav{padding:1rem 1.5rem;border-bottom:1px solid var(--border)}.nav-tabs{display:flex;gap:.5rem;background:var(--bg-primary);padding:.25rem;border-radius:10px}.nav-tab{flex:1;padding:.5rem;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:all .2s}.nav-tab.active{background:var(--bg-tertiary);color:var(--text-primary)}.conversations-list{flex:1;overflow-y:auto;padding:.5rem}.conversation-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;position:relative;cursor:pointer;transition:background-color .2s ease,transform .2s ease,padding-left .2s ease;margin-bottom:.25rem}.conversation-item:hover{background:var(--bg-primary)}.conversation-item.active{background:var(--bg-tertiary);transform:scale(1.02);padding-left:1.25rem}.friends-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:.75rem 1rem .25rem}.friends-section{margin-bottom:.5rem}.friend-request-item.outgoing{opacity:.8;cursor:default}.friend-request-item.outgoing:hover{opacity:1}.conversation-item .avatar{width:52px;height:52px;position:relative}.conversation-item .avatar .status-dot{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;background:var(--success);border:2px solid var(--bg-secondary)}.conversation-info{flex:1;min-width:0}.conversation-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.25rem}.conversation-header h4{font-size:1rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-header h4[data-role=DEV]{color:var(--role-dev)}.conversation-header h4[data-role=ADM]{color:var(--role-adm)}.conversation-header h4[data-role=MANAGER]{color:var(--role-manager)}.conversation-header h4[data-role=SUPERADMIN]{color:var(--role-superadmin);text-shadow:0 0 5px var(--role-superadmin)}.conversation-time{font-size:.75rem;color:var(--text-muted);flex-shrink:0;margin-left:.5rem}.conversation-preview{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background:var(--primary);color:#fff;font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:12px;min-width:20px;text-align:center}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary);position:relative}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted)}.empty-state svg{width:120px;height:120px;margin-bottom:1.5rem;opacity:.3}.empty-state h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-secondary)}.chat-container{flex:1;display:flex;flex-direction:column;height:100%}.chat-header{padding:1.25rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.chat-info{display:flex;align-items:center;gap:1rem}.chat-info h2{font-size:1.125rem;font-weight:600}.chat-info h2[data-role=DEV]{color:var(--role-dev)}.chat-info h2[data-role=ADM]{color:var(--role-adm)}.chat-info h2[data-role=MANAGER]{color:var(--role-manager)}.chat-info h2[data-role=SUPERADMIN]{color:var(--role-superadmin);text-shadow:0 0 10px var(--role-superadmin)}.chat-status{font-size:.875rem;color:var(--text-secondary);transition:color .3s ease}.chat-status.typing{color:var(--primary);font-weight:500}.chat-status.typing:after{content:"...";display:inline-block;animation:typing-dots 1.4s infinite;width:20px;text-align:left}@keyframes typing-dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.chat-actions{display:flex;gap:.5rem;position:relative}.chat-actions .friend-request-actions{display:flex;gap:.5rem;align-items:center}.chat-actions .friend-request-actions .btn-icon{padding:.5rem;border-radius:6px;width:32px;height:32px}.chat-actions .friend-request-actions .accept-friend-header{color:var(--success)}.chat-actions .friend-request-actions .decline-friend-header{color:var(--danger)}.chat-menu-btn{position:relative}.chat-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;padding:.5rem 0;min-width:180px;box-shadow:0 10px 30px var(--shadow);z-index:100;display:none}.chat-dropdown.show{display:block;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.chat-dropdown button{width:100%;padding:.6rem .75rem;background:none;border:none;border-radius:6px;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .15s;font-size:.9rem;display:flex;align-items:center}.chat-dropdown button span{flex:1}.chat-dropdown button:hover{background:var(--bg-hover)}.chat-dropdown button.danger{color:var(--danger)}.chat-dropdown button.danger:hover{background:#ef444426}.profile-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;z-index:2000;display:none;align-items:center;justify-content:center}.profile-modal.show{display:flex;animation:fadeIn .2s ease}.profile-content{background:var(--bg-secondary);border-radius:16px;padding:2rem;width:90%;max-width:400px;box-shadow:0 20px 60px #00000080;position:relative}.profile-close{position:absolute;top:1rem;right:1rem;background:var(--bg-tertiary);border:none;width:32px;height:32px;border-radius:50%;color:var(--text-secondary);cursor:pointer;font-size:1.2rem}.profile-avatar-large{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;font-weight:700}.profile-info{text-align:center;margin-bottom:2rem}.profile-info h2{font-size:1.5rem;margin-bottom:.5rem}.profile-info .profile-status{color:var(--text-secondary);font-size:.9rem}.profile-actions{display:flex;gap:.75rem;flex-direction:column}.profile-actions button{padding:.875rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.profile-btn-primary{background:var(--primary);color:#fff}.profile-btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.profile-btn-danger{background:#ef44441a;color:var(--danger)}.messages-area{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.message{display:flex;gap:.75rem;max-width:70%;animation:messageSlide .3s ease}@keyframes messageSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.own{align-self:flex-end;flex-direction:row}.message:not(.own){align-self:flex-start;flex-direction:row-reverse}.message .avatar{width:36px;height:36px;font-size:.9rem}.message-content{flex:1}.message-bubble{padding:.875rem 1rem;border-radius:16px;background:var(--bg-secondary);word-wrap:break-word;position:relative;max-width:100%}.message.own .message-bubble{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;border-bottom-right-radius:4px}.message:not(.own) .message-bubble{border-bottom-left-radius:4px}.message-media{max-width:300px;border-radius:12px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.message-media:hover{transform:scale(1.02);box-shadow:0 5px 20px #0000004d}.message-media img,.message-media video{width:100%;height:auto;border-radius:12px;display:block}.message-bubble:has(.message-audio),.message-bubble:has(.message-video-circle){padding:0;background:transparent;border:none;box-shadow:none}.video-circle-bubble{padding:0!important;background:transparent!important;border:none!important;box-shadow:none!important}.message-bubble:has(.message-audio) .message-audio{margin:0}.message-bubble:has(.message-video-circle){display:flex;justify-content:flex-start}.message-audio{display:flex;align-items:center;gap:12px;padding:10px 14px;background:linear-gradient(135deg,#ffffff0f,#ffffff05);border:1px solid rgba(255,255,255,.08);border-radius:16px;margin-bottom:.25rem;max-width:380px;min-width:220px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.message.own .message-audio{background:linear-gradient(135deg,#6366f126,#6366f10d);border-color:#6366f133}.audio-play-btn{width:42px;height:42px;border:none;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s ease;box-shadow:0 4px 12px #6366f14d;position:relative;overflow:hidden}.audio-play-btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.15),transparent);pointer-events:none}.audio-play-btn:hover{transform:scale(1.08);box-shadow:0 6px 20px #6366f166}.audio-play-btn:active{transform:scale(.95)}.audio-play-btn svg{width:18px;height:18px;position:relative;z-index:1}.audio-play-btn.playing{animation:audioPulse 1.5s ease-in-out infinite}@keyframes audioPulse{0%,to{box-shadow:0 4px 12px #6366f14d}50%{box-shadow:0 4px 20px #6366f180,0 0 0 6px #6366f11a}}.audio-waveform-container{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.audio-waveform{display:flex;align-items:center;gap:2px;height:32px;flex:1}.audio-waveform-bar{width:3px;min-width:2px;background:var(--primary);border-radius:2px;opacity:.4;transition:opacity .15s,height .15s}.audio-waveform-bar.played{opacity:1}.audio-waveform-bar.playing{opacity:1;animation:waveBarPulse .8s ease-in-out infinite}@keyframes waveBarPulse{0%,to{opacity:.6}50%{opacity:1}}.audio-info{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);white-space:nowrap;padding:0 2px}.message.own .audio-info{color:#ffffffb3}.message.own .audio-waveform-bar{background:#ffffffb3}.message.own .audio-waveform-bar.played,.message.own .audio-waveform-bar.playing{background:#fff}.message-video-circle{display:flex;justify-content:flex-start;margin:4px 0;padding:0}.message.own .message-video-circle{justify-content:flex-end}.message-video-circle .video-circle-container{position:relative;width:240px;height:240px;border-radius:50%!important;overflow:hidden;background:#0a0a0a;border:3px solid var(--primary);cursor:pointer;aspect-ratio:1 / 1;flex-shrink:0;box-shadow:0 8px 32px #0006,0 0 0 1px #ffffff0d;transition:border-color .3s,box-shadow .3s,transform .2s}.message-video-circle .video-circle-container:hover{transform:scale(1.02);box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff1a}.message-video-circle.playing .video-circle-container{border-color:#22c55e;animation:circleGlow 2s ease-in-out infinite}@keyframes circleGlow{0%,to{box-shadow:0 8px 32px #0006,0 0 #22c55e4d}50%{box-shadow:0 8px 32px #0006,0 0 0 6px #22c55e1a}}.message-video-circle video,.message-video-circle .video-circle-player{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:50%!important;display:block;background:#000;clip-path:circle(50% at 50% 50%);-webkit-clip-path:circle(50% at 50% 50%);transform:translateZ(0);object-position:center}.message-video-circle .video-circle-play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;border:none;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;z-index:10;box-shadow:0 4px 16px #0000004d}.message-video-circle .video-circle-play-btn:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid rgba(255,255,255,.15);pointer-events:none}.message-video-circle .video-circle-play-btn:hover{transform:translate(-50%,-50%) scale(1.12);background:#000000b3}.message-video-circle .video-circle-play-btn svg{width:28px;height:28px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.message-video-circle .video-circle-pause-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:56px;height:56px;border-radius:50%;border:none;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;display:none;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;z-index:10;opacity:0}.message-video-circle .video-circle-pause-btn svg{width:24px;height:24px}.message-video-circle.playing .video-circle-play-btn{opacity:0;pointer-events:none}.message-video-circle.playing .video-circle-pause-btn{display:flex}.message-video-circle.playing .video-circle-container:hover .video-circle-pause-btn{opacity:1}.message-video-circle.playing .video-circle-pause-btn:hover{transform:translate(-50%,-50%) scale(1.12);background:#000000b3}.message-video-circle video::-webkit-media-controls,.message-video-circle video::-webkit-media-controls-enclosure,.message-video-circle video::-webkit-media-controls-panel{display:none!important;-webkit-appearance:none!important}.message-video-circle video::-moz-media-controls{display:none!important}.message-video-circle video::-ms-media-controls{display:none!important}.message-file{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0d;border-radius:8px;margin-bottom:.5rem;cursor:pointer;transition:all .2s}.message-file:hover{background:#ffffff1a}.message-sender{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem;font-weight:500}.message-sender[data-role=DEV]{color:gold;font-weight:600;text-shadow:0 0 10px rgba(255,215,0,.5)}.message-sender[data-role=ADM]{color:var(--role-adm);font-weight:600}.message-sender[data-role=MANAGER]{color:var(--role-manager);font-weight:600}.message-sender[data-role=SUPERADMIN]{color:var(--role-superadmin);font-weight:700;text-shadow:0 0 10px var(--role-superadmin)}.message.own .message-sender{text-align:right}.message-time{font-size:.75rem;color:var(--text-muted);margin-top:.25rem;text-align:left}.message-wrapper{position:relative;display:flex;align-items:flex-start;gap:.5rem}.message-actions-left{position:relative;opacity:0;transition:opacity .2s;margin-top:.25rem}.message:hover .message-actions-left{opacity:1}.message-action-btn{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .2s}.message-action-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.message-menu-dropdown{position:absolute;top:100%;left:0;margin-top:.25rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:.25rem;min-width:160px;box-shadow:0 4px 16px #0006;z-index:100;display:none}.message-menu-dropdown.show{display:block;animation:menuFadeIn .15s ease}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.message-menu-dropdown button{width:100%;padding:.6rem .75rem;background:none;border:none;border-radius:6px;color:var(--text-primary);text-align:left;cursor:pointer;transition:all .15s;font-size:.9rem;display:flex;align-items:center}.message-menu-dropdown button span{flex:1}.message-menu-dropdown button:hover{background:var(--bg-hover)}.message-menu-dropdown button.danger{color:var(--danger)}.message-menu-dropdown button.danger:hover{background:#ef444426}.typing-indicator{display:flex;gap:.25rem;padding:1rem 1.5rem;align-items:center}.typing-indicator span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.message-input-container{padding:1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;align-items:center;gap:.75rem}.message-input{flex:1;max-height:120px;overflow-y:auto;padding:.875rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:1rem;line-height:1.5;outline:none}.message-input:empty:before{content:attr(data-placeholder);color:var(--text-muted)}.message-input:focus{border-color:var(--primary)}.message-input-container .btn-icon.btn-primary{background:var(--primary);color:#fff}.message-input-container .btn-icon.btn-primary:hover{background:var(--primary-hover)}.emoji-picker{position:absolute;bottom:80px;right:20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1rem;box-shadow:0 10px 40px var(--shadow);display:none;z-index:100;max-width:320px}.emoji-picker.show{display:block;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.emoji-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem;max-height:200px;overflow-y:auto}.emoji-item{font-size:1.5rem;padding:.5rem;cursor:pointer;border-radius:8px;transition:all .2s;text-align:center}.emoji-item:hover{background:var(--bg-hover);transform:scale(1.2)}.file-preview{position:absolute;bottom:80px;left:20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1rem;box-shadow:0 10px 40px var(--shadow);display:none;z-index:100;max-width:400px}.file-preview.show{display:block;animation:slideUp .2s ease}.file-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.file-preview-header h4{font-size:1rem;font-weight:600}.file-preview-close{background:var(--bg-tertiary);border:none;color:var(--text-secondary);width:30px;height:30px;border-radius:50%;cursor:pointer}.file-preview-content{margin-bottom:1rem}.file-preview-content img,.file-preview-content video{max-width:100%;border-radius:8px}.file-preview-options{display:flex;gap:.5rem;margin-bottom:1rem}.file-preview-options button{flex:1;padding:.5rem;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;cursor:pointer;transition:all .2s}.file-preview-options button.active{background:var(--primary);border-color:var(--primary)}.file-preview-send{width:100%;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;z-index:1000;align-items:center;justify-content:center}.modal.active{display:flex}.call-container{width:100%;height:100%;display:flex;flex-direction:column;position:relative}.call-header{position:absolute;top:2rem;left:50%;transform:translate(-50%);text-align:center;z-index:10;display:flex;flex-direction:column;align-items:center;gap:.5rem}.call-header h2{font-size:1.5rem;margin-bottom:.5rem;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}.call-header p{color:#fffc;text-shadow:0 2px 8px rgba(0,0,0,.5)}.call-minimize-btn{position:absolute;top:2rem;right:2rem;width:48px;height:48px;border:none;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:20}.call-minimize-btn:hover{background:#000000b3;transform:scale(1.1)}.call-minimize-btn svg{width:24px;height:24px}.call-video-container{flex:1;position:relative;background:#000}#remote-video{width:100%;height:100%;object-fit:cover}#local-video{position:absolute;bottom:2rem;right:2rem;width:240px;height:180px;object-fit:cover;border-radius:16px;border:2px solid var(--border);box-shadow:0 10px 40px var(--shadow)}.call-controls{position:absolute;bottom:3rem;left:50%;transform:translate(-50%);display:flex;gap:1.5rem;z-index:10}.btn-call{width:64px;height:64px;border:none;border-radius:50%;background:#4f545ccc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 8px 32px #0000004d;position:relative}.btn-call:hover{transform:scale(1.1);background:#4f545c}.btn-call.disabled{opacity:.5;background:#c82829cc}.btn-call.active{background:#5865f2cc}.btn-call svg{width:28px;height:28px;stroke-width:2.5}.btn-end-call{background:#ed4245e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-end-call:hover{background:#c82829;transform:scale(1.15)}@media (max-width: 768px){.sidebar{width:100%;position:absolute;z-index:100}.sidebar.hide-mobile{display:none}#local-video{width:120px;height:90px;bottom:1rem;right:1rem}.message{max-width:85%}}.editing-mode-indicator{position:absolute;bottom:calc(100% + .5rem);left:1.5rem;right:1.5rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px 12px 0 0;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;opacity:0;transform:translateY(10px);pointer-events:none;transition:all .3s ease;z-index:10}.editing-mode-indicator.show{opacity:1;transform:translateY(0);pointer-events:all}.editing-info{display:flex;align-items:center;gap:.5rem;color:var(--primary);font-size:.875rem;font-weight:500}.editing-info svg{width:16px;height:16px}.editing-message-preview{color:var(--text-secondary);font-size:.875rem;margin-left:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}.cancel-edit-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .2s;font-size:.875rem}.cancel-edit-btn:hover{background:var(--bg-hover);color:var(--text-primary)}#send-btn.edit-mode{background:var(--warning)!important}#send-btn.edit-mode:hover{background:#f59e0b!important}#send-btn.edit-mode svg{display:none}#send-btn.edit-mode:after{content:"✏️";font-size:1.25rem}.delete-message-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.delete-message-modal.show{opacity:1;pointer-events:all}.delete-modal-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:2rem;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;transform:scale(.9);transition:transform .3s ease}.delete-message-modal.show .delete-modal-content{transform:scale(1)}.delete-modal-header{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.delete-modal-option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;cursor:pointer;transition:all .2s}.delete-modal-option:hover{background:var(--bg-hover);border-color:var(--primary)}.delete-modal-option.selected{background:var(--primary-transparent);border-color:var(--primary)}.delete-checkbox{width:20px;height:20px;border:2px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.delete-modal-option.selected .delete-checkbox{background:var(--primary);border-color:var(--primary)}.delete-checkbox:after{content:"✓";color:#fff;font-size:14px;font-weight:700;opacity:0;transform:scale(0);transition:all .2s}.delete-modal-option.selected .delete-checkbox:after{opacity:1;transform:scale(1)}.delete-option-label{flex:1;color:var(--text-primary);font-size:.95rem}.delete-modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.delete-modal-btn{flex:1;padding:.875rem;border:none;border-radius:12px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.delete-modal-btn.cancel{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.delete-modal-btn.cancel:hover{background:var(--bg-hover)}.delete-modal-btn.delete{background:var(--danger);color:#fff}.delete-modal-btn.delete:hover{background:#dc2626;transform:translateY(-1px)}.message-menu{min-width:180px}.message-menu button{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;width:100%;background:none;border:none;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:background .2s;border-radius:8px}.message-menu button:hover{background:var(--bg-hover)}.message-menu button.danger{color:var(--danger)}.message-menu button.danger:hover{background:#ef44441a}.message-menu button svg{width:18px;height:18px}.message.edited:after{content:"изменено";font-size:.75rem;color:var(--text-muted);margin-left:.5rem;font-style:italic}.new-chat-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s}.new-chat-modal.show{opacity:1;pointer-events:all}.new-chat-modal-content{background:var(--bg-secondary);border-radius:16px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.new-chat-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.new-chat-modal-header h3{margin:0;font-size:1.25rem}.new-chat-modal-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted)}.new-chat-search{padding:1rem;border-bottom:1px solid var(--border)}.new-chat-search input{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem}.new-chat-section-title{padding:.75rem 1rem;font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase}.new-chat-results{flex:1;overflow-y:auto}.new-chat-user-item{display:flex;align-items:center;gap:1rem;padding:1rem;cursor:pointer;transition:background .2s}.new-chat-user-item:hover{background:var(--bg-hover)}.new-chat-user-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:#fff}.new-chat-user-info{flex:1}.new-chat-user-name{font-size:1rem;font-weight:500;color:var(--text-primary)}.new-chat-user-username{font-size:.85rem;color:var(--text-muted)}.forward-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s}.forward-modal.show{opacity:1;pointer-events:all}.forward-modal-content{background:var(--bg-secondary);border-radius:16px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column}.forward-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border)}.forward-modal-header h3{margin:0;font-size:1.25rem}.forward-modal-header button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted)}.forward-search{padding:1rem;border-bottom:1px solid var(--border)}.forward-search input{width:100%;padding:.75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem}.forward-list{flex:1;overflow-y:auto;padding:.5rem}.forward-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;cursor:pointer;transition:background .2s}.forward-item:hover{background:var(--bg-hover)}.forward-avatar{width:48px;height:48px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:#fff}.forward-name{font-size:1rem;font-weight:500;color:var(--text-primary)}.floating-video{position:fixed;bottom:20px;right:20px;min-width:240px;min-height:180px;width:320px;height:240px;max-width:640px;max-height:480px;background:var(--bg-secondary);border-radius:12px;box-shadow:0 10px 40px #0000004d;overflow:hidden;z-index:1000;opacity:0;pointer-events:none;transform:translateY(20px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);resize:both}.floating-video.show{opacity:1;pointer-events:all;transform:translateY(0)}.floating-video-header{background:linear-gradient(135deg,var(--primary),var(--primary-hover));padding:.75rem;display:flex;justify-content:space-between;align-items:center;color:#fff;font-size:.9rem;font-weight:500;cursor:move;-webkit-user-select:none;user-select:none}.floating-video-close{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.floating-video-close:hover{background:#ffffff4d}.floating-video-container{position:relative;width:100%;height:calc(100% - 45px);background:#000}.floating-video-container video{width:100%;height:100%;object-fit:cover}#floating-remote-video{position:absolute;top:0;left:0;width:100%;height:100%;display:none}#floating-remote-video:only-child{display:block}#floating-local-video{position:absolute;bottom:10px;right:10px;width:80px;height:60px;border-radius:8px;border:2px solid white;box-shadow:0 2px 8px #0000004d;display:none}.floating-video-container:has(#floating-remote-video[style*="display: none"]) #floating-local-video,.floating-video-container:has(#floating-remote-video:not([srcObject])) #floating-local-video{width:100%;height:100%;bottom:0;right:0;border-radius:0;border:none}.call-status-bar{position:absolute;top:0;left:0;right:0;background:linear-gradient(135deg,var(--primary),var(--primary-hover));padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center;transform:translateY(-100%);opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:100;cursor:pointer}.call-status-bar.show{transform:translateY(0);opacity:1;pointer-events:all}.call-status-info{display:flex;align-items:center;gap:1rem;color:#fff;font-size:.95rem;font-weight:500}.call-status-duration{font-variant-numeric:tabular-nums;opacity:.9}.call-status-actions{display:flex;gap:.5rem}.call-status-btn{width:36px;height:36px;border:none;border-radius:50%;background:#fff3;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.call-status-btn:hover{background:#ffffff4d;transform:scale(1.1)}.call-status-btn.end{background:var(--danger)}.call-status-btn.end:hover{background:#dc2626}.call-status-btn svg{width:20px;height:20px}.chat-header{position:relative;transition:padding-top .4s}.chat-header.with-call{padding-top:3.5rem}.message-system{display:flex;flex-direction:column;align-items:center;margin:1rem 0;padding:0 1rem}.system-message-content{background:var(--bg-tertiary);color:var(--text-muted);padding:.5rem 1.25rem;border-radius:12px;font-size:.875rem;text-align:center;max-width:80%}.system-message-time{font-size:.7rem;color:var(--text-muted);margin-top:.25rem;opacity:.6}.incoming-call-modal{position:absolute;top:0;left:0;right:0;background:linear-gradient(135deg,var(--primary),var(--primary-hover));padding:1.5rem;display:flex;flex-direction:column;align-items:center;z-index:2000;transform:translateY(-100%);opacity:0;pointer-events:none;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 40px #0000004d}.incoming-call-modal.show{transform:translateY(0);opacity:1;pointer-events:all}.incoming-call-content{width:100%;text-align:center}.incoming-call-avatar{width:60px;height:60px;margin:0 auto 1rem;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 20px #fff0}to{box-shadow:0 0 #fff0}}.incoming-call-content h3{font-size:1.25rem;color:#fff;margin-bottom:.25rem;font-weight:600}.incoming-call-content p{font-size:.95rem;color:#ffffffe6;margin-bottom:1.5rem}.incoming-call-actions{display:flex;gap:1rem;justify-content:center}.incoming-call-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:24px;cursor:pointer;transition:all .2s;font-size:.95rem;font-weight:500}.incoming-call-btn svg{width:20px;height:20px}.incoming-call-btn.decline{background:var(--danger);color:#fff}.incoming-call-btn.decline:hover{background:#dc2626;transform:translateY(-2px)}.incoming-call-btn.accept{background:var(--success);color:#fff}.incoming-call-btn.accept:hover{background:#16a34a;transform:translateY(-2px)}.message-audio{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#ffffff0d;border-radius:12px;min-width:200px;max-width:280px}.message-audio audio{display:none}.audio-play-btn{width:36px;height:36px;border-radius:50%;background:#fff3;border:none;color:inherit;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.audio-play-btn:hover{background:#ffffff4d;transform:scale(1.05)}.audio-play-btn svg{width:18px;height:18px}.audio-waveform-container{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:100px}.audio-waveform{display:flex;align-items:center;gap:2px;height:24px}.audio-waveform-bar{flex:1;background:#ffffff4d;border-radius:2px;min-width:2px;transition:height .1s}.audio-waveform-bar.playing{background:currentColor}.audio-info{display:flex;justify-content:space-between;font-size:.7rem;opacity:.7}.audio-duration{font-weight:500}.audio-size{opacity:.6}.audio-waveform canvas{width:100%;height:40px;display:block}.pinned-message-bar{display:none;background:var(--bg-secondary);border-bottom:1px solid rgba(255,255,255,.1);padding:.75rem 1rem;align-items:center;gap:.75rem;cursor:pointer;transition:background .2s}.pinned-message-bar.show{display:flex}.pinned-message-bar:hover{background:var(--bg-hover)}.pinned-messages-bar{display:none;background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(99,102,241,.08) 100%);border-bottom:1px solid var(--border);padding:10px 16px;align-items:center;gap:12px;cursor:pointer;transition:all .2s ease;position:relative}.pinned-messages-bar:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary)}.pinned-messages-bar.show{display:flex;animation:slideInDown .25s ease}.pinned-messages-bar:hover{background:linear-gradient(135deg,var(--bg-tertiary) 0%,rgba(99,102,241,.12) 100%)}.pinned-icon{width:20px;height:20px;color:var(--primary);flex-shrink:0}.pinned-messages-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.pinned-messages-counter{font-size:12px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px}#pinned-message-text,.pinned-message-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;color:var(--text-primary);line-height:1.4}.pinned-messages-nav{display:flex;align-items:center;gap:4px}.pinned-nav-btn{width:28px;height:28px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.pinned-nav-btn:hover{background:var(--primary);color:#fff;transform:scale(1.1)}.pinned-nav-btn svg{width:14px;height:14px}.pinned-close-btn{width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;margin-left:8px}.pinned-close-btn:hover{background:#ef444433;color:#ef4444}.pinned-close-btn svg{width:16px;height:16px}.pinned-messages-list{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-top:none;border-radius:0 0 12px 12px;max-height:300px;overflow-y:auto;z-index:100;display:none;box-shadow:0 8px 32px #0000004d}.pinned-messages-list.show{display:block;animation:slideInDown .2s ease}.pinned-message-item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;cursor:pointer;transition:all .15s ease;border-bottom:1px solid var(--border)}.pinned-message-item:last-child{border-bottom:none}.pinned-message-item:hover{background:var(--bg-hover)}.pinned-message-item.active{background:#6366f11a}.pinned-item-content{flex:1;min-width:0}.pinned-item-sender{font-size:12px;font-weight:600;color:var(--primary);margin-bottom:4px}.pinned-item-text{font-size:14px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-item-unpin{opacity:0;width:24px;height:24px;border-radius:50%;border:none;background:#ef444433;color:#ef4444;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.pinned-message-item:hover .pinned-item-unpin{opacity:1}.pinned-item-unpin:hover{background:#ef4444;color:#fff}.pinned-item-unpin svg{width:12px;height:12px}.pinned-message-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.pinned-message-close:hover{background:#ef44441a;color:var(--danger)}.pinned-message-close svg{width:18px;height:18px}.message-text code.inline-code,code.inline-code{background:#6e768166;color:#d4d4d4;padding:.15rem .5rem;border-radius:6px;font-family:Consolas,Monaco,Courier New,monospace;font-size:.875em;font-weight:500;border:1px solid rgba(255,255,255,.1)}.message-code-block{margin:0;border-radius:10px;overflow:hidden;background:#0d1117;border:none;font-size:.875rem;width:fit-content;max-width:100%;min-width:200px}.message-bubble:has(.message-code-block):not(:has(.message-text)){padding:.5rem}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .85rem;background:#161b22;border-bottom:none}.code-language{font-size:.8rem;color:#7d8590;text-transform:lowercase;font-weight:600;letter-spacing:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.message-code-block[data-code-id] .code-language{background:linear-gradient(135deg,var(--lang-color-1, #7d8590),var(--lang-color-2, #7d8590));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.message-code-block[data-code-id*=""] .code-language:is(:has-text("php"),[data-lang=php]){--lang-color-1: #c678dd;--lang-color-2: #e06c75}[data-language=python] .code-language{color:#3776ab;font-weight:700}[data-language=javascript] .code-language,[data-language=js] .code-language{color:#f7df1e;font-weight:700}[data-language=typescript] .code-language,[data-language=ts] .code-language{color:#3178c6;font-weight:700}[data-language=php] .code-language{color:#c678dd;font-weight:700}[data-language=html] .code-language{color:#e34c26;font-weight:700}[data-language=css] .code-language{color:#264de4;font-weight:700}[data-language=json] .code-language{color:#5cb85c;font-weight:700}[data-language=rust] .code-language{color:#f74c00;font-weight:700}[data-language=go] .code-language{color:#00add8;font-weight:700}[data-language=java] .code-language{color:#b07219;font-weight:700}[data-language=ruby] .code-language{color:#cc342d;font-weight:700}[data-language=sql] .code-language{color:#e38c00;font-weight:700}.code-copy-btn{background:#21262d;border:1px solid #30363d;color:#c9d1d9;cursor:pointer;padding:.25rem .6rem;display:flex;align-items:center;gap:.3rem;justify-content:center;border-radius:6px;transition:all .2s;font-size:.7rem}.code-copy-btn:after{content:"Copy";font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.code-copy-btn:hover{background:#30363d;border-color:#8b949e;color:#fff}.code-copy-btn svg{width:12px;height:12px;flex-shrink:0}.message-code-block pre{margin:0;padding:.85rem;overflow-x:auto;background:#0d1117}.message-code-block pre::-webkit-scrollbar{height:8px}.message-code-block pre::-webkit-scrollbar-track{background:#161b22}.message-code-block pre::-webkit-scrollbar-thumb{background:#30363d;border-radius:4px}.message-code-block pre::-webkit-scrollbar-thumb:hover{background:#484f58}.message-code-block code{font-family:SF Mono,Monaco,Menlo,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.6;color:#c9d1d9;display:block}.syntax-keyword{color:#569cd6;font-weight:600}.syntax-string{color:#ce9178}.syntax-number{color:#b5cea8}.syntax-boolean{color:#569cd6}.syntax-function{color:#dcdcaa}.syntax-comment{color:#6a9955;font-style:italic}.syntax-builtin{color:#4ec9b0}.syntax-tag{color:#569cd6}.syntax-attr,.syntax-property,.syntax-variable{color:#9cdcfe}.message-text strong{font-weight:700;color:inherit}.message-text em{font-style:italic;color:inherit}.message-text u{text-decoration:underline;color:inherit}.message-text s{text-decoration:line-through;opacity:.7}.message-text a{color:var(--primary);text-decoration:underline;transition:color .2s}.message-text a:hover{color:var(--primary-hover)}.formatting-toolbar{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.5rem;display:none;gap:.25rem;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideUpFade .2s}.formatting-toolbar.show{display:flex}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(0)}to{opacity:1;transform:translate(-50%) translateY(-8px)}}.formatting-btn{background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:Courier New,Courier,monospace;font-weight:600;font-size:.9rem}.formatting-btn:hover{background:#ffffff1a;color:var(--primary)}.formatting-btn svg{width:18px;height:18px}#voice-btn{color:var(--primary)}.voice-recording-ui{position:fixed;bottom:0;left:0;right:0;z-index:10000;background:#141923f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:0;display:none;opacity:0;transform:translateY(100%);transition:transform .25s cubic-bezier(.2,0,0,1),opacity .15s ease}.voice-recording-ui.show{display:block;opacity:1;transform:translateY(0)}.voice-recording-ui.hiding{opacity:0;transform:translateY(100%)}.vr-container{display:flex;align-items:center;padding:14px 20px;gap:14px;position:relative;transition:transform .1s ease}.vr-cancel-slide{display:flex;align-items:center;gap:8px;flex-shrink:0;animation:vrSlideHint 1.5s ease-in-out infinite}.vr-slide-arrow svg{width:18px;height:18px;color:#fff6}.vr-slide-text{font-size:13px;color:#fff6;white-space:nowrap;-webkit-user-select:none;user-select:none}@keyframes vrSlideHint{0%,to{transform:translate(0)}50%{transform:translate(-6px)}}.vr-center{display:flex;align-items:center;gap:10px;flex:1;justify-content:center}.vr-rec-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:vrRecPulse 1s ease-in-out infinite;flex-shrink:0}@keyframes vrRecPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.85)}}.vr-time{font-size:16px;font-weight:600;color:#fff;font-variant-numeric:tabular-nums;min-width:40px}.vr-waveform{display:flex;align-items:center;gap:2px;height:28px}.vr-wave-bar{width:3px;height:6px;border-radius:2px;background:var(--primary, #6366f1);transition:height .1s ease}.vr-lock-zone{position:absolute;right:16px;top:-70px;width:44px;display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.6;transition:opacity .2s,transform .2s}.vr-lock-zone.locked{opacity:0;pointer-events:none}.vr-lock-icon{width:40px;height:40px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;transition:transform .2s,background .2s}.vr-lock-icon svg{width:20px;height:20px;color:#ffffffb3}.vr-lock-arrow svg{width:16px;height:16px;color:#ffffff4d;animation:vrLockBounce 1s ease-in-out infinite}@keyframes vrLockBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.voice-recording-ui.locked .vr-cancel-slide{display:none}.voice-recording-ui.locked .vr-lock-zone{opacity:0}.voice-recording-ui.locked .vr-container{justify-content:center}.vr-send-btn,.vr-cancel-btn{width:42px;height:42px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.vr-send-btn{background:var(--primary, #6366f1);color:#fff}.vr-send-btn:hover{transform:scale(1.1);filter:brightness(1.2)}.vr-send-btn svg{width:22px;height:22px}.vr-cancel-btn{background:#ef444433;color:#f87171}.vr-cancel-btn:hover{background:#ef44444d;transform:scale(1.1)}.vr-cancel-btn svg{width:20px;height:20px}.background-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:9999;display:none;align-items:center;justify-content:center;animation:fadeIn .3s}.background-modal.show{display:flex}.background-modal-content{background:var(--bg-primary);border-radius:16px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0006}.background-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.background-modal-header h3{margin:0;font-size:1.25rem}.background-modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:color .2s}.background-modal-close:hover{color:var(--text-primary)}.background-options{padding:1.5rem}.background-section{margin-bottom:2rem}.background-section:last-child{margin-bottom:0}.background-section h4{margin:0 0 1rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.background-colors,.background-patterns{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:.75rem}.bg-option{width:100%;aspect-ratio:1;border-radius:12px;cursor:pointer;border:3px solid transparent;transition:all .2s;position:relative}.bg-option:hover{border-color:var(--primary);transform:scale(1.05)}.bg-option.selected{border-color:var(--primary)}.bg-option:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:1.5rem;font-weight:700;opacity:0;transition:opacity .2s}.bg-option.selected:after,.bg-option:hover:after{opacity:1}.message-context-menu{position:fixed;z-index:10000;display:none}.message-context-menu.show{display:block;animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.message-context-menu-content{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.5rem;min-width:200px;box-shadow:0 8px 24px #0006}.context-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);font-size:.95rem;cursor:pointer;border-radius:8px;transition:all .2s;text-align:left}.context-menu-item:hover{background:#ffffff1a}.context-menu-item svg{width:18px;height:18px;flex-shrink:0}.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;z-index:9999;display:none;align-items:center;justify-content:center;animation:fadeIn .3s}.modal.show{display:flex}.modal-content{background:var(--bg-primary);border-radius:16px;max-width:600px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0006;animation:slideUp .3s}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{margin:0;font-size:1.25rem}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px}.modal-close:hover{color:var(--text-primary);background:#ffffff1a}.modal-body{padding:1.5rem}.edit-profile-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.9rem;font-weight:600;color:var(--text-primary)}.form-input,.form-textarea{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.75rem;color:var(--text-primary);font-size:.95rem;transition:all .2s;font-family:inherit}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);background:var(--bg-primary)}.form-input:disabled{opacity:.6;cursor:not-allowed;background:#ffffff0d}.form-textarea{resize:vertical;min-height:80px}.form-hint{font-size:.8rem;color:var(--text-muted)}.full-width{width:100%}.profile-view{display:flex;flex-direction:column;align-items:center;gap:1rem;text-align:center}.profile-avatar-large{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,#667eea 100%);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:600;color:#fff;margin-bottom:.5rem;background-size:cover;background-position:center}.profile-view h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.user-profile-username{margin:0;color:var(--text-muted);font-size:.9rem}.user-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff0d;border-radius:20px;font-size:.85rem;margin-bottom:.5rem}.status-indicator{width:10px;height:10px;border-radius:50%;background:var(--text-muted)}.status-indicator.online{background:#10b981;box-shadow:0 0 8px #10b98180}.status-indicator.away{background:#f59e0b}.status-indicator.busy{background:#ef4444}.status-indicator.offline{background:#6b7280}.profile-details{width:100%;display:flex;flex-direction:column;gap:1rem;margin:1.5rem 0}.profile-detail-item{background:var(--bg-secondary);border-radius:12px;padding:1rem;text-align:left}.detail-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.detail-value{font-size:.95rem;color:var(--text-primary);word-break:break-word}.profile-actions-buttons{width:100%;display:flex;flex-direction:column;gap:.75rem}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3}.btn svg{margin-right:.5rem}.btn svg{width:18px;height:18px}#video-circle-btn{background:var(--bg-tertiary);color:var(--text-primary)}#video-circle-btn:hover{background:var(--bg-hover)}.video-circle-recording-ui{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);border-radius:20px;padding:2rem;box-shadow:0 10px 40px #00000080;z-index:10000;display:flex;flex-direction:column;align-items:center;gap:1rem;min-width:350px}.video-circle-preview{width:200px;height:200px;border-radius:50%;object-fit:cover;background:var(--bg-tertiary);border:3px solid var(--primary)}.video-circle-controls{display:flex;gap:1rem;align-items:center}.video-circle-timer{font-size:1.2rem;font-weight:600;color:var(--text-primary);min-width:60px;text-align:center}.video-circle-btn-cancel,.video-circle-btn-send{width:50px;height:50px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.video-circle-btn-cancel{background:var(--danger);color:#fff;font-size:1.5rem}.video-circle-btn-cancel:hover{background:#dc2626;transform:scale(1.1)}.video-circle-btn-send{background:var(--success);color:#fff}.video-circle-btn-send:hover{background:#059669;transform:scale(1.1)}.video-circle-btn-send svg{width:24px;height:24px}.video-circle-hint{font-size:.875rem;color:var(--text-muted);text-align:center}.group-call-participants{width:100%;height:100%;display:flex;flex-direction:column;background:#1e1f22}.group-call-header{padding:1.5rem;text-align:center;color:#fff;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;background:#0003;border-bottom:1px solid rgba(255,255,255,.05)}.group-call-videos-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:.5rem;padding:.5rem;overflow-y:auto}.group-call-videos-grid:has(>:nth-child(1):last-child){grid-template-columns:1fr}.group-call-videos-grid:has(>:nth-child(2):last-child){grid-template-columns:repeat(2,1fr)}.group-call-videos-grid:has(>:nth-child(n+3):last-child){grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.group-video-wrapper{position:relative;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#2b2d31;box-shadow:0 2px 10px #0000004d;transition:all .2s ease}.group-video-wrapper:hover{transform:scale(1.02);box-shadow:0 4px 16px #00000080}.group-call-participant-video{width:100%;height:100%;object-fit:cover}.group-video-name{position:absolute;bottom:.75rem;left:.75rem;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-weight:500;z-index:10;box-shadow:0 2px 8px #0000004d}.group-video-wrapper.local{box-shadow:0 0 0 2px #5865f2,0 2px 10px #0000004d}.group-video-wrapper.local .group-video-name{background:#5865f2e6}.message-context-menu{position:fixed;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 20px #00000080;padding:.5rem 0;min-width:200px;z-index:10000;opacity:0;transform:scale(.95);pointer-events:none;transition:opacity .15s,transform .15s}.message-context-menu.active{opacity:1;transform:scale(1);pointer-events:all}.context-menu-item{padding:.75rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.75rem;color:var(--text-primary);font-size:.9rem;transition:background .1s}.context-menu-item svg{width:18px;height:18px;stroke:currentColor}.context-menu-separator{height:1px;background:var(--border);margin:.5rem 0}.unified-record-btn{position:relative!important;transition:all .2s!important}.unified-record-btn[data-mode=video]{background:var(--bg-tertiary)!important}.unified-record-btn .record-icon{width:20px;height:20px}.unified-record-btn .voice-icon{display:block}.unified-record-btn .video-icon,.unified-record-btn[data-mode=video] .voice-icon{display:none}.unified-record-btn[data-mode=video] .video-icon{display:block}.record-mode-badge{position:absolute;bottom:3px;right:3px;width:8px;height:8px;background:var(--success);border-radius:50%;border:2px solid var(--bg-primary);transition:background .2s}.unified-record-btn[data-mode=video] .record-mode-badge{background:var(--warning)}.voice-video-preview{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--primary);display:none;margin-right:1rem}.voice-recording-ui.video-mode .voice-hint{content:"← Влево для отмены"}@keyframes highlight{0%,to{background:transparent}50%{background:var(--primary-alpha)}}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(400px);opacity:0}}.notification-toast{animation:slideInRight .3s ease}.settings-menu{position:fixed;top:0;right:-100%;width:400px;height:100vh;z-index:10001;transition:right .3s ease}.settings-menu.show{right:0}.settings-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:10000;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.settings-menu-overlay.show{opacity:1;visibility:visible}.settings-menu-content{width:100%;height:100%;background:var(--bg-secondary);box-shadow:-4px 0 20px #0000004d;display:flex;flex-direction:column;overflow-y:auto;position:relative;z-index:10002}.settings-menu-header{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary)}.settings-menu-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.settings-menu-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.settings-menu-close:hover{background:var(--bg-tertiary)}.settings-menu-body{flex:1;overflow-y:auto}.settings-menu-section{border-bottom:8px solid var(--bg-primary);padding:.5rem 0}.settings-menu-item{display:flex;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:background .2s;gap:1rem}.settings-menu-item:hover{background:var(--bg-tertiary)}.settings-menu-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--primary-alpha);border-radius:50%;color:var(--primary);flex-shrink:0}.settings-menu-icon svg{width:20px;height:20px}.settings-menu-icon.telegram-icon{background:#0088cc26;color:#08c}.settings-menu-text{flex:1;display:flex;flex-direction:column}.settings-menu-title{font-weight:500;color:var(--text-primary);font-size:.95rem}.settings-menu-subtitle{font-size:.85rem;color:var(--text-muted);margin-top:.2rem}.settings-menu-arrow{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.theme-selector{display:flex;align-items:center}.theme-buttons-container{display:flex;gap:.5rem;width:100%}.theme-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:12px;color:var(--text-muted);cursor:pointer;transition:all .2s;font-size:.85rem}.theme-btn svg{width:24px;height:24px;stroke-width:2}.theme-btn:hover{background:var(--bg-hover);border-color:var(--primary);color:var(--text-primary)}.theme-btn.active{background:var(--primary-alpha);border-color:var(--primary);color:var(--primary)}.theme-btn.active svg{stroke:var(--primary)}.message-context-menu{position:fixed!important;z-index:999999!important;background:var(--bg-secondary)!important;border-radius:12px!important;box-shadow:0 8px 32px #0009!important;min-width:200px!important;display:none!important;overflow:hidden!important;border:1px solid var(--border)!important}.message-context-menu.active{display:block!important}.context-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:none;color:var(--text-primary);font-size:15px;cursor:pointer;transition:background .1s;width:100%;text-align:left}.context-menu-item:hover{background:var(--bg-hover)}.context-menu-item svg{width:20px;height:20px;color:var(--text-muted)}.context-menu-item:hover svg{color:var(--text-primary)}.context-menu-item.danger{color:var(--danger)}.context-menu-item.danger:hover{background:#ef44441a}.context-menu-item.danger svg{color:var(--danger)}.context-menu-separator{height:1px;background:var(--border);margin:4px 0}.reaction-icon{font-size:20px}.connection-indicator{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.connection-indicator-content{background:var(--bg-secondary);border-radius:12px;padding:2rem;text-align:center;min-width:300px;border:1px solid var(--border);box-shadow:0 10px 40px #0000004d}.connection-indicator-content span{color:var(--text-primary);font-size:1.1rem;font-weight:500;margin:1rem 0;display:block}.connection-spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top:3px solid var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.connection-lost{animation:pulse 2s infinite}.connection-error .connection-indicator-content{border-color:var(--danger);background:linear-gradient(135deg,var(--bg-secondary) 0%,rgba(239,68,68,.1) 100%)}.error-icon{font-size:3rem;margin-bottom:1rem}.retry-button{background:var(--primary);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;margin-top:1rem;transition:all .2s ease}.retry-button:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.message-reactions-container{display:none;flex-wrap:wrap;gap:.25rem;margin-top:.5rem;margin-bottom:.25rem;padding:0 .5rem}.message-reaction{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;font-size:.75rem;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.message-reaction:hover{background:#fff3;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.message-reaction.my-reaction{background:var(--primary);border-color:var(--primary);color:#fff}.message-reaction.my-reaction:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.reaction-emoji{font-size:1rem;line-height:1}.reaction-count{font-size:.75rem;font-weight:600;min-width:1ch;text-align:center}.reaction-picker{position:fixed;z-index:10000;animation:reactionPickerSlideIn .2s ease-out}.reaction-picker-content{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:.5rem;box-shadow:0 4px 20px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.reaction-picker-emojis{display:flex;gap:.25rem}.reaction-emoji-btn{background:transparent;border:none;font-size:1.5rem;padding:.5rem;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:2.5rem;min-height:2.5rem}.reaction-emoji-btn:hover{background:#ffffff1a;transform:scale(1.1)}.reaction-emoji-btn:active{transform:scale(.95)}.context-menu-item .reaction-icon{font-size:1.2rem;line-height:1;margin-right:.5rem}@keyframes reactionPickerSlideIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.reaction-picker-content{padding:.75rem}.reaction-emoji-btn{font-size:1.75rem;min-width:3rem;min-height:3rem}.message-reaction{padding:.375rem .625rem;font-size:.8rem}.reaction-emoji{font-size:1.1rem}}.theme-selector{position:relative}.theme-switch-container{margin-left:auto;position:relative}.theme-selector-dropdown{background:transparent;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;outline:none;padding:.25rem .5rem;border-radius:6px;transition:all .2s ease}.theme-selector-dropdown:hover{background:#ffffff1a}.theme-selector-dropdown:focus{background:#ffffff1a;box-shadow:0 0 0 2px var(--primary)}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease}.btn,.btn-icon,.message-bubble,.conversation-item,.settings-menu-item,.context-menu-item,.message-reaction,.copy-id-btn,.reaction-emoji-btn{will-change:transform,opacity;transform:translateZ(0)}body{transition:background-color .3s cubic-bezier(.4,0,.2,1),color .3s cubic-bezier(.4,0,.2,1);will-change:background-color,color}[data-theme=light] .settings-menu-icon svg,[data-theme=light] .btn-icon svg,[data-theme=light] .context-menu-item svg{opacity:.8}[data-theme=light] .auth-card,[data-theme=light] .message-bubble,[data-theme=light] .settings-menu,[data-theme=light] .connection-indicator-content,[data-theme=light] .reaction-picker-content{box-shadow:0 4px 20px #0000001a}[data-theme=light] .floating-call-container{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border)}[data-theme=light] .message.own .message-bubble{background:var(--primary);color:#fff}[data-theme=light] .message:not(.own) .message-bubble{background:var(--bg-tertiary);border:1px solid var(--border)}[data-theme=light] .btn-primary{box-shadow:0 2px 8px #6366f14d}[data-theme=light] .btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border)}.current-user-id{font-size:.75rem;color:var(--text-muted);display:flex;align-items:center;gap:.25rem;margin-top:.25rem;padding:.25rem 0;border-radius:4px;transition:all .2s ease}.current-user-id:hover{background:#ffffff0d;padding-left:.5rem;padding-right:.5rem}.user-id-container{display:flex;align-items:center;gap:.5rem;font-family:Courier New,monospace;font-size:.8rem}.copy-id-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:.6}.copy-id-btn:hover{background:var(--bg-hover);color:var(--text-primary);opacity:1;transform:scale(1.1)}.copy-id-btn:active{transform:scale(.95)}.copy-id-btn svg{width:14px;height:14px}.current-user-id .copy-id-btn svg{width:12px;height:12px}.current-user-id span{font-family:Courier New,monospace;font-size:.7rem;color:var(--text-secondary)}[data-theme=light] .current-user-id:hover{background:#0000000d}[data-theme=light] .copy-id-btn:hover{background:var(--bg-tertiary)}.search-hint{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;margin-top:.25rem;padding:1rem;box-shadow:0 4px 12px #0000004d;z-index:1000;animation:slideDownFade .2s ease-out}.search-hint-content{display:flex;align-items:flex-start;gap:.75rem}.search-hint-content svg{width:20px;height:20px;color:var(--primary);flex-shrink:0;margin-top:.25rem}.search-hint-text strong{display:block;color:var(--text-primary);font-size:.9rem;margin-bottom:.25rem}.search-hint-text p{color:var(--text-muted);font-size:.8rem;margin:0;line-height:1.4}@keyframes slideDownFade{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}[data-theme=light] .search-hint{box-shadow:0 4px 12px #0000001a}:root{--animation-duration-fast: .15s;--animation-duration-normal: .25s;--animation-duration-slow: .4s;--animation-easing-bounce: cubic-bezier(.68, -.55, .265, 1.55);--animation-easing-smooth: cubic-bezier(.4, 0, .2, 1);--animation-easing-sharp: cubic-bezier(.4, 0, .6, 1)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px) translateZ(0)}to{opacity:1;transform:translateY(0) translateZ(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8) translateZ(0)}to{opacity:1;transform:scale(1) translateZ(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px) translateZ(0)}to{opacity:1;transform:translate(0) translateZ(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px) translateZ(0)}to{opacity:1;transform:translate(0) translateZ(0)}}.message.new-message{animation:fadeInUp var(--animation-duration-normal) var(--animation-easing-smooth) forwards}.message.own.new-message{animation:slideInRight var(--animation-duration-normal) var(--animation-easing-smooth) forwards}.message:not(.own).new-message{animation:slideInLeft var(--animation-duration-normal) var(--animation-easing-smooth) forwards}.conversation-item:hover{transform:translate(4px) translateZ(0);background:var(--bg-hover);transition:all var(--animation-duration-fast) var(--animation-easing-smooth)}.btn:hover{transform:translateY(-2px) translateZ(0) scale(1.02);transition:all var(--animation-duration-fast) var(--animation-easing-bounce)}.btn:active{transform:translateY(0) translateZ(0) scale(.98);transition:all var(--animation-duration-fast) var(--animation-easing-sharp)}.message-reaction{animation:fadeInScale var(--animation-duration-normal) var(--animation-easing-bounce) forwards}.message-reaction:hover{transform:translateY(-2px) translateZ(0) scale(1.05);transition:all var(--animation-duration-fast) var(--animation-easing-bounce)}.modal.show{animation:fadeInScale var(--animation-duration-normal) var(--animation-easing-smooth) forwards}.profile-modal.show,.settings-menu.show{animation:slideInRight var(--animation-duration-normal) var(--animation-easing-smooth) forwards}@keyframes pulse{0%,to{opacity:1;transform:scale(1) translateZ(0)}50%{opacity:.7;transform:scale(1.05) translateZ(0)}}.loading-indicator{animation:pulse 1.5s ease-in-out infinite}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.message-bubble,.conversation-item,.btn,.modal,.settings-menu{contain:layout style}:root{--button-min-height: 36px;--touch-target-size: 40px;--interactive-area-padding: 8px}.mobile-device{--button-min-height: 44px;--touch-target-size: 44px;--interactive-area-padding: 12px}.mobile-device .btn,.mobile-device .btn-icon{min-height:var(--button-min-height);min-width:var(--touch-target-size);padding:var(--interactive-area-padding)}.mobile-device .conversation-item{padding:1rem}.mobile-device .message-bubble{font-size:1rem;line-height:1.5}.tablet-device{--button-min-height: 40px;--touch-target-size: 42px;--interactive-area-padding: 10px}.tablet-device .sidebar{width:320px}.touch-device .copy-id-btn,.touch-device .reaction-emoji-btn,.touch-device .message-reaction{min-width:var(--touch-target-size);min-height:var(--touch-target-size)}.touch-device .conversation-item:hover{background:var(--bg-hover)}.desktop-device .conversation-item:hover{transform:translate(4px) translateZ(0);transition:all var(--animation-duration-fast) var(--animation-easing-smooth)}.desktop-device .btn:hover{transform:translateY(-2px) translateZ(0)}@media (hover: none){.conversation-item:hover,.btn:hover,.message-reaction:hover{transform:none}}@media (max-width: 768px){body:not(.mobile-device){--button-min-height: 42px;--touch-target-size: 42px}}@media (min-width: 1200px){.desktop-device .sidebar{width:380px}.desktop-device .chat-area{padding:1.5rem}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 2dppx){.avatar,.profile-avatar-large{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}.audio-duration{font-family:JetBrains Mono,Courier New,monospace;font-weight:500;font-size:.75rem;letter-spacing:.02em}.audio-size{opacity:.6;font-size:.7rem}[data-theme=light] .message-audio{background:linear-gradient(135deg,#0000000a,#00000005);border-color:#0000001a}[data-theme=light] .audio-waveform-bar{background:var(--text-secondary)}.contact-item{position:relative;transition:all .2s ease}.contact-item:hover{background:var(--bg-hover);transform:translate(4px)}.conversation-actions{display:flex;gap:.5rem;opacity:0;transition:opacity .2s ease;position:absolute;right:1rem;top:50%;transform:translateY(-50%)}.contact-item:hover .conversation-actions,.conversation-item:hover .conversation-actions{opacity:1}.conversation-actions .btn-icon{padding:.5rem;background:#ffffff1a;border-radius:6px;width:32px;height:32px}.conversation-actions .btn-icon:hover{background:var(--primary);transform:scale(1.1)}.user-status-indicator{width:8px;height:8px;border-radius:50%;margin-left:.5rem;flex-shrink:0}.user-status-indicator.online{background:#10b981;box-shadow:0 0 6px #10b98180}.user-status-indicator.away{background:#f59e0b;box-shadow:0 0 6px #f59e0b80}.user-status-indicator.busy{background:#ef4444;box-shadow:0 0 6px #ef444480}.user-status-indicator.offline{background:#6b7280;border:2px solid var(--bg-secondary)}.status-dot{position:absolute;bottom:2px;right:2px;width:10px;height:10px;background:#10b981;border:2px solid var(--bg-primary);border-radius:50%;box-shadow:0 0 6px #10b98180}[data-theme=light] .conversation-actions .btn-icon{background:#0000001a}[data-theme=light] .user-status-indicator.offline,[data-theme=light] .status-dot{border-color:var(--bg-primary)}.settings-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease;pointer-events:none}.settings-modal-overlay.show{opacity:1;pointer-events:all}.settings-modal{background:var(--bg-secondary, #1e2330);border-radius:16px;box-shadow:0 20px 60px #00000080;border:1px solid rgba(255,255,255,.08);width:90%;max-width:420px;max-height:80vh;overflow-y:auto;transform:scale(.95) translateY(10px);transition:transform .25s cubic-bezier(.2,0,0,1)}.settings-modal-overlay.show .settings-modal{transform:scale(1) translateY(0)}.settings-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid rgba(255,255,255,.06)}.settings-modal-header h3{font-size:17px;font-weight:600;color:#fff;margin:0}.settings-modal-close{width:32px;height:32px;border-radius:8px;border:none;background:#ffffff0f;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.settings-modal-close:hover{background:#ffffff1f;color:#fff}.settings-modal-close svg{width:18px;height:18px}.settings-modal-body{padding:16px 20px}.settings-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:12px 20px 18px;border-top:1px solid rgba(255,255,255,.06)}.sm-btn-cancel,.sm-btn-save{padding:8px 20px;border-radius:10px;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.sm-btn-cancel{background:#ffffff0f;color:#ffffffb3}.sm-btn-cancel:hover{background:#ffffff1f}.sm-btn-save{background:var(--primary, #6366f1);color:#fff}.sm-btn-save:hover{filter:brightness(1.15)}.settings-group{display:flex;flex-direction:column;gap:12px}.settings-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#ffffff0a;border-radius:10px;cursor:pointer;transition:background .15s}.settings-toggle:hover{background:#ffffff14}.settings-toggle span:first-child{font-size:14px;color:#e8eaed}.toggle-slider{position:relative;width:44px;height:24px;border-radius:12px;background:#ffffff26;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}.settings-toggle input{display:none}.settings-toggle input:checked+.toggle-slider{background:var(--primary, #6366f1)}.settings-toggle input:checked+.toggle-slider:after{transform:translate(20px)}.settings-select-group{display:flex;flex-direction:column;gap:6px;padding:6px 0}.settings-select-group label{font-size:13px;color:#fff9}.settings-select-group select{padding:8px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#fff;font-size:14px;outline:none}.settings-select-group select:focus{border-color:var(--primary, #6366f1)}.settings-input-group{display:flex;flex-direction:column;gap:6px}.settings-input-group label{font-size:13px;color:#fff9}.settings-input-group input{padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:#fff;font-size:14px;outline:none;transition:border-color .15s}.settings-input-group input:focus{border-color:var(--primary, #6366f1)}.settings-range-group{padding:6px 0}.settings-range-group label{font-size:13px;color:#fff9;display:block;margin-bottom:8px}.settings-range-group input[type=range]{width:100%;accent-color:var(--primary, #6366f1)}.settings-hint{font-size:12px;color:#ffffff59;margin:4px 0 0;padding:0 4px}.settings-radio-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;border:2px solid transparent;background:#ffffff0a;cursor:pointer;transition:all .15s}.settings-radio-card:hover{background:#ffffff14}.settings-radio-card.active{border-color:var(--primary, #6366f1);background:#6366f114}.settings-radio-card input{display:none}.radio-flag{font-size:28px}.settings-radio-card strong{font-size:15px;color:#fff;display:block}.settings-radio-card small{font-size:12px;color:#fff6}.broadcast-panel{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,var(--role-superadmin) 0%,#7c3aed 100%);border-radius:16px;padding:1.5rem;box-shadow:0 10px 40px #a855f766;min-width:300px;max-width:400px;z-index:1000;display:none}.broadcast-panel.show{display:block;animation:slideInRight .3s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.broadcast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.broadcast-header h3{color:#fff;font-size:1.125rem;font-weight:700;text-shadow:0 0 10px rgba(255,255,255,.5)}.broadcast-close{background:#fff3;border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.broadcast-close:hover{background:#ffffff4d;transform:rotate(90deg)}.broadcast-textarea{width:100%;min-height:100px;padding:.75rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.95rem;resize:vertical;margin-bottom:1rem}.broadcast-textarea::placeholder{color:#ffffff80}.broadcast-textarea:focus{outline:none;border-color:#fff6;background:#ffffff26}.broadcast-btn{width:100%;padding:.875rem;background:#fff;color:var(--role-superadmin);border:none;border-radius:8px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .3s}.broadcast-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px #ffffff4d}.broadcast-btn:disabled{opacity:.5;cursor:not-allowed}.broadcast-toggle{position:fixed;bottom:20px;right:20px;width:60px;height:60px;background:linear-gradient(135deg,var(--role-superadmin) 0%,#7c3aed 100%);border:none;border-radius:50%;color:#fff;font-size:1.5rem;cursor:pointer;box-shadow:0 10px 30px #a855f766;transition:all .3s;display:none;align-items:center;justify-content:center;z-index:999}.broadcast-toggle.show{display:flex}.broadcast-toggle:hover{transform:scale(1.1) rotate(15deg);box-shadow:0 15px 40px #a855f799}.broadcast-stats{margin-top:1rem;padding:.75rem;background:#ffffff1a;border-radius:8px;font-size:.875rem;color:#fffc}
