html,body,#root{height:100%;margin:0;padding:0;font-family:Inter,Roboto,sans-serif;background:#edf2f7;color:#333}.layout{display:flex;height:100%;min-height:100vh}.layout__sidebar{width:240px;background:#1f2937;border-right:1px solid #374151;display:flex;flex-direction:column;padding:1rem;color:#f9fafb}.layout__sidebar--right{border-left:1px solid #374151;border-right:none}.layout__sidebar-title{font-size:1.2rem;font-weight:600;margin-bottom:1rem;color:#10b981}.layout__nav-list{list-style:none;padding:0;margin:0;flex-grow:1;overflow-y:auto}.layout__nav-item{margin-bottom:.5rem}.layout__nav-link{display:flex;justify-content:center;align-items:center;padding:.5rem .75rem;border-radius:6px;color:#e5e7eb;text-decoration:none;transition:background .2s,color .2s;font-weight:500}.layout__nav-link{background:#374151}.layout__nav-link:hover{background:#4b5563;color:#fff}.layout__nav-link.group{background:#3b82f6;color:#fff}.layout__nav-link.group:hover{background:#2563eb}.layout__nav-link.active{background:#10b981;color:#fff}.layout__new-chat-btn,.send-button,.button-group button,.popup__send-btn{padding:.5rem .75rem;border:none;border-radius:6px;margin-bottom:.75rem;cursor:pointer;font-size:.95rem;background:#14b8a6;color:#f9fafb;transition:background .2s,transform .1s}.layout__new-chat-btn:hover,.send-button:hover,.button-group button:hover,.popup__send-btn:hover{background:#0d9488;transform:translateY(-1px)}.layout__logout-btn,.popup__close-btn{padding:.5rem .75rem;border:none;border-radius:6px;margin-top:auto;cursor:pointer;font-size:.95rem;background:#ef4444;color:#f9fafb;transition:background .2s,transform .1s}.layout__logout-btn:hover,.popup__close-btn:hover{background:#b91c1c;transform:translateY(-1px)}.layout__content{flex:1;display:flex;flex-direction:column;min-height:0}.layout__main{flex:1;display:flex;flex-direction:column;background:#f3f4f6;overflow-y:auto}.layout__users{display:flex;flex-direction:column;gap:.5rem}.layout__users h3{margin-top:.5rem;margin-bottom:.75rem;font-size:1.1rem;color:#10b981}.layout__user-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:6px;color:#e5e7eb;background:transparent;cursor:default;transition:background .2s}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:#fff;padding:1.5rem;border-radius:10px;width:320px;max-width:90%;display:flex;flex-direction:column;gap:.75rem}.modal-content input{padding:.6rem .8rem;font-size:.95rem;border:1px solid #cbd5e1;border-radius:6px;width:100%;box-sizing:border-box}.modal-content button{padding:.5rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.modal-content button:first-of-type{background:#14b8a6;color:#fff}.modal-content button:first-of-type:hover{background:#0d9488}.modal-content button:last-of-type{background:#e5e7eb;color:#333}.modal-content button:last-of-type:hover{background:#d1d5db}.select-container{width:100%;margin-bottom:.75rem}.styled-select{width:100%;padding:.6rem .8rem;border-radius:6px;border:1px solid #cbd5e1;background-color:#f3f4f6;color:#111827;font-size:.95rem;transition:border .2s,background .2s;cursor:pointer}.styled-select:focus{outline:none;border-color:#14b8a6;background-color:#e0f2f1}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#1f2937bf;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#f9fbff;color:#111827;padding:20px;border-radius:8px;max-width:400px;width:90%;display:flex;flex-direction:column;gap:.8rem;box-shadow:0 4px 15px #00000040}.modal-content h3{margin:0;font-size:1.3rem;color:#10b981}.modal-content input{width:100%;padding:.6rem .75rem;border-radius:6px;border:1px solid #d1d5db;background:#f0f4f8;color:#111827;font-size:.95rem}.modal-content button{width:100%;padding:.6rem 1rem;border-radius:6px;border:none;font-weight:600;cursor:pointer;font-size:.95rem;transition:background .2s,transform .1s}.modal-content button:first-of-type{background:#14b8a6;color:#f9fafb}.modal-content button:first-of-type:hover{background:#0d9488;transform:translateY(-1px)}.modal-content button:last-of-type{background:#ef4444;color:#f9fafb;margin-top:.5rem}.modal-content button:last-of-type:hover{background:#b91c1c;transform:translateY(-1px)}.friend-request{display:flex;justify-content:space-between;align-items:center;padding:8px;background-color:#dcf5e6;border-radius:10px;height:50px}.friend-request p{margin:0;width:calc(100% - 100px);color:#111827}.friend-request button{background-color:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;width:140px;margin-top:0}.friend-request button:hover{background:#0d7a63}.home-window{padding:2rem;background:#f3f4f6;height:100%;display:flex;flex-direction:column;flex:1;overflow-y:auto}.home-title{font-size:1.8rem;font-weight:700;color:#000;margin-bottom:1.5rem;text-align:center}.button-group{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:center}.button-group button{border:none;padding:.6rem 1.2rem;border-radius:6px;background:#14b8a6;color:#fff;font-weight:600;cursor:pointer;transition:background .2s ease,transform .1s ease}.button-group button:hover{background:#0d9488;transform:translateY(-1px)}.friends-container{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1rem}.friend{padding:.6rem 1rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;box-shadow:0 2px 6px #0000000d;font-weight:500;color:#333;transition:transform .15s ease,box-shadow .15s ease}.friend:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001a}.error{color:#ef4444;margin-top:.5rem;font-weight:500}body{background:#1f2937;color:#f9fafb;font-family:Inter,Roboto,sans-serif;margin:0;padding:0;overflow:hidden}.wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:0 20px;background:#1f2937}.form-container{width:360px;padding:35px 30px;background:#1e1e1e;border-radius:12px;box-shadow:0 10px 25px #00000080;display:flex;flex-direction:column;gap:15px}.form-container h2{margin-bottom:25px;text-align:center;color:#10b981;letter-spacing:1px}.form{display:flex;flex-direction:column;gap:15px}.input-group{display:flex;flex-direction:column}.input-group label{margin-bottom:5px;font-weight:600;color:#cfd8dc}.input-group input{padding:12px;border-radius:6px;border:1px solid #333;background:#2c2c2c;color:#f9fafb;font-size:.95rem;transition:border .2s,background .2s}.input-group input:focus{outline:none;border-color:#10b981;background:#272727}.button{width:100%;padding:12px;background-color:#10b981;color:#f9fafb;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.button:hover{background-color:#0d9488;transform:translateY(-2px)}.demo-button{margin-top:12px}.toggle-text{margin-top:20px;font-size:.9rem;text-align:center;color:#cfd8dc}.toggle-link{margin-left:5px;color:#10b981;font-weight:600;cursor:pointer;transition:color .2s}.toggle-link:hover{color:#0d9488;text-decoration:underline}.chat-window{display:flex;flex-direction:column;height:100%;background:#f3f4f6;overflow:hidden;box-shadow:0 2px 8px #00000014}.chat-title{background:#14b8a6;color:#fff;padding:1rem;border-bottom:1px solid #0d7a63}.chat-title h2{margin:0;font-size:1.25rem}.chat-subtitle{font-size:.9rem;opacity:.9;margin-top:.25rem}.messages-container{flex:1;padding:1rem;overflow-y:auto;background:#edf2f7;display:flex;flex-direction:column}.message{display:flex;flex-direction:column;margin-bottom:1rem;max-width:70%}.message-left{align-self:flex-start}.message-right{align-self:flex-end;text-align:right}.message-bubble{padding:.6rem .9rem;border-radius:12px;box-shadow:0 2px 6px #00000014;display:inline-block;word-break:break-word;font-size:.95rem;line-height:1.4}.message-left .message-bubble{background:#fff;border:1px solid #e2e8f0;color:#333}.message-right .message-bubble{background:#10b981;color:#fff}.chat-input-container{display:flex;align-items:center;padding:.8rem;background:#f3f4f6;border-top:1px solid #e2e8f0;gap:.5rem}.chat-input{flex:1;border:1px solid #cbd5e1;border-radius:20px;padding:.6rem 1rem;background:#fff;height:40px;font-size:1rem}.send-button{border:none;background:#14b8a6;color:#fff;padding:0 1rem;border-radius:20px;cursor:pointer;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin:0}.send-button:hover{background:#0d9488}
