.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#0a0e27,#1a1f3a);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;padding:20px}.login-card{background:#15192b;border:1px solid #7c3aed30;border-radius:16px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-logo{text-align:center;margin-bottom:40px}.logo-image{max-width:120px;height:120px;width:120px;border-radius:50%;object-fit:cover;box-shadow:0 4px 12px #7c3aed4d}.login-form{display:flex;flex-direction:column;gap:24px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{color:#a0aec0;font-size:14px;font-weight:500}.login-field input{background:#1e2140;border:1px solid #7c3aed20;border-radius:8px;padding:12px 16px;color:#fff;font-size:16px;transition:all .2s}.login-field input:focus{outline:none;border-color:#7c3aed;background:#1e2140;box-shadow:0 0 0 3px #7c3aed1a}.login-field input:disabled{opacity:.5;cursor:not-allowed}.login-error{background:#7c3aed20;border:1px solid #7c3aed40;border-radius:8px;padding:12px;color:#f8d7da;font-size:14px;text-align:center}.login-submitBtn{background:linear-gradient(135deg,#7c3aed,#6d28d9);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px}.login-submitBtn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #7c3aed66}.login-submitBtn:active:not(:disabled){transform:translateY(0)}.login-submitBtn:disabled{opacity:.7;cursor:not-allowed}.chatlist-container{width:320px;height:100vh;background:#0f1229;border-right:1px solid #7c3aed15;display:flex;flex-direction:column;overflow:hidden}.chatlist-header{padding:16px;border-bottom:1px solid #7c3aed15;display:flex;justify-content:space-between;align-items:center}.chatlist-header h1{color:#fff;font-size:20px;font-weight:700;margin:0;background:linear-gradient(135deg,#fff,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chatlist-profileBtn{background:none;border:none;color:#7c3aed;font-size:20px;cursor:pointer;padding:4px;transition:transform .2s}.chatlist-profileBtn:hover{transform:scale(1.1)}.chatlist-searchBox{padding:12px}.chatlist-searchBox input{width:100%;background:#1e2140;border:1px solid #7c3aed20;border-radius:8px;padding:8px 12px;color:#a0aec0;font-size:14px;transition:all .2s}.chatlist-searchBox input:focus{outline:none;border-color:#7c3aed;color:#fff}.chatlist-roomsList{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:2px}.chatlist-roomsList::-webkit-scrollbar{width:6px}.chatlist-roomsList::-webkit-scrollbar-track{background:transparent}.chatlist-roomsList::-webkit-scrollbar-thumb{background:#7c3aed40;border-radius:3px}.chatlist-roomsList::-webkit-scrollbar-thumb:hover{background:#7c3aed60}.chatlist-roomItem{display:flex;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:all .2s;align-items:flex-start}.chatlist-roomItem:hover{background:#7c3aed15}.chatlist-roomItem.chatlist-active{background:#7c3aed25;border-left:3px solid #7c3aed;padding-left:9px}.chatlist-roomAvatar{flex-shrink:0;width:48px;height:48px}.chatlist-roomAvatar img{width:100%;height:100%;border-radius:8px;object-fit:cover}.chatlist-avatarPlaceholder{width:100%;height:100%;background:linear-gradient(135deg,#7c3aed,#6d28d9);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px}.chatlist-roomInfo{flex:1;min-width:0;padding-top:4px}.chatlist-roomName{color:#fff;font-size:15px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.chatlist-lastMessage{color:#8892b0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chatlist-roomTime{color:#64748b;font-size:12px;flex-shrink:0}.chatlist-loading,.chatlist-empty{color:#64748b;display:flex;align-items:center;justify-content:center;height:100%;font-size:14px}.chat-container{display:flex;flex-direction:column;height:100vh;background:#0a0e27;flex:1}.chat-header{padding:16px 24px;border-bottom:1px solid #7c3aed15;background:#0f1229}.chat-header h2{color:#fff;font-size:18px;font-weight:600;margin:0}.chat-emptyState{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b}.chat-emptyIcon{font-size:64px;margin-bottom:16px;opacity:.5}.chat-emptyState p{font-size:16px}.chat-messagesList{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:8px}.chat-messagesList::-webkit-scrollbar{width:8px}.chat-messagesList::-webkit-scrollbar-track{background:transparent}.chat-messagesList::-webkit-scrollbar-thumb{background:#7c3aed40;border-radius:4px}.chat-messagesList::-webkit-scrollbar-thumb:hover{background:#7c3aed60}.chat-loading,.chat-noMessages{display:flex;align-items:center;justify-content:center;height:100%;color:#64748b;font-size:14px}.chat-messageGroup{display:flex;flex-direction:column;align-items:flex-start;gap:4px;margin-bottom:8px}.chat-messageGroup.chat-ownMessage{align-items:flex-end}.chat-sender{color:#8892b0;font-size:12px;font-weight:500;padding:0 12px}.chat-messageGroup.chat-ownMessage .chat-sender{display:none}.chat-messageContent{display:flex;max-width:60%}.chat-messageGroup.chat-ownMessage .chat-messageContent{justify-content:flex-end}.chat-bubble{background:#1e2140;border:1px solid #7c3aed20;border-radius:12px;padding:10px 14px;min-width:80px}.chat-messageGroup.chat-ownMessage .chat-bubble{background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none}.chat-text{color:#fff;font-size:14px;line-height:1.4;word-break:break-word;white-space:pre-wrap}.chat-time{color:#64748b;font-size:11px;margin-top:4px;text-align:right}.chat-messageGroup.chat-ownMessage .chat-time{color:#fff9}.chat-inputArea{padding:16px 24px;border-top:1px solid #7c3aed15;display:flex;gap:12px;background:#0f1229}.chat-input{flex:1;background:#1e2140;border:1px solid #7c3aed20;border-radius:8px;padding:12px 16px;color:#fff;font-size:14px;transition:all .2s}.chat-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.chat-input::placeholder{color:#64748b}.chat-sendBtn{background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:8px;color:#fff;padding:12px 24px;font-size:18px;cursor:pointer;transition:all .2s;font-weight:600}.chat-sendBtn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #7c3aed66}.chat-sendBtn:disabled{opacity:.5;cursor:not-allowed}.profile-container{width:320px;height:100vh;background:#0f1229;border-right:1px solid #7c3aed15;display:flex;flex-direction:column;overflow:hidden}.profile-header{padding:16px;border-bottom:1px solid #7c3aed15;display:flex;align-items:center;gap:12px}.profile-backBtn{background:none;border:none;color:#7c3aed;font-size:16px;cursor:pointer;padding:4px;transition:transform .2s;font-weight:600}.profile-backBtn:hover{transform:translate(-2px)}.profile-header h2{color:#fff;font-size:18px;font-weight:600;margin:0;flex:1}.profile-content{flex:1;padding:24px 16px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.profile-avatarSection{display:flex;justify-content:center;padding-bottom:12px;border-bottom:1px solid #7c3aed15}.profile-avatar{width:80px;height:80px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff}.profile-infoSection{display:flex;flex-direction:column;gap:16px}.profile-infoField{display:flex;flex-direction:column;gap:8px}.profile-infoField label{color:#8892b0;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.profile-infoValue{color:#fff;font-size:14px;background:#1e2140;border:1px solid #7c3aed20;border-radius:8px;padding:10px 12px;word-break:break-all}.profile-logoutBtn{margin-top:auto;background:linear-gradient(135deg,#dc2626,#991b1b);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.profile-logoutBtn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #dc26264d}.profile-logoutBtn:active{transform:translateY(0)}.app{width:100%;height:100vh}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100vh;background:linear-gradient(135deg,#0a0e27,#1a1f3a);color:#fff;gap:16px}.app-spinner{width:40px;height:40px;border:3px solid #7c3aed30;border-top-color:#7c3aed;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-mainLayout{display:flex;width:100%;height:100vh}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;background:#0a0e27;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{overflow:hidden}button,input,textarea,select{font-family:inherit}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#7c3aed40;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#7c3aed60}@supports (scrollbar-width: thin){*{scrollbar-width:thin;scrollbar-color:#7c3aed40 transparent}}
