*{margin:0;padding:0;box-sizing:border-box}body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:#f5f5f5;color:#333;line-height:1.6;height:100vh;overflow:hidden}.page{display:none;width:100%;height:100vh}.page.active{display:block}#auth-page{display:none}#auth-page.active{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0,#764ba2 100%)}#chat-page{display:none}#chat-page.active{display:flex;flex-direction:column;height:100vh}.chat-main{display:grid;grid-template-columns:320px 1fr;grid-template-rows:1fr;height:calc(100vh - 72px);flex:1}@media (max-width:768px){.chat-main{grid-template-columns:1fr}.chat-main .chat-sidebar{transform:translateX(-100%);transition:transform .3s ease}.chat-main .chat-sidebar.active{transform:translateX(0)}}button{cursor:pointer;border:none;border-radius:4px;padding:8px 16px;transition:background-color .3s}button:hover{opacity:.9}input{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}input:focus{outline:0;border-color:#4caf50}.modal-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:1000}.modal-overlay.active{display:flex;align-items:center;justify-content:center}.modal-overlay .modal-content{background:#fff;padding:20px;border-radius:8px;min-width:300px;max-width:90vw;z-index:1001}.auth-container{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.2);width:100%;max-width:400px}.auth-tabs{display:flex;margin-bottom:30px;border-bottom:2px solid #eee}.tab-btn{flex:1;padding:10px;background:0 0;border:none;border-bottom:2px solid transparent}.tab-btn.active{border-bottom-color:#4caf50;color:#4caf50}.auth-form{display:none}.auth-form.active{display:block}.auth-form h2{margin-bottom:20px;text-align:center;color:#333}.auth-form input{width:100%;margin-bottom:15px}.auth-form button{width:100%;background:#4caf50;color:#fff;padding:12px;font-size:16px}.auth-links{text-align:center;margin-top:15px}.auth-links a{color:#666;text-decoration:none}.auth-links a:hover{color:#4caf50}.chat-header{background:#2c3e50;color:#fff;padding:0 20px;height:72px;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:100}@media (max-width:768px){.chat-header{height:60px;padding:0 15px}}.chat-header #welcome-text{color:#fff;font-size:18px;font-weight:600;margin:0;flex:1;text-align:center}@media (max-width:768px){.chat-header #welcome-text{font-size:16px}}.menu-toggle{display:none;background:0 0;color:#fff;font-size:20px}@media (max-width:768px){.menu-toggle{display:block}}.logout-btn{background:#e74c3c;color:#fff}.logout-btn:hover{background:#c0392b}.chat-sidebar{background:#34495e;color:#fff;overflow-y:auto}@media (max-width:768px){.chat-sidebar{position:fixed;top:60px;left:0;width:280px;height:calc(100vh - 60px);z-index:100}}.sidebar-header{padding:20px;border-bottom:1px solid #2c3e50;display:flex;justify-content:space-between;align-items:center}.sidebar-header h3{margin:0}.new-chat-btn{background:#4caf50;color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.chat-list{padding:10px 0}.chat-item{padding:15px 20px;cursor:pointer;border-bottom:1px solid #2c3e50}.chat-item:hover{background:#2c3e50}.chat-item.active{background:#4caf50}.chat-item .chat-name{font-weight:700;margin-bottom:5px}.chat-item .last-message{font-size:12px;opacity:.8}.user-list{padding:20px}.user-list h4{margin-bottom:10px;color:#ecf0f1}.user-item{padding:8px 0;display:flex;align-items:center}.user-item .status-dot{width:8px;height:8px;border-radius:50%;background:#2ecc71;margin-right:10px}.chat-area{background:#ecf0f1;display:flex;flex-direction:column}.no-chat{display:flex;align-items:center;justify-content:center;height:100%;color:#7f8c8d;font-size:18px}.active-chat{display:flex;flex-direction:column;height:100%}.chat-header{background:#fff;padding:15px 20px;border-bottom:1px solid #bdc3c7;display:flex;justify-content:space-between;align-items:center}.call-btn{background:#4caf50;color:#fff;margin-left:10px;padding:8px 12px}.messages-container{flex:1;padding:20px;overflow-y:auto}.message{margin-bottom:15px;max-width:70%}.message.own{margin-left:auto}.message.own .message-content{background:#4caf50;color:#fff}.message-header{font-size:12px;margin-bottom:5px;opacity:.7}.message-content{background:#fff;padding:10px 15px;border-radius:18px;display:inline-block}.message-input-container{padding:20px;background:#fff;border-top:1px solid #bdc3c7;display:flex}.message-input-container input{flex:1;margin-right:10px}.message-input-container button{background:#4caf50;color:#fff}.typing-indicator{display:flex;align-items:center;padding:10px;color:#666;font-style:italic}.typing-indicator .typing-dots{display:flex;margin-right:10px}.typing-indicator .typing-dots span{width:6px;height:6px;background:#666;border-radius:50%;margin:0 2px;animation:typingDots 1.4s infinite ease-in-out}.typing-indicator .typing-dots span:nth-child(1){animation-delay:-.32s}.typing-indicator .typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typingDots{0%,100%,80%{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-meta{display:flex;justify-content:space-between;font-size:11px;opacity:.7;margin-top:5px}.user-checkbox{display:flex;align-items:center;margin:5px 0}.user-checkbox input[type=checkbox]{margin-right:8px}.audio-call-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#fff;text-align:center}.audio-call-screen h2{font-size:24px;margin-bottom:10px}@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideOut{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}.video-container{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:2000;display:flex;flex-direction:column}.video-container #remote-video{flex:1;width:100%;height:100%;object-fit:cover;background:#000}.video-container #remote-video[srcObject]{background:0 0}.video-container #local-video{position:absolute;top:20px;right:20px;width:200px;height:150px;border:2px solid #fff;border-radius:8px;z-index:2001;background:#000;object-fit:cover}.video-container #local-video[srcObject]{background:0 0}@media (max-width:768px){.video-container #local-video{width:120px;height:90px;top:10px;right:10px}}.video-container .audio-call-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center;background:linear-gradient(135deg,#667eea 0,#764ba2 100%)}.video-container .audio-call-screen h2{font-size:32px;margin-bottom:20px}@media (max-width:768px){.video-container .audio-call-screen h2{font-size:24px}}.video-container .audio-call-screen p{font-size:18px;opacity:.9}@media (max-width:768px){.video-container .audio-call-screen p{font-size:16px}}.video-container #remote-audio{display:none}.video-container .call-controls{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;gap:15px;z-index:2001}.video-container .call-controls button{width:60px;height:60px;border-radius:50%;font-size:24px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:all .3s ease}.video-container .call-controls button:hover{transform:scale(1.1)}.video-container .call-controls button.mute{background:#3498db;color:#fff}.video-container .call-controls button.mute.muted{background:#e74c3c}.video-container .call-controls button.end-call{background:#e74c3c;color:#fff}@media (max-width:768px){.video-container .call-controls{bottom:20px}.video-container .call-controls button{width:50px;height:50px;font-size:20px}}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:18px;z-index:2002}.video-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;background:#333}.video-fallback.remote-fallback::before{content:"🖼️ Ожидание видео..."}.video-fallback.local-fallback::before{content:"📹 Камера не доступна"}.refresh-video{background:#f39c12!important;color:#fff!important}.video-status{position:absolute;top:20px;left:20px;color:#fff;background:rgba(0,0,0,.7);padding:10px;border-radius:5px;font-size:12px;z-index:2002}.video-status{position:absolute;top:20px;left:50%;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.8);padding:10px 20px;border-radius:20px;font-size:14px;z-index:2002;pointer-events:none;transition:opacity .3s ease}.video-status:hover{opacity:.7}.video-container video{cursor:pointer;transition:opacity .3s ease}.video-container video:hover{opacity:.9}.video-container video[data-waiting]{cursor:wait;opacity:.7}.call-controls button{transition:all .3s ease}.call-controls button:disabled{opacity:.5;cursor:not-allowed}.call-controls button.refreshing{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.video-status{position:absolute;top:20px;left:50%;transform:translateX(-50%);color:#fff;background:rgba(0,0,0,.9);padding:12px 24px;border-radius:25px;font-size:14px;font-weight:500;z-index:2002;pointer-events:none;transition:all .3s ease;border:2px solid rgba(255,255,255,.2);backdrop-filter:blur(10px)}.video-status.error{background:rgba(231,76,60,.9);border-color:rgba(255,255,255,.3)}.video-status.warning{background:rgba(243,156,18,.9);border-color:rgba(255,255,255,.3)}.video-status.success{background:rgba(46,204,113,.9);border-color:rgba(255,255,255,.3)}.video-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:16px;z-index:2003}.video-loading::after{content:'';display:inline-block;width:20px;height:20px;border:2px solid transparent;border-top:2px solid #fff;border-radius:50%;animation:spin 1s linear infinite;margin-left:10px}.refresh-video{background:#f39c12!important;color:#fff!important}.refresh-video:hover{background:#e67e22!important}.refresh-video.recovering{animation:pulse 1s infinite;background:#3498db!important}@keyframes pulse{0%{opacity:1}50%{opacity:.7}100%{opacity:1}}.video-container{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:1000}#remote-video{width:100%;height:100%;object-fit:cover}#local-video{position:absolute;top:20px;right:20px;width:200px;height:150px;border:2px solid #fff;border-radius:8px;object-fit:cover}.call-controls{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;gap:10px}.call-controls button{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:5px;cursor:pointer}.video-status{position:absolute;top:20px;left:20px;color:#fff;background:rgba(0,0,0,.7);padding:10px;border-radius:5px}