:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#000000de;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #f0f2f5;--bg-secondary: #ffffff;--bg-tertiary: #ffffff;--text-primary: #050505;--text-secondary: #65676b;--border-color: #e4e6eb;--hover-color: #f0f2f5;--primary-color: #06b6d4;--shadow: rgba(0, 0, 0, .1)}body.dark{--bg-primary: #18191a;--bg-secondary: #242526;--bg-tertiary: #3a3b3c;--text-primary: #e4e6eb;--text-secondary: #b0b3b8;--border-color: #3e4042;--hover-color: #3a3b3c;--primary-color: #06b6d4;--shadow: rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh}.navbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);z-index:1000;box-shadow:0 1px 2px var(--shadow);transition:background-color .3s ease,border-color .3s ease}.navbar-container{max-width:1920px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 16px;gap:16px}.navbar-left{display:flex;align-items:center;gap:12px;flex:1;max-width:600px}.navbar-logo{display:flex;align-items:center;text-decoration:none;height:40px}.logo-image{height:40px;width:auto;object-fit:contain;cursor:pointer;transition:opacity .2s;filter:brightness(1)}.dark .logo-image{filter:brightness(.9)}.logo-image:hover{opacity:.8}.logo-text{font-size:24px}.navbar-search{flex:1;max-width:400px;display:flex;align-items:center;gap:4px;background:var(--bg-secondary);border-radius:50px;padding:0 12px;height:40px;transition:background-color .3s ease}.search-input{flex:1;border:none;background:transparent;outline:none;font-size:15px;color:var(--text-primary);transition:color .3s ease}.search-input::placeholder{color:var(--text-secondary)}.search-btn{background:transparent;border:none;cursor:pointer;font-size:13px;padding:4px 8px;display:flex;align-items:center;justify-content:center;color:#65676b;transition:opacity .2s}.search-btn:hover{opacity:1}.navbar-center{display:flex;align-items:center;gap:8px;flex:1;justify-content:center;max-width:600px}.nav-item{display:flex;align-items:center;justify-content:center;min-width:100px;height:56px;text-decoration:none;color:var(--text-secondary);position:relative;transition:background-color .2s,color .3s ease;border-radius:8px}.nav-item:hover{background-color:var(--bg-secondary)}.nav-item.active{color:#06b6d4}.nav-item.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background-color:#06b6d4}.nav-icon{font-size:14px;font-weight:500}.navbar-right{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end}.icon-btn{height:40px;padding:0 16px;border-radius:8px;background:var(--bg-secondary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:14px;font-weight:500;color:var(--text-primary);transition:background-color .2s,color .3s ease;position:relative}.icon-btn.theme-toggle{font-size:20px;padding:0 12px}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ff4458;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.icon-btn:hover{background-color:var(--bg-tertiary)}.user-menu-container{position:relative}.user-avatar{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;transition:opacity .2s}.user-avatar:hover{opacity:.9}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:280px;background:var(--bg-primary);border-radius:8px;box-shadow:0 12px 28px var(--shadow),0 2px 4px var(--shadow);overflow:hidden;animation:fadeIn .2s ease;border:1px solid var(--border-color)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:12px;display:flex;align-items:center;gap:12px;background:var(--bg-secondary)}.dropdown-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.dropdown-name{font-weight:600;color:var(--text-primary)}.dropdown-divider{height:1px;background:var(--border-color);margin:4px 0}.dropdown-item{display:flex;align-items:center;gap:12px;padding:8px 12px;color:var(--text-primary);text-decoration:none;background:transparent;border:none;width:100%;text-align:left;cursor:pointer;font-size:15px;transition:background-color .2s,color .3s ease}.dropdown-item:hover{background-color:var(--bg-secondary)}@media(max-width:768px){.navbar-container{padding:0 8px;gap:8px}.navbar-left{flex:0;min-width:0}.navbar-center{flex:1;gap:4px;max-width:none}.nav-item{min-width:60px;flex:1}.navbar-right{flex:0;min-width:0;gap:4px}.navbar-search,.logo-text{display:none}.logo-icon{font-size:28px}.icon-btn:first-child{display:none}.icon-btn:nth-child(2){display:none}}@media(min-width:769px){.icon-btn:first-child{display:none}}.sidebar-left{position:fixed;left:0;top:56px;width:280px;height:calc(100vh - 56px);background:var(--bg-primary);overflow-y:auto;overflow-x:hidden;padding:8px;display:flex;flex-direction:column;transition:background-color .3s ease}.sidebar-left::-webkit-scrollbar{width:8px}.sidebar-left::-webkit-scrollbar-track{background:transparent}.sidebar-left::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.sidebar-left::-webkit-scrollbar-thumb:hover{background:#999}.sidebar-content{flex:1}.sidebar-item{display:flex;align-items:center;gap:12px;padding:8px;border-radius:8px;text-decoration:none;color:var(--text-primary);cursor:pointer;transition:background-color .2s,color .3s ease;margin-bottom:4px}.sidebar-item:hover{background-color:var(--bg-secondary)}.sidebar-item.active{background-color:#e0f2fe;color:#06b6d4}.dark .sidebar-item.active{background-color:#164e63;color:#06b6d4}.sidebar-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0}.sidebar-icon{font-size:24px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-label{font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-divider{height:1px;background-color:var(--border-color);margin:8px 0}.sidebar-section{margin-top:8px}.sidebar-section-header{padding:8px 8px 4px;font-size:14px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.online-indicator{width:8px;height:8px;background:#31a24c;border-radius:50%;display:inline-block}.online-contacts-list-sidebar{display:flex;flex-direction:column;gap:2px;margin-top:4px}.online-contact-item-sidebar{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background-color .2s}.online-contact-item-sidebar:hover{background-color:var(--bg-secondary)}.contact-avatar-small{width:32px;height:32px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;position:relative}.contact-avatar-small.online:after{content:"";position:absolute;bottom:0;right:0;width:10px;height:10px;background:#31a24c;border:2px solid var(--bg-primary);border-radius:50%}.contact-name-small{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.sidebar-footer{padding:12px 8px;font-size:12px;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:4px;align-items:center;border-top:1px solid var(--border-color);margin-top:auto}.footer-link{color:var(--text-secondary);text-decoration:none}.footer-link:hover{text-decoration:underline}.footer-copy{width:100%;margin-top:4px}@media(max-width:1100px){.sidebar-left{display:none}}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 8px}.quick-action-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;background:linear-gradient(135deg,#e0f2fe,#f3e8ff);border:none;border-radius:12px;cursor:pointer;transition:all .2s;min-height:80px}.quick-action-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #06b6d433;background:linear-gradient(135deg,#bae6fd,#e9d5ff)}.quick-action-icon{width:32px;height:32px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.quick-action-label{font-size:12px;font-weight:600;color:#050505;text-align:center;line-height:1.3}.bottom-nav{display:none}@media(max-width:1100px){.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:8px 0;z-index:1000;justify-content:space-around;box-shadow:0 -2px 10px #0000001a}.dark .bottom-nav{background:var(--bg-tertiary);box-shadow:0 -2px 10px #0000004d}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex:1;padding:8px;text-decoration:none;color:var(--text-secondary);transition:color .2s,background-color .2s;border-radius:8px;max-width:100px}.bottom-nav-item:active{background-color:var(--hover-color)}.bottom-nav-item.active{color:var(--primary-color)}.bottom-nav-icon{font-size:24px;line-height:1}.bottom-nav-label{font-size:11px;font-weight:500;white-space:nowrap}.layout-main{padding-bottom:80px!important}}.message{margin:4px 0;display:flex;align-items:flex-end;gap:8px;max-width:70%;position:relative}.message.own{margin-left:auto;flex-direction:row-reverse}.message.other{margin-right:auto}.message-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.message.own .message-avatar{background:var(--primary-color)}.message.other .message-avatar{background:#8b8b8b}.dark .message.other .message-avatar{background:#6b7280}.message-wrapper{display:flex;flex-direction:column;gap:4px;max-width:100%}.message-content{padding:10px 16px;border-radius:18px;word-wrap:break-word;white-space:pre-wrap;line-height:1.4;font-size:15px;max-width:100%;word-break:break-word}.message.own .message-content{background:var(--primary-color);color:#fff;border-bottom-right-radius:4px}.message.other .message-content{background:#e0e7ff;color:#1e293b;border-bottom-left-radius:4px}.dark .message.other .message-content{background:#3b4d6b;color:#e2e8f0;border:none}.message-info{font-size:11px;color:var(--text-secondary);display:flex;gap:6px;align-items:center;padding:0 4px}.message.own .message-info{justify-content:flex-end}.message.other .message-info{color:var(--text-secondary);font-size:11px}.read-status{white-space:nowrap;font-size:11px}.message.system{justify-content:center;margin:12px auto;max-width:80%}.message.system .message-content{background:var(--hover-color);color:var(--text-secondary);font-size:13px;padding:6px 12px;border-radius:16px;text-align:center}.dark .message.system .message-content{background:var(--bg-tertiary)}.messages-container{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:20px;background:var(--bg-primary);display:flex;flex-direction:column}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.empty-messages{text-align:center;padding:50px;color:var(--text-secondary);font-size:15px}.error-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;margin:auto}.error-icon{font-size:48px;margin-bottom:16px}.error-text{color:var(--text-secondary);font-size:15px;margin-bottom:20px;max-width:300px;line-height:1.5}.retry-btn{background:var(--primary-color);color:#fff;border:none;padding:10px 24px;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.retry-btn:hover{opacity:.9;transform:translateY(-1px)}.retry-btn:active{transform:translateY(0)}.load-more-indicator{text-align:center;padding:16px;color:var(--text-secondary);font-size:13px}.date-divider{display:flex;align-items:center;justify-content:center;margin:16px 0;position:relative}.date-divider:before,.date-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.date-divider span{padding:4px 12px;background:var(--hover-color);color:var(--text-secondary);font-size:12px;font-weight:500;border-radius:12px;margin:0 12px}.unread-divider{display:flex;align-items:center;justify-content:center;margin:16px 0;position:relative}.unread-divider:before,.unread-divider:after{content:"";flex:1;height:1px;background:var(--primary-color)}.unread-divider span{padding:6px 16px;background:#06b6d41a;color:var(--primary-color);font-size:13px;font-weight:600;border-radius:16px;margin:0 12px;border:1px solid var(--primary-color)}.dark .unread-divider span{background:#06b6d426}.message-input-container{background:var(--bg-secondary);border-top:1px solid var(--border-color)}.input-error{padding:8px 20px;background:#ffebe9;color:#c41c00;font-size:13px;border-bottom:1px solid var(--border-color)}.dark .input-error{background:#3a1f1f;color:#ff6b6b}.message-input{padding:12px 20px;display:flex;gap:12px;align-items:center}.message-input input{flex:1;padding:10px 16px;border:1px solid var(--border-color);border-radius:20px;outline:none;font-size:15px;background:var(--hover-color);color:var(--text-primary);transition:all .2s}.message-input input:focus{background:var(--bg-secondary);border-color:var(--primary-color)}.message-input input:disabled{background:var(--hover-color);cursor:not-allowed;opacity:.6}.send-btn{padding:10px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:20px;cursor:pointer;font-weight:600;font-size:15px;transition:background .2s;flex-shrink:0}.send-btn:hover:not(:disabled){background:#0891b2}.send-btn:active:not(:disabled){background:#0e7490}.send-btn:disabled{background:var(--border-color);color:var(--text-secondary);cursor:not-allowed}.chat-popup{position:fixed;bottom:0;right:20px;width:328px;height:455px;border-radius:12px 12px 0 0;box-shadow:0 -4px 24px #00000026;display:flex;flex-direction:column;z-index:1000;transition:height .2s ease,transform .2s ease;overflow:hidden;border:none;background:#fff}.chat-popup.minimized{height:48px;cursor:pointer}.chat-popup.minimized:hover{background:#f3f4f6}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;min-height:48px;border-radius:12px 12px 0 0}.popup-user{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.popup-avatar{width:32px;height:32px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;flex-shrink:0}.popup-info{display:flex;flex-direction:column;min-width:0}.popup-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.popup-status{font-size:11px;opacity:.85}.popup-actions{display:flex;gap:4px;flex-shrink:0}.popup-btn{width:28px;height:28px;border:none;background:#ffffff26;color:#fff;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:background .15s ease}.popup-btn:hover{background:#ffffff40}.popup-close:hover{background:#ff646480}.popup-messages{flex:1;overflow:hidden;position:relative;background:#fff}.popup-messages .messages-container{height:100%;padding:12px;background:#fff;overflow-y:auto;overscroll-behavior:contain}.popup-messages .message-list{padding:0}.popup-messages .loading-messages,.popup-messages .empty-messages{padding:20px;font-size:13px;text-align:center;color:#64748b}.popup-messages .message-content{max-width:220px;font-size:13px;padding:8px 12px}.popup-messages .message-time{font-size:10px}.popup-input{border-top:1px solid #e5e7eb;background:#fff}.popup-input .message-input-container{padding:8px 12px;gap:8px}.popup-input .message-textarea{font-size:13px;min-height:36px;max-height:100px}.popup-input .btn-send{width:36px;height:36px;font-size:16px}.popup-input .input-tools{display:none}.popup-messages .date-divider:before,.popup-messages .date-divider:after{background:#e5e7eb}.popup-messages .date-divider span{background:#f1f5f9;color:#64748b}@media(max-width:768px){.chat-popup{display:none}}.popup-messages .error-messages{padding:20px;text-align:center}.popup-messages .error-messages .error-icon{font-size:24px;margin-bottom:8px}.popup-messages .error-messages .error-text{font-size:13px;margin-bottom:12px;color:#64748b}.popup-messages .error-messages .retry-btn{padding:6px 16px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer}.popup-messages .error-messages .retry-btn:hover{opacity:.9}.dark .chat-popup{background:#242526;box-shadow:0 -4px 24px #0009}.dark .chat-popup.minimized:hover{background:#3a3b3c}.dark .popup-header{background:linear-gradient(135deg,#06b6d4,#8b5cf6)}.dark .popup-messages,.dark .popup-messages .messages-container{background:#242526}.dark .popup-messages .loading-messages,.dark .popup-messages .empty-messages{color:#b0b3b8}.dark .popup-input{border-top:1px solid #3a3b3c;background:#242526}.dark .popup-messages .date-divider:before,.dark .popup-messages .date-divider:after{background:#3a3b3c}.dark .popup-messages .date-divider span{background:#3a3b3c;color:#b0b3b8}.dark .popup-messages .error-messages .error-text{color:#94a3b8}.dark .popup-messages .messages-container::-webkit-scrollbar{width:6px}.dark .popup-messages .messages-container::-webkit-scrollbar-track{background:#242526}.dark .popup-messages .messages-container::-webkit-scrollbar-thumb{background:#4a4b4c;border-radius:3px}.dark .popup-messages .messages-container::-webkit-scrollbar-thumb:hover{background:#5a5b5c}.connection-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:20px;text-align:center}.connection-error .error-icon{font-size:40px;margin-bottom:12px}.connection-error .error-title{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:8px}.connection-error .error-desc{font-size:13px;color:#6b7280;margin-bottom:16px}.connection-error .retry-btn{padding:8px 20px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.connection-error .retry-btn:hover{opacity:.9}.dark .connection-error .error-title{color:#f3f4f6}.dark .connection-error .error-desc{color:#9ca3af}.layout{min-height:100vh;background:var(--bg-primary);transition:background-color .3s ease}.layout-body{padding-top:56px;min-height:calc(100vh - 56px)}.layout-main{margin-left:280px;padding:80px 20px 20px;max-width:1920px;min-height:calc(100vh - 56px)}@media(max-width:1100px){.layout-main{margin-left:0}}@media(max-width:768px){.layout-main{padding:8px}}.login-page{min-height:100vh;background:linear-gradient(135deg,#06b6d4,#8b5cf6);display:flex;align-items:center;justify-content:center;padding:20px}.login-container{width:100%;max-width:1100px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.login-left{display:flex;align-items:center;justify-content:center;color:#fff;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;width:400px;height:400px;background:#ffffff1a;border-radius:50%;top:-100px;left:-100px;animation:float 6s ease-in-out infinite}.login-left:after{content:"";position:absolute;width:300px;height:300px;background:#ffffff0d;border-radius:50%;bottom:-50px;right:-50px;animation:float 8s ease-in-out infinite reverse}.brand-content{position:relative;z-index:1;text-align:center}.brand-logo{display:inline-block;font-size:56px;font-weight:900;margin-bottom:32px;letter-spacing:2px;text-shadow:0 4px 20px rgba(0,0,0,.2)}.brand-title{font-size:32px;font-weight:600;margin:0 0 20px;letter-spacing:4px}.brand-description{font-size:18px;line-height:1.6;opacity:.95;margin:0;font-weight:300;letter-spacing:1px}.login-right{display:flex;justify-content:center}.login-box{width:100%;max-width:440px;background:#fff;border-radius:20px;padding:48px;box-shadow:0 20px 60px #0003}.login-title{font-size:32px;font-weight:700;margin:0 0 8px;color:#050505}.login-subtitle{font-size:15px;color:#65676b;margin:0 0 32px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:600;color:#050505}.form-input{padding:14px 16px;border:2px solid #e4e6eb;border-radius:10px;font-size:15px;transition:all .2s;outline:none}.form-input:focus{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d426}.form-input:disabled{background-color:#f0f2f5;cursor:not-allowed}.error-message{padding:12px 16px;background:#ffe8e8;color:#d32f2f;border-radius:8px;font-size:14px;font-weight:500}.login-button{padding:16px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #06b6d466}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.register-link{text-align:center;font-size:14px;color:#65676b;margin-top:24px}.link-btn{background:none;border:none;color:#06b6d4;font-weight:600;cursor:pointer;padding:0 4px;text-decoration:none;margin-left:4px}.link-btn:hover{text-decoration:underline;color:#8b5cf6}@media(max-width:968px){.login-container{grid-template-columns:1fr;gap:0}.login-left{display:none}.login-right{width:100%;max-width:480px;margin:0 auto}}@media(max-width:640px){.login-page{padding:16px}.login-box{padding:32px 24px}.login-title{font-size:24px}}.register-page{min-height:100vh;background:linear-gradient(135deg,#06b6d4,#8b5cf6);display:flex;align-items:center;justify-content:center;padding:20px}.register-container{width:100%;max-width:1100px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}.register-left{display:flex;align-items:center;justify-content:center;color:#fff;position:relative;overflow:hidden}.register-left:before{content:"";position:absolute;width:400px;height:400px;background:#ffffff1a;border-radius:50%;top:-100px;left:-100px;animation:float 6s ease-in-out infinite}.register-left:after{content:"";position:absolute;width:300px;height:300px;background:#ffffff0d;border-radius:50%;bottom:-50px;right:-50px;animation:float 8s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.05)}}.register-right{display:flex;justify-content:center}.register-box{width:100%;max-width:440px;background:#fff;border-radius:20px;padding:48px;box-shadow:0 20px 60px #0003}.register-title{font-size:32px;font-weight:700;margin:0 0 8px;color:#050505}.register-subtitle{font-size:15px;color:#65676b;margin:0 0 32px}.register-form{display:flex;flex-direction:column;gap:20px}.register-button{padding:16px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px}.register-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #06b6d466}.register-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-link{text-align:center;font-size:14px;color:#65676b;margin-top:24px}@media(max-width:968px){.register-container{grid-template-columns:1fr;gap:0}.register-left{display:none}.register-right{width:100%;max-width:480px;margin:0 auto}}@media(max-width:640px){.register-page{padding:16px}.register-box{padding:32px 24px}.register-title{font-size:24px}}.home-page{width:100%;min-height:100%;background:var(--bg-primary)}.home-container{max-width:1200px;margin:0 auto;padding:0 20px 20px}.welcome-section{text-align:center;margin-bottom:32px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);padding:40px 32px;border-radius:16px;box-shadow:0 4px 12px #0000001a}.dark .welcome-section{background:linear-gradient(135deg,#0891b2,#7c3aed);box-shadow:0 4px 12px #0000004d}.welcome-title{font-size:36px;font-weight:700;color:#fff;margin:0 0 12px}.welcome-subtitle{font-size:18px;color:#fffffff2;margin:0 0 24px}.notification-summary{background:#fffffff2;border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:16px;margin-top:24px;box-shadow:0 2px 8px #0000001a;max-width:500px;margin-left:auto;margin-right:auto}.dark .notification-summary{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.notification-icon{position:relative;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#06b6d4,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.notification-badge{position:absolute;top:-4px;right:-4px;background:#ff3b30;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center;box-shadow:0 2px 4px #ff3b304d}.notification-text{flex:1;text-align:left;display:flex;flex-direction:column;gap:4px}.notification-text strong{font-size:16px;font-weight:600;color:#050505}.dark .notification-text strong{color:#fff}.notification-text span{font-size:13px;color:#65676b}.dark .notification-text span{color:#ffffffb3}.notification-btn{padding:8px 20px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;flex-shrink:0}.notification-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #06b6d466}.notification-btn:active{transform:translateY(0)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-bottom:48px}.action-card{background:var(--bg-secondary);border-radius:16px;padding:32px;display:flex;align-items:flex-start;gap:20px;border:none;cursor:pointer;transition:all .3s;text-align:left;box-shadow:0 4px 12px #0000001a}.dark .action-card{background:var(--bg-tertiary);box-shadow:0 4px 12px #0000004d}.action-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.dark .action-card:hover{box-shadow:0 8px 24px #00000080}.action-card.primary{background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff}.action-card.primary h3,.action-card.primary p{color:#fff}.action-icon{width:56px;height:56px;border-radius:12px;background:#06b6d41a;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;flex-shrink:0;color:#06b6d4}.action-card.primary .action-icon{background:#fff3;color:#fff}.action-content{flex:1}.action-content h3{font-size:20px;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.action-content p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.recent-section{background:var(--bg-secondary);border-radius:16px;padding:32px;margin-bottom:40px;box-shadow:0 4px 12px #0000001a}.dark .recent-section{background:var(--bg-tertiary);box-shadow:0 4px 12px #0000004d}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-size:24px;font-weight:600;margin:0;color:var(--text-primary)}.link-button{background:none;border:none;color:var(--primary-color);font-size:15px;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:8px;transition:background-color .2s}.link-button:hover{background-color:var(--hover-color)}.recent-chats{display:grid;gap:12px}.chat-card{display:flex;align-items:center;gap:16px;padding:16px;border-radius:12px;cursor:pointer;transition:background-color .2s}.chat-card:hover{background-color:var(--hover-color)}.chat-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;flex-shrink:0}.chat-info{flex:1;min-width:0}.chat-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.chat-preview{font-size:14px;color:var(--text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-badge{background:#8b5cf6;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;min-width:24px;text-align:center}.features-section{background:var(--bg-secondary);border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000001a}.dark .features-section{background:var(--bg-tertiary);box-shadow:0 4px 12px #0000004d}.features-section h2{font-size:24px;font-weight:600;margin:0 0 32px;text-align:center;color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:32px}.feature-item{text-align:center}.feature-icon{width:80px;height:80px;margin:0 auto 20px;border-radius:20px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600}.feature-item h3{font-size:18px;font-weight:600;margin:0 0 12px;color:var(--text-primary)}.feature-item p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.online-contacts-section{background:var(--bg-secondary);border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000001a;position:sticky;top:20px}.dark .online-contacts-section{background:var(--bg-tertiary);box-shadow:0 4px 12px #0000004d}.online-contacts-section .section-header{margin-bottom:16px}.online-contacts-section .section-header h2{font-size:18px;display:flex;align-items:center}.online-indicator-title{display:inline-block;width:10px;height:10px;background:#31a24c;border-radius:50%;margin-right:8px;vertical-align:middle}.online-contacts-list{display:grid;gap:0}.online-contact-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;transition:background-color .15s ease;background:transparent;border-radius:8px}.online-contact-item:hover{background:var(--hover-color)}.online-contact-avatar{width:48px;height:48px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0;position:relative}.online-contact-avatar.online:after{content:"";position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:#31a24c;border:2px solid var(--bg-secondary);border-radius:50%}.dark .online-contact-avatar.online:after{border-color:var(--bg-tertiary)}.online-contact-name{font-size:15px;font-weight:500;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.home-container{padding:20px 16px}.welcome-section{padding:40px 24px;margin-bottom:24px}.welcome-title{font-size:32px}.welcome-subtitle{font-size:16px}.quick-actions{grid-template-columns:1fr;gap:16px;margin-bottom:32px}.action-card,.recent-section,.features-section{padding:24px}}.room-item{display:flex;align-items:center;padding:10px 16px;margin:0;background:transparent;cursor:pointer;transition:background .15s ease;border:none;position:relative}.room-item:hover{background:var(--hover-color)}.room-item.active{background:#06b6d41a}.dark .room-item.active{background:#06b6d426}.room-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary-color)}.room-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;flex-shrink:0;margin-right:12px}.room-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.room-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.room-name{font-weight:600;font-size:15px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.room-item.active .room-name{color:var(--primary-color)}.room-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.room-time{font-size:12px;color:var(--text-secondary);flex-shrink:0}.room-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.unread-badge{background:#ff3b30;color:#fff;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:700;min-width:20px;text-align:center;flex-shrink:0;box-shadow:0 2px 4px #ff3b304d}.chat-list-container{height:100%;display:flex;flex-direction:column;overflow:hidden}.room-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px}.room-list::-webkit-scrollbar{width:8px}.room-list::-webkit-scrollbar-track{background:transparent}.room-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.room-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.empty-list{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:14px}.loading-indicator{text-align:center;padding:16px;color:var(--text-secondary);font-size:13px}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 12px 28px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px 24px;border-bottom:1px solid #e4e6eb;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:#050505}.close-btn{background:#f0f2f5;border:none;font-size:24px;color:#65676b;cursor:pointer;line-height:1;padding:0;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.close-btn:hover{background:#e4e6eb}.modal-body{padding:20px 24px;flex:1;overflow-y:auto}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:transparent}.modal-body::-webkit-scrollbar-thumb{background:#ccd0d5;border-radius:4px}.error-message{background:#ffebe9;color:#c41c00;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:15px;color:#050505}.form-group input[type=text]{width:100%;padding:12px 16px;border:1px solid #e4e6eb;border-radius:8px;font-size:15px;background:#f0f2f5;transition:all .2s}.form-group input[type=text]:focus{outline:none;border-color:#0084ff;background:#fff}.member-list{border:1px solid #e4e6eb;border-radius:8px;max-height:240px;overflow-y:auto;background:#fff}.member-list::-webkit-scrollbar{width:8px}.member-list::-webkit-scrollbar-track{background:transparent}.member-list::-webkit-scrollbar-thumb{background:#ccd0d5;border-radius:4px}.member-item{padding:12px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;border-bottom:1px solid #f0f2f5;transition:background .15s}.member-item:last-child{border-bottom:none}.member-item:hover{background:#f8f9fa}.member-item.selected{background:#e7f3ff}.member-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#0084ff}.member-item span{font-size:15px;color:#050505;font-weight:500}.modal-footer{padding:16px 24px;border-top:1px solid #e4e6eb;display:flex;gap:12px;justify-content:flex-end;background:#f8f9fa}.modal-footer .btn{padding:10px 24px;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:15px;transition:all .2s}.modal-footer .btn:hover:not(:disabled){transform:translateY(-1px)}.modal-footer .btn:disabled{opacity:.5;cursor:not-allowed}.modal-footer .btn-primary{background:#0084ff;color:#fff}.modal-footer .btn-primary:hover:not(:disabled){background:#0073e6}.modal-footer .btn-secondary{background:#e4e6eb;color:#050505}.modal-footer .btn-secondary:hover{background:#d8dadf}.messages-page{width:100%;height:calc(100vh - 56px);overflow:hidden}.messages-container{height:100%;display:flex;background:var(--bg-secondary);border-radius:8px;box-shadow:0 1px 2px #0000001a;overflow:hidden}.dark .messages-container{background:var(--bg-tertiary);box-shadow:0 1px 2px #0000004d}.messages-sidebar-wrapper{width:360px;height:100%;border-right:1px solid var(--border-color);display:flex;flex-direction:column}.messages-sidebar-wrapper.messages-full-width{width:400px;max-width:100%}.messages-info{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.messages-sidebar{height:100%;display:flex;flex-direction:column}.messages-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-color)}.messages-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.btn-new-message{width:36px;height:36px;border-radius:50%;background:var(--hover-color);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;transition:background-color .2s;color:var(--text-primary)}.btn-new-message:hover{background-color:var(--border-color)}.messages-content{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.messages-empty{text-align:center;padding:40px;max-width:400px}.empty-icon{font-size:48px;margin-bottom:16px;color:var(--text-secondary);font-weight:600}.empty-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.empty-text{font-size:14px;color:var(--text-secondary);margin:0 0 24px;line-height:1.5}.btn-start-chat{padding:10px 24px;background:linear-gradient(135deg,#06b6d4,#8b5cf6);color:#fff;border:none;border-radius:6px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.btn-start-chat:hover{transform:translateY(-2px);box-shadow:0 8px 20px #06b6d44d}.redirect-notice{font-size:16px;color:#65676b}@media(max-width:768px){.messages-page{border-radius:0}.messages-container{border-radius:0;box-shadow:none}.messages-sidebar-wrapper{width:100%}.messages-content{display:none}}.contacts-section{margin-bottom:8px}.contacts-section h4{margin:0;padding:12px 20px 8px;font-size:12px;font-weight:600;color:#65676b;text-transform:uppercase;letter-spacing:.5px}.contacts-list{margin-bottom:0}.contact-item{display:flex;align-items:center;padding:10px 16px;margin:0;cursor:pointer;transition:background .15s ease;background:transparent;position:relative}.contact-item:hover{background:#f2f3f5}.contact-item.loading{opacity:.6;pointer-events:none}.contact-avatar{width:48px;height:48px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;margin-right:12px;flex-shrink:0;position:relative}.contact-avatar.online:after{content:"";position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:#31a24c;border:2px solid #ffffff;border-radius:50%}.contact-info{flex:1;min-width:0}.contact-name{font-weight:500;font-size:15px;color:#050505;margin-bottom:2px}.contact-status{font-size:13px;color:#65676b}.contacts-page{width:100%;min-height:100%;background:var(--bg-primary)}.contacts-container{max-width:1200px;margin:0 auto;padding:0 20px 20px}.contacts-header{padding:24px 0;border-bottom:1px solid var(--border-color);margin-bottom:32px}.contacts-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.contacts-subtitle{font-size:16px;color:var(--text-secondary);margin:0}@media(max-width:768px){.contacts-container{padding:0 16px 16px}.contacts-header{padding:16px 0;margin-bottom:24px}.contacts-title{font-size:24px}.contacts-subtitle{font-size:14px}}.settings-page{width:100%;min-height:calc(100vh - 56px);padding:24px;background:var(--bg-secondary);overflow-y:auto}.settings-container{max-width:800px;margin:0 auto;width:100%}.settings-title{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:32px}.settings-section{background:var(--bg-primary);border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px var(--shadow)}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--border-color);gap:20px;flex-wrap:wrap}.setting-item:last-child{border-bottom:none}@media(max-width:640px){.setting-item{flex-direction:column;align-items:flex-start}}.setting-info{flex:1}.setting-label{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.setting-description{font-size:13px;color:var(--text-secondary)}.theme-options{display:flex;gap:16px;flex-wrap:wrap}.theme-option{display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s}.theme-option:hover{border-color:#06b6d4}.theme-option.active{border-color:#06b6d4;background:#06b6d41a}.theme-option span{font-size:14px;font-weight:500;color:var(--text-primary)}.theme-preview{width:100px;height:70px;border-radius:8px;overflow:hidden;border:1px solid var(--border-color)}.theme-preview.light{background:#fff}.theme-preview.dark{background:#18191a}.preview-header{height:16px;background:#06b6d4}.theme-preview.dark .preview-header{background:#0891b2}.preview-body{padding:8px;display:flex;flex-direction:column;gap:4px}.preview-bar{height:8px;background:#e4e6eb;border-radius:4px}.theme-preview.dark .preview-bar{background:#3a3b3c}.preview-bar.short{width:60%}.toggle-switch{position:relative;display:inline-block;width:48px;height:28px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#06b6d4,#8b5cf6)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}@media(max-width:768px){.settings-page{padding:16px}.settings-title{font-size:24px}.theme-options{flex-direction:column}.theme-option{flex-direction:row;width:100%}.theme-preview{width:80px;height:56px}}.placeholder-page{display:flex;align-items:center;justify-content:center;min-height:50vh;font-size:24px;color:var(--text-secondary);background:var(--bg-primary);border-radius:8px;box-shadow:0 1px 2px var(--shadow);margin:20px;padding:40px;text-align:center}
