*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;max-width:100vw;overflow-x:hidden;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);width:100%}body,html{-webkit-overflow-scrolling:touch;overscroll-behavior:none;touch-action:pan-y}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0d0f12;color:#eaeaea;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;padding:0;position:relative}#root{-webkit-overflow-scrolling:touch;height:100svh;min-height:100svh;overflow:hidden;overscroll-behavior:none;touch-action:pan-y;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1d21}::-webkit-scrollbar-thumb{background:#2c3036;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#3ba6ff}.login-container{align-items:center;background:#0d0f12;display:flex;height:100vh;justify-content:center;padding:20px}.login-box{animation:slideUp .5s ease;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1d21cc;border:1px solid #2c3036;border-radius:12px;box-shadow:0 8px 32px #0009;max-width:450px;padding:50px 40px;text-align:center;width:100%}.login-header h1{color:#eaeaea;font-size:32px;font-weight:700;letter-spacing:2px;margin-bottom:10px}.login-header p{color:#9a9fa5;font-size:16px;margin-bottom:30px}.login-content{margin:20px 0}.auth-title{color:#eaeaea;font-size:24px;font-weight:600;margin-bottom:25px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{text-align:left}.form-group label{font-weight:600}.form-input{background:#0d0f1299;border:1px solid #2c3036;border-radius:8px;color:#eaeaea;font-size:15px;outline:none;padding:12px 16px;transition:all .3s ease;width:100%}.form-input::placeholder{color:#9a9fa5}.form-input:focus{border-color:#3ba6ff;box-shadow:0 0 0 3px #3ba6ff1a}.form-input:disabled{background:#2c30364d;cursor:not-allowed;opacity:.6}.error-message{animation:shake .3s ease;background:#ff444426;border:1px solid #ff44444d;border-radius:8px;color:#f44;font-size:14px;padding:12px;text-align:left}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.submit-btn{align-items:center;background:#3ba6ff;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-top:10px;padding:14px 30px;transition:all .3s ease;width:100%}.submit-btn:hover:not(:disabled){background:#2b8ee5;box-shadow:0 6px 20px #3ba6ff66;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-spinner{animation:spin .8s linear infinite}.divider{margin:25px 0;position:relative;text-align:center}.divider:before{background:#2c3036;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#1a1d21cc;padding:0 15px;position:relative}.divider span,.toggle-btn{color:#9a9fa5;font-size:14px}.toggle-btn{background:#0000;border:1px solid #2c3036;border-radius:8px;cursor:pointer;font-weight:600;padding:12px;transition:all .3s ease;width:100%}.toggle-btn:hover:not(:disabled){background:#3ba6ff0d;border-color:#3ba6ff;color:#3ba6ff;transform:translateY(-1px)}.toggle-btn:disabled{cursor:not-allowed;opacity:.5}.login-footer{border-top:1px solid #2c3036;margin-top:30px;padding-top:20px}.privacy-note{color:#9a9fa5;font-size:14px}@media (max-width:480px){.login-box{padding:40px 25px}.login-header h1{font-size:26px}.auth-title{font-size:20px}}.sidebar{background:#1a1d21;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.sidebar-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0d0f12cc;border-bottom:1px solid #2c3036;color:#eaeaea;justify-content:space-between;padding:15px 20px}.sidebar-header,.user-profile{align-items:center;display:flex}.user-profile{gap:12px}.profile-image{border:2px solid #3ba6ff4d;border-radius:50%;height:40px;width:40px}.user-info h3{color:#eaeaea;font-size:16px;margin:0}.status{color:#9a9fa5;font-size:12px;opacity:.9}.status.online:before{color:#4ade80;content:"●";margin-right:5px}.header-actions{display:flex;gap:8px}.header-icon-btn{align-items:center;background:#2c303680;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;height:40px;justify-content:center;transition:background .3s,color .3s,transform .2s;width:40px}.header-icon-btn:hover{background:#3ba6ff1a;color:#3ba6ff}.header-icon-btn:nth-child(2):hover{transform:rotate(90deg)}.header-icon-btn .material-symbols-outlined{font-size:20px}.sidebar-actions{background:#0d0f1299;border-bottom:1px solid #2c3036;display:flex;flex-wrap:wrap;gap:8px;padding:15px}.action-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d2199;border:1px solid #2c3036;border-radius:8px;color:#9a9fa5;cursor:pointer;display:flex;flex:1 1;font-weight:600;gap:8px;justify-content:center;min-width:100px;padding:10px;transition:all .3s}.action-btn .material-symbols-outlined{font-size:20px}.action-btn:hover{background:#2c303680;border-color:#3ba6ff;color:#3ba6ff;transform:translateY(-2px)}.new-chat-panel,.new-group-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0d0f12cc;border-bottom:1px solid #2c3036;max-height:300px;overflow-y:auto;padding:15px}.new-chat-panel h4,.new-group-panel h4{color:#9a9fa5;font-size:14px;margin:0 0 10px}.group-name-input{background:#1a1d2199;font-size:14px;margin-bottom:10px;padding:10px;transition:border-color .2s,box-shadow .2s}.group-name-input:focus{box-shadow:0 0 0 2px #3ba6ff1a}.group-name-input::placeholder{color:#9a9fa5}.users-list{display:flex;flex-direction:column;gap:5px}.user-item{align-items:center;background:#1a1d2199;border:1px solid #2c3036;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:10px;transition:background .2s,border-color .2s,transform .2s}.user-item:hover{background:#2c303680;border-color:#3ba6ff;transform:translateY(-1px)}.user-item.selectable.selected{background:#3ba6ff26;border:1px solid #3ba6ff}.user-avatar{height:40px;width:40px}.user-details{display:flex;flex:1 1;flex-direction:column}.user-name{color:#eaeaea;font-weight:600}.user-status{font-size:12px}.user-status.online{color:#4ade80}.user-status.offline{color:#9a9fa5}.empty-friends{color:#9a9fa5;padding:20px;text-align:center}.empty-friends p{margin:5px 0}.empty-friends .hint{color:#9a9fa5;font-size:12px}.check-mark{color:#3ba6ff;font-size:24px}.create-group-btn{background:#3ba6ff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:10px;padding:10px;transition:background .3s,transform .2s,box-shadow .3s;width:100%}.create-group-btn:hover:not(:disabled){background:#2b8ee5;box-shadow:0 4px 16px #3ba6ff4d;transform:translateY(-2px)}.create-group-btn:disabled{background:#2c3036;cursor:not-allowed;opacity:.5}.rooms-list{flex:1 1;overflow-y:auto;padding:10px;position:relative}.rooms-list.refreshing{padding-top:40px}.rooms-list .refresh-indicator{color:#888;font-size:13px;left:50%;position:absolute;top:10px;transform:translateX(-50%);z-index:10}.rooms-list h4{color:#9a9fa5;font-size:14px;letter-spacing:.5px;margin:10px 10px 15px;text-transform:uppercase}.empty-state p{margin:5px 0}.hint{color:#9a9fa5;font-size:14px}.room-item{align-items:center;border:1px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:5px;padding:12px;transition:background .2s,transform .2s}.room-item:hover{background:#2c303680;border-color:#2c3036;transform:translateX(4px)}.room-item.active{background:#3ba6ff1a;border-color:#3ba6ff}.room-avatar{align-items:center;background:#2c3036;border:2px solid #3ba6ff33;border-radius:50%;display:flex;font-size:24px;height:50px;justify-content:center;overflow:visible;position:relative;width:50px}.dm-avatar-container{height:100%;position:relative;width:100%}.direct-message-avatar,.group-photo{border-radius:50%;height:100%;object-fit:cover;width:100%}.presence-dot{background:#4ade80;border:3px solid #1a1d21;border-radius:50%;bottom:-2px;box-shadow:0 0 8px #4ade8080;height:16px;position:absolute;right:-2px;width:16px;z-index:10}.group-icon{color:#3ba6ff;font-weight:700}.room-details{flex:1 1;min-width:0}.room-header{justify-content:space-between;margin-bottom:4px}.room-actions,.room-header{align-items:center;display:flex}.room-actions{gap:8px}.room-name{color:#eaeaea;font-size:15px;font-weight:600}.room-time{color:#9a9fa5;font-size:11px}.room-last-message{color:#9a9fa5;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-settings-btn{background:#3ba6ff33;border:1px solid #3ba6ff4d;color:#3ba6ff;height:24px;margin-right:4px;opacity:.7;transition:background .2s,transform .2s;width:24px}.group-settings-btn .material-symbols-outlined{font-size:16px}.group-settings-btn:hover{background:#3ba6ff4d;opacity:1;transform:scale(1.1)}.delete-group-btn{align-items:center;background:#f443;border:1px solid #ff44444d;border-radius:50%;color:#f44;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:.7;transition:background .2s,transform .2s;width:24px}.delete-group-btn .material-symbols-outlined{font-size:16px}.delete-group-btn:hover{background:#ff44444d;opacity:1;transform:scale(1.1)}.group-settings-overlay{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.group-settings-container{animation:slideUp .3s ease-out;background:#1a1d21;border:1px solid #2c3036;border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:500px;overflow:hidden;width:90%}.group-settings-header{align-items:center;background:#1a1d21cc;border-bottom:1px solid #2c3036;display:flex;justify-content:space-between;padding:20px 24px}.group-settings-header h2{color:#eaeaea;font-size:24px;font-weight:600;margin:0}.close-btn{padding:8px;transition:all .2s}.close-btn:hover:not(:disabled){background:#ffffff1a;color:#eaeaea}.close-btn:disabled{cursor:not-allowed;opacity:.5}.group-settings-form{max-height:calc(90vh - 80px);overflow-y:auto;padding:24px}.form-section{margin-bottom:28px}.form-section h3{color:#eaeaea;font-size:16px;font-weight:600;margin:0 0 16px}.photo-upload-section{align-items:center;display:flex;flex-direction:column;gap:16px}.photo-preview{align-items:center;background:#2c3036;border:3px solid #3ba6ff4d;border-radius:50%;display:flex;height:150px;justify-content:center;overflow:hidden;width:150px}.photo-preview .group-photo{height:100%;object-fit:cover;width:100%}.photo-preview .no-photo{align-items:center;color:#9a9fa5;display:flex;font-size:64px;justify-content:center}.photo-preview .no-photo .material-symbols-outlined{font-size:64px}.photo-actions{flex-wrap:wrap;justify-content:center}.remove-photo-btn,.upload-photo-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.upload-photo-btn{background:#3ba6ff;color:#fff}.upload-photo-btn:hover{background:#2b8fe5;transform:translateY(-1px)}.remove-photo-btn{background:#dc2626;color:#fff}.remove-photo-btn:hover:not(:disabled){background:#b91c1c;transform:translateY(-1px)}.remove-photo-btn:disabled{cursor:not-allowed;opacity:.5}.group-name-input{background:#0d0f12;border:1px solid #2c3036;border-radius:8px;box-sizing:border-box;color:#eaeaea;font-size:16px;padding:14px 16px;transition:all .2s;width:100%}.group-name-input:focus{border-color:#3ba6ff;box-shadow:0 0 0 3px #3ba6ff1a;outline:none}.group-name-input:disabled{cursor:not-allowed;opacity:.5}.group-settings-error,.group-settings-success{border-radius:8px;font-size:14px;font-weight:500;margin-top:16px;padding:12px 16px}.group-settings-error{background:#dc262626;border:1px solid #dc26264d;color:#fca5a5}.group-settings-success{background:#22c55e26;border:1px solid #22c55e4d;color:#86efac}.group-settings-actions{border-top:1px solid #2c3036;display:flex;gap:12px;margin-top:28px;padding-top:20px}.cancel-btn,.save-btn{align-items:center;border-radius:8px;display:flex;flex:1 1;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .2s}.cancel-btn{background:#2c3036;color:#eaeaea}.cancel-btn:hover:not(:disabled){background:#3c4047;transform:translateY(-1px)}.save-btn:hover:not(:disabled){background:#2b8fe5;transform:translateY(-1px)}.btn-spinner{height:16px;width:16px}@media (max-width:768px){.group-settings-container{max-height:85vh;width:95%}.group-settings-header{padding:16px 20px}.group-settings-header h2{font-size:20px}.group-settings-form{padding:20px}.photo-preview{height:120px;width:120px}.group-settings-actions{flex-direction:column}.cancel-btn,.save-btn{width:100%}}.tenor-gif-picker-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.tenor-gif-picker{animation:slideUp .3s ease;background:#1a1d21;border:1px solid #2c3036;border-radius:16px;box-shadow:0 12px 40px #0009;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.tenor-gif-picker-header{align-items:center;border-bottom:1px solid #2c3036;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.tenor-gif-picker-header h3{color:#eaeaea;font-size:18px;font-weight:600;margin:0}.tenor-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;height:36px;justify-content:center;padding:8px;transition:all .2s;width:36px}.tenor-close-btn:hover{background:#ffffff1a;color:#eaeaea}.tenor-search-container{align-items:center;border-bottom:1px solid #2c3036;display:flex;flex-shrink:0;gap:12px;padding:16px 20px;position:relative}.tenor-search-container .search-icon{color:#9a9fa5;flex-shrink:0;font-size:24px}.tenor-search-input{background:#0d0f1299;border:1px solid #2c3036;border-radius:12px;color:#eaeaea;flex:1 1;font-size:15px;outline:none;padding:12px 16px;transition:border-color .2s,box-shadow .2s}.tenor-search-input::placeholder{color:#9a9fa5}.tenor-search-input:focus{border-color:#3ba6ff;box-shadow:0 0 0 2px #3ba6ff1a}.clear-search-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;padding:6px;transition:all .2s;width:32px}.clear-search-btn:hover{background:#ffffff1a;color:#eaeaea}.tenor-gif-grid{-ms-overflow-style:none;align-content:start;display:flex;flex:1 1;flex-wrap:wrap;gap:12px;justify-content:center;overflow-y:auto;padding:16px;scrollbar-width:none}.tenor-gif-grid::-webkit-scrollbar{display:none}.tenor-gif-item{background:#0d0f12;border-radius:8px;cursor:pointer;flex:0 0 auto;max-width:250px;overflow:hidden;position:relative;transition:transform .2s,box-shadow .2s}.tenor-gif-item:hover{box-shadow:0 4px 16px #3ba6ff66;transform:scale(1.05);z-index:10}.tenor-gif-preview{border-radius:8px;display:block;height:180px;max-width:250px;width:auto}.tenor-loading{align-items:center;color:#9a9fa5;display:flex;flex-direction:column;gap:16px;grid-column:1/-1;justify-content:center;padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #3ba6ff33;border-radius:50%;border-top-color:#3ba6ff;height:40px;width:40px}.tenor-no-results{color:#9a9fa5;grid-column:1/-1;padding:40px;text-align:center}.tenor-gif-picker-footer{border-top:1px solid #2c3036;display:flex;flex-shrink:0;justify-content:center;padding:12px 20px}.tenor-attribution{color:#9a9fa5;font-size:12px;text-decoration:none;transition:color .2s}.tenor-attribution:hover{color:#3ba6ff}@media (max-width:768px){.tenor-gif-picker{border-radius:16px 16px 0 0;bottom:0;left:0;max-height:90vh;max-width:none;position:fixed;right:0;width:100%}.tenor-gif-picker-overlay{align-items:flex-end}.tenor-gif-grid{gap:8px;padding:12px}.tenor-gif-item{max-width:160px}.tenor-gif-preview{height:140px;max-width:160px}.tenor-gif-picker-header,.tenor-search-container{padding:12px 16px}}.message-effect-canvas{height:100vh;left:0;pointer-events:none;position:fixed;top:0;width:100vw;z-index:9999}.chat-window{background:#0d0f12;display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}.chat-window.empty{align-items:center;justify-content:center}.empty-chat{color:#9a9fa5;padding:40px;text-align:center}.empty-icon{font-size:80px;margin-bottom:20px}.empty-chat h2{color:#eaeaea;margin-bottom:10px}.chat-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d21cc;border-bottom:1px solid #2c3036;display:flex;gap:15px;padding:15px 20px;position:relative}.back-btn{align-items:center;background:none;border:none;border-radius:50%;color:#3ba6ff;cursor:pointer;display:none;flex-shrink:0;height:40px;justify-content:center;padding:8px;transition:background .2s,transform .2s;width:40px}.back-btn .material-symbols-outlined{font-size:24px;font-weight:600}.back-btn:hover{background:#3ba6ff1a;transform:scale(1.05)}.chat-info{flex:1 1;gap:12px}.chat-avatar,.chat-info{align-items:center;display:flex}.chat-avatar{background:#2c3036;border:2px solid #3ba6ff33;border-radius:50%;font-size:24px;height:45px;justify-content:center;margin-left:auto;order:2;overflow:visible;position:relative;width:45px}.chat-avatar .dm-avatar-container{height:100%;position:relative;width:100%}.chat-avatar .direct-message-avatar{border-radius:50%;height:100%;object-fit:cover;width:100%}.chat-avatar .presence-dot{background:#4ade80;border:2px solid #1a1d21;border-radius:50%;bottom:-2px;box-shadow:0 0 8px #4ade8080;height:14px;position:absolute;right:-2px;width:14px;z-index:10}.chat-avatar .group-icon{color:#3ba6ff;font-weight:700}.chat-avatar .group-photo{border-radius:50%;height:100%;object-fit:cover;width:100%}.group-settings-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;height:40px;justify-content:center;margin-left:8px;padding:8px;transition:all .2s;width:40px}.group-settings-btn:hover{background:#ffffff1a;color:#eaeaea}.group-settings-btn .material-symbols-outlined{font-size:24px}.chat-details{order:1}.chat-details h3{color:#eaeaea;font-size:16px;font-weight:600;margin:0}.chat-members{font-size:12px;font-weight:500}.chat-members.online{color:#4ade80}.chat-members.offline{color:#6b7280}.messages-container{-ms-overflow-style:none;display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:20px;scrollbar-width:none}.messages-container::-webkit-scrollbar{display:none}.no-messages{color:#9a9fa5;padding:40px;text-align:center}.message{animation:fadeIn .3s ease;display:flex;gap:10px;max-width:70%;min-width:0;width:-webkit-fit-content;width:fit-content}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.own{align-self:flex-end;flex-direction:row-reverse}.message.other{align-self:flex-start}.message-avatar{border-radius:50%;flex-shrink:0;height:32px;width:32px}.message-content{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.message-sender{color:#9a9fa5;font-size:12px;font-weight:600;margin-bottom:2px}.message-bubble{word-wrap:break-word;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d2199;border:1px solid #2c3036;border-radius:18px;box-shadow:0 4px 12px #0000004d;color:#eaeaea;-webkit-hyphens:auto;hyphens:auto;line-height:1.4;max-width:100%;min-width:0;overflow-wrap:break-word;padding:12px 16px;word-break:break-word}.message-bubble.clickable{cursor:pointer;transition:background .2s,border-color .2s}.message-bubble.clickable:hover{background:#2c303680;border-color:#3ba6ff}.link-bubble{background:linear-gradient(135deg,#3ba6ff26,#1a1d2199);border:1px solid #3ba6ff59}.link-bubble-link{align-items:center;color:inherit;display:flex;gap:10px;text-decoration:none}.link-icon{color:#3ba6ff}.link-text{display:flex;flex-direction:column;min-width:0}.link-host{color:#eaeaea;font-weight:700}.link-url{color:#9a9fa5;font-size:12px;max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.link-favicon{border-radius:4px;display:inline-block;height:18px;width:18px}.seen-indicator{font-size:10px;margin-left:6px;opacity:.7}.seen-by-container{align-items:center;display:flex;gap:2px;margin-left:6px}.seen-avatar{border:1px solid #ffffff4d;border-radius:50%;cursor:pointer;height:18px;object-fit:cover;transition:transform .2s,border-color .2s;width:18px}.seen-avatar:hover{border-color:#3ba6ffb3;transform:scale(1.15);z-index:10}.seen-avatar-more{align-items:center;background:#3ba6ff33;border:1px solid #3ba6ff66;border-radius:50%;color:#3ba6ff;cursor:pointer;display:flex;font-size:9px;font-weight:700;height:18px;justify-content:center;transition:background .2s,border-color .2s;width:18px}.seen-avatar-more:hover{background:#3ba6ff4d;border-color:#3ba6ff}.threejs-canvas{cursor:grab}.threejs-canvas:active{cursor:grabbing}.message.own .message-bubble{background:#3ba6ff26;border:1px solid #3ba6ff4d;color:#eaeaea}.message.own .message-bubble.clickable:hover{background:#3ba6ff40;border-color:#3ba6ff}.message-media{background:#1a1d21;border:1px solid #2c3036;border-radius:12px;box-shadow:0 4px 12px #0006;overflow:hidden}.message-image{cursor:pointer;display:block;max-height:400px;max-width:100%;transition:transform .2s}.message-image:hover{transform:scale(1.02)}.message-video{display:block;max-height:400px;max-width:100%}.message-file{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d2199;border:1px solid #2c3036;border-radius:12px;box-shadow:0 4px 12px #0006;display:flex;gap:12px;min-width:250px;padding:12px 16px}.file-icon{color:#3ba6ff;font-size:28px}.file-info{flex:1 1;min-width:0}.file-name{color:#eaeaea;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#9a9fa5;font-size:12px}.file-type{color:#9a9fa5;font-size:11px;margin-top:2px;opacity:.8}.file-uploading{align-items:center;color:#3ba6ff;display:flex;font-size:11px;gap:6px;margin-top:4px}.uploading-spinner{animation:spin 1s linear infinite;border:2px solid #3ba6ff33;border-radius:50%;border-top-color:#3ba6ff;display:inline-block;height:12px;width:12px}.message-3d{background:linear-gradient(135deg,#9c27b01a,#1a1d2199);border:1px solid #9c27b04d}.message-3d.expanded{border-bottom:none;border-radius:12px 12px 0 0}.file-action-btn{align-items:center;background:none;border:none;border-radius:6px;color:#9c27b0;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:background-color .2s,opacity .2s,transform .2s}.file-action-btn:hover:not(:disabled){background-color:#9c27b01a;transform:scale(1.05)}.file-action-btn:disabled{cursor:not-allowed;opacity:.5}.file-action-btn:disabled:hover{background-color:initial;transform:none}.file-download{align-items:center;border-radius:6px;color:#3ba6ff;display:flex;justify-content:center;padding:8px;text-decoration:none;transition:background-color .2s}.file-download:hover{background-color:#3ba6ff1a}.message-time{color:#9a9fa5;font-size:11px;margin-top:2px}.message-reactions{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.reaction-bubble{align-items:center;background:#1a1d2180;border:1px solid #2c3036;border-radius:12px;cursor:pointer;display:inline-flex;gap:4px;padding:4px 8px;transition:all .2s}.reaction-bubble:hover{background:#3ba6ff26;border-color:#3ba6ff;transform:scale(1.1)}.reaction-bubble.reacted{background:#3ba6ff33;border-color:#3ba6ff}.reaction-emoji{font-size:14px;line-height:1}.reaction-count{color:#eaeaea;font-size:11px;font-weight:600}.reaction-picker{animation:reactionPopIn .2s ease-out;background:#1a1d21f2;border:1px solid #3ba6ff;border-radius:30px;box-shadow:0 8px 24px #00000080,0 0 20px #3ba6ff4d;gap:4px;padding:8px}.emoji-picker,.reaction-picker{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex}.emoji-picker{background:#1a1d21fa;border:1px solid #2c3036;border-radius:16px;box-shadow:0 12px 28px #00000080;color:#eaeaea;flex-direction:column;max-height:60vh;width:480px}.emoji-picker.mobile{border-radius:16px 16px 0 0;bottom:0;left:0;max-height:75vh;padding-bottom:env(safe-area-inset-bottom,12px);position:fixed;right:0;width:100%;z-index:2100}.emoji-picker-header{align-items:center;border-bottom:1px solid #2c3036;display:flex;gap:8px;padding:10px}.emoji-search{background:#0d0f1299;border:1px solid #2c3036;border-radius:10px;color:#eaeaea;flex:1 1;padding:8px 12px}.emoji-close{background:#0000;border:1px solid #2c3036;border-radius:8px;color:#eaeaea;cursor:pointer;padding:6px 10px}.emoji-picker-content{overflow-y:auto;padding:10px}.emoji-category{margin-bottom:12px}.emoji-category-title{color:#9a9fa5;font-size:12px;margin:6px 0}.emoji-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(10,1fr)}.emoji-list{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(8,1fr)}.emoji-list-mobile{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(6,1fr);padding:4px 0}.mobile-emoji-container{display:flex;flex-direction:column;gap:8px}.desktop-emoji-container{display:flex;flex-direction:column;gap:6px}.emoji-item{background:#0000;border:none;border-radius:10px;cursor:pointer;font-size:22px;padding:8px}.emoji-item:hover{background:#3ba6ff26}.image-context-menu{animation:reactionPopIn .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d21f2;border:1px solid #3ba6ff;border-radius:12px;box-shadow:0 8px 24px #00000080,0 0 20px #3ba6ff4d;min-width:200px;padding:12px}.context-menu-section{margin-bottom:8px}.context-menu-label{color:#9a9fa5;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.reaction-options{display:flex;flex-wrap:wrap;gap:4px}.context-menu-divider{background:#2c3036;height:1px;margin:8px 0}.context-menu-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#eaeaea;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:8px 12px;transition:all .2s;width:100%}.context-menu-item:hover{background:#3ba6ff1a;color:#3ba6ff}.context-menu-item .material-symbols-outlined{font-size:18px}@keyframes reactionPopIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.reaction-option{align-items:center;background:#0000;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;line-height:1;padding:8px;transition:all .2s;width:40px}.reaction-option:hover{background:#3ba6ff33;transform:scale(1.3)}.typing-indicator{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d2199;border:1px solid #2c3036;border-radius:18px;box-shadow:0 2px 8px #0000004d;display:flex;gap:8px;max-width:-webkit-fit-content;max-width:fit-content;padding:10px}.typing-text{color:#9a9fa5;font-size:13px;font-style:italic}.message-input-container{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d21cc;border-top:1px solid #2c3036;box-sizing:border-box;display:flex;gap:10px;padding:15px 20px}.attach-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;padding:8px;transition:background .2s,transform .2s;width:40px}.attach-btn .material-symbols-outlined{font-size:24px}.attach-btn:hover:not(:disabled){background:#3ba6ff1a;color:#3ba6ff;transform:rotate(-45deg)}.attach-btn:disabled{cursor:not-allowed;opacity:.5}.gif-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;padding:8px;transition:background .2s,transform .2s,color .2s;width:40px}.gif-btn .material-symbols-outlined{font-size:24px}.gif-btn:hover:not(:disabled){background:#3ba6ff1a;color:#3ba6ff;transform:scale(1.1)}.gif-btn:disabled{cursor:not-allowed;opacity:.5}.effect-selector{position:relative}.effect-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;padding:8px;transition:background .2s,transform .2s,color .2s;width:40px}.effect-btn:hover:not(:disabled){background:#3ba6ff1a;transform:scale(1.1)}.effect-btn.active{background:#3ba6ff26;color:#3ba6ff}.effect-btn:disabled{cursor:not-allowed;opacity:.5}.effect-picker{animation:effectPickerPopIn .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1a1d21fa;border:1px solid #3ba6ff;border-radius:12px;bottom:50px;box-shadow:0 8px 24px #00000080,0 0 20px #3ba6ff4d;display:flex;gap:6px;left:0;padding:8px;position:absolute;z-index:1000}@keyframes effectPickerPopIn{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.effect-option{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:24px;height:44px;justify-content:center;line-height:1;padding:8px;transition:all .2s;width:44px}.effect-option:hover{background:#3ba6ff33;transform:scale(1.2)}.effect-option.selected{background:#3ba6ff4d;box-shadow:0 0 8px #3ba6ff80}.effect-option.clear{border-left:1px solid #2c3036;color:#e11d48;font-size:20px;margin-left:4px;padding-left:12px}.effect-option.clear:hover{background:#e11d4833}.message-input{background:#0d0f1299;border:1px solid #2c3036;border-radius:24px;color:#eaeaea;flex:1 1;font-size:15px;outline:none;padding:12px 16px;transition:border-color .2s,box-shadow .2s}.message-input::placeholder{color:#9a9fa5}.message-input:focus{border-color:#3ba6ff;box-shadow:0 0 0 2px #3ba6ff1a}.contenteditable-input{word-wrap:break-word;max-height:120px;min-height:20px;overflow-y:auto;user-select:text;-webkit-user-select:text;white-space:pre-wrap}.contenteditable-input:empty:before{color:#9a9fa5;content:attr(data-placeholder);cursor:text}.contenteditable-input:focus:empty:before{content:attr(data-placeholder)}.send-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;transition:transform .2s,box-shadow .2s,background .2s;width:42px}.send-btn .material-symbols-outlined{font-size:20px;font-weight:500}.send-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98180;transform:translateY(-1px)}.send-btn:disabled{background:#4b5563;box-shadow:none;cursor:not-allowed;opacity:.5}.btn{background:#1a1d2199;border:1px solid #2c3036;border-radius:10px;color:#eaeaea;cursor:pointer;font-size:13px;line-height:1;padding:8px 12px;transition:background .2s,border-color .2s,color .2s,transform .2s,box-shadow .2s}.btn:hover{background:#2c303699;border-color:#3ba6ff}.btn:active{transform:translateY(1px)}.btn-primary{background:linear-gradient(135deg,#3ba6ff,#1e88e5);border:1px solid #3ba6ff4d;box-shadow:0 2px 8px #3ba6ff4d;color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#1e88e5,#1565c0);border-color:#3ba6ff;box-shadow:0 4px 12px #3ba6ff80}.btn-text{background:#0000;border:none;color:#9a9fa5;padding:6px 8px}.btn-text:hover{color:#eaeaea}.edit-textarea{background:#0d0f1299;border:1px solid #2c3036;border-radius:10px;color:#eaeaea;outline:none}.edit-textarea:focus{border-color:#3ba6ff;box-shadow:0 0 0 2px #3ba6ff1a}@media (min-width:769px){.chat-header{display:none}}@media (max-width:768px){.back-btn{display:flex}.message{max-width:85%}.messages-container{padding:15px}.message-input-container{gap:8px;padding:10px 12px}.send-btn{height:40px;width:40px}.attach-btn,.effect-btn,.gif-btn{height:36px;width:36px}.effect-btn{font-size:18px}.effect-picker{bottom:45px}.message-image,.message-video{max-height:480px}}.message.first,.message.middle{margin-bottom:2px}.message.last,.message.middle{margin-top:2px}.message.last,.message.single{margin-bottom:12px}.message-avatar-spacer{border-radius:50%;flex-shrink:0;height:32px;width:32px}.settings-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0d0f12e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.settings-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#1a1d21f2;border:1px solid #2c3036;border-radius:12px;box-shadow:0 10px 40px #000c;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.settings-header{align-items:center;border-bottom:1px solid #2c3036;display:flex;justify-content:space-between;padding:24px}.settings-header h2{color:#eaeaea;font-size:24px;margin:0}.close-btn{height:36px;padding:4px;transition:background-color .2s,color .2s,transform .2s;width:36px}.settings-form{padding:24px}.photo-section{align-items:center;border-bottom:1px solid #2c3036;display:flex;flex-direction:column;margin-bottom:32px;padding-bottom:32px}.photo-preview{margin-bottom:20px}.preview-image{border:4px solid #3ba6ff4d;border-radius:50%;box-shadow:0 4px 16px #0006;height:150px;object-fit:cover;width:150px}.photo-actions{display:flex;gap:12px;margin-bottom:8px}.upload-btn{background:#3ba6ff;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s,transform .2s,box-shadow .2s}.upload-btn:hover{background:#2b8ee5;box-shadow:0 4px 12px #3ba6ff4d;transform:translateY(-1px)}.remove-photo-btn{background:#f443;border:1px solid #ff44444d;border-radius:6px;color:#f44;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s,transform .2s}.remove-photo-btn:hover{background:#ff44444d;transform:translateY(-1px)}.remove-photo-btn:disabled,.upload-btn:disabled{cursor:not-allowed;opacity:.5}.photo-hint{color:#9a9fa5;font-size:12px;margin:0}.form-section{margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{color:#9a9fa5;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.settings-input{background:#0d0f1299;border:1px solid #2c3036;border-radius:6px;box-sizing:border-box;color:#eaeaea;font-size:14px;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.settings-input::placeholder{color:#9a9fa5}.settings-input:focus{border-color:#3ba6ff;box-shadow:0 0 0 2px #3ba6ff1a;outline:none}.settings-input:disabled{background:#2c30364d;color:#9a9fa5;cursor:not-allowed;opacity:.6}.input-hint{color:#9a9fa5;font-size:12px;margin:6px 0 0}.settings-error{background:#ff444426;border:1px solid #ff44444d;border-radius:6px;color:#f44}.settings-error,.settings-success{font-size:14px;margin-bottom:20px;padding:12px}.settings-success{background:#4ade8026;border:1px solid #4ade804d;border-radius:6px;color:#4ade80}.settings-actions{border-top:1px solid #2c3036;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.cancel-btn,.save-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:background-color .2s,transform .2s,box-shadow .2s}.cancel-btn{background:#2c303699}.cancel-btn:hover{background:#2c3036cc}.save-btn{align-items:center;background:#3ba6ff;color:#fff;display:flex;gap:8px}.save-btn:hover{background:#2b8ee5;box-shadow:0 4px 12px #3ba6ff4d;transform:translateY(-1px)}.cancel-btn:disabled,.save-btn:disabled{cursor:not-allowed;opacity:.5}.logout-btn{background:#f443;border:1px solid #ff44444d;border-radius:6px;color:#f44;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:background-color .2s,transform .2s}.logout-btn:hover{background:#ff44444d;transform:translateY(-1px)}.logout-btn:disabled{cursor:not-allowed;opacity:.5}.btn-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:14px;width:14px}@media (max-width:768px){.settings-overlay{padding:0}.settings-container{border-radius:0;max-height:100vh;max-width:100%}.settings-form,.settings-header{padding:16px}.photo-section{margin-bottom:24px;padding-bottom:24px}.settings-actions{flex-direction:column-reverse}.cancel-btn,.save-btn{width:100%}}.friend-requests-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#0d0f12e6;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.friend-requests-modal{-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background-color:#1a1d21f2;border:1px solid #2c3036;border-radius:12px;box-shadow:0 10px 40px #000c;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overscroll-behavior:contain;width:90%}.modal-header{align-items:center;border-bottom:1px solid #2c3036;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#eaeaea;font-size:24px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#9a9fa5;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;transition:color .2s,background .2s,transform .2s;width:40px}.close-btn .material-symbols-outlined{font-size:28px}.close-btn:hover{background:#3ba6ff1a;color:#3ba6ff;transform:rotate(90deg)}.tabs{border-bottom:1px solid #2c3036;display:flex}.tab{background:none;border:none;color:#9a9fa5;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:15px;position:relative;transition:all .2s}.tab:hover{background-color:#3ba6ff0d;color:#eaeaea}.tab.active{color:#3ba6ff}.tab.active:after{background-color:#3ba6ff;bottom:0;box-shadow:0 0 8px #3ba6ff80;content:"";height:2px;left:0;position:absolute;right:0}.modal-content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:20px;scroll-behavior:smooth}.search-bar{display:flex;gap:10px;margin-bottom:20px}.search-bar input{background-color:#0d0f1299;border:1px solid #2c3036;border-radius:8px;color:#eaeaea;flex:1 1;font-size:14px;padding:12px;transition:border-color .2s,box-shadow .2s}.search-bar input::placeholder{color:#9a9fa5}.search-bar input:focus{border-color:#3ba6ff;box-shadow:0 0 0 2px #3ba6ff1a;outline:none}.search-bar button{align-items:center;background-color:#3ba6ff;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:12px 24px;transition:background-color .2s,transform .2s,box-shadow .2s}.search-bar button .material-symbols-outlined{font-size:18px}.search-bar button:hover:not(:disabled){background-color:#2b8ee5;box-shadow:0 4px 12px #3ba6ff4d;transform:translateY(-1px)}.search-bar button:disabled{cursor:not-allowed;opacity:.5}.requests-tab,.results-list{display:flex;flex-direction:column;gap:10px;transform:translateZ(0);will-change:scroll-position}.request-item,.user-result{align-items:center;background-color:#1a1d2199;border:1px solid #2c3036;border-radius:8px;display:flex;gap:12px;padding:12px;transition:background-color .2s,border-color .2s,transform .2s}.user-result:hover{background-color:#2c303680;border-color:#3ba6ff;transform:translateY(-1px)}.user-avatar{border:2px solid #3ba6ff33;border-radius:50%;height:48px;object-fit:cover;width:48px}.request-info,.user-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.username{color:#eaeaea;font-size:15px;font-weight:500}.email{color:#9a9fa5;font-size:13px}.status-text{color:#9a9fa5;font-size:14px}.accept-btn,.add-btn,.cancel-btn,.reject-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:4px;padding:8px 16px;transition:all .2s}.accept-btn .material-symbols-outlined,.add-btn .material-symbols-outlined,.cancel-btn .material-symbols-outlined,.reject-btn .material-symbols-outlined{font-size:18px}.add-btn{background-color:#3ba6ff;color:#fff}.add-btn:hover{background-color:#2b8ee5;box-shadow:0 4px 12px #3ba6ff4d;transform:translateY(-1px)}.request-actions{display:flex;gap:8px}.accept-btn{background-color:#4ade8033;border:1px solid #4ade804d;color:#4ade80}.accept-btn:hover{background-color:#4ade804d;transform:translateY(-1px)}.reject-btn{background-color:#f443;border:1px solid #ff44444d;color:#f44}.reject-btn:hover{background-color:#ff44444d;transform:translateY(-1px)}.cancel-btn{background-color:#2c303699;border:1px solid #2c3036;color:#9a9fa5}.cancel-btn:hover{background-color:#2c3036cc;color:#eaeaea;transform:translateY(-1px)}.empty-state{color:#9a9fa5;font-size:14px;padding:40px 20px;text-align:center}@media (max-width:768px){.friend-requests-modal{margin:10px;max-height:90vh;width:95%}.modal-header{padding:16px 20px}.modal-header h2{font-size:20px}.close-btn{font-size:24px;height:44px;width:44px}.tabs{padding:0 20px}.tab{font-size:13px;min-height:48px;padding:14px 12px}.modal-content{padding:16px 20px}.search-bar{flex-direction:column;gap:12px}.search-bar input{padding:16px}.search-bar button,.search-bar input{font-size:16px;min-height:48px;width:100%}.search-bar button{justify-content:center;padding:16px 24px}.request-item,.user-result{align-items:stretch;flex-direction:column;gap:16px;padding:16px}.user-avatar{align-self:center;height:56px;width:56px}.request-info,.user-info{align-items:center;text-align:center}.username{font-size:16px;font-weight:600}.email{font-size:14px}.request-actions{gap:12px;justify-content:center;margin-top:8px;width:100%}.accept-btn,.add-btn,.cancel-btn,.reject-btn{flex:1 1;font-size:15px;min-height:44px;padding:12px 16px}.empty-state{font-size:15px;padding:60px 20px}}@media (max-width:480px){.friend-requests-modal{border-radius:0;height:100%;margin:0;max-height:100vh;width:100%}.modal-header{padding:12px 16px}.modal-header h2{font-size:18px}.tabs{padding:0 16px}.tab{font-size:12px;padding:12px 8px}.modal-content{padding:12px 16px}.search-bar{gap:8px}.search-bar input{padding:14px}.request-item,.user-result{padding:12px}.user-avatar{height:48px;width:48px}}.chat-container{-webkit-overflow-scrolling:touch;background:#0d0f12;display:flex;height:100vh;overflow:hidden;overscroll-behavior:none;position:relative}.sidebar-wrapper{background:#1a1d21;border-right:1px solid #2c3036;display:flex;flex-direction:column;flex-shrink:0;width:350px}.chat-wrapper{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}@media (max-width:768px){.chat-container{overflow:hidden;position:relative}.chat-wrapper,.sidebar-wrapper{-webkit-overflow-scrolling:touch;height:100vh;left:0;overflow:hidden;overscroll-behavior:none;position:absolute;top:0;transition:transform .3s ease;width:100vw}.sidebar-wrapper.mobile-hidden{transform:translateX(-100%)}.sidebar-wrapper.mobile-visible{transform:translateX(0)}.chat-wrapper.mobile-hidden{transform:translateX(100%)}.chat-wrapper.mobile-visible{transform:translateX(0)}}.App{-webkit-overflow-scrolling:touch;overflow:hidden;overscroll-behavior:none;position:relative}.App,.loading-screen{background:#1a1a1a;display:flex;flex-direction:column;height:100vh}.loading-screen{align-items:center;color:#fff;justify-content:center;overflow:hidden}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.loading-screen p{font-size:18px;margin-top:20px}@media (max-width:768px){.App{overflow:hidden}.App,.loading-screen{height:100vh;height:-webkit-fill-available}}
/*# sourceMappingURL=main.f9f2ee2c.css.map*/