*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body.buzz-shake{animation:buzz-shake-animation .5s ease-in-out}@keyframes buzz-shake-animation{0%,to{transform:translate(0) rotate(0deg)}10%{transform:translate(-5px,-5px) rotate(-2deg)}20%{transform:translate(5px,5px) rotate(2deg)}30%{transform:translate(-5px,5px) rotate(-2deg)}40%{transform:translate(5px,-5px) rotate(2deg)}50%{transform:translate(-5px,-5px) rotate(-2deg)}60%{transform:translate(5px,5px) rotate(2deg)}70%{transform:translate(-5px,5px) rotate(-2deg)}80%{transform:translate(5px,-5px) rotate(2deg)}90%{transform:translate(-5px,-5px) rotate(-2deg)}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,.App,body,html{height:100%;width:100%}.auth-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;height:100%;justify-content:center;min-height:100vh;padding:20px}.toggle-auth{color:#fff;font-size:14px;margin-top:20px;text-align:center}.toggle-auth button{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-left:5px;text-decoration:underline}.toggle-auth button:hover{opacity:.8}@media (max-width:480px){.auth-container{padding:15px}.toggle-auth{font-size:12px}}.auth-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:500px;padding:40px;width:100%}.auth-form h2{color:#333;margin-bottom:30px;text-align:center}.form-row{display:flex;gap:15px;margin-bottom:20px}.form-row .form-group{margin-bottom:0}.form-group.half{flex:1 1}.form-group label{margin-bottom:8px}.form-group input{border:1px solid #ddd;border-radius:5px;padding:10px 12px;transition:border-color .3s}.form-group input:focus{box-shadow:0 0 0 3px #667eea1a}.password-input-wrapper{position:relative;width:100%}.password-input-wrapper input{padding-right:40px;width:100%}.password-toggle-btn{align-items:center;border:none!important;color:#aaa!important;cursor:pointer;display:flex;height:30px!important;justify-content:center;margin:0!important;padding:0!important;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:color .3s;width:30px!important;z-index:2}.password-toggle-btn,.password-toggle-btn:hover{background:#0000!important;box-shadow:none!important}.password-toggle-btn:hover{color:#667eea!important;transform:translateY(-50%)!important}.password-toggle-btn svg{height:20px;width:20px}.form-hint{color:#888;display:block;font-size:12px;margin-top:4px}.password-requirements{background:#f8f9fa;border-left:3px solid #667eea;border-radius:5px;margin-top:10px;padding:10px}.requirement{color:#666;font-size:13px;margin:4px 0;transition:all .3s}.requirement.valid{color:#28a745;font-weight:500}.text-success{color:#28a745}.text-error,.text-success{display:block;font-size:12px;margin-top:4px}.text-error{color:#dc3545}.auth-form button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px;transition:all .3s;width:100%}.auth-form button:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.auth-form button:disabled{background:#ccc;cursor:not-allowed;transform:none}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#721c24;font-size:14px;margin-bottom:20px;padding:12px;text-align:center}.user-list{flex:1 1;list-style:none;margin:0;overflow-y:auto;padding:0}.user-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:10px;padding:12px 15px;transition:all .3s}.user-item:hover{background:#f9f9f9}.user-item.active{background:#e8f0fe;border-left:3px solid #667eea}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:45px;justify-content:center;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s;width:45px}.user-avatar:hover{box-shadow:0 4px 12px #667eea66;transform:scale(1.1)}.avatar-fallback,.avatar-image{border-radius:50%;height:100%;object-fit:cover;width:100%}.avatar-fallback{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center}.user-details{flex:1 1;min-width:0}.user-name-row{align-items:center;display:flex;gap:8px}.user-name{color:#333;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.new-user-badge{animation:pulse-badge 2s ease-in-out infinite;background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:10px;box-shadow:0 2px 4px #11998e4d;color:#fff;flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}@keyframes pulse-badge{0%,to{box-shadow:0 2px 4px #11998e4d;transform:scale(1)}50%{box-shadow:0 3px 6px #11998e80;transform:scale(1.05)}}.user-email{color:#999}.last-message-preview,.user-email{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.last-message-preview{color:#666;font-style:italic;margin-top:2px}.typing-indicator{color:#667eea;font-size:12px;font-style:italic;gap:6px;margin-top:2px}.typing-text{animation:typing-pulse 1.5s ease-in-out infinite}@keyframes typing-pulse{0%,to{opacity:1}50%{opacity:.6}}.typing-dots{align-items:center;display:flex;gap:2px}.typing-dots .dot{animation:typing-bounce 1.4s ease-in-out infinite;background-color:#667eea;border-radius:50%;height:4px;width:4px}.typing-dots .dot:first-child{animation-delay:0s}.typing-dots .dot:nth-child(2){animation-delay:.2s}.typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{opacity:.5;transform:scale(1)}40%{opacity:1;transform:scale(1.3)}}.user-status-info{align-items:flex-end;display:flex;flex-direction:column;gap:4px;margin-left:auto}.message-timestamp{color:#999;font-size:10px;white-space:nowrap}.read-status{font-size:10px;margin-top:2px}.read-indicator{color:#4caf50}.read-indicator,.sent-indicator{align-items:center;display:flex;font-weight:500;gap:2px}.sent-indicator{color:#999}.status-indicator{border-radius:12px;flex-shrink:0;font-size:11px;padding:3px 6px;white-space:nowrap}.status-indicator.online{background:#e8f5e9;color:#2e7d32}.status-indicator.offline{background:#f5f5f5;color:#999}.unread-badge{align-items:center;animation:pulse 2s infinite;background:#ff4757;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:24px;justify-content:center;margin-left:8px;width:24px}@media (max-width:1024px){.user-item{padding:10px 12px}.user-avatar{font-size:14px;height:40px;width:40px}.user-name{font-size:13px}.user-email{font-size:11px}}@media (max-width:768px){.user-item{padding:10px 12px}.user-avatar{font-size:14px;height:40px;width:40px}.user-name{font-size:13px}.user-email{font-size:10px}.status-indicator{font-size:10px;padding:2px 4px}.unread-badge{font-size:11px;height:20px;width:20px}}@media (max-width:480px){.user-item{padding:8px 10px}.user-avatar{height:36px;overflow:visible!important;position:relative;width:36px}.user-avatar,.user-name{font-size:12px}.user-email{font-size:9px}.status-indicator{display:none}.unread-badge{font-size:10px;height:18px;width:18px}.user-avatar:after{background:#4caf50;border:2px solid #fff;border-radius:50%;bottom:-3px;box-shadow:0 2px 6px #0000004d;content:"";display:none;height:12px;position:absolute;right:-3px;width:12px;z-index:9999}.user-avatar.online-indicator:after{display:block}}.gif-selector-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.gif-selector-modal{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;max-height:600px;max-width:500px;width:100%}.gif-selector-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;padding:15px 20px}.gif-selector-header h3{color:#333;font-size:16px;margin:0}.close-btn{transition:color .3s}.gif-search-input{border:none;border-bottom:1px solid #ddd;font-family:inherit;font-size:14px;padding:10px 15px}.gif-search-input:focus{border-bottom-color:#e91e63;outline:none}.gif-grid{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));overflow-y:auto;padding:15px}.gif-item{border-radius:8px;cursor:pointer;height:100px;overflow:hidden;transition:transform .2s,box-shadow .2s}.gif-item:hover{box-shadow:0 2px 8px #0003;transform:scale(1.05)}.gif-item img{display:block;height:100%;object-fit:cover;width:100%}.loading-gifs,.no-gifs{align-items:center;color:#999;display:flex;font-size:14px;grid-column:1/-1;justify-content:center;min-height:200px}@media (max-width:768px){.gif-selector-modal{max-height:80vh;max-width:95%}.gif-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.gif-item{height:80px}}@media (max-width:480px){.gif-grid,.gif-selector-overlay{padding:10px}.gif-grid{gap:8px;grid-template-columns:repeat(3,1fr)}.gif-item{height:70px}}.forward-modal-overlay{align-items:center;animation:fadeIn .2s;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.forward-modal{animation:slideUp .3s;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:500px;width:90%}.forward-modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.forward-modal-header h3{color:#333;font-size:18px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.close-btn:hover{background:#f0f0f0;color:#333}.forward-message-preview{background:#f9f9f9;border-bottom:1px solid #e0e0e0;padding:15px 20px}.forward-message-preview p{color:#666;font-size:12px;margin:0 0 8px}.message-content-preview{background:#fff;border-left:3px solid #667eea;border-radius:6px;color:#333;font-size:14px;font-style:italic;padding:8px}.forward-search{border-bottom:1px solid #e0e0e0;padding:15px 20px}.forward-search-input{border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;padding:10px 15px;transition:border-color .2s;width:100%}.forward-search-input:focus{border-color:#667eea}.forward-user-list{flex:1 1;max-height:400px;min-height:200px;overflow-y:auto;padding:10px 0}.forward-user-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:12px 20px;transition:background .2s}.forward-user-item:hover{background:#f9f9f9}.forward-user-item.selected{background:#e8f0fe}.user-checkbox{accent-color:#667eea;cursor:pointer;height:20px;width:20px}.user-avatar-small{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:40px;justify-content:center;width:40px}.user-info-forward{flex:1 1;min-width:0}.user-name-forward{color:#333;font-size:14px;font-weight:600}.user-email-forward,.user-name-forward{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email-forward{color:#999;font-size:12px}.no-users-found{color:#999;font-size:14px;padding:40px 20px;text-align:center}.forward-modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:10px;padding:15px 20px}.cancel-forward-btn,.send-forward-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.cancel-forward-btn{background:#f0f0f0;color:#666}.cancel-forward-btn:hover{background:#e0e0e0}.send-forward-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.send-forward-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.send-forward-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.forward-modal{max-height:90vh;width:95%}.forward-modal-header h3{font-size:16px}.forward-user-list{max-height:300px}}.sticker-manager-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.sticker-manager{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:700px;width:90%}.sticker-manager-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #eee;border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px}.sticker-manager-header h2{font-size:24px;margin:0}.close-sticker-btn{background:#0000;border:none;color:#fff;cursor:pointer;font-size:32px;line-height:1;padding:0;transition:transform .2s}.close-sticker-btn:hover{transform:scale(1.2)}.sticker-manager-nav{background:#f9f9f9;border-bottom:1px solid #eee;display:flex;gap:10px;padding:15px 20px}.sticker-manager-nav button{background:#fff;border:none;border-radius:8px;box-shadow:0 2px 5px #0000001a;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s}.sticker-manager-nav button:hover{box-shadow:0 4px 10px #00000026;transform:translateY(-2px)}.sticker-manager-nav button.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sticker-manager-nav button.create-btn{background:#4caf50;color:#fff;margin-left:auto}.sticker-manager-nav button.create-btn:hover{background:#45a049}.sticker-manager-content{flex:1 1;overflow-y:auto;padding:20px}.stickers-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.sticker-item{aspect-ratio:1;background:#fff;border:2px solid #eee;border-radius:12px;cursor:pointer;overflow:hidden;position:relative;transition:all .3s}.sticker-item:hover{border-color:#667eea;box-shadow:0 6px 20px #667eea4d;transform:scale(1.05)}.sticker-item img,.sticker-item video{height:100%;object-fit:contain;padding:10px;width:100%}.animated-sticker{border:2px solid #ff6b6b!important}.delete-sticker-btn{background:#f44336e6;border:none;border-radius:50%;cursor:pointer;font-size:16px;height:30px;opacity:0;position:absolute;right:5px;top:5px;transition:opacity .3s;width:30px}.sticker-item:hover .delete-sticker-btn{opacity:1}.delete-sticker-btn:hover{background:#f44336;transform:scale(1.1)}.empty-message{color:#999;font-size:16px;padding:40px 20px;text-align:center}.packs-list{display:flex;flex-direction:column;gap:15px}.create-pack-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px;transition:all .3s}.create-pack-btn:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.pack-item{align-items:center;background:#fff;border:2px solid #eee;border-radius:12px;cursor:pointer;display:flex;gap:15px;padding:15px;position:relative;transition:all .3s}.pack-item:hover{border-color:#667eea;box-shadow:0 4px 15px #667eea33;transform:translateY(-2px)}.pack-cover{background:#f5f5f5;border-radius:8px;height:80px;object-fit:contain;padding:5px;width:80px}.pack-info{flex:1 1}.pack-info h3{color:#333;font-size:18px;margin:0 0 5px}.pack-info p{color:#666;font-size:14px;margin:0}.delete-pack-btn{background:#f44336e6;border:none;border-radius:8px;cursor:pointer;font-size:18px;padding:8px 12px;transition:all .3s}.delete-pack-btn:hover{background:#f44336;transform:scale(1.1)}.back-btn{background:#666;border:none;border-radius:8px;color:#fff;cursor:pointer;margin-bottom:15px;padding:10px 15px;transition:all .3s}.back-btn:hover{background:#555}.add-to-pack-btn{background:#4caf50;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:20px;padding:12px;transition:all .3s;width:100%}.add-to-pack-btn:hover{background:#45a049;transform:translateY(-2px)}.create-pack-form,.upload-sticker-form{display:flex;flex-direction:column;gap:15px;margin:0 auto;max-width:500px}.create-pack-form h3,.upload-sticker-form h3{color:#333;margin:0 0 10px}.create-pack-form input,.create-pack-form textarea,.upload-sticker-form input[type=text]{border:2px solid #eee;border-radius:8px;font-family:inherit;font-size:16px;padding:12px;transition:border-color .3s}.create-pack-form input:focus,.create-pack-form textarea:focus,.upload-sticker-form input[type=text]:focus{border-color:#667eea;outline:none}.create-pack-form textarea{min-height:80px;resize:vertical}.file-input-container{background:#f9f9ff;border:2px dashed #667eea;border-radius:12px;padding:20px;text-align:center}.file-input-container input[type=file]{margin-bottom:15px}.sticker-preview{display:flex;justify-content:center;margin-top:15px}.sticker-preview img,.sticker-preview video{border-radius:8px;box-shadow:0 4px 10px #0000001a;max-height:200px;max-width:200px;object-fit:contain}.help-text{background:#f0f0f0;border-radius:8px;color:#666;font-size:14px;margin:0;padding:10px}.form-buttons{display:flex;gap:10px}.form-buttons button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px;transition:all .3s}.form-buttons button[type=submit]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.form-buttons button[type=submit]:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.form-buttons button[type=submit]:disabled{cursor:not-allowed;opacity:.5}.form-buttons button[type=button]{background:#ccc;color:#333}.form-buttons button[type=button]:hover{background:#bbb}@media (max-width:768px){.sticker-manager{max-height:90vh;width:95%}.stickers-grid{gap:10px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.pack-item{flex-direction:column;text-align:center}.pack-cover{height:150px;width:100%}}.sticker-toast{align-items:center;animation:slideInRight .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;display:flex;font-size:15px;font-weight:500;gap:12px;max-width:400px;padding:16px 24px;position:fixed;right:20px;top:20px;z-index:10000}.sticker-toast.fade-out{animation:fadeOut .3s ease-out forwards}.sticker-toast-success{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sticker-toast-error{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.toast-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:20px;font-weight:700;height:28px;justify-content:center;width:28px}.toast-message{flex:1 1}@media (max-width:768px){.sticker-toast{font-size:14px;left:10px;max-width:calc(100% - 20px);padding:14px 18px;right:10px;top:10px}}.chat-window{display:flex;flex-direction:column;height:100%;width:100%}.chat-header{align-items:center;background:linear-gradient(135deg,#667eea,#624ba2);border-bottom:1px solid #ddd;color:#fff;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:20px}.back-button{background:#0000;border:none;color:#fff;cursor:pointer;display:none;font-size:28px;font-weight:700;line-height:1;margin-right:5px;padding:0;transition:all .3s}.back-button:hover{color:#fffc;transform:scale(1.1)}.back-button:active{transform:scale(.95)}@media (max-width:768px){.back-button{align-items:center;display:flex;justify-content:center}}.header-info{align-items:center;display:flex;flex:1 1;gap:15px}.header-info h2{font-size:20px;margin:0}.status{align-items:center;display:flex;font-size:14px;gap:5px;white-space:nowrap}.status.online{color:#4caf50;font-weight:600}.status.offline{color:#bbb}.messages-container{background:#f9f9f9;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-x:hidden;overflow-y:auto;padding:20px;width:100%}.message{word-wrap:break-word;align-items:flex-end;animation:slideIn .3s ease-in-out;display:flex;gap:10px;margin-bottom:8px;max-width:80%;position:relative}.message .sender-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 2px 8px #00000026;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;min-width:48px;overflow:hidden;position:relative;transition:transform .2s;width:48px}.message .sender-avatar:hover{transform:scale(1.1)}.message .sender-avatar-image{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.message .sender-avatar-fallback{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;height:100%;justify-content:center;width:100%}.message-bubble-wrapper{display:flex;flex:1 1;flex-direction:column;gap:8px;max-width:calc(100% - 58px)}.message-check-icon{align-items:center;align-self:flex-end;color:#666;display:flex;flex-shrink:0;font-size:14px;font-weight:700;margin-bottom:8px;margin-left:4px}.message.sent .message-check-icon{color:#0006}.message.sent .message-check-icon.read{color:#69f0ae}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-wrapper{display:flex;flex:1 1;flex-direction:column;position:relative}.message.sent{align-self:flex-end;flex-direction:row-reverse;margin-right:10px}.message.sent .message-bubble-wrapper{align-items:flex-end}.message.received{align-self:flex-start;flex-direction:row;margin-left:10px}.message.received .message-bubble-wrapper{align-items:flex-start}.message-content{word-wrap:break-word;border-radius:18px;-webkit-hyphens:auto;hyphens:auto;line-height:1.5;max-width:100%;overflow:hidden;overflow-wrap:anywhere;padding:12px 16px;position:relative;white-space:pre-wrap;word-break:break-word}.message.sent .message-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:18px 18px 4px 18px;box-shadow:0 2px 8px #667eea4d;color:#fff}.message.received .message-content{background:#fff;border-radius:18px 18px 18px 4px;box-shadow:0 2px 8px #0000001a;color:#333}.forward-btn{align-items:center;background:#0000000d;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;min-width:28px;opacity:0;position:absolute;top:0;transition:all .2s;width:28px;z-index:1}.message.sent .forward-btn{right:0}.message.received .forward-btn{left:0}.message:hover .forward-btn{opacity:.8}.forward-btn:hover{background:#0000001a;opacity:1!important;transform:scale(1.1)}.message.sent .forward-btn{background:#fff3;color:#fff}.message.sent .forward-btn:hover{background:#ffffff4d}.message-time{color:#fffc}.message.received .message-time{color:#999}.message.sent .message-time{text-align:right}.typing-indicator{align-items:center;color:#999;display:flex;font-size:14px;gap:8px;padding:0 8px}.spam-warning{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,gold,orange);border-top:1px solid #ddd;color:#333;display:flex;gap:12px;padding:12px 20px}.warning-icon{flex-shrink:0;font-size:20px}.warning-text{flex:1 1;font-size:14px;font-weight:500}.message-counter{background:#0000001a;border-radius:4px;font-weight:700;margin-left:4px;padding:2px 6px}.ban-warning{align-items:center;animation:slideDown .3s ease-out;background:linear-gradient(135deg,#f44,#c00);border-top:1px solid #ddd;color:#fff;display:flex;gap:12px;padding:15px 20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.ban-icon{flex-shrink:0;font-size:24px}.ban-text{flex:1 1;font-size:14px;font-weight:500}.ban-text strong{background:#fff3;border-radius:4px;font-size:16px;font-weight:700;padding:2px 6px}.code-btn:disabled,.gif-btn:disabled,.message-input:disabled,.send-btn:disabled{cursor:not-allowed;opacity:.5}.message-form{background:#fff;border-top:1px solid #ddd;display:flex;flex-wrap:wrap;gap:8px;padding:15px}.message-input{border:1px solid #ddd;border-radius:5px;flex:1 1;font-family:inherit;font-size:14px;max-height:100px;min-width:200px;padding:10px 12px;resize:none}.message-input:focus{border-color:#667eea;outline:none}.send-btn{white-space:nowrap}.send-btn:active{transform:scale(.98)}.code-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 12px;transition:all .3s}.code-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.code-input-container{background:#f5f5f5;border-top:2px solid #ddd;display:flex;flex-direction:column;gap:10px}.code-input-header select{border-radius:4px;padding:8px 12px}.code-textarea{background:#fff;color:#333;font-family:Courier New,Courier,monospace;font-size:13px;padding:12px;resize:none}.code-textarea:focus{box-shadow:0 0 5px #667eea4d}.cancel-btn{background:#bbb;border:none;border-radius:4px;color:#fff;padding:10px 20px}.cancel-btn:hover{background:#999}.send-code-btn{border-radius:4px;padding:10px 20px}.code-block{background:#1e1e1e;border-radius:5px;color:#d4d4d4;font-family:Courier New,Courier,monospace;font-size:13px;line-height:1.5;margin:0;max-height:400px;max-width:100%;overflow-wrap:anywhere;overflow-x:auto;overflow-y:auto;padding:15px;word-break:break-all}.copy-toast{animation:slideInRight .3s ease-out;background:#4caf50;border-radius:8px;box-shadow:0 4px 12px #0000004d;color:#fff;font-weight:600;padding:12px 20px;position:fixed;right:20px;top:20px;z-index:10000}.code-block code{word-wrap:normal;display:block;overflow-wrap:normal;white-space:pre}.message-link{border-bottom:1px dotted #667eea;color:#667eea;cursor:pointer;overflow-wrap:break-word;text-decoration:none;transition:all .3s ease;word-break:break-all}.message-link:hover{border-bottom-color:#764ba2;color:#764ba2;text-decoration:underline}.message-link:visited{color:#8b6fa8}.gif-message{border-radius:12px;display:block;margin:5px 0;max-height:300px;max-width:100%}.gif-btn{background:#e91e63;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 12px;transition:background .3s}.gif-btn:hover{background:#c2185b}.sticker-btn{background:#9c27b0;border:none;border-radius:5px;color:#fff;cursor:pointer;flex-shrink:0;font-size:18px;font-weight:600;padding:10px 12px;transition:background .3s}.sticker-btn:hover:not(:disabled){background:#7b1fa2}.sticker-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.buzz-btn{background:#ff9800;border:none;border-radius:5px;color:#fff;cursor:pointer;flex-shrink:0;font-size:18px;padding:10px 12px;transition:all .3s}.buzz-btn:hover:not(:disabled){background:#f57c00;transform:scale(1.05)}.buzz-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.buzz-shake{animation:buzzShake .5s ease-in-out}@keyframes buzzShake{0%,to{transform:translate(0) rotate(0deg)}10%{transform:translate(-10px,-5px) rotate(-2deg)}20%{transform:translate(10px,5px) rotate(2deg)}30%{transform:translate(-10px,5px) rotate(-2deg)}40%{transform:translate(10px,-5px) rotate(2deg)}50%{transform:translate(-10px,-5px) rotate(-2deg)}60%{transform:translate(10px,5px) rotate(2deg)}70%{transform:translate(-10px,5px) rotate(-2deg)}80%{transform:translate(10px,-5px) rotate(2deg)}90%{transform:translate(-5px,-2px) rotate(-1deg)}}.buzz-message{align-items:center;display:flex;flex-direction:column;gap:10px;padding:15px;text-align:center}.buzz-icon{animation:buzzPulse 1s ease-in-out infinite;font-size:48px}.buzz-text{color:#333;font-size:14px;font-weight:600}.buzz-reply-btn{background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:20px;box-shadow:0 2px 8px #ff98004d;color:#fff;cursor:pointer;font-size:13px;font-weight:600;margin-top:5px;padding:8px 16px;transition:all .3s}.buzz-reply-btn:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#e65100);box-shadow:0 4px 12px #ff980066;transform:translateY(-2px)}.buzz-reply-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;opacity:.6}@media (max-width:1024px){.chat-header{padding:15px}.header-info h2{font-size:18px}.status{font-size:12px}.message{max-width:85%}.messages-container{gap:10px;padding:15px}.message-content{padding:10px 14px}.message-form{gap:6px;padding:12px}}@media (max-width:768px){.chat-header{padding:12px}.chat-header,.header-info{align-items:center;flex-direction:row;gap:10px}.header-info{flex:1 1;width:auto}.header-info h2{font-size:16px;margin:0}.status{font-size:11px}.message{max-width:85%}.message-bubble-wrapper{max-width:100%;overflow:hidden}.messages-container{gap:8px;padding:10px}.message-content{font-size:13px;padding:8px 12px}.message-check-icon{font-size:12px}.message-time{font-size:10px}.message-read-status{font-size:10px;margin-top:2px}.message-form{gap:5px;padding:10px}.message-input{font-size:13px;min-width:150px;padding:8px 10px}.code-btn,.gif-btn,.send-btn{font-size:12px;padding:8px 10px}.code-input-container{padding:12px}.code-textarea{font-size:12px;max-height:150px;padding:10px}.code-block{font-size:11px;padding:10px}}@media (max-width:480px){.chat-header{padding:10px}.back-button{font-size:24px;margin-right:3px}.header-info{gap:8px}.header-info h2{font-size:14px}.status{font-size:10px}.message{max-width:90%}.message-bubble-wrapper{max-width:100%;overflow:hidden}.message-content{border-radius:12px;max-width:100%;overflow-wrap:anywhere;padding:8px 10px;word-break:break-all}.messages-container{gap:6px;padding:8px}.message-form{gap:3px;padding:8px 5px}.message-input{font-size:13px;min-width:100px;padding:6px 8px}.code-btn,.gif-btn,.send-btn{font-size:11px;padding:6px 8px}.typing-indicator{font-size:12px;padding:0 4px}.message-check-icon{font-size:11px}}.image-message{border-radius:8px;cursor:pointer;display:block;max-height:400px;max-width:300px;object-fit:cover;transition:transform .2s,box-shadow .2s}.image-message:hover{box-shadow:0 4px 12px #0003;transform:scale(1.02)}.file-message{align-items:center;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;color:#333;display:flex;gap:10px;max-width:300px;padding:12px 16px;text-decoration:none;transition:all .2s}.file-message:hover{background:#e8e8e8;box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.file-icon{flex-shrink:0;font-size:24px}.file-info{display:flex;flex-direction:column;gap:2px;min-width:0}.file-name{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#666;font-size:12px}@media (max-width:768px){.attachment-btn{font-size:16px;padding:8px 12px}.image-message{max-height:350px;max-width:250px}.file-message{max-width:250px;padding:10px 12px}}@media (max-width:480px){.attachment-btn{font-size:14px;padding:6px 10px}.image-message{max-height:300px;max-width:200px}.file-message{max-width:200px;padding:8px 10px}.file-name{font-size:13px}.file-size{font-size:11px}}.messages-container{position:relative}.messages-container.dragging{background:#667eea0d}.drop-overlay{animation:fadeIn .2s ease;background:#667eeae6}.drop-message{background:#ffffff1a;border:3px dashed #fff;border-radius:20px;padding:40px}.drop-icon{animation:bounce .6s infinite;font-size:60px;margin-bottom:15px}.drop-message p{font-size:18px;font-weight:600}.file-message-container,.image-message-container,.video-message-container{display:inline-block;position:relative}.video-message{background:#000;border:1px solid #0000001a;border-radius:10px;cursor:pointer;max-height:400px;max-width:400px}.image-message.uploading,.video-message.uploading{filter:blur(1px);opacity:.6}.file-message-container .download-btn{margin-left:10px;opacity:1;position:relative;right:auto;top:auto}.message.sent .image-caption-text{color:#fff}.image-preview-header{border-bottom:1px solid #e0e0e0}.image-preview-header h3{color:#333}.close-preview-btn{background:none;padding:4px 8px;transition:color .2s}.close-preview-btn:hover{color:#333}.preview-image{border-radius:8px}.private-caption-section{align-items:center!important;background:#fff;border-top:1px solid #e0e0e0;box-sizing:border-box;display:flex!important;flex-direction:row!important;gap:16px;justify-content:space-between!important;padding:20px 24px;width:100%}.private-caption-input{border:2px solid #e0e0e0;border-radius:30px;flex:1 1 auto!important;font-size:14px;min-width:0;outline:none;padding:14px 18px;transition:border-color .3s}.private-caption-input:focus{border-color:#667eea}.private-send-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:30px;color:#fff;cursor:pointer;flex:0 0 auto!important;flex-shrink:0!important;font-size:14px;font-weight:600;padding:14px 28px;transition:all .3s;white-space:nowrap}.private-send-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.private-send-btn:active{transform:translateY(0)}.desktop-buttons{gap:8px}.mobile-menu-btn{background:#667eea;border:none;color:#fff;font-size:18px;min-width:45px;padding:10px;transition:background .3s}.mobile-menu-btn:hover{background:#764ba2}.mobile-menu-btn:active{transform:scale(.95)}.mobile-options-menu{box-shadow:0 -4px 20px #0003;max-height:70vh}.mobile-options-header{background:linear-gradient(135deg,#667eea,#624ba2);border-bottom:1px solid #eee;color:#fff;padding:15px 20px}.mobile-options-header h3{font-size:18px;font-weight:600}.close-menu-btn{color:#fff;font-size:28px;transition:transform .2s}.close-menu-btn:hover{transform:scale(1.1)}.close-menu-btn:active{transform:scale(.9)}.mobile-options-grid{grid-gap:15px;gap:15px;padding:20px}.mobile-option-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 10px #667eea4d;color:#fff;gap:10px;min-height:100px;padding:20px;transition:all .3s}.mobile-option-btn:hover{box-shadow:0 6px 15px #667eea66}.mobile-option-btn:active{transform:translateY(0)}.option-icon{font-size:32px;line-height:1}.option-label{font-size:14px;font-weight:600}@media (max-width:768px){.desktop-buttons{display:none}.mobile-menu-btn{align-items:center;display:flex;justify-content:center}.message-form{flex-wrap:nowrap;gap:8px;padding:10px}.message-input{flex:1 1;font-size:16px;min-width:0;padding:12px 14px}.send-btn{font-size:14px;min-width:80px;padding:12px 18px}.private-caption-section{gap:10px;padding:12px 15px}.private-caption-input{font-size:16px;padding:10px 14px}.private-send-btn{font-size:13px;padding:10px 20px}.message{max-width:90%}.message .sender-avatar{font-size:16px;height:40px;min-width:40px;width:40px}.message-content{font-size:15px;padding:10px 14px}.chat-header{padding:12px 15px}.selected-user-info h3{font-size:16px}.selected-user-info p{font-size:12px}}@media (max-width:480px){.mobile-options-grid{gap:12px;grid-template-columns:1fr;padding:15px}.mobile-option-btn{flex-direction:row;gap:15px;justify-content:flex-start;min-height:70px;padding:15px}.option-icon{font-size:28px}.option-label{font-size:15px;text-align:left}.message{max-width:95%}.message-form{gap:6px;padding:8px}.message-input{font-size:16px;padding:10px 12px}.send-btn{font-size:13px;min-width:70px;padding:10px 16px}.private-caption-section{gap:8px;padding:10px 12px}.private-send-btn{font-size:12px;padding:10px 16px}}.toast-notification{align-items:center;animation:slideInRight .4s ease-out,fadeOut .3s ease-in 4.7s forwards;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 8px 24px #0003;color:#fff;cursor:pointer;display:flex;gap:12px;max-width:400px;min-width:320px;padding:16px 20px;position:fixed;right:20px;top:20px;transition:transform .2s;z-index:10000}.toast-notification.toast-buzz{animation:slideInRight .4s ease-out,buzzPulse .3s ease-in-out .4s 3,fadeOut .3s ease-in 4.7s forwards;background:linear-gradient(135deg,#ff6b35,#ff9800)}@keyframes buzzPulse{0%,to{box-shadow:0 8px 24px #ff6b3566;transform:scale(1)}50%{box-shadow:0 12px 32px #ff6b3599;transform:scale(1.05)}}.toast-notification:hover{box-shadow:0 12px 32px #0000004d;transform:translateY(-2px)}@keyframes slideInRight{0%{opacity:0;transform:translateX(400px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{to{opacity:0;transform:translateX(400px)}}.toast-content{align-items:center;display:flex;flex:1 1;gap:12px}.toast-icon{flex-shrink:0;font-size:32px}.toast-text{flex:1 1}.toast-title{font-size:16px;font-weight:700;margin-bottom:4px}.toast-message{font-size:14px;margin-bottom:4px;opacity:.95}.toast-action{font-size:12px;font-style:italic;opacity:.8}.toast-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:24px;justify-content:center;transition:background .2s;width:24px}.toast-close:hover{background:#ffffff4d}.global-room{background:#fff;display:flex;flex-direction:column;height:100%;width:100%}.global-room-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #ddd;color:#fff;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;padding:20px;position:relative}.global-room-header .back-button{background:#0000;border:none;color:#fff;cursor:pointer;display:none;font-size:28px;line-height:1;margin-right:15px;padding:0;transition:transform .2s}.global-room-header .back-button:hover{transform:scale(1.1)}@media (max-width:768px){.global-room-header .back-button{display:inline-block}}.header-title h2{font-size:20px;margin:0}.users-count{display:block;font-size:12px;margin-top:5px;opacity:.9}.penetrations-counters{display:flex;flex-wrap:wrap;gap:10px}.penetrations-counter{background:#fff3;border-radius:20px;cursor:help;font-size:13px;font-weight:600;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.penetrations-counter:hover{background:#ffffff4d;transform:scale(1.05)}.nopor-btn{align-items:center;animation:shake-nopor 3s infinite;background:#fff3;border:2px solid #ffffff80;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:50px;justify-content:center;padding:8px 15px;transition:all .3s ease;width:50px}@keyframes shake-nopor{0%,to{transform:rotate(0deg)}2%{transform:rotate(-15deg)}4%{transform:rotate(15deg)}6%{transform:rotate(-15deg)}8%{transform:rotate(15deg)}10%{transform:rotate(0deg)}}.nopor-btn:hover:not(.disabled){animation:none;background:#ff00004d;border-color:red;transform:scale(1.1)}.nopor-btn.disabled{animation:none;cursor:not-allowed;filter:grayscale(100%);opacity:.5}.global-messages-container{background:#f9f9f9;display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:20px;position:relative}.global-messages-container.dragging{background:#e3f2fd;border:3px dashed #667eea}.loading-older-messages{align-items:center;background:#667eea1a;border-radius:8px;color:#667eea;display:flex;font-size:14px;font-weight:600;gap:10px;justify-content:center;margin-bottom:10px;padding:15px}.loading-older-messages .spinner{animation:spin .8s linear infinite;border:3px solid #667eea4d;border-radius:50%;border-top-color:#667eea;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.drop-overlay{align-items:center;background:#667eeaf2;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:1000}.drop-message{color:#fff;text-align:center}.drop-icon{animation:bounce 1s infinite;display:block;font-size:80px;margin-bottom:20px}.drop-message p{font-size:24px;font-weight:700;margin:0}.loading-messages,.no-messages{align-items:center;color:#999;display:flex;font-size:16px;height:100%;justify-content:center}.global-message{align-items:flex-start;animation:slideIn .3s ease-in-out;border-radius:12px;display:flex;gap:10px;margin:4px 0;max-width:70%;padding:4px;transition:background-color .3s ease}.global-message.highlight-message{animation:pulse .5s ease-in-out 2;background-color:#667eea26}.global-message.mine{align-self:flex-end;flex-direction:row-reverse}.global-message:not(.mine){align-self:flex-start;flex-direction:row}.message-content-wrapper{display:flex;flex:1 1;flex-direction:column;gap:4px}.message-header{gap:8px;margin-bottom:4px;padding:0 10px}.message-header,.sender-avatar{align-items:center;display:flex}.sender-avatar{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;overflow:hidden;position:relative;transition:transform .2s;width:48px}.sender-avatar:hover{transform:scale(1.1)}.sender-avatar-fallback,.sender-avatar-image{border-radius:50%;height:100%;object-fit:cover;width:100%}.sender-avatar-fallback{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center}.message-sender{color:#666;font-size:12px;font-weight:600;margin-bottom:2px;padding:0 8px}.global-message.mine .message-sender{color:#667eea;text-align:right}.message-bubble{word-wrap:break-word;background:#fff;border-radius:18px;box-shadow:0 2px 8px #0000001a;line-height:1.5;max-width:100%;overflow-wrap:break-word;padding:12px 16px;word-break:break-word}.message-gif{border-radius:10px;display:block;max-height:250px;max-width:250px}.sticker-message-container{display:inline-block;position:relative}.sticker-message{border-radius:8px;display:block;margin:5px 0;max-height:200px;max-width:200px;object-fit:contain}.save-sticker-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;opacity:0;position:absolute;right:5px;top:5px;transition:all .3s;width:32px}.sticker-message-container:hover .save-sticker-btn{opacity:1}.save-sticker-btn:hover{background:#000c;transform:scale(1.1)}.message-code{background:#0000001a;border-radius:8px;font-family:Courier New,monospace;font-size:13px;margin:0;overflow-x:auto;padding:12px;white-space:pre-wrap}.code-container{position:relative}.copy-code-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;opacity:0;padding:4px 10px;position:absolute;right:8px;top:8px;transition:all .2s ease;z-index:2}.code-container:hover .copy-code-btn{opacity:1}.copy-code-btn:hover{background:#667eeaf2;transform:scale(1.05)}.copy-code-btn:active{transform:scale(.95)}.global-message.mine .message-code{background:#fff3}.global-message:not(.mine) .message-bubble{background:#e8e8e8;border-bottom-left-radius:4px;color:#333}.global-message.mine .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-right-radius:4px;color:#fff}.global-message.penetration .message-bubble{animation:pulse .5s ease-in-out;background:linear-gradient(135deg,#ff6b9d,#c471ed);border-radius:18px;color:#fff;font-size:15px;font-weight:600;text-align:center}.global-message.nopor-hour .message-bubble{animation:pulse 1s ease-in-out 3;background:linear-gradient(135deg,red,#8b0000);border-radius:18px;box-shadow:0 4px 15px #ff000080;color:#fff;font-size:14px;font-weight:700;padding:20px;text-align:left}.nopor-content{line-height:1.8;white-space:pre-wrap}.nopor-header{font-size:16px;font-weight:700;margin-bottom:15px;text-align:center;text-shadow:2px 2px 4px #00000080}.nopor-toggle-btn{background:linear-gradient(135deg,#ff4500,red);border:none;border-radius:8px;box-shadow:0 4px 8px #0000004d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;letter-spacing:1px;margin:10px 0;padding:12px;text-transform:uppercase;transition:all .3s;width:100%}.nopor-toggle-btn:hover{background:linear-gradient(135deg,tomato,#ff4500);box-shadow:0 6px 12px #0006;transform:translateY(-2px)}.nopor-toggle-btn:active{transform:translateY(0)}.nopor-links{background:#0000004d;border-radius:8px;margin-top:15px;max-height:300px;overflow-y:auto;padding:10px}.nopor-content a{border-radius:4px;color:#ff0;display:block;font-weight:600;margin:5px 0;padding:5px;text-decoration:none;transition:all .2s}.nopor-content a:hover{background:#ffffff1a;color:#fff;text-decoration:underline;transform:translateX(5px)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.message-time{align-items:center;color:#999;display:flex;font-size:11px;gap:4px;margin-top:4px;padding:0 8px}.global-message.mine .message-time{color:#667eeacc;text-align:right}.global-message-form{align-items:center;background:#fff;border-top:1px solid #ddd;display:flex;flex-wrap:nowrap;gap:5px;padding:10px}.global-message-input{border:1px solid #ddd;border-radius:5px;flex:1 1;font-family:inherit;font-size:14px;min-width:100px;padding:10px 12px}.global-message-input:focus{border-color:#667eea;outline:none}.desktop-buttons{align-items:center;display:flex;gap:5px}.attachment-btn,.code-btn,.gif-btn,.sticker-btn{background:#f0f0f0;border:1px solid #ddd;border-radius:5px;color:#333;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:600;min-width:auto;padding:8px;transition:all .3s;white-space:nowrap}.attachment-btn:hover,.code-btn:hover,.gif-btn:hover,.sticker-btn:hover{background:#e0e0e0;border-color:#999}.attachment-btn:disabled{opacity:.5}.mobile-menu-btn{background:#f0f0f0;border:1px solid #ddd;border-radius:5px;color:#333;cursor:pointer;display:none;font-size:16px;padding:8px 12px;transition:all .3s}.mobile-menu-btn:hover{background:#e0e0e0}.penetrate-btn{background:#ff6b9d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:background .3s;white-space:nowrap}.penetrate-btn:hover{background:#ff4081}.send-btn{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:background .3s}.send-btn:hover{background:#764ba2}.mobile-options-menu{animation:slideUp .3s ease-out;background:#fff;border-top:2px solid #667eea;bottom:0;box-shadow:0 -4px 20px #00000026;left:0;max-height:60vh;overflow-y:auto;padding:20px;position:fixed;right:0;z-index:1000}.mobile-options-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.mobile-options-header h3{color:#333;font-size:16px;margin:0}.close-menu-btn{background:#0000;border:none;color:#666;cursor:pointer;font-size:24px;line-height:1;padding:0;transition:color .2s}.close-menu-btn:hover{color:#000}.mobile-options-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.mobile-option-btn{align-items:center;background:#f8f9fa;border:1px solid #ddd;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:15px;transition:all .2s}.mobile-option-btn:hover{background:#e9ecef;border-color:#667eea;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.mobile-option-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.option-icon{font-size:24px}.option-label{color:#666;font-size:12px;font-weight:500;text-align:center}.penetrate-user-list{animation:slideUp .3s ease-out;background:#fff;border-radius:10px;bottom:80px;box-shadow:0 5px 20px #0000004d;max-height:400px;overflow:hidden;position:fixed;right:20px;width:300px;z-index:1000}.penetrate-header{align-items:center;background:linear-gradient(135deg,#ff6b9d,#c471ed);color:#fff;display:flex;justify-content:space-between;padding:15px}.penetrate-header h3{font-size:16px;margin:0}.penetrate-header button{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.user-items{max-height:300px;overflow-y:auto}.no-users-message{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.no-users-message .sad-emoji{animation:sadShake 2s ease-in-out infinite;font-size:60px;margin-bottom:15px}@keyframes sadShake{0%,to{transform:rotate(0deg)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}.no-users-message p{color:#333;font-size:15px;font-weight:600;margin:5px 0}.no-users-message .subtitle{color:#999;font-size:13px;font-style:italic;font-weight:400}.penetrate-user-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:12px;padding:12px 15px;transition:background .2s}.penetrate-user-item:hover{background:#f9f9f9}.penetrate-user-item .user-avatar{align-items:center;background:linear-gradient(135deg,#ff6b9d,#c471ed);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;position:relative;width:40px}.penetrate-user-item .user-avatar .online-indicator{background:#4caf50;border:2px solid #fff;border-radius:50%;bottom:0;box-shadow:0 0 4px #0000004d;height:12px;position:absolute;right:0;width:12px}.penetrate-user-item .user-name{align-items:center;color:#333;display:flex;font-size:14px;font-weight:500;gap:6px}.online-badge{animation:pulse-green 2s ease-in-out infinite;font-size:10px}@keyframes pulse-green{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@media (max-width:768px){.global-room-header{padding:12px}.global-room-header .back-button{display:inline-block}.header-title h2{font-size:18px}.penetrations-counter{font-size:12px;padding:6px 12px}.global-message{max-width:85%}.message-bubble{font-size:14px;padding:10px 14px}.message-gif{max-height:200px;max-width:200px}.global-message-form{flex-wrap:nowrap;gap:4px;padding:8px}.desktop-buttons{display:none}.mobile-menu-btn{display:block}.global-message-input{font-size:14px;min-width:80px;padding:8px 10px}.send-btn{font-size:12px;padding:8px 12px}.penetrate-user-list{bottom:70px;left:10px;right:10px;width:auto}}@media (max-width:480px){.global-room-header{align-items:center;flex-direction:row;flex-wrap:wrap}.global-room-header .back-button{font-size:24px}.penetrations-counters{justify-content:center;margin-top:8px;order:3;width:100%}.penetrations-counter{font-size:11px;padding:6px 10px}.global-message{max-width:90%}.message-gif{max-height:180px;max-width:180px}.nopor-links{font-size:12px;max-height:200px}.nopor-toggle{font-size:12px;padding:8px 15px}.code-btn,.gif-btn{font-size:10px;padding:8px 5px}.penetrate-btn{font-size:10px;padding:8px}.send-btn{font-size:11px;padding:8px 10px}.global-message-input{font-size:13px;min-width:60px;padding:8px}}.code-input-container{animation:slideUp .3s ease-out;background:#fff;border-top:1px solid #ddd;padding:15px}.code-input-header{align-items:center;display:flex;gap:10px;margin-bottom:10px}.code-input-header label{color:#333;font-weight:600}.code-input-header select{background:#fff;cursor:pointer;padding:6px 10px}.code-input-header select,.code-textarea{border:1px solid #ddd;border-radius:5px;font-size:14px}.code-textarea{font-family:Courier New,monospace;min-height:100px;padding:10px;resize:vertical;width:100%}.code-textarea:focus{border-color:#667eea;outline:none}.code-input-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.cancel-btn{background:#f0f0f0;border:1px solid #ddd;border-radius:5px;color:#333}.cancel-btn,.send-code-btn{cursor:pointer;font-weight:600;padding:8px 16px;transition:background .3s}.send-code-btn{background:#667eea;border:none;border-radius:5px;color:#fff}.send-code-btn:hover{background:#764ba2}@media (max-width:480px){.code-input-container{padding:10px}.code-textarea{font-size:13px;min-height:80px}}.attachment-btn{background:#2196f3;border:none;border-radius:5px;color:#fff;cursor:pointer;flex-shrink:0;font-size:18px;padding:10px 15px;transition:all .3s}.attachment-btn:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.attachment-btn:active:not(:disabled){transform:translateY(0)}.attachment-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.message-image{border-radius:8px;cursor:pointer;display:block;max-height:500px;max-width:400px;object-fit:cover;transition:transform .2s,box-shadow .2s}.message-image:hover{box-shadow:0 4px 12px #0003;transform:scale(1.02)}@media (max-width:768px){.attachment-btn{font-size:16px;padding:8px 12px}.message-image{max-height:400px;max-width:300px}}@media (max-width:480px){.attachment-btn{font-size:14px;padding:6px 10px}.message-image{max-height:350px;max-width:250px}}.image-message-container{display:inline-block;position:relative}.message-image.uploading{filter:blur(1px);opacity:.6}.upload-overlay{align-items:center;background:#000c;border-radius:10px;display:flex;flex-direction:column;gap:10px;left:50%;min-width:150px;padding:15px 20px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:5}.upload-progress-bar{background:#ffffff4d;border-radius:3px;height:6px;overflow:hidden;width:100%}.upload-progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;height:100%;transition:width .3s ease}.upload-progress-text{color:#fff;font-size:14px;font-weight:600}.download-btn{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;opacity:.8;position:absolute;right:8px;top:8px;transition:all .3s;width:32px;z-index:10}.download-btn:hover{background:#000000e6;opacity:1;transform:scale(1.1)}.download-btn:active{transform:scale(.95)}.image-caption-text{word-wrap:break-word;color:#333;font-size:14px;line-height:1.4;padding:8px 12px 4px}.global-message.mine .image-caption-text{color:#fff}.sticker-preview-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.sticker-preview-modal{align-items:center;animation:scaleIn .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 10px 50px #0000004d;display:flex;flex-direction:column;gap:20px;max-width:500px;padding:30px;position:relative;width:90%}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.close-preview-btn{color:#666;font-size:20px;transition:all .3s}.sticker-preview-image{border-radius:15px;box-shadow:0 5px 20px #0000001a;max-height:300px;max-width:300px}.sticker-preview-info{display:flex;flex-direction:column;gap:8px;text-align:center}.sticker-preview-info h3{color:#333;font-size:22px;font-weight:600;margin:0}.animated-badge{border-radius:20px;display:inline-block;font-size:13px;padding:6px 12px}.animated-badge,.save-sticker-preview-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:600}.save-sticker-preview-btn{border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;cursor:pointer;font-size:16px;padding:14px 28px;transition:all .3s}.save-sticker-preview-btn:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.scroll-to-bottom-btn{align-items:center;animation:slideInUp .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:30px;bottom:120px;box-shadow:0 4px 20px #667eea80;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:10px;padding:12px 20px;position:fixed;right:30px;transition:all .3s;z-index:1000}.scroll-to-bottom-btn:hover{box-shadow:0 6px 25px #667eeab3;transform:translateY(-2px)}.unread-count-badge{background:#fff3;border-radius:15px;font-size:13px;padding:4px 10px}.scroll-arrow{animation:bounce 1.5s infinite;font-size:18px;font-weight:700}.permanent-scroll-to-end{align-items:center;animation:fadeIn .3s ease;background:#0000;border:none;border-radius:50%;bottom:140px;color:#667eea;cursor:pointer;display:flex;font-size:32px;height:45px;justify-content:center;opacity:.7;position:fixed;right:20px;transition:all .3s ease;width:45px;z-index:50}.permanent-scroll-to-end:hover{color:#764ba2;opacity:1;transform:scale(1.2)}.permanent-scroll-to-end:active{transform:scale(.9)}.scroll-to-bottom-btn.pending-messages{bottom:95px}@media (max-width:768px){.scroll-to-bottom-btn.pending-messages{bottom:95px;font-size:12px;padding:10px 15px;right:15px}.permanent-scroll-to-end{bottom:130px;font-size:28px;height:40px;right:15px;width:40px}.unread-count-badge{font-size:11px;padding:3px 8px}.scroll-arrow{font-size:16px}}@media (max-width:480px){.permanent-scroll-to-end{bottom:120px;font-size:26px;height:38px;right:12px;width:38px}.scroll-to-bottom-btn.pending-messages{bottom:75px;right:10px}}@media (max-width:768px){.avatar-preview-image{height:250px;width:250px}}.save-sticker-preview-btn:active{transform:translateY(0)}.message-reactions-row{gap:8px;margin-top:8px}.message-reactions,.message-reactions-row{align-items:center;display:flex;flex-wrap:wrap}.message-reactions{gap:6px}.reaction-badge{align-items:center;background:#677eea1a;border:1.5px solid #677eea4d;border-radius:16px;color:#333;cursor:pointer;display:inline-flex;font-size:14px;gap:4px;padding:4px 10px;transition:all .2s ease}.reaction-badge:hover{background:#677eea33;border-color:#677eea80;transform:scale(1.05)}.reaction-badge.my-reaction{background:#677eea40;border-color:#667eea;font-weight:600}.message-actions{align-items:center;display:flex;gap:6px;margin-top:8px;opacity:0;transition:opacity .2s ease}.global-message:hover .message-actions{opacity:1}.action-btn{background:#0000000d;border:1px solid #0000001a;border-radius:12px;cursor:pointer;font-size:16px;padding:6px 12px;transition:all .2s ease}.action-btn:hover{background:#0000001a;transform:scale(1.1)}.action-btn.reaction-btn:hover{background:#ffc80033}.action-btn.penetrate-btn:hover{background:#7c3aed33}.penetration-indicator{align-items:center;background:linear-gradient(135deg,#7c3aed26,#a855f726);border:1.5px solid #7c3aed4d;border-radius:14px;box-shadow:0 2px 6px #7c3aed1a;cursor:help;display:inline-flex;font-size:20px;padding:4px 10px;transition:all .2s ease}.penetration-indicator:hover{background:linear-gradient(135deg,#7c3aed40,#a855f740);border-color:#7c3aed80;box-shadow:0 4px 12px #7c3aed33;transform:scale(1.15)}.emoji-picker-native{animation:slideUp .2s ease;background:#fff;border:2px solid #ddd;border-radius:16px;box-shadow:0 8px 24px #00000026;display:flex;flex-direction:column;margin-top:8px;max-width:340px;overflow:hidden;padding:0;position:absolute;z-index:100}.emoji-picker-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:12px 15px}.emoji-picker-title{font-size:14px;font-weight:600}.close-emoji-picker{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:28px}.close-emoji-picker:hover{background:#ffffff4d;transform:rotate(90deg)}.emoji-input{border:2px solid #ddd;border-radius:10px;font-size:16px;margin:12px 12px 0;outline:none;padding:10px;transition:border-color .2s;width:calc(100% - 24px)}.emoji-input:focus{border-color:#667eea}.emoji-suggestions{display:flex;flex-wrap:wrap;gap:6px;max-height:200px;overflow-y:auto;padding:12px}.emoji-suggestions::-webkit-scrollbar{width:6px}.emoji-suggestions::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.emoji-suggestions::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.emoji-option{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:24px;height:44px;justify-content:center;padding:8px;transition:all .2s ease;width:44px}.emoji-option:hover{background:#677eea1a;transform:scale(1.2)}.emoji-option:active{transform:scale(.95)}@media (max-width:768px){.message-actions{opacity:1}.action-btn{font-size:14px;padding:5px 10px}.emoji-picker-native{left:50%;max-width:300px;transform:translateX(-50%)}.emoji-picker-title{font-size:12px}.close-emoji-picker{font-size:18px;height:24px;width:24px}.emoji-input{font-size:14px;margin:10px 10px 0;padding:8px;width:calc(100% - 20px)}.emoji-suggestions{gap:4px;max-height:150px;padding:10px}.emoji-option{font-size:20px;height:38px;padding:6px;width:38px}.reaction-badge{font-size:12px;padding:3px 8px}.penetration-indicator{font-size:16px;padding:3px 6px}}.reply-preview{align-items:flex-start;background:#f0f2f5;border-bottom:1px solid #e9edef;display:flex;gap:12px;margin:0;padding:12px 16px;position:relative}.reply-preview-bar{background:#06cf9c;bottom:0;left:0;position:absolute;top:0;width:4px}.reply-preview-content{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0;padding-left:8px}.reply-preview-header{align-items:center;display:flex;gap:6px}.reply-icon-preview{color:#06cf9c;font-size:12px}.reply-to-label{color:#06cf9c;font-size:13px;font-weight:600}.reply-preview-text{word-wrap:break-word;color:#667781;font-size:13px;font-style:italic;line-height:1.4;max-height:60px;overflow-wrap:break-word;overflow-y:auto;white-space:pre-wrap}.cancel-reply-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#8696a0;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:28px;justify-content:center;transition:all .2s ease;width:28px}.cancel-reply-btn:hover{background:#0000000d;color:#111b21}.cancel-reply-btn:active{transform:scale(.9)}.replied-message-context{background:#0000000f;border-left:4px solid #06cf9c;border-radius:8px;cursor:pointer;display:flex;margin-bottom:12px;padding:10px 12px;transition:background .2s ease}.replied-message-context:hover{background:#0000001a}.global-message:not(.mine) .replied-message-context{background:#0000000f}.global-message:not(.mine) .replied-message-context:hover{background:#0000001a}.global-message.mine .replied-message-context{background:#ffffff26;border-left:4px solid #fffc}.global-message.mine .replied-message-context:hover{background:#fff3}.reply-content{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0;overflow:hidden}.reply-header-info{align-items:center;display:flex;gap:6px;margin-bottom:2px}.reply-icon{font-size:13px;opacity:.8}.global-message:not(.mine) .reply-icon,.reply-icon{color:#06cf9c}.global-message.mine .reply-icon{color:#ffffffe6;opacity:1}.reply-sender{color:#06cf9c;font-size:13px;font-weight:700;letter-spacing:.2px}.global-message:not(.mine) .reply-sender{color:#06cf9c}.global-message.mine .reply-sender{color:#fff;text-shadow:0 1px 2px #0000001a}.reply-text{word-wrap:break-word;font-size:14px;font-weight:400;line-height:1.5;max-height:80px;overflow-wrap:break-word;overflow-y:auto;padding:2px 0;white-space:pre-wrap}.global-message:not(.mine) .reply-text,.reply-text{color:#3b4a54}.global-message.mine .reply-text{color:#fffffff2;text-shadow:0 1px 2px #0000001a}.reply-btn{background:linear-gradient(135deg,#667eea,#764ba2)}.reply-btn:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-2px)}.input-wrapper-with-mentions{align-items:center;display:flex;flex:1 1;position:relative}.mention-suggestions{background:#fff;border-radius:12px 12px 0 0;bottom:100%;box-shadow:0 -4px 12px #00000026;left:0;margin-bottom:8px;max-height:300px;overflow-y:auto;position:absolute;right:0;z-index:1000}.mention-suggestion-item{align-items:center;border-bottom:1px solid #f0f2f5;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .2s ease}.mention-suggestion-item:last-child{border-bottom:none}.mention-suggestion-item:hover{background:linear-gradient(135deg,#667eea1a,#764ba21a)}.mention-avatar{border-radius:50%;flex-shrink:0;height:40px;overflow:hidden;width:40px}.mention-avatar img{height:100%;object-fit:cover;width:100%}.mention-avatar-fallback,.mention-avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:18px;font-weight:700;height:100%;justify-content:center;width:100%}.mention-user-info{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.mention-username{color:#667eea;font-size:14px;font-weight:600}.mention-fullname,.mention-name{color:#8696a0;font-size:12px}.message-mention{background:#667eea26;border-radius:4px;color:#667eea;cursor:pointer;display:inline-block;font-weight:600;padding:2px 6px;text-decoration:none;transition:all .2s ease;-webkit-user-select:none;user-select:none}.message-mention:hover{background:#667eea4d;box-shadow:0 2px 4px #667eea33;transform:translateY(-1px)}.message-mention:active{transform:translateY(0)}.global-message.mine .message-mention{background:#fff3;color:#fff;text-shadow:0 1px 2px #0000001a}.global-message.mine .message-mention:hover{background:#ffffff59;box-shadow:0 2px 4px #0000001a}@media (max-width:768px){.reply-preview{padding:10px 12px}.reply-to-label{font-size:12px}.reply-preview-text{font-size:12px;max-height:50px}.cancel-reply-btn{font-size:16px;height:26px;width:26px}.replied-message-context{margin-bottom:8px;padding:6px 8px}.reply-sender{font-size:12px}.reply-text{max-height:50px}.reply-header-info{gap:4px}.reply-icon{font-size:11px}.reply-text{font-size:12px}.reply-btn{font-size:13px;padding:5px 10px}.mention-suggestions{margin-bottom:6px;max-height:200px}.mention-suggestion-item{padding:10px 12px}.mention-avatar{height:35px;width:35px}.mention-avatar-fallback{font-size:16px}.mention-username{font-size:13px}.mention-name{font-size:11px}.message-mention{font-size:13px}.image-preview-modal{max-height:90vh;max-width:none;width:95%}.preview-image{max-height:50vh}.image-caption-input{font-size:14px}.send-image-btn{font-size:14px;padding:10px 20px}}.image-preview-overlay{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.image-preview-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:600px;overflow:hidden;width:90%}.image-preview-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e9edef;display:flex;justify-content:space-between;padding:16px 20px}.image-preview-header h3{color:#fff;font-size:18px;font-weight:600;margin:0}.image-preview-header .close-preview-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.image-preview-header .close-preview-btn:hover{background:#ffffff4d;transform:scale(1.1)}.image-preview-content{align-items:center;background:#f5f5f5;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:20px}.preview-image{border-radius:12px;box-shadow:0 4px 12px #0000001a;max-height:60vh;max-width:100%;object-fit:contain}.image-caption-section{background:#fff;border-top:1px solid #e9edef;display:flex;flex-direction:column;gap:0;padding:0;position:relative}.caption-mention-suggestions{background:#fff;border-bottom:1px solid #e9edef;box-shadow:0 -4px 12px #0000001a;max-height:250px;overflow-y:auto}.caption-input-row{display:flex;gap:12px;padding:16px 20px}.image-caption-input{border:2px solid #e9edef;border-radius:24px;flex:1 1;font-size:15px;outline:none;padding:12px 16px;transition:border-color .2s ease}.image-caption-input:focus{border-color:#667eea}.send-image-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:24px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.send-image-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.send-image-btn:disabled{cursor:not-allowed;opacity:.6}.profile-overlay{align-items:center;animation:fadeIn .2s ease-in;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.profile-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 50px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.profile-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.profile-header h2{font-size:24px;margin:0}.close-profile-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:background .2s;width:36px}.close-profile-btn:hover{background:#ffffff4d}.profile-form{padding:30px}.avatar-section{align-items:center;background:#f5f5f5;border-radius:10px;display:flex;flex-direction:column;margin-bottom:30px;padding:20px}.avatar-preview-container{margin-bottom:15px}.avatar-preview{object-fit:cover}.avatar-placeholder,.avatar-preview{border:4px solid #667eea;border-radius:50%;box-shadow:0 4px 15px #667eea4d;height:120px;width:120px}.avatar-placeholder{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:48px;font-weight:700;justify-content:center}.change-avatar-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background .2s}.change-avatar-btn:hover{background:#5568d3}.form-section{margin-bottom:30px}.form-section h3{border-bottom:2px solid #667eea;color:#333;font-size:18px;margin-bottom:15px;padding-bottom:10px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.form-group input{border:2px solid #ddd;border-radius:6px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input.error{border-color:#f44336}.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-group.readonly{opacity:.7}.form-group small{color:#999}.error-message,.form-group small{display:block;font-size:12px;margin-top:5px}.error-message{color:#f44336}.profile-actions{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding-top:20px}.cancel-btn,.save-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.cancel-btn{background:#f5f5f5;color:#666}.cancel-btn:hover{background:#e0e0e0}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.save-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.profile-modal{max-height:95vh;width:95%}.profile-form{padding:20px}.profile-header h2{font-size:20px}.avatar-placeholder,.avatar-preview{height:100px;width:100px}.avatar-placeholder{font-size:40px}.profile-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}}.notification-banner{animation:slideInUp .3s ease-out;bottom:20px;position:fixed;right:20px;z-index:10000}@keyframes slideInUp{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.notification-banner-content{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 10px 40px #0000004d;color:#fff;display:flex;gap:15px;max-width:450px;min-width:350px;padding:20px}.notification-banner-icon{animation:bounce 2s infinite;flex-shrink:0;font-size:32px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.notification-banner-text{flex:1 1}.notification-banner-text strong{display:block;font-size:16px;margin-bottom:5px}.notification-banner-text p{font-size:13px;line-height:1.4;margin:0;opacity:.9}.notification-banner-actions{display:flex;flex-direction:column;gap:8px}.notification-banner-btn{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.notification-banner-btn.primary{background:#fff;color:#667eea}.notification-banner-btn.primary:hover{background:#f0f0f0;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.notification-banner-btn.secondary{background:#fff3;border:1px solid #ffffff4d;color:#fff}.notification-banner-btn.secondary:hover{background:#ffffff4d}@media (max-width:768px){.notification-banner{bottom:10px;left:10px;right:10px}.notification-banner-content{flex-direction:column;max-width:100%;min-width:auto;text-align:center}.notification-banner-actions{flex-direction:row;width:100%}.notification-banner-btn{flex:1 1}}.chat-container{background:#f5f5f5;height:100vh;position:relative}.chat-container,.sidebar{display:flex;overflow:hidden}.sidebar{background:#fff;border-right:1px solid #ddd;flex-direction:column;min-height:0;transition:transform .3s ease;width:300px}.sidebar-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #ddd;color:#fff;padding:20px}.sidebar-header h1{font-size:24px;margin:0 0 15px}.global-room-item{border-bottom:1px solid #eee;cursor:pointer}.global-room-item.active{background:linear-gradient(135deg,#11998e1a,#38ef7d1a)}.global-avatar{background:linear-gradient(135deg,#11998e,#38ef7d)!important;font-size:24px}.unread-count{align-items:center;animation:pulse-count 2s infinite;background:#ff1744;border-radius:50%;box-shadow:0 2px 6px #ff174480;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:24px;justify-content:center;margin-left:8px;width:24px}@keyframes pulse-count{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.user-info{align-items:center;display:flex;font-size:14px;gap:10px;justify-content:space-between}.current-user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;overflow:hidden;position:relative;width:40px}.current-avatar-fallback,.current-avatar-image{border-radius:50%;height:100%;object-fit:cover;width:100%}.current-avatar-fallback{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center}.username{flex:1 1;font-weight:600}.profile-btn{align-items:center;background:#0000;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:18px;justify-content:center;opacity:.8;padding:6px 10px;transition:all .3s;white-space:nowrap}.profile-btn:hover{opacity:1;transform:scale(1.15)}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .3s;white-space:nowrap}.logout-btn:hover{background:#ffffff4d}.search-container{border-bottom:1px solid #ddd;padding:15px}.search-input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:10px;transition:border-color .3s;width:100%}.search-input:focus{border-color:#667eea;outline:none}.loading,.no-users{color:#999;font-size:14px;padding:20px;text-align:center}.chat-area{background:#fff;display:flex;flex:1 1;flex-direction:column;max-width:100%;overflow:hidden}.no-chat-selected{align-items:center;color:#999;display:flex;flex:1 1;font-size:16px;justify-content:center;padding:20px;text-align:center}@media (max-width:1024px){.sidebar{width:250px}.sidebar-header h1{font-size:20px;margin-bottom:10px}.user-info{font-size:12px}}@media (max-width:768px){.chat-container{flex-direction:column}.sidebar{border-bottom:1px solid #ddd;border-right:none;height:auto;max-height:50%;width:100%}.sidebar-header{padding:15px}.sidebar-header h1{font-size:18px;margin-bottom:10px}.user-info{flex-wrap:wrap;font-size:12px}.chat-area{flex:1 1;width:100%}.no-chat-selected{font-size:14px}.chat-container{height:100vh;height:100dvh;position:relative}.sidebar{border-right:none;max-height:none;z-index:10}.chat-area,.sidebar{height:100vh;height:100dvh;left:0;position:fixed;top:0;transition:transform .3s ease;width:100%}.chat-area{transform:translateX(100%);z-index:5}.chat-container.chat-open .sidebar{transform:translateX(-100%)}.chat-container.chat-open .chat-area{transform:translateX(0);z-index:15}}@media (max-width:480px){.sidebar-header{padding:12px 15px}.sidebar-header h1{font-size:16px;margin-bottom:8px}.user-info{font-size:11px;gap:8px}.current-user-avatar{font-size:14px;height:35px;width:35px}.edit-profile-btn{font-size:12px;padding:6px 12px}.username{max-width:100%}.logout-btn{font-size:11px;padding:4px 8px}.search-container{padding:10px}.search-input{font-size:12px;padding:8px}.no-chat-selected{font-size:12px;padding:15px}}.avatar-preview-overlay{align-items:center;animation:fadeIn .3s ease;background:#000c;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.avatar-preview-modal{align-items:center;animation:slideUp .3s ease;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;gap:20px;max-width:500px;padding:30px;position:relative;width:90%}.close-preview-btn{align-items:center;background:#0000001a;border:none;border-radius:50%;color:#333;cursor:pointer;display:flex;font-size:24px;height:35px;justify-content:center;position:absolute;right:15px;top:15px;transition:all .2s;width:35px}.close-preview-btn:hover{background:#0003;transform:rotate(90deg)}.avatar-preview-image{border:5px solid #f0f0f0;border-radius:50%;box-shadow:0 5px 20px #0003;height:300px;object-fit:cover;width:300px}.avatar-preview-info{text-align:center}.avatar-preview-info h3{color:#333;font-size:24px;font-weight:600;margin:0}@media (max-width:768px){.avatar-preview-image{height:250px;width:250px}.avatar-preview-info h3{font-size:20px}}
/*# sourceMappingURL=main.7b61e70b.css.map*/