*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,sans-serif;background-color:#f5f5f5}.home-container{display:flex;height:100vh;height:100dvh;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden;position:relative}.sidebar{width:380px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;box-shadow:4px 0 20px #00000014}.sidebar-header{padding:24px;border-bottom:1px solid rgba(0,0,0,.05)}.logo{display:flex;align-items:center;gap:12px}.logo-icon{font-size:32px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.logo-text{font-size:24px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.current-user{display:flex;align-items:center;gap:12px;padding:20px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:relative}.current-user .user-avatar{width:50px;height:50px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;border:2px solid rgba(255,255,255,.3)}.current-user .user-info{flex:1}.current-user h3{margin:0;font-size:16px;font-weight:600}.current-user .user-status{margin:4px 0 0;font-size:13px;opacity:.9;display:flex;align-items:center;gap:6px}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-dot.online{background:#10b981}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.logout-btn{width:36px;height:36px;border-radius:8px;background:#fff3;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.logout-btn svg{width:20px;height:20px}.logout-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.search-container{padding:16px 24px;position:relative}.search-icon{position:absolute;left:40px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:#9ca3af;pointer-events:none}.search-input{width:100%;padding:12px 16px 12px 44px;border:1px solid rgba(0,0,0,.1);border-radius:12px;font-size:14px;background:#00000005;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.users-list{flex:1;overflow-y:auto;padding:8px}.list-title{padding:12px 16px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin:0}.user-item{display:flex;align-items:center;gap:12px;padding:12px 16px;margin:4px 0;border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative}.user-item:hover{background:#667eea14;transform:translate(4px)}.user-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.user-avatar-container{position:relative}.user-item .user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#fbbf24,#f59e0b);display:flex;align-items:center;justify-content:center;font-size:24px}.online-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;background:#10b981;border:2px solid white;border-radius:50%}.user-details{flex:1;min-width:0}.user-details h5{margin:0;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.last-message{margin:4px 0 0;font-size:13px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-item.active .last-message{opacity:.9}.message-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.message-time{font-size:11px;opacity:.6}.unread-badge{min-width:20px;height:20px;padding:0 6px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:10px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{transform:scale(1);box-shadow:0 0 #ef4444b3}50%{transform:scale(1.05);box-shadow:0 0 0 4px #ef444400}}.user-item.active .unread-badge{background:#ffffff4d;animation:none}.chat-area{flex:1;display:flex;flex-direction:column;background:#fff;min-height:0}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;background:#fff;border-bottom:1px solid rgba(0,0,0,.05);box-shadow:0 2px 8px #0000000a;flex-shrink:0}.chat-user-info{display:flex;align-items:center;gap:16px}.user-avatar.large{width:48px;height:48px;font-size:24px}.chat-user-info h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.user-status-text{margin:4px 0 0;font-size:13px;color:#10b981}.chat-actions{display:flex;gap:8px}.action-btn{width:40px;height:40px;border-radius:10px;background:#667eea1a;border:none;color:#667eea;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.action-btn svg{width:20px;height:20px}.action-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.messages-container{flex:1;overflow-y:auto;padding:24px 32px;background:linear-gradient(to bottom,#f9fafb,#fff);min-height:0;-webkit-overflow-scrolling:touch}.no-messages{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#9ca3af}.no-messages-icon{font-size:64px;margin-bottom:16px;opacity:.5}.no-messages h3{margin:0;font-size:20px;color:#6b7280}.no-messages p{margin:8px 0 0;font-size:14px}.message{display:flex;margin-bottom:16px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.me{justify-content:flex-end}.message-bubble{max-width:60%;padding:12px 16px;border-radius:16px;position:relative}.message.me .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.message.other .message-bubble{background:#f3f4f6;color:#1f2937;border-bottom-left-radius:4px}.message-bubble p{margin:0;font-size:15px;line-height:1.5;word-wrap:break-word}.message-bubble .message-time{display:block;font-size:11px;margin-top:6px;opacity:.7;display:flex;align-items:center;gap:4px}.read-receipt{font-size:12px;margin-right:4px}.read-receipt.unread{color:#fff9}.read-receipt.read{color:#60a5fa}.message.other .message-bubble .read-receipt{display:none}.message-image-wrapper{position:relative;display:inline-block;border-radius:10px;overflow:hidden}.message-image{display:block;max-width:240px;width:100%;border-radius:10px;cursor:pointer;object-fit:cover;transition:opacity .2s ease,transform .2s ease}.message-image:hover{opacity:.92;transform:scale(1.01)}.message-image.uploading{opacity:.5;filter:blur(1px)}.message-bubble:has(.message-image-wrapper){padding:4px;background:transparent!important}.message.me .message-bubble:has(.message-image-wrapper){background:transparent!important}.message.other .message-bubble:has(.message-image-wrapper){background:transparent!important}.message-bubble:has(.message-image-wrapper) .message-time{padding:0 8px 4px;margin-top:4px;opacity:.7}.message.me .message-bubble:has(.message-image-wrapper) .message-time{color:#4b5563}.image-upload-overlay{position:absolute;inset:0;background:#00000059;display:flex;align-items:center;justify-content:center;border-radius:10px}.uploading-spinner{display:inline-block;width:18px;height:18px;border:3px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.uploading-spinner.large{width:32px;height:32px;border-width:4px}.attachment-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.message-image{max-width:180px}.message-bubble{max-width:75%}}@media(max-width:480px){.message-image{max-width:140px}}.message-input-wrapper{position:relative;flex-shrink:0}.message-input-container{display:flex;align-items:center;gap:12px;padding:20px 32px;background:#fff;border-top:1px solid rgba(0,0,0,.05);box-shadow:0 -2px 8px #0000000a;flex-shrink:0}.attachment-btn,.emoji-btn{width:40px;height:40px;border-radius:10px;background:transparent;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.attachment-btn svg,.emoji-btn svg{width:22px;height:22px}.attachment-btn:hover,.emoji-btn:hover{background:#667eea1a;color:#667eea}.message-input{flex:1;padding:12px 20px;border:1px solid rgba(0,0,0,.1);border-radius:24px;font-size:15px;background:#f9fafb;transition:all .3s ease}.message-input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.send-btn{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.send-btn svg{width:20px;height:20px}.send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.send-btn:disabled{opacity:.5;cursor:not-allowed}.no-chat-selected{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea0d,#764ba20d);color:#9ca3af;position:relative}.no-chat-icon{font-size:96px;margin-bottom:24px;opacity:.3;animation:float 3s ease-in-out infinite}.no-chat-selected h2{margin:0;font-size:28px;color:#6b7280;font-weight:700}.no-chat-selected p{margin:12px 0 0;font-size:16px;color:#9ca3af}.users-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:6px}.users-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:transparent}.users-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:#0000001a;border-radius:10px}.users-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:#0003}.emoji-picker-container{position:absolute;bottom:70px;right:32px;z-index:1000;box-shadow:0 8px 24px #00000026;border-radius:12px;overflow:hidden}.emoji-picker-container aside{border-radius:12px!important;box-shadow:none!important}.mobile-menu-btn{display:none;width:44px;height:44px;min-width:44px;min-height:44px;border-radius:10px;background:#667eea1a;border:none;color:#667eea;cursor:pointer;align-items:center;justify-content:center;transition:all .3s ease;margin-right:12px;flex-shrink:0}.mobile-menu-btn svg{width:24px;height:24px}.mobile-menu-btn:hover{background:#667eea;color:#fff}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:998;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1024px){.sidebar{width:300px}.chat-header{padding:16px 24px}.messages-container{padding:20px 24px}.message-input-container{padding:16px 24px}}@media(max-width:900px){.sidebar{width:280px}.logo-text{font-size:20px}.current-user .user-avatar{width:46px;height:46px}.message-bubble{max-width:70%}}@media(max-width:768px){.home-container{display:flex;flex-direction:row;height:100vh;height:100dvh}.mobile-menu-btn{display:flex}.sidebar{position:fixed;top:0;left:-100%;width:85%;max-width:320px;height:100vh;height:100dvh;z-index:999;transition:left .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 20px #0000004d;will-change:left}.sidebar.open{left:0}.chat-area{width:100%;flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.chat-header{padding:12px 16px;flex-wrap:wrap;flex-shrink:0;position:sticky;top:0;z-index:10}.chat-user-info{gap:12px}.chat-user-info h3{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:150px}.user-status-text{font-size:12px}.user-avatar.large{width:40px;height:40px;font-size:20px}.chat-actions{gap:4px}.action-btn{width:36px;height:36px;min-width:36px}.action-btn svg{width:18px;height:18px}.messages-container{padding:16px;min-height:0;overscroll-behavior:contain}.message-bubble{max-width:85%;padding:10px 14px}.message-bubble p{font-size:14px}.message-bubble .message-time{font-size:10px}.message-input-container{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));gap:8px;flex-shrink:0}.attachment-btn,.emoji-btn{width:36px;height:36px}.attachment-btn svg,.emoji-btn svg{width:20px;height:20px;flex-shrink:0}.message-input{padding:10px 16px;font-size:14px}.send-btn{width:40px;height:40px;min-width:40px;min-height:40px;flex-shrink:0}.send-btn svg{width:18px;height:18px}.emoji-picker-container{bottom:65px;right:16px;left:16px;max-height:50vh;max-height:50dvh}.emoji-picker-container aside{width:100%!important}.no-chat-selected h2{font-size:22px}.no-chat-selected p{font-size:14px;padding:0 20px}.no-chat-icon{font-size:72px}.sidebar-header{padding:20px}.logo-text{font-size:20px}.current-user{padding:16px 20px}.current-user .user-avatar{width:45px;height:45px;font-size:18px}.current-user h3{font-size:15px}.search-container{padding:12px 20px}.search-input{padding:10px 14px 10px 38px;font-size:13px}.search-icon{left:36px}.user-item{padding:10px 14px}.user-item .user-avatar{width:42px;height:42px;font-size:20px}.user-details h5{font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.last-message{font-size:12px}}@media(max-width:480px){.sidebar{width:90%;max-width:100%}.chat-header h3{font-size:15px}.chat-header{padding:10px 12px;min-height:60px}.chat-actions button:nth-child(2){display:none}.message-bubble{max-width:90%;padding:8px 12px}.message-bubble p{font-size:13px}.no-messages h3{font-size:18px}.no-messages p{font-size:13px;padding:0 16px}.no-messages-icon{font-size:48px}.emoji-picker-container{left:8px;right:8px;bottom:60px}.message-input-container{padding:10px 12px}.message-input{font-size:13px;padding:8px 14px}.no-chat-selected h2{font-size:20px;padding:0 20px;text-align:center}.no-chat-selected p{padding:0 24px;text-align:center}}@media(max-width:768px)and (orientation:landscape){.sidebar{width:70%;max-width:280px}.messages-container{padding:12px 16px}.no-chat-selected h2{font-size:20px}.no-chat-icon{font-size:60px;margin-bottom:16px}}.typing-indicator{display:flex;align-items:center;gap:8px;padding:4px 8px 12px;color:#9ca3af;font-size:13px;font-style:italic;animation:slideIn .2s ease}.typing-dots{display:flex;gap:4px;align-items:center}.typing-dots span{width:6px;height:6px;background:#667eea;border-radius:50%;animation:typingBounce 1.2s ease-in-out infinite}.typing-dots span:nth-child(1){animation-delay:0s}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.image-preview-modal{position:fixed;inset:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:10000;cursor:zoom-out;animation:fadeInModal .15s ease}@keyframes fadeInModal{0%{opacity:0}to{opacity:1}}.image-preview-content{position:relative;max-width:90vw;max-height:90vh;cursor:default;animation:scaleInModal .18s ease}@keyframes scaleInModal{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.image-preview-content img{max-width:100%;max-height:88vh;object-fit:contain;border-radius:12px;box-shadow:0 24px 80px #0009;display:block}.close-preview{position:absolute;top:-14px;right:-14px;width:34px;height:34px;border-radius:50%;background:#ef4444;color:#fff;border:2px solid white;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:700;box-shadow:0 4px 12px #ef444480;transition:transform .15s ease,background .15s ease;z-index:1}.close-preview:hover{transform:scale(1.12);background:#dc2626}.user-item .user-avatar{font-size:20px;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-background{position:absolute;inset:0;overflow:hidden;z-index:0}.gradient-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:float 20s ease-in-out infinite}.orb-1{width:400px;height:400px;background:linear-gradient(135deg,#f093fb,#f5576c);top:-100px;left:-100px;animation-delay:0s}.orb-2{width:500px;height:500px;background:linear-gradient(135deg,#4facfe,#00f2fe);bottom:-150px;right:-150px;animation-delay:7s}.orb-3{width:350px;height:350px;background:linear-gradient(135deg,#43e97b,#38f9d7);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:14s}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,-50px) scale(1.1)}66%{transform:translate(-30px,30px) scale(.9)}}.auth-card{position:relative;z-index:1;width:100%;max-width:450px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:3rem;box-shadow:0 20px 60px #0000004d;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:2.5rem}.logo-container{margin-bottom:1.5rem}.logo-icon{font-size:4rem;display:inline-block;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.auth-title{font-size:2rem;font-weight:700;color:#1a202c;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-subtitle{color:#718096;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:600;color:#2d3748;margin-left:.25rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;width:20px;height:20px;color:#a0aec0;pointer-events:none;transition:color .3s ease}.form-input{width:100%;padding:.875rem 1rem .875rem 3rem;border:2px solid #e2e8f0;border-radius:12px;font-size:.95rem;color:#2d3748;background:#fff;transition:all .3s ease;outline:none}.form-input::placeholder{color:#cbd5e0}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-input:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:#667eea}.error-message{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff5f5;border:1px solid #feb2b2;border-radius:12px;color:#c53030;font-size:.875rem;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-icon{width:20px;height:20px;flex-shrink:0}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;margin-top:.5rem}.submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.submit-btn:hover:before{left:100%}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner{display:inline-block;width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-footer{margin-top:2rem;text-align:center}.auth-switch{color:#718096;font-size:.875rem}.auth-link{color:#667eea;font-weight:600;text-decoration:none;transition:color .3s ease}.auth-link:hover{color:#764ba2;text-decoration:underline}@media(max-width:640px){.auth-container{padding:1.5rem}.auth-card{padding:2rem 1.5rem}.auth-title{font-size:1.75rem}.logo-icon{font-size:3rem}.gradient-orb{filter:blur(60px)}.orb-1,.orb-2,.orb-3{width:250px;height:250px}}@media(max-width:375px){.auth-container{padding:1rem}.auth-card{padding:1.5rem 1.25rem}.auth-title{font-size:1.5rem}.auth-subtitle{font-size:.875rem}.logo-icon{font-size:2.5rem}.form-input{padding:.75rem .875rem .75rem 2.75rem;font-size:.875rem}.submit-btn{padding:.875rem;font-size:.95rem}.auth-header{margin-bottom:2rem}.auth-form{gap:1.25rem}}
