*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f0f2f5;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;transition:background-color .3s,color .3s}body.dark-mode{background-color:#1a1a1a;color:#e0e0e0}.app-container{display:flex;height:100vh;overflow:hidden}.sidebar{background-color:#fff;border-right:1px solid #ddd;display:flex;flex-direction:column;min-height:100vh;position:relative;transition:transform .3s ease;width:400px;z-index:1000}body.dark-mode .sidebar{background-color:#2a2a2a;border-right-color:#444}.sidebar.closed{transform:translateX(-100%)}.sidebar-toggle-btn{align-items:center;background-color:#007bff;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:40px;justify-content:center;left:10px;position:fixed;top:10px;transition:background-color .3s;width:40px;z-index:1100}.sidebar-toggle-btn:hover,body.dark-mode .sidebar-toggle-btn{background-color:#0056b3}.user-profile{align-items:center;border-bottom:1px solid #ddd;display:flex;padding:15px;position:relative}body.dark-mode .user-profile{border-bottom-color:#444}.user-profile-info{flex-grow:1;margin-left:10px}.user-profile-name{font-size:1.1rem;font-weight:600}.logout-btn{background:none;border:none;color:#ff4d4f;cursor:pointer;margin-right:10px}.logout-btn:hover{color:#d9363e}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem}.sidebar-content{flex-grow:1;max-height:100%;overflow-y:auto;padding:5px}.sidebar-section-title{color:#555;font-size:1rem;font-weight:600;margin-bottom:10px}body.dark-mode .sidebar-section-title{color:#bbb}.sidebar-list{list-style:none}.sidebar-list-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;margin-bottom:2px;min-height:30px;padding:.5px;transition:background-color .2s}.sidebar-list-item:hover{background-color:#f0f0f0}body.dark-mode .sidebar-list-item:hover{background-color:#3a3a3a}.sidebar-list-item.active{background-color:#e6f0ff}body.dark-mode .sidebar-list-item.active{background-color:#444}.sidebar-list-item-avatar{align-items:center;display:flex;height:20px;justify-content:center;margin-left:15px;margin-right:6px;width:20px}.sidebar-list-item-name{align-items:center;display:flex;flex-grow:1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-indicator{border-radius:50%;display:inline-block;height:8px;margin-left:4px;width:8px}.status-indicator.online{background-color:#007bff}.status-indicator.offline{background-color:#2a2b2d}body.dark-mode .status-indicator.online{background-color:#2f5986}body.dark-mode .status-indicator.offline{background-color:#495057}.sidebar-list-item-actions{align-items:center;display:flex}.call-button{background:none;border:none;color:#007bff;font-size:1rem;margin-right:30px;padding:2px}.call-button:hover{color:#073a63}.call-button:disabled{color:#ccc}.call-button{align-items:center;background:#fff;border:1px solid #007bff;border-radius:50%;cursor:pointer;display:flex;justify-content:center;padding:6px}.call-button svg{display:block}.call-button:disabled{cursor:not-allowed;opacity:.5}body.dark-mode .call-button:disabled{color:#555}.sidebar-buttons-container{border-top:1px solid #ddd;padding:10px}body.dark-mode .sidebar-buttons-container{border-top-color:#444}.add-friend-btn,.notification-btn{align-items:center;background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;margin-bottom:10px;padding:10px;transition:background-color .3s;width:100%}.add-friend-btn:hover,.notification-btn:hover{background-color:#0056b3}.add-friend-icon{margin-right:8px}.chat-container{background-color:#fff;display:flex;flex-direction:column;flex-grow:1;height:100vh;left:410px;margin:0 10px;position:absolute;top:0;width:calc(100vw - 420px);z-index:1000}body.dark-mode .chat-container{background-color:#2a2a2a}@media (max-width:1023px){.chat-container{height:100%;left:0;position:fixed;top:0;transform:translateX(100%);transition:transform .3s ease;width:100%}.chat-container.open{transform:translateX(0)}.call-controls{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:center;padding:0 15x}}.chat-header{align-items:center;border-bottom:1px solid #ddd;display:flex;padding:15px}body.dark-mode .chat-header{border-bottom-color:#444}.back-button{background:none;border:none;color:#007bff;cursor:pointer;margin-right:10px}.back-button:hover{color:#0056b3}.chat-info h2{font-size:1.2rem;font-weight:600}.chat-info p{color:#777;font-size:.9rem}body.dark-mode .chat-info p{color:#aaa}.messages-area{display:flex;flex-direction:column;flex-grow:1;gap:10px;overflow-y:auto;padding:20px}.message-item{border-radius:10px;max-width:70%;padding:10px 15px;position:relative}.my-message{align-self:flex-end;background-color:#007bff;border-bottom-right-radius:2px;color:#fff}.other-message{align-self:flex-start;background-color:#e9ecef;border-bottom-left-radius:2px}body.dark-mode .other-message{background-color:#3a3a3a}.message-username{font-size:.8rem;font-weight:600;margin-bottom:5px}.message-content{font-size:1rem}.message-time{color:#999;font-size:.7rem;margin-top:5px;text-align:right}body.dark-mode .message-time{color:#777}.no-messages{color:#777;margin-top:20px;text-align:center}body.dark-mode .no-messages{color:#aaa}body.dark-mode .message-input-container{border-top-color:#444}.message-input{border:1px solid #ddd;flex-grow:1;font-size:1rem;padding:10px}body.dark-mode .message-input{background-color:#3a3a3a;border-color:#555;color:#e0e0e0}.send-button{background:none;border:none;color:#007bff;cursor:pointer;margin-left:10px}.send-button:hover:not(:disabled){color:#0056b3}.no-chat-selected{align-items:center;color:#777;display:flex;flex-direction:column;flex-grow:1;justify-content:center;padding:20px;text-align:center}body.dark-mode .no-chat-selected{color:#aaa}.active-call-screen,.calling-overlay,.incoming-call-overlay{align-items:center;background-color:#000c;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.active-call-card,.calling-content,.incoming-call-content{background-color:#fff;border-radius:10px;height:75%;max-width:400px;padding:20px;text-align:center;width:90%}.active-call-card:fullscreen video{height:100%;object-fit:contain;width:100%}body.dark-mode .active-call-card,body.dark-mode .calling-content,body.dark-mode .incoming-call-content{background-color:#2a2a2a}.video-container{background-color:#000;border-radius:8px;display:flex;flex-direction:column;gap:10px;height:80%;margin:20px 0;overflow:hidden;position:relative;width:100%}.remote-video{height:100%;left:0;top:0;width:100%}.local-video,.remote-video{object-fit:cover;position:absolute}.local-video{background-color:#000;border:2px solid #fff;border-radius:8px;bottom:20px;display:block;height:90px;right:20px;transform:translateZ(0);width:120px;will-change:transform;z-index:1000}.call-controls{background-color:#00000080;border-radius:12px;bottom:20px;display:flex;gap:10px;height:61px;justify-content:center;left:50%;padding:10px 20px;position:absolute;transform:translateX(-50%);width:auto;z-index:10}.activate-audio-btn,.activate-video-btn,.end-call-button-large{border:none;border-radius:8px;cursor:pointer;font-size:1rem;padding:10px 20px}.activate-audio-btn,.activate-video-btn{background-color:#007bff;color:#fff}.activate-audio-btn:hover,.activate-video-btn:hover{background-color:#0056b3}.end-call-button-large{background-color:#007bff;color:#fff}.end-call-button-large:hover{background-color:#1e22e9}.incoming-call-actions{display:flex;gap:20px;justify-content:center;margin-top:20px}.call-accept-btn,.call-reject-btn{border:none;border-radius:50%;cursor:pointer;font-size:1.5rem;height:60px;width:60px}.call-accept-btn{background-color:#007bff}.call-accept-btn:hover{background-color:#218838}.call-reject-btn{background-color:#0f4f61}.call-reject-btn:hover{background-color:#d9363e}.modal-overlay{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:2000}.modal-content{background-color:#fff;border-radius:10px;box-shadow:0 4px 8px #0003;max-width:400px;padding:20px;position:relative;width:90%}body.dark-mode .modal-content{background-color:#2a2a2a;box-shadow:0 4px 8px #0006}.modal-content h3{align-items:center;display:flex;font-size:1.5rem;font-weight:600;justify-content:center}.modal-content .text-blue-600{color:#007bff}body.dark-mode .modal-content .text-blue-400{color:#60a5fa}.modal-content button[title=Cerrar]{background:none;border:none;cursor:pointer;transition:color .2s}.modal-content button[title=Cerrar]:hover{color:#000}body.dark-mode .modal-content button[title=Cerrar]:hover{color:#fff}.username-setup-input{border:1px solid #ddd;border-radius:8px;font-size:1rem;margin-bottom:15px;outline:none;padding:10px;transition:border-color .2s;width:100%}body.dark-mode .username-setup-input{background-color:#3a3a3a;border-color:#555;color:#e0e0e0}.username-setup-input:focus{border-color:#007bff}body.dark-mode .username-setup-input:focus{border-color:#60a5fa}.username-setup-input:disabled{background-color:#f0f0f0;cursor:not-allowed}body.dark-mode .username-setup-input:disabled{background-color:#444}.username-setup-button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:10px;transition:background-color .2s;width:100%}.username-setup-button[type=submit]{background-color:#007bff;color:#fff}.username-setup-button[type=submit]:hover:not(:disabled){background-color:#0056b3}.username-setup-button[type=submit]:disabled{background-color:#ccc;cursor:not-allowed}body.dark-mode .username-setup-button[type=submit]:disabled{background-color:#555}.username-setup-button[type=button]{background-color:#6c757d;color:#fff}.username-setup-button[type=button]:hover{background-color:#5a6268}.username-setup-button .animate-spin{display:inline-block}.space-y-3>*+*{margin-top:.75rem}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f0f2f5}body.dark-mode ::-webkit-scrollbar-track{background:#2a2a2a}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}.missed-call-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.missed-call-content{background:#fff;border-radius:10px;padding:20px;text-align:center}.close-missed-call-btn{background-color:#f44;border:none;border-radius:5px;color:#fff;cursor:pointer;margin-top:10px;padding:5px 10px}.close-missed-call-btn:hover{background-color:#c00}.sound-prompt-actions button{font-size:16px;margin:0 10px;padding:5px 15px}.sound-allow-btn{background-color:#4caf50;color:#fff}.sound-deny-btn{background-color:#f44336;color:#fff}.message-file{margin:5px 0}.message-image{max-width:200px}.message-image,.message-video{border-radius:5px;max-height:200px}.message-video{max-width:300px}.message-audio{width:200px}.file-upload-btn{color:#555;cursor:pointer;margin:0 5px}.file-upload-btn:hover{color:#000}.sound-prompt-overlay{align-items:center;background:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.sound-prompt-content{background:#fff;border-radius:8px;padding:20px;text-align:center}.message-video,.preview-video{max-height:200px;max-width:200px}.record-button{background:none;border:none;color:#555;cursor:pointer;padding:5px}.record-button.recording{animation:pulse 1s infinite;color:#f44}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.preview-audio{margin-top:10px;max-width:200px}.message-input-container{align-items:center;background:#fff;border-top:1px solid #ddd;display:flex;gap:10px;padding:10px}.file-upload-btn,.record-button,.send-button{background:none;border:none;color:#555;cursor:pointer;padding:5px}.file-upload-btn:hover,.record-button:hover,.send-button:hover{color:#000}.send-button:disabled{color:#ccc;cursor:not-allowed}.preview-container{border:1px solid #ddd;border-radius:5px;bottom:70px;box-shadow:0 2px 5px #0000001a;max-width:300px;padding:10px;position:fixed;right:20px}.preview-content{display:flex;flex-direction:column;gap:10px}.preview-audio,.preview-image,.preview-video{max-height:200px;max-width:200px}.preview-doc{font-size:.9rem;margin:0}.preview-message-input{border:1px solid #ccc;border-radius:3px;font-size:.9rem;padding:5px;width:100%}.preview-actions{gap:5px;margin-top:10px}.btn-cancel,.btn-send{border-radius:3px;padding:5px 10px}.btn-cancel{background:#f44}.btn-send{background:#4caf50}.dark-mode .preview-container{background:#333;border-color:#555}.dark-mode .preview-message-input{background:#444;border-color:#666;color:#fff}@media (max-width:1024px){.message-input-container{padding:5px}}.temp-preview{background-color:#ffebee;border:2px dashed #f44}.temp-preview .preview-content p{color:#d32f2f;font-weight:700}.message-input-bar{align-items:center;background:#fff;border-top:1px solid #ccc;display:flex;gap:8px;padding:8px}.action-icons{align-items:center;display:flex;gap:12px}.message-input{border:1px solid #ccc;border-radius:20px;flex:1 1;outline:none;padding:8px 12px}.preview-modal-overlay{align-items:center;background:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:999}.preview-modal-content{background:#fff;border-radius:8px;max-height:80%;max-width:90%;overflow:auto;padding:16px}.preview-audio,.preview-image,.preview-video{display:block;margin:0 auto 16px;max-height:60vh;max-width:100%}.preview-actions{gap:8px;justify-content:space-between}.preview-container{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;gap:.75rem;margin:1rem auto;max-width:90%;padding:1rem;position:relative;z-index:1000}.preview-container.temp-preview{background:#f0f7ff;border:2px solid #4f82f8}.preview-image{border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:300px;max-width:100%;object-fit:contain}.preview-actions{display:flex;gap:1rem;justify-content:center;width:100%}.btn-cancel,.btn-send{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:background-color .2s}.btn-cancel{background-color:#ef4444;color:#fff}.btn-send{background-color:#4f82f8;color:#fff}.btn-cancel:hover{background-color:#dc2626}.btn-send:hover{background-color:#3c6ed1}.message-item.selected{outline:2px solid #1976d2;transform:scale(1.02);transition:transform .2s ease}.message-actions-bar{background:#f0f0f0;border-top:1px solid #ddd;display:flex;font-size:14px;gap:10px;padding:10px}.message-actions-bar button{border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 12px}.message-actions-bar .delete-btn{background:#e53935;color:#fff}.message-actions-bar button:not(.delete-btn){background:#1976d2;color:#fff}.mic-button{background:none;border:none;color:#555;cursor:pointer;transition:color .3s ease}.mic-button.recording svg{animation:pulse-blue 1.5s infinite;color:#007bff}@keyframes pulse-blue{0%{opacity:.7;transform:scale(.95)}50%{opacity:1;transform:scale(1.1)}to{opacity:.7;transform:scale(.95)}}@media screen and (min-width:1024px){.app-container{display:flex;height:100vh;margin:0 auto;max-width:1600px}.sidebar{width:350px}.chat-container{flex:1 1;min-width:0}}.fullscreen-btn{position:fixed;right:10px;top:10px;z-index:2000}:fullscreen{background:#000}.active-call-card:fullscreen{align-items:center;background-color:#000;border-radius:0;display:flex;flex-direction:column;height:90vh;justify-content:center;overflow:hidden;padding:0;width:100vw}.active-call-card:fullscreen .video-container{align-items:center;display:flex;height:80vh;justify-content:flex-end;position:relative;width:100vw}.active-call-card:fullscreen .remote-video{height:100%;max-height:100vh;object-fit:cover;width:100%}.active-call-card:fullscreen .local-video{border:2px solid #fff;bottom:20px;height:auto;position:absolute;right:20px;width:250px;z-index:2}.active-call-card:fullscreen h2,.active-call-card:fullscreen p{display:none}.active-call-card:fullscreen .call-controls{background:#0009;border-radius:12px;bottom:20px;display:flex;gap:16px;justify-content:center;left:50%;padding:12px 24px;position:absolute;transform:translateX(-50%);z-index:10001}.active-call-card:fullscreen .fullscreen-btn{position:absolute;right:20px;top:20px;z-index:10003}.active-call-card:fullscreen .call-controls{background:#0009!important;border-radius:12px!important;bottom:20px!important;display:flex!important;gap:5px!important;justify-content:center!important;left:50%!important;padding:12px 24px!important;position:relative!important;transform:translateX(-50%)!important;z-index:10001!important}.control-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:28px;transition:transform .2s}.control-btn:hover{transform:scale(1.2)}.end-call{font-size:32px}.reconnect-overlay{background:#ffeb3b;border-radius:4px;font-weight:700;left:50%;padding:8px 16px;position:fixed;top:10px;transform:translateX(-50%);z-index:1000}
/*# sourceMappingURL=main.a5c24f37.css.map*/