.login-container{max-width:400px;width:90%;margin:30px auto;padding:25px;background-color:#1a1e29;border-radius:10px;box-shadow:0 4px 20px #0000004d;border:1px solid #2a2f3d;text-align:center;box-sizing:border-box}.login-logo{width:100px;height:auto;display:block;margin:0 auto 15px;border-radius:50%;box-shadow:0 4px 8px #0000004d}.login-title{color:#6d8eff;text-align:center;margin-bottom:20px;font-size:22px}.login-form{display:flex;flex-direction:column}.success-message{background-color:#d4edda;color:#155724;padding:10px;margin-bottom:15px;border:1px solid #c3e6cb;border-radius:5px;text-align:center}.login-button{background-color:#6d3d6d;color:#fff;border:none;padding:12px;border-radius:6px;font-size:16px;cursor:pointer;transition:background-color .3s;margin-top:10px;width:100%}.login-button:hover{background-color:#7d4d7d}.register-link-text,.forgot-password-text{text-align:center;margin-top:15px;color:#a0a8c0;font-size:14px}.register-link,.forgot-password-link{color:#6d8eff;text-decoration:none;font-size:14px}.register-link:hover,.forgot-password-link:hover{text-decoration:underline}@media (max-width: 480px){.login-container{padding:20px 15px;margin:20px auto;width:95%}.login-logo{width:80px;margin-bottom:10px}.login-title{font-size:20px;margin-bottom:15px}.form-input{padding:10px 12px}.login-button{padding:10px;font-size:15px}}@media (max-width: 360px){.form-label,.register-link-text,.forgot-password-text{font-size:13px}}.user-list-item{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #2a2f3d;cursor:pointer;background-color:#1a1e29;transition:background-color .2s ease,transform .1s ease;border-radius:8px;margin-bottom:5px}.user-list-item:not(.selected):hover{background-color:#252a3a;transform:translate(5px)}.user-list-item.selected{background-color:#2a3a5a;border-left:4px solid #6d8eff;font-weight:700}.user-info-container{display:flex;align-items:center;flex-grow:1}.user-name{color:#e0e0e0;font-size:1rem;margin-right:auto}.unseen-badge{background-color:#ff4757;color:#fff;font-size:.75rem;font-weight:700;padding:3px 8px;border-radius:12px;margin-left:10px}.online-indicator{width:10px;height:10px;background-color:#4cd137;border-radius:50%;margin-left:10px;border:2px solid #1a1e29}.chat-box-container{display:flex;flex-direction:column;height:100vh;background-color:#1a1e28;border-radius:12px;overflow:hidden;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;box-shadow:0 10px 30px #0006}.chat-header{display:flex;align-items:center;padding:16px 20px;background:linear-gradient(to right,#242938,#1e222d);color:#f1f5f9;border-bottom:1px solid #2d3240;box-shadow:0 2px 10px #0003;flex-shrink:0}.chat-header h3{flex-grow:1;margin:0;font-size:1.1rem;font-weight:600;text-align:center;color:#fff;letter-spacing:.5px}.header-actions{display:flex;align-items:center;gap:12px}.back-button,.clear-chat-button{background:none;border:none;color:#94a3b8;font-size:.9rem;cursor:pointer;padding:6px 10px;border-radius:8px;transition:all .2s ease}.back-button:hover,.clear-chat-button:hover{background-color:#2e3444;color:#f1f5f9}.connection-status{font-size:.8rem;color:#ef4444;font-weight:500;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.chat-messages{flex:1;overflow-y:auto;padding:20px;background-color:#1a1e28;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;min-height:0;overflow-anchor:auto}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-thumb{background-color:#3b4252;border-radius:10px}.chat-messages::-webkit-scrollbar-track{background:#1a1e28}.message{display:flex;flex-direction:column;gap:6px;width:fit-content;max-width:75%;padding:12px 16px;border-radius:20px;color:#e2e8f0;line-height:1.5;word-break:break-word;overflow-wrap:anywhere;box-shadow:0 4px 12px #0003;position:relative;transition:transform .15s ease-out}.message.sent{margin-left:auto;background:linear-gradient(135deg,#4c66f0,#2540c7);border-bottom-right-radius:8px}.message.received{margin-right:auto;background:linear-gradient(135deg,#334155,#1e293b);border-bottom-left-radius:8px}.message-content{display:block}.message-sender{font-weight:600;color:#81a4ff;font-size:.9rem;margin-bottom:2px;display:block}.message-time{display:flex;align-items:center;gap:8px;justify-content:flex-end;font-size:.75rem;color:#fff9;margin-top:4px}.read-status{font-size:.7rem;padding-left:6px;line-height:1}.read-status.read{color:#38bdf8}.read-status.unread{color:#fff6}.delete-message-button{position:absolute;top:6px;right:6px;background:none;border:none;color:#fff9;font-weight:700;font-size:.9rem;cursor:pointer;opacity:0;transition:opacity .2s ease,transform .2s ease}.message:hover .delete-message-button{opacity:1}.delete-message-button:hover{transform:scale(1.1);color:#fff}.chat-input-form{display:flex;padding:16px 20px;border-top:1px solid #2d3240;background-color:#1e222d;gap:12px;flex-shrink:0}.chat-input{flex:1;padding:12px 16px;border-radius:25px;border:1px solid #3b4252;background-color:#242938;color:#f1f5f9;font-size:1rem;transition:border-color .2s ease}.chat-input:focus{outline:none;border-color:#4c66f0;box-shadow:0 0 0 2px #4c66f04d}.chat-input::placeholder{color:#64748b}.send-button{padding:12px 24px;border:none;border-radius:25px;background:linear-gradient(135deg,#4c66f0,#2540c7);color:#fff;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.send-button:disabled{background:#3b4252;color:#64748b;cursor:not-allowed}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #4c66f066}.no-chat-selected,.no-messages,.error-message{flex-grow:1;display:flex;justify-content:center;align-items:center;text-align:center;color:#94a3b8;font-size:1rem;padding:20px}.error-message{color:#ef4444}@media (max-width: 768px){.chat-box-container{height:calc(var(--vh, 1vh) * 100);position:relative;border-radius:0}.chat-header{padding:14px 16px}.chat-header h3{font-size:1rem}.chat-messages{flex:1;overflow-y:auto;padding:12px;gap:8px;min-height:0}.message{max-width:85%}.message-time,.read-status{font-size:.7rem}.chat-input-form{padding:12px 16px;position:static;bottom:unset;left:unset;right:unset;z-index:100;flex-shrink:0}.send-button{padding:10px 18px;font-size:.9rem}}.settings-panel{padding:20px;display:flex;flex-direction:column;height:100%}.settings-panel h3{color:#6d8eff;margin-bottom:10px}.settings-panel p{color:#b0b0b0;font-size:.9rem}.settings-actions{margin-top:20px;display:flex;flex-direction:column;gap:30px}.change-password-button{background-color:#6d8eff;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:16px;cursor:pointer;transition:background-color .2s ease}.change-password-button:hover{background-color:#7d9bff}.delete-account-button{background-color:#d13c3c;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:16px;cursor:pointer;transition:background-color .2s ease}.delete-account-button:hover{background-color:#e04b4b}.back-button-styled{background-color:#3a4052;color:#e0e0e0;border:1px solid #4a5063;padding:10px 20px;border-radius:8px;font-size:16px;cursor:pointer;font-weight:700;width:100%;transition:background-color .2s ease,border-color .2s ease;margin-bottom:25px}.back-button-styled:hover{background-color:#4a5063;border-color:#6d8eff}.password-change-form{padding:20px;display:flex;flex-direction:column;gap:15px;height:100%}.password-change-form h3{color:#6d8eff;margin-bottom:5px}.password-change-form form{display:flex;flex-direction:column;gap:10px}.password-change-form input{padding:12px 15px;background-color:#252a3a;border:1px solid #3a4052;border-radius:8px;color:#e0e0e0;outline:none}.password-change-form button{padding:12px 20px;border:none;border-radius:8px;cursor:pointer;font-weight:700;transition:background-color .2s ease}.password-change-form button[type=submit]{background-color:#6d8eff;color:#fff}.password-change-form button[type=submit]:hover{background-color:#7d9bff}.password-change-form .back-button{margin-top:10px;align-self:flex-start;color:#b0b0b0}.modal-content{background-color:#1e2029;color:#e0e0e0;padding:25px;border-radius:12px;width:90%;max-width:400px;box-shadow:0 5px 15px #00000080;text-align:center}.modal-content h3{color:#6d8eff;margin-bottom:15px;font-size:1.5rem}.modal-content p{margin-bottom:25px;font-size:1rem}.modal-actions{display:flex;justify-content:center;gap:15px}.modal-confirm-btn,.modal-cancel-btn{padding:12px 25px;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:background-color .2s ease}.modal-confirm-btn{background-color:#6d8eff;color:#fff}.modal-confirm-btn:hover{background-color:#7d9bff}.modal-cancel-btn{background-color:#3a4052;color:#e0e0e0}.modal-cancel-btn:hover{background-color:#4a5063}@media (max-width: 768px){.settings-panel{display:flex;flex-direction:column;width:100%}}html,body,#root,.chat-container{height:100%;margin:0;padding:0;overflow:hidden}.chat-container{display:flex;height:100%;width:100%;overflow:hidden}:root{--bg-color: #1a1e29;--bg-darker: #12151c;--bg-light: #252a3a;--text-color: #e0e0e0;--text-secondary: #a0a8c0;--accent-color: #6d8eff;--button-color: #6d3d6d;--button-hover-color: #7d4d7d;--border-color: #2a2f3d;--online-color: #2ed573;--offline-color: #ff4757;--unread-bg: #6d8eff;--unread-text: #ffffff}body{background-color:var(--bg-darker);color:var(--text-color);font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding:0;box-sizing:border-box}.sidebar{width:350px;min-width:300px;background-color:var(--bg-color);border-right:1px solid var(--border-color);padding:20px;display:flex;flex-direction:column;box-shadow:2px 0 10px #0003}.sidebar-content{display:flex;flex-direction:column;height:100%}.user-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-shrink:0}.user-info h3{color:var(--accent-color);margin:0;font-size:1.2rem}.user-actions{display:flex;gap:10px}.settings-button,.logout-button{background-color:var(--bg-light);color:var(--text-color);border:1px solid var(--border-color);padding:8px 12px;border-radius:8px;cursor:pointer;transition:background-color .3s,transform .2s}.logout-button{background-color:var(--button-color)}.settings-button:hover{background-color:#31374a}.logout-button:hover{background-color:var(--button-hover-color);transform:scale(1.05)}.divider{border:none;border-top:1px solid var(--border-color);margin:15px 0;flex-shrink:0}.create-group-form{display:flex;gap:10px;margin-bottom:20px;flex-shrink:0}.create-group-input{flex-grow:1;padding:10px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-light);color:var(--text-color)}.create-group-button{padding:10px 15px;background-color:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s,transform .2s}.create-group-button:disabled{background-color:var(--text-secondary);cursor:not-allowed}.create-group-button:not(:disabled):hover{background-color:#5577e0;transform:scale(1.05)}.search-container{margin:15px 0 10px;flex-shrink:0}.search-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-light);color:var(--text-color)}.chat-list-container{overflow-y:auto;flex-grow:1}.chat-list-container{flex-grow:1;overflow-y:auto}.chat-list{list-style:none;padding:0;margin:0}.no-users-message{color:var(--text-secondary);font-style:italic;text-align:center;margin-top:10px}.chat-main{flex-grow:1;display:flex;flex-direction:column;background-color:var(--bg-light)}.no-chat-selected{display:flex;justify-content:center;align-items:center;height:100%;color:var(--text-secondary);font-size:1.2rem;text-align:center}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--bg-color);padding:30px;border-radius:10px;box-shadow:0 5px 15px #00000080;max-width:400px;width:90%;text-align:center;border:1px solid var(--border-color)}.modal-content h3{color:var(--accent-color);margin-top:0}.modal-actions{display:flex;justify-content:center;gap:15px;margin-top:20px}.modal-confirm-btn,.modal-cancel-btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:1rem;transition:background-color .3s}.modal-confirm-btn{background-color:var(--button-color);color:#fff}.modal-confirm-btn:hover{background-color:var(--button-hover-color)}.modal-cancel-btn{background-color:var(--bg-light);color:var(--text-color)}.modal-cancel-btn:hover{background-color:#3a4052}.settings-panel,.password-change-form{padding:20px}.settings-panel h3,.password-change-form h3{color:var(--accent-color);margin-bottom:20px}.settings-panel button,.password-change-form button{width:100%;padding:12px;margin-bottom:15px;border-radius:8px;border:none;cursor:pointer;font-size:1rem;transition:background-color .3s}.settings-panel .back-button,.password-change-form .back-button{background-color:var(--bg-light);color:var(--text-color)}.settings-panel .back-button:hover,.password-change-form .back-button:hover{background-color:#3a4052}.settings-panel .delete-account-button{background-color:#ff4757;color:#fff}.settings-panel .delete-account-button:hover{background-color:#d13a48}.settings-panel .change-password-button,.password-change-form button[type=submit]{background-color:var(--button-color);color:#fff}.settings-panel .change-password-button:hover,.password-change-form button[type=submit]:hover{background-color:var(--button-hover-color)}.password-change-form form{display:flex;flex-direction:column;gap:15px}.password-change-form input{padding:10px;border-radius:8px;border:1px solid var(--border-color);background-color:var(--bg-light);color:var(--text-color)}.loading-sidebar,.loading-main{background-color:var(--bg-color);padding:20px}.user-info-skeleton,.create-group-skeleton{height:60px;background-color:var(--bg-light);border-radius:8px;margin-bottom:20px;animation:pulse 1.5s infinite ease-in-out}.chat-list-skeleton{height:50px;background-color:var(--bg-light);border-radius:6px;margin-bottom:10px;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%{opacity:.6}50%{opacity:.3}to{opacity:.6}}@media (max-width: 768px){.chat-container{flex-direction:column;height:calc(var(--vh, 1vh) * 100);overflow:hidden}.sidebar{width:100%;min-width:unset;border-right:none;height:100%;padding:10px;display:flex;flex-direction:column}.sidebar-content{height:100%;display:flex;flex-direction:column}.chat-list-container{flex-grow:1;overflow-y:auto}.chat-main{width:100%;height:100%}.user-info{flex-direction:row;gap:10px}.user-actions{flex-direction:row}}.forgot-password-container{max-width:400px;width:90%;margin:30px auto;padding:25px;background-color:#1a1e29;border-radius:10px;box-shadow:0 4px 20px #0000004d;border:1px solid #2a2f3d;text-align:center;box-sizing:border-box}.forgot-password-logo{width:100px;height:auto;display:block;margin:0 auto 15px;border-radius:50%;box-shadow:0 4px 8px #0000004d}.forgot-password-title{color:#6d8eff;text-align:center;margin-bottom:20px;font-size:22px}.forgot-password-description{color:#a0a8c0;text-align:center;margin-bottom:20px;font-size:14px}.forgot-password-form{display:flex;flex-direction:column}.form-group{margin-bottom:15px;text-align:left}.form-label{display:block;margin-bottom:8px;color:#a0a8c0;font-size:14px}.form-input{width:100%;padding:12px 15px;border:1px solid #3a4052;border-radius:6px;background-color:#252a3a;color:#e0e0e0;font-size:14px;transition:border-color .3s;box-sizing:border-box}.form-input:focus{border-color:#6d8eff;outline:none}.reset-button{background-color:#6d3d6d;color:#fff;border:none;padding:12px;border-radius:6px;font-size:16px;cursor:pointer;transition:background-color .3s;margin-top:10px;width:100%}.reset-button:hover{background-color:#7d4d7d}.error-message{color:#ff4757;background-color:#ff47571a;padding:10px;border-radius:6px;margin-bottom:15px;text-align:center;font-size:14px}.success-message{color:#2ed573;background-color:#2ed5731a;padding:10px;border-radius:6px;margin-bottom:15px;text-align:center;font-size:14px}.back-to-login-text{text-align:center;margin-top:15px;color:#a0a8c0;font-size:14px}.back-to-login-link{color:#6d8eff;text-decoration:none;font-size:14px}.back-to-login-link:hover{text-decoration:underline}@media (max-width: 480px){.forgot-password-container{padding:20px 15px;margin:20px auto;width:95%}.forgot-password-logo{width:80px;margin-bottom:10px}.forgot-password-title{font-size:20px;margin-bottom:15px}.form-input{padding:10px 12px}.reset-button{padding:10px;font-size:15px}}@media (max-width: 360px){.form-label,.back-to-login-text,.forgot-password-description{font-size:13px}}.reset-password-container{max-width:500px;margin:50px auto;padding:30px;background-color:#1a1e29;border-radius:10px;box-shadow:0 4px 20px #0000004d;border:1px solid #2a2f3d}.reset-password-title{color:#6d8eff;text-align:center;margin-bottom:25px;font-size:28px}.reset-password-form{display:flex;flex-direction:column}.password-strength{margin-top:5px;height:5px;background-color:#252a3a;border-radius:3px;overflow:hidden}.password-strength-bar{height:100%;transition:width .3s,background-color .3s}.password-strength-weak{background-color:#ff4757;width:30%}.password-strength-medium{background-color:#ffa502;width:60%}.password-strength-strong{background-color:#2ed573;width:100%}.password-requirements{margin-top:10px;font-size:13px;color:#7f8c9d}.password-requirement{display:flex;align-items:center;margin-bottom:5px}.password-requirement.valid{color:#2ed573}.password-requirement.invalid{color:#ff4757}.password-requirement-icon{margin-right:5px;font-size:16px}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#0a0e17;color:#e0e0e0}.app-container{background:radial-gradient(circle at center,#1a1e29,#0a0e17);min-height:100vh}a{color:#6d8eff;text-decoration:none}a:hover{color:#8fa7ff;text-decoration:underline}.loading-spinner{border:4px solid rgba(109,142,255,.3);border-radius:50%;border-top:4px solid #6d8eff;width:40px;height:40px;animation:spin 1s linear infinite;margin:20px auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-10px)}to{transform:translateY(0)}}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}@keyframes slideIn{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1a1e29}::-webkit-scrollbar-thumb{background:#3a4052;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4a5062}.tooltip{position:relative;display:inline-block}.tooltip .tooltiptext{visibility:hidden;width:120px;background-color:#252a3a;color:#e0e0e0;text-align:center;border-radius:6px;padding:5px;position:absolute;z-index:1;bottom:125%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s;border:1px solid #3a4052;font-size:13px}.tooltip:hover .tooltiptext{visibility:visible;opacity:1}@media (max-width: 768px){.login-container,.register-container,.forgot-password-container,.reset-password-container{margin:20px;padding:20px}.login-title,.register-title,.forgot-password-title,.reset-password-title{font-size:24px}}.icon{font-family:Material Icons;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased}
