.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.login-form{background:#fff;padding:3rem;border-radius:20px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:400px;animation:fadeIn .5s ease-out}.login-form h1{text-align:center;margin-bottom:2rem;color:#333;font-size:2rem;font-weight:600}.form-group{margin-bottom:2rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.form-group input{width:100%;padding:1rem;border:2px solid #e1e5e9;border-radius:10px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.avatar-selector{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;margin-top:.5rem;margin-right:.5rem}.avatar-option{background:#f8f9fa;border:2px solid transparent;border-radius:8px;padding:.5rem;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.avatar-option:hover{background:#e9ecef;transform:scale(1.1)}.avatar-option.selected{border-color:#3b82f6;background:#eff6ff;transform:scale(1.1)}.join-button{width:100%;padding:1rem 2rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.join-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.join-button:active{transform:translateY(0)}@media (max-width: 768px){.login-container{padding:1rem}.login-form{padding:2rem;border-radius:15px}.avatar-selector{grid-template-columns:repeat(6,1fr)}.avatar-option{font-size:1.2rem;padding:.4rem}}@media (max-width: 480px){.avatar-selector{grid-template-columns:repeat(4,1fr)}}.message-list{flex:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;background:#f8f9fa}.message{display:flex;gap:.75rem;max-width:70%;animation:slideIn .3s ease-out}.message.own{align-self:flex-end;flex-direction:row-reverse}.message.other{align-self:flex-start}.message.system{align-self:center;max-width:100%;justify-content:center}.message-avatar{font-size:1.5rem;flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000001a}.message-content{flex:1;min-width:0}.message-username{font-size:.8rem;font-weight:600;color:#6b7280;margin-bottom:.25rem}.message-text{background:#fff;padding:.75rem 1rem;border-radius:18px;box-shadow:0 2px 8px #0000001a;word-wrap:break-word;line-height:1.4}.message.own .message-text{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.message.system .message-text{background:#e5e7eb;color:#6b7280;font-style:italic;text-align:center;border-radius:12px;font-size:.9rem}.message-time{font-size:.7rem;color:#9ca3af;margin-top:.25rem;text-align:right}.message.own .message-time{text-align:left}.message.system .message-time{text-align:center}.typing-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border-radius:18px;box-shadow:0 2px 8px #0000001a;max-width:200px;animation:fadeIn .3s ease-out}.typing-dots{display:flex;gap:.2rem}.typing-dots span{width:6px;height:6px;background:#9ca3af;border-radius:50%;animation:typingAnimation 1.4s infinite ease-in-out}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typingAnimation{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.typing-text{font-size:.8rem;color:#6b7280}@media (max-width: 768px){.message-list{padding:.75rem;gap:.75rem}.message{max-width:85%}.message-avatar{width:35px;height:35px;font-size:1.3rem}.message-text{padding:.6rem .8rem;font-size:.95rem}}@media (max-width: 480px){.message{max-width:95%}.message-text{padding:.5rem .7rem;font-size:.9rem}}.message-input-form{padding:1rem;background:#fff;border-top:1px solid #e5e7eb}.input-container{display:flex;gap:.75rem;align-items:flex-end;max-width:100%}.message-textarea{flex:1;min-height:44px;max-height:120px;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:22px;font-family:inherit;font-size:1rem;resize:none;outline:none;transition:all .3s ease;line-height:1.4}.message-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.message-textarea:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.send-button{width:44px;height:44px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:50%;color:#fff;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #3b82f64d}.send-button:active{transform:scale(.95)}.send-button:disabled{background:#d1d5db;cursor:not-allowed;transform:none;box-shadow:none}.message-textarea{overflow:hidden}@media (max-width: 768px){.message-input-form{padding:.75rem}.input-container{gap:.5rem}.message-textarea{font-size:16px;padding:.6rem .9rem}.send-button{width:40px;height:40px;font-size:1.1rem}}@media (max-width: 480px){.message-textarea{padding:.5rem .8rem}.send-button{width:36px;height:36px;font-size:1rem}}.user-list{width:300px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;animation:slideIn .3s ease-out}.user-list-header{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#f8f9fa}.user-list-header h3{font-size:1.1rem;font-weight:600;color:#374151}.close-button{background:none;border:none;font-size:1.5rem;color:#6b7280;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .3s ease}.close-button:hover{background:#e5e7eb;color:#374151}.user-list-content{flex:1;overflow-y:auto;padding:.5rem 0}.user-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;transition:background .3s ease}.user-item:hover{background:#f8f9fa}.user-item.current-user{background:#eff6ff;border-left:3px solid #3b82f6}.user-item .user-avatar{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:50%;flex-shrink:0}.user-details{flex:1;min-width:0}.user-name{font-weight:500;color:#374151;display:flex;align-items:center;gap:.5rem}.you-label{font-size:.7rem;background:#3b82f6;color:#fff;padding:.1rem .4rem;border-radius:8px;font-weight:600}.user-join-time{font-size:.8rem;color:#6b7280;margin-top:.1rem}.user-status{font-size:.8rem;flex-shrink:0}@media (max-width: 768px){.user-list{position:fixed;top:0;right:0;height:100vh;width:280px;z-index:1000;box-shadow:-4px 0 10px #0000001a}}@media (max-width: 480px){.user-list{width:100vw;left:0}.user-list-header{padding:1rem}.user-item{padding:.75rem 1rem}}.chat-room{width:100%;max-width:1200px;height:100vh;background:#fff;border-radius:15px;overflow:hidden;box-shadow:0 20px 40px #0000001a;display:flex;flex-direction:column;animation:fadeIn .5s ease-out}.chat-header{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:1rem 1.5rem;display:flex;justify-content:between;align-items:center;box-shadow:0 2px 10px #0000001a}.header-left{flex:1}.header-left h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;opacity:.9}.status-indicator{font-size:.8rem}.header-right{display:flex;align-items:center;gap:1rem}.users-toggle{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .3s ease}.users-toggle:hover{background:#ffffff4d}.user-info{display:flex;align-items:center;gap:.5rem;background:#ffffff1a;padding:.5rem 1rem;border-radius:8px}.user-avatar{font-size:1.2rem}.username{font-weight:500}.logout-button{background:#dc262633;border:none;color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.9rem;transition:background .3s ease}.logout-button:hover{background:#dc262666}.chat-content{flex:1;display:flex;min-height:0}.main-chat{flex:1;display:flex;flex-direction:column;min-height:0}@media (max-width: 768px){.chat-room{height:100vh;border-radius:0;max-width:none}.chat-header{padding:1rem;flex-wrap:wrap;gap:.5rem}.header-left h1{font-size:1.2rem}.header-right{gap:.5rem}.user-info{padding:.4rem .8rem}.username{font-size:.9rem}}@media (max-width: 480px){.chat-header{flex-direction:column;align-items:stretch;text-align:center}.header-right{justify-content:center;margin-top:.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea,#e6e4e8);color:#333;line-height:1.6}.app{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}@media (max-width: 768px){.app{padding:0;align-items:stretch}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.fade-in{animation:fadeIn .3s ease-out}.slide-in{animation:slideIn .3s ease-out}
