body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.user-hover-card{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 5px 15px #0000001a;display:flex;flex-direction:column;padding:16px;text-align:center;width:280px;z-index:100}.hover-card-pfp{border:3px solid #f0f0f0;border-radius:50%;height:70px;margin-bottom:12px;object-fit:cover;width:70px}.hover-card-username{color:#333;font-size:1.15em;font-weight:700;margin-bottom:6px}.hover-card-bio{color:#555;font-size:.9em;line-height:1.4;margin-bottom:16px;max-height:3.78em;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.hover-card-actions{display:flex;gap:10px;width:100%}.hover-card-actions .hover-action-button{background-color:#6c63ff;border:none;border-radius:6px;color:#fff;cursor:pointer;flex-grow:1;font-size:.85em;font-weight:500;padding:9px 12px;transition:background-color .2s ease;white-space:nowrap}.hover-card-actions .hover-action-button:hover{background-color:#574fd8}.username-hover-wrapper{display:inline-block;position:relative}.username-hover-wrapper .user-hover-card-popup-container{bottom:100%;display:none;left:50%;margin-bottom:8px;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .25s ease-in-out,visibility 0s .25s,transform .25s ease-in-out;visibility:hidden}.username-hover-wrapper:hover .user-hover-card-popup-container{display:block;opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(-5px);transition-delay:0s,0s,0s;visibility:visible}.messages-container{background-color:#f4f0fb;display:flex;gap:1rem;height:calc(100vh - 120px);padding:1rem}.contacts-sidebar{background-color:#fff;border-radius:8px;overflow:auto;padding:1rem;width:250px}.search-bar-container{padding:0 1rem 1rem}.search-bar-input{border:1px solid #ddd;border-radius:20px;font-size:14px;outline:none;padding:8px 12px;width:100%}.no-friends-message{padding:1rem;text-align:center}.no-friends-filtered{color:#666}.add-friends-btn{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:.5rem;padding:8px 16px}.clear-search-btn{background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:12px;margin-top:.5rem;padding:4px 8px}.contacts-list{list-style:none;margin:0;padding:0}.contact-item{border-radius:4px;cursor:pointer;margin-bottom:.5rem;padding:.75rem;transition:background .2s}.contact-item.selected,.contact-item:hover{background-color:#f0f0ff}.contact-item.has-new-messages{background-color:#e3f2fd;border-left:3px solid #2196f3}.contact-item.has-new-messages .contact-name{font-weight:700}.contact-avatar,.contact-avatar-row{align-items:center;display:flex}.contact-avatar{background-color:#6c63ff;border-radius:50%;color:#fff;font-size:1.2rem;font-weight:700;height:40px;justify-content:center;margin-right:.75rem;overflow:hidden;width:40px}.avatar-img{height:100%;object-fit:cover;width:100%}.contact-name{font-weight:700}.contact-bio{color:#666;font-size:.8rem}.messages-area{background-color:#fff;border-radius:8px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.contact-header{align-items:center;border-bottom:1px solid #eee;display:flex;padding:1rem}.contact-status{color:#666;font-size:.8rem}.messages-list{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:1rem;scroll-behavior:smooth}.no-messages{align-items:center;color:#666;display:flex;flex:1 1;justify-content:center}.message-bubble{border-radius:1rem;margin-bottom:.5rem;max-width:70%;padding:.75rem;position:relative;transition:all .3s ease;word-break:break-word}.message-bubble.sent{align-self:flex-end;background-color:#6c63ff;color:#fff;margin-left:auto}.message-bubble.received{align-self:flex-start;background-color:#f0f0f0;color:#000}.message-bubble.new-message{animation:newMessageGlow .5s ease-in-out;border:2px solid #28a745;box-shadow:0 0 10px #28a7454d}.message-bubble.received.new-message{background-color:#d4edda}.message-bubble.sent.new-message{border-color:#ffc107;box-shadow:0 0 10px #ffc1074d}.new-message-indicator{animation:pulse 1s infinite;background-color:#28a745;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;position:absolute;right:-8px;top:-8px}@keyframes newMessageGlow{0%{box-shadow:0 0 5px #28a74580;transform:scale(1)}50%{box-shadow:0 0 15px #28a745b3;transform:scale(1.02)}to{box-shadow:0 0 10px #28a7454d;transform:scale(1)}}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.message-time{font-size:.7rem;margin-top:.25rem;opacity:.7;text-align:right}.message-bubble.received .message-time{text-align:left}.message-input-row{align-items:center;background-color:#f8f9fa;border-top:1px solid #eee;display:flex;gap:.5rem;padding:1rem}.message-input{background-color:#fff;border:1px solid #ddd;border-radius:2rem;flex:1 1;font-size:1rem;outline:none;padding:.75rem}.message-input:focus{border-color:#6c63ff;box-shadow:0 0 0 2px #6c63ff40}.send-button{background-color:#6c63ff;border:none;border-radius:2rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s ease}.send-button:hover:not(:disabled){background-color:#5a52d5}.send-button:disabled{background-color:#6c757d;cursor:not-allowed}.select-contact-message{align-items:center;color:#666;display:flex;flex:1 1;justify-content:center}.profile-sidebar{background-color:#fff;border-radius:8px;display:flex;flex-direction:column;max-width:400px;overflow-y:auto;padding:1.5rem;width:33.333%}.profile-sidebar .profile-header{margin-bottom:20px;text-align:center}.profile-sidebar .profile-avatar{object-fit:cover}.profile-sidebar .profile-avatar,.profile-sidebar .profile-avatar-placeholder{border:3px solid #e0e0e0;border-radius:50%;height:120px;margin:0 auto 15px;width:120px}.profile-sidebar .profile-avatar-placeholder{align-items:center;background-color:#6c63ff;color:#fff;display:flex;font-size:3rem;justify-content:center}.profile-sidebar h3{color:#333;font-size:1.6em;margin:0 0 8px}.profile-sidebar .profile-details h4{border-bottom:1px solid #f0f0f0;color:#555;font-size:.85em;letter-spacing:.5px;margin:1rem 0 .25rem;padding-bottom:.25rem;text-transform:uppercase}.profile-sidebar .profile-details p{word-wrap:break-word;color:#444;font-size:.95em;line-height:1.5;margin:.25rem 0 .75rem}.profile-sidebar .no-profile-selected{align-items:center;color:#777;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.profile-sidebar .no-profile-selected p{font-size:1em}@media (max-width:768px){.messages-container{flex-direction:column;height:auto;min-height:calc(100vh - 120px)}.contacts-sidebar{margin-bottom:1rem;max-height:200px;width:100%}.messages-area{height:400px}.message-bubble{max-width:85%}.new-message-indicator{font-size:9px;padding:1px 4px}.message-input-row{padding:.5rem}}.main-nav{align-items:center;background-color:blue;display:flex;justify-content:space-between;padding:10px 20px}.nav-title-link{color:inherit;text-decoration:none}.nav-title{border-radius:20px;color:blue;font-size:2rem;font-weight:700;margin:0;padding:.5rem}.nav-title:hover{background-color:blue;color:#4b47b5}.nav-links{align-items:center;display:flex}.nav-links>a{color:#fff;font-size:24px;margin-left:20px;text-decoration:none}.auth-buttons>button{background-color:#add8e6;border:none;color:blue;cursor:pointer;font-size:16px;padding:10px 20px}.nav-bar{background-color:#6c63ff;justify-content:space-between;margin-bottom:1rem;padding:1rem}.nav-bar,.nav-list{align-items:center;display:flex}.nav-list{gap:1rem;list-style:none;margin:0;padding:0}.logout-button,.nav-link,.nav-notification-btn{border:1px solid #fff;border-radius:20px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:.5rem;text-decoration:none;transition:background .2s,color .2s}.logout-button:hover,.nav-link:hover,.nav-notification-btn:hover{background-color:#edeef1;border:2px solid #000;color:#4b47b5}.logout-button{background-color:#6c63ff}.nav-item-with-badge{position:relative}.nav-badge{align-items:center;border-radius:10px;color:#fff;display:flex;font-size:11px;font-weight:700;height:16px;justify-content:center;min-width:16px;padding:2px 6px;position:absolute;right:-8px;top:-8px}.nav-badge-messages{background-color:#28a745}.nav-badge-bell{background-color:#dc3545}.nav-notification-container{position:relative}.nav-notification-btn{align-items:center;background:none;display:flex;justify-content:center}.bell-icon{height:20px;width:20px}.nav-notification-dropdown{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:8px;overflow:hidden;position:absolute;right:0;top:100%;width:320px;z-index:1000}.nav-notification-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:16px}.nav-notification-header h3{color:#333;font-size:16px;font-weight:600;margin:0}.nav-notification-count{background-color:#e9ecef;border-radius:12px;color:#666;font-size:12px;padding:4px 8px}.nav-notification-list{max-height:400px;overflow-y:auto}.nav-notification-empty{color:#666;font-size:14px;padding:32px 16px;text-align:center}.nav-notification-item{align-items:flex-start;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background-color .2s}.nav-notification-item:hover{background-color:#f8f9fa}.nav-notification-item:last-child{border-bottom:none}.nav-notification-item.friend_request{border-left:3px solid #007bff}.nav-notification-icon{align-items:center;border-radius:50%;display:flex;height:32px;justify-content:center;margin-top:2px;width:32px}.nav-notification-item.friend_request .nav-notification-icon{background-color:#e3f2fd;color:#007bff}.nav-notification-content{flex:1 1}.nav-notification-message{color:#333;font-size:14px;line-height:1.4;margin-bottom:4px}.nav-notification-time{color:#666;font-size:12px}.nav-notification-footer{background-color:#f8f9fa;border-top:1px solid #e0e0e0;padding:12px 16px;text-align:center}.nav-notification-clear{background:none;border:none;border-radius:4px;color:#007bff;cursor:pointer;font-size:14px;padding:4px 8px;transition:background-color .2s}.nav-notification-clear:hover{background-color:#e3f2fd}@media (max-width:768px){.nav-notification-dropdown{right:-20px;width:280px}.nav-badge{font-size:10px;height:14px;min-width:14px;padding:1px 4px}.nav-list{gap:.5rem}.nav-link{font-size:.9rem}.nav-link,.nav-notification-btn{padding:.3rem}}.friend-system-container{margin:0 auto;max-width:1200px;padding:2rem}.friend-search-row{margin-bottom:2rem}.friend-search-input{border:1px solid #ddd;border-radius:5px;padding:10px;width:300px}.friend-columns{display:flex;gap:2rem}.friend-col{flex:1 1}.friend-card-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.friend-card{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem}.friend-card-friend{background-color:#f9f9f9}.friend-card-header{align-items:center;display:flex;margin-bottom:10px}.friend-avatar{border-radius:50%;height:50px;margin-right:10px;object-fit:cover;width:50px}.friend-card-title{margin:0}.friend-card-email{color:#666}.friend-card-bio{color:#666;font-size:14px;margin-bottom:10px}.friend-card-date{color:#888;font-size:12px}.friend-card-actions{margin-top:10px}.friend-remove-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:5px 10px}.friend-accept-btn,.friend-add-btn,.friend-cancel-btn,.friend-decline-btn,.friend-friend-btn,.friend-pending-btn{border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:8px 16px;transition:background-color .3s}.friend-add-btn{background-color:#007bff;font-size:14px}.friend-friend-btn{cursor:not-allowed;font-size:14px}.friend-accept-btn,.friend-friend-btn{background-color:#28a745}.friend-accept-btn:hover{background-color:#218838}.friend-decline-btn{background-color:#dc3545}.friend-decline-btn:hover{background-color:#c82333}.friend-cancel-btn{background-color:#6c757d}.friend-cancel-btn:hover{background-color:#5a6268}.friend-pending-btn{background-color:#ffc107;color:#212529}.friend-empty-msg{color:#666}.friend-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:2rem;padding-bottom:10px}.friend-tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;font-size:16px;padding:10px 20px;transition:all .3s}.friend-tab:hover{color:#007bff}.friend-tab.active{border-bottom-color:#007bff;color:#007bff;font-weight:700}.friend-tab-content{min-height:400px}.friend-card-request{border-left:4px solid #007bff}.friend-card-sent{border-left:4px solid #ffc107}
/*# sourceMappingURL=main.cd1ec483.css.map*/