*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#f5f7fa;color:#333;overflow-x:hidden}.App{height:100vh;display:flex;flex-direction:column;position:relative}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(180deg)}}.login-form{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:40px;border-radius:20px;box-shadow:0 20px 40px #0000001a;width:100%;max-width:420px;position:relative;z-index:1;border:1px solid rgba(255,255,255,.2)}.login-form h2{text-align:center;margin-bottom:30px;color:#333;font-weight:700;font-size:28px}.form-group{margin-bottom:20px;position:relative}.form-group input{width:100%;padding:16px 20px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px;transition:all .3s ease;background-color:#fff}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;transform:translateY(-2px)}.login-form button{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.login-form button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.login-form button:hover:not(:disabled):before{left:100%}.login-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.login-form button:disabled{opacity:.6;cursor:not-allowed;transform:none}.switch-mode{text-align:center;margin-top:25px;color:#666;font-size:14px}.link-button{background:none;border:none;color:#667eea;cursor:pointer;text-decoration:underline;font-size:inherit;font-weight:600;transition:color .3s ease}.link-button:hover{color:#5a6fd8}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;text-align:center;border:1px solid #fcc;font-size:14px}.dashboard{height:100vh;display:flex;flex-direction:column;background-color:#fff;position:relative}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 10px #0000001a;position:relative;z-index:100}.header-left{display:flex;align-items:center;gap:15px;flex:1;min-width:0}.dashboard-header h2{font-weight:600;margin:0;font-size:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.total-unread-badge{background-color:#ff4757;color:#fff;border-radius:50%;padding:4px 8px;font-size:12px;font-weight:700;min-width:20px;text-align:center;animation:pulse 2s infinite}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.logout-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:14px;font-weight:500}.logout-btn:hover{background:#ffffff4d;transform:translateY(-1px)}.dashboard-content{display:flex;flex:1;overflow:hidden;position:relative}.mobile-nav-toggle{display:none;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:8px;border-radius:8px;transition:background-color .3s ease}.mobile-nav-toggle:hover{background:#fff3}.sidebar{width:350px;background-color:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;transition:transform .3s ease;position:relative;z-index:90}.sidebar-header{padding:20px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background-color:#fff}.sidebar-header h3{margin:0;color:#333;font-weight:600;font-size:18px}.new-chat-btn{background:#667eea;color:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:5px}.new-chat-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.chat-list{flex:1;overflow-y:auto;background-color:#fff}.no-chats{padding:40px 20px;text-align:center;color:#666;font-style:italic;line-height:1.5}.chat-item{padding:16px 20px;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:all .2s ease;position:relative;background-color:#fff}.chat-item:hover{background-color:#f8f9fa;transform:translate(2px)}.chat-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:inset 4px 0 #fff}.chat-header-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.chat-info h4{margin:0;font-weight:600;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.unread-badge{background-color:#ff4757;color:#fff;border-radius:50%;padding:3px 7px;font-size:11px;font-weight:700;min-width:18px;text-align:center;animation:bounce .5s ease}@keyframes bounce{0%,20%,60%,to{transform:translateY(0)}40%{transform:translateY(-3px)}80%{transform:translateY(-1px)}}.chat-item.active .unread-badge{background-color:#ffffffe6;color:#667eea}.last-message-info{display:flex;justify-content:space-between;align-items:center;gap:10px}.last-message{opacity:.8;font-size:13px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.last-message-time{opacity:.6;font-size:11px;white-space:nowrap;font-weight:500}.main-content{flex:1;display:flex;flex-direction:column;background-color:#fff;position:relative}.welcome-message{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#666;text-align:center;padding:40px}.welcome-message h3{margin-bottom:15px;font-weight:600;font-size:24px;color:#333}.welcome-message p{font-size:16px;line-height:1.5;max-width:400px}.user-list{height:100%;display:flex;flex-direction:column;background-color:#fff}.user-list-header{padding:20px;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;align-items:center;background-color:#f8f9fa}.user-list-header h3{margin:0;color:#333;font-weight:600;font-size:18px}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-btn:hover{background-color:#e9ecef;color:#333;transform:rotate(90deg)}.search-container{padding:20px;border-bottom:1px solid #e9ecef;background-color:#fff}.search-input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:12px;font-size:16px;transition:all .3s ease;background-color:#f8f9fa}.search-input:focus{outline:none;border-color:#667eea;background-color:#fff;box-shadow:0 0 0 3px #667eea1a}.users-container{flex:1;overflow-y:auto;padding:0}.user-item{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #f0f0f0;background-color:#fff;transition:all .2s ease}.user-item:hover{background-color:#f8f9fa;transform:translate(2px)}.user-item:last-child{border-bottom:none}.user-info h4{margin:0;color:#333;font-weight:600;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.start-chat-btn{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;white-space:nowrap}.start-chat-btn:hover{background:#5a6fd8;transform:translateY(-1px)}.no-users-found{padding:40px 20px;text-align:center;color:#666;font-style:italic;line-height:1.5}.chat-room{height:100%;display:flex;flex-direction:column;background-color:#fff;position:relative}.chat-header{padding:20px;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#f8f9fa,#e9ecef);position:relative}.chat-header h3{margin:0;color:#333;font-weight:600;font-size:18px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messages-container{flex:1;overflow-y:auto;padding:20px;background:linear-gradient(135deg,#fafbfc,#f8f9fa);scroll-behavior:smooth}.no-messages{display:flex;justify-content:center;align-items:center;height:100%;color:#666;font-style:italic;text-align:center;flex-direction:column;gap:10px}.message{margin-bottom:16px;display:flex;animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.own-message{justify-content:flex-end}.other-message{justify-content:flex-start}.message-content{max-width:75%;padding:12px 16px;border-radius:20px;position:relative;box-shadow:0 1px 2px #0000001a;word-wrap:break-word}.own-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:8px}.other-message .message-content{background-color:#e9ecef;color:#333;border-bottom-left-radius:8px}.message-text{margin-bottom:4px;line-height:1.4;font-size:15px}.message-time{font-size:11px;opacity:.7;text-align:right;margin-top:4px}.other-message .message-time{text-align:left}.message-input-container{padding:20px;border-top:1px solid #e9ecef;background-color:#fff;display:flex;gap:12px;align-items:flex-end}.message-input{flex:1;border:2px solid #e9ecef;border-radius:24px;padding:12px 18px;font-size:16px;resize:none;outline:none;transition:all .3s ease;font-family:inherit;max-height:120px;min-height:48px;line-height:1.4}.message-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.send-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50%;width:48px;height:48px;cursor:pointer;font-size:16px;font-weight:600;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #667eea4d}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.chat-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar,.users-container::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track,.users-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chat-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb,.users-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.chat-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover,.users-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width: 768px){.dashboard-header{padding:12px 16px}.dashboard-header h2{font-size:18px}.mobile-nav-toggle{display:block}.logout-btn{padding:6px 12px;font-size:13px}.dashboard-content{position:relative}.sidebar{position:fixed;top:0;left:0;height:100vh;width:100%;max-width:350px;transform:translate(-100%);z-index:1000;box-shadow:2px 0 10px #0000001a}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999}.sidebar-overlay.show{display:block}.main-content{width:100%}.message-content{max-width:85%}.message-input-container{padding:16px;gap:10px}.message-input{font-size:16px;padding:10px 16px;min-height:44px}.send-button{width:44px;height:44px;font-size:14px}.login-form{padding:30px 20px;margin:20px;max-width:100%}.form-group input{padding:14px 16px;font-size:16px}.login-form button{padding:14px;font-size:16px}.chat-header,.messages-container,.sidebar-header,.search-container{padding:16px}.user-item,.chat-item{padding:14px 16px}}@media (max-width: 480px){.dashboard-header h2{font-size:16px}.sidebar{width:100%;max-width:100%}.message-content{max-width:90%;padding:10px 14px}.login-form{padding:25px 16px;border-radius:16px}.login-form h2{font-size:24px}.welcome-message{padding:20px}.welcome-message h3{font-size:20px}.welcome-message p{font-size:14px}}@media (max-width: 768px) and (orientation: landscape){.sidebar{width:300px;max-width:300px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.login-form,.chat-item,.user-item,.message-content{border-width:.5px}}@media (prefers-color-scheme: dark){body{background-color:#1a1a1a;color:#e0e0e0}.sidebar,.main-content,.user-list,.chat-room{background-color:#2d2d2d}.sidebar-header,.chat-header,.chat-item:hover,.user-item:hover{background-color:#3a3a3a}.other-message .message-content{background-color:#3a3a3a;color:#e0e0e0}.messages-container{background:linear-gradient(135deg,#2d2d2d,#3a3a3a)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
