.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-title{font-size:2rem;margin-bottom:8px;text-align:center;color:#333}.login-subtitle{text-align:center;color:#666;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#333;font-size:14px}.form-input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .2s}.form-input:focus{outline:none;border-color:#667eea}.form-input select{cursor:pointer}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center}.login-button{padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.login-card{padding:30px 20px}.login-title{font-size:1.5rem}}.message-reactions{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}.reaction-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#0000000d;border:1px solid rgba(0,0,0,.1);border-radius:12px;cursor:pointer;transition:all .2s;font-size:12px}.reaction-badge:hover{background:#0000001a;transform:scale(1.05)}.reaction-badge.reacted{background:#667eea33;border-color:#667eea}.reaction-emoji{font-size:14px}.reaction-count{font-weight:600;color:#666;font-size:11px}.reaction-badge.reacted .reaction-count{color:#667eea}.message{display:flex;gap:12px;margin-bottom:8px;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.own-message{flex-direction:row-reverse}.message.system-message{justify-content:center;margin:16px 0}.message.system-message p{background:#e3f2fd;color:#1976d2;padding:8px 16px;border-radius:16px;font-size:12px;font-style:italic}.message-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.message-content{flex:1;max-width:70%}.message-header{display:flex;gap:8px;align-items:center;margin-bottom:4px}.message-sender{font-weight:600;font-size:14px;color:#333}.message-time{font-size:11px;color:#999}.message-body{background:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 1px 2px #0000001a;position:relative}.message.own-message .message-body{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message-text{margin:0;word-wrap:break-word;line-height:1.5;font-size:14px}.message-file{margin-bottom:8px}.message-image{max-width:100%;border-radius:8px;margin-top:8px}.message-file-link{display:inline-block;padding:8px 12px;background:#0000000d;border-radius:8px;text-decoration:none;color:inherit;margin-top:8px}.message.own-message .message-file-link{background:#fff3}.reaction-button{background:none;border:none;cursor:pointer;font-size:16px;padding:4px;margin-top:4px;opacity:.6;transition:opacity .2s}.reaction-button:hover{opacity:1}.reaction-picker{display:flex;gap:4px;margin-top:8px;padding:8px;background:#0000000d;border-radius:8px}.message.own-message .reaction-picker{background:#fff3}.reaction-emoji{background:none;border:none;cursor:pointer;font-size:20px;padding:4px 8px;border-radius:4px;transition:background .2s}.reaction-emoji:hover{background:#0000001a}.reaction-close{background:none;border:none;cursor:pointer;font-size:14px;padding:4px 8px;color:#666}@media (max-width: 768px){.message-content{max-width:85%}.message-avatar{width:32px;height:32px;font-size:12px}}.message-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f9f9f9}.empty-messages{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:14px}.typing-indicator{display:flex;align-items:center;gap:8px;padding:8px 16px;color:#666;font-size:14px;font-style:italic}.typing-dots{display:flex;gap:4px}.typing-dots span{width:6px;height:6px;background:#999;border-radius:50%;animation:typing 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}@media (max-width: 768px){.message-list{padding:12px;gap:8px}}.message-input-container{padding:16px;background:#fff;border-top:1px solid #e0e0e0}.file-preview{margin-bottom:8px;padding:8px 12px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center}.file-name{font-size:14px;color:#666;display:flex;align-items:center;gap:8px}.remove-file{background:none;border:none;cursor:pointer;color:#999;font-size:16px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.remove-file:hover{background:#0000001a}.message-input-form{display:flex;gap:8px;align-items:center}.input-actions{display:flex;align-items:center}.file-input{display:none}.file-input-label{cursor:pointer;font-size:20px;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.file-input-label:hover{background:#0000000d}.message-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:24px;font-size:14px;outline:none;transition:border-color .2s}.message-input:focus{border-color:#667eea}.send-button{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s;flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.message-input-container{padding:12px}.message-input{font-size:16px}}.chat-room{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-room-header{padding:16px 24px;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.chat-room-header h2{margin:0;font-size:1.2rem;color:#333;text-transform:capitalize}.room-info{display:flex;gap:12px;align-items:center;font-size:14px;color:#666}.user-count{font-weight:500}.reconnecting{color:#ff9800;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.chat-room-header{padding:12px 16px}.chat-room-header h2{font-size:1rem}}.user-list{display:flex;flex-direction:column;height:100%;overflow:hidden;background:#fff}.user-list-header{padding:16px;border-bottom:1px solid #e0e0e0;background:#f9f9f9}.user-list-header h3{margin:0;font-size:14px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.user-list-content{flex:1;overflow-y:auto;padding:8px}.user-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .2s}.user-item:hover:not(.current-user){background:#f5f5f5}.user-item.current-user{background:#667eea1a}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.user-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.user-name{font-weight:500;font-size:14px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-status{font-size:12px;color:#4caf50}.empty-users{padding:20px;text-align:center;color:#999;font-size:14px}.private-message-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:400px;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.modal-header h3{margin:0;font-size:18px;color:#333}.modal-close{background:none;border:none;cursor:pointer;font-size:20px;color:#999;padding:4px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.modal-close:hover{background:#0000001a}.private-message-form{display:flex;gap:8px}.private-message-input{flex:1;padding:10px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.private-message-send{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s}.private-message-send:hover:not(:disabled){transform:translateY(-2px)}.private-message-send:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.user-list-header{padding:12px}.user-item{padding:8px}.user-avatar{width:36px;height:36px;font-size:14px}}.room-selector{display:flex;flex-direction:column;border-bottom:1px solid #e0e0e0;background:#fff}.room-selector-header{padding:16px;display:flex;justify-content:space-between;align-items:center;background:#f9f9f9;border-bottom:1px solid #e0e0e0}.room-selector-header h3{margin:0;font-size:14px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.create-room-button{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;cursor:pointer;font-size:20px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:transform .2s}.create-room-button:hover{transform:scale(1.1)}.create-room-form{padding:12px 16px;background:#f9f9f9;border-bottom:1px solid #e0e0e0}.create-room-input{width:100%;padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;margin-bottom:8px;outline:none;transition:border-color .2s}.create-room-input:focus{border-color:#667eea}.create-room-actions{display:flex;gap:8px}.create-room-submit,.create-room-cancel{flex:1;padding:6px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:transform .2s}.create-room-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.create-room-submit:hover:not(:disabled){transform:translateY(-2px)}.create-room-submit:disabled{opacity:.5;cursor:not-allowed}.create-room-cancel{background:#e0e0e0;color:#666}.create-room-cancel:hover{background:#d0d0d0}.room-list{display:flex;flex-direction:column;padding:8px;max-height:200px;overflow-y:auto}.room-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:none;background:none;border-radius:8px;cursor:pointer;transition:background .2s;text-align:left}.room-item:hover{background:#f5f5f5}.room-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);font-weight:600}.room-name{font-size:14px;color:#333;text-transform:capitalize}.room-unread{background:#f44336;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}@media (max-width: 768px){.room-selector-header{padding:12px}.room-item{padding:8px}}.private-message-panel{display:flex;flex-direction:column;height:100%;overflow:hidden;background:#fff}.private-message-header{padding:16px;border-bottom:1px solid #e0e0e0;background:#f9f9f9;display:flex;justify-content:space-between;align-items:center}.private-message-header h3{margin:0;font-size:14px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.private-unread-badge{background:#f44336;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:12px;min-width:20px;text-align:center}.private-message-list{flex:1;overflow-y:auto;padding:8px}.empty-private{padding:20px;text-align:center;color:#999;font-size:14px}.private-user-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background .2s}.private-user-item:hover{background:#f5f5f5}.private-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.private-user-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.private-user-name{font-weight:500;font-size:14px;color:#333}.private-last-message{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.private-chat-view{display:flex;flex-direction:column;height:100%;overflow:hidden}.private-chat-header{padding:12px 16px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;gap:12px;background:#f9f9f9}.back-button{background:none;border:none;cursor:pointer;font-size:20px;color:#666;padding:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.back-button:hover{background:#0000001a}.private-chat-user{display:flex;align-items:center;gap:12px;flex:1}.private-chat-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.private-messages-list{flex:1;overflow-y:auto;padding:16px;background:#f9f9f9;display:flex;flex-direction:column;gap:12px}.empty-private-messages{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:14px}.private-message-form{padding:12px 16px;border-top:1px solid #e0e0e0;display:flex;gap:8px;background:#fff}.private-message-input{flex:1;padding:10px 14px;border:2px solid #e0e0e0;border-radius:20px;font-size:14px;outline:none;transition:border-color .2s}.private-message-input:focus{border-color:#667eea}.private-message-send-button{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s}.private-message-send-button:hover:not(:disabled){transform:translateY(-2px)}.private-message-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.private-message-header{padding:12px}.private-user-item{padding:10px}}.chat-container{min-height:100vh;display:flex;flex-direction:column;background:#f5f5f5}.chat-header{background:#fff;padding:16px 24px;box-shadow:0 2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;z-index:10}.chat-header h1{font-size:1.5rem;color:#333;margin:0}.header-info{display:flex;gap:16px;align-items:center}.connection-status{font-size:14px;font-weight:500}.connection-status.connected{color:#4caf50}.connection-status.disconnected{color:#f44336}.username{font-size:14px;color:#666;font-weight:500}.logout-button{padding:8px 16px;background:#f44336;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.logout-button:hover{background:#d32f2f}.chat-layout{display:flex;flex:1;overflow:hidden}.chat-sidebar{width:250px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fff}.chat-sidebar-right{width:300px;background:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden}@media (max-width: 1024px){.chat-sidebar-right{display:none}}@media (max-width: 768px){.chat-header{padding:12px 16px}.chat-header h1{font-size:1.2rem}.header-info{flex-direction:column;gap:4px;align-items:flex-end}.chat-sidebar{width:200px}.chat-sidebar-right{display:none}}@media (max-width: 640px){.chat-layout{flex-direction:column}.chat-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid #e0e0e0}}.App{min-height:100vh;display:flex;flex-direction:column}@media (max-width: 768px){.App{font-size:14px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}
