body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.call-overlay{align-items:center;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10000}.call-overlay--incoming{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ab8;pointer-events:auto}.call-incoming-ring-audio{clip:rect(0,0,0,0);height:0;opacity:0;overflow:hidden;pointer-events:none;position:absolute;width:0}.call-overlay--active{background:linear-gradient(165deg,#0f172a,#1e293b 45%,#0f172a);flex-direction:column;pointer-events:auto}.call-overlay--active.call-overlay--video-call{align-items:stretch;background:#020617;justify-content:stretch;padding:0}.call-overlay--video-call .call-active-layout{box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;height:100%;max-height:100dvh;max-width:none;min-height:0;overflow:hidden;padding:.5rem .75rem max(.45rem,env(safe-area-inset-bottom,0px));width:100%}.call-overlay--video-call .call-video-stage--video-call{border-radius:12px;flex:1 1;margin-bottom:.5rem;min-height:0}.call-overlay--video-call .call-active-layout--chrome-hidden{min-height:100vh;min-height:100dvh;padding:0}.call-overlay--video-call .call-active-layout--chrome-hidden .call-video-stage--video-call{border-radius:0;flex:1 1;margin-bottom:0;min-height:0}.call-overlay--video-call .call-active-layout--chrome-hidden .call-active-chrome,.call-overlay--video-call .call-active-layout--chrome-hidden .call-toolbar{display:none}.call-tap-to-show-layer{background:#0000;border:none;cursor:default;inset:0;margin:0;position:absolute;z-index:50}.call-tap-to-show-layer,.call-video-hangup-fab{-webkit-tap-highlight-color:transparent;padding:0}.call-video-hangup-fab{align-items:center;background:#dc2626eb;border:2px solid #ffffff59;border-radius:50%;bottom:max(1rem,calc(env(safe-area-inset-bottom, 0px) + .75rem));box-shadow:0 6px 24px #00000073,inset 0 0 0 1px #0003;color:#fff;cursor:pointer;display:flex;height:58px;justify-content:center;left:50%;position:fixed;transform:translateX(-50%);width:58px;z-index:60}.call-video-hangup-fab:active{transform:translateX(-50%) scale(.96)}.call-video-hangup-fab__icon{font-size:1.45rem;line-height:1}.call-overlay--video-call .call-tool:not(.call-tool--end){background:#0f172a6b;border-color:#ffffff1f;box-shadow:0 2px 12px #00000059}.call-overlay--video-call .call-tool:not(.call-tool--end):not(:disabled):hover{background:#1e293b8c}.call-overlay--video-call .call-tool-label{color:#e2e8f0eb}.call-incoming-card{background:#fff;border:1px solid #94a3b840;border-radius:22px;box-shadow:0 24px 48px #00000047,inset 0 0 0 1px #ffffff14;max-width:360px;padding:2rem 1.5rem;text-align:center;width:100%}body.dark-mode .call-incoming-card{background:linear-gradient(165deg,#1e293b,#0f172a);border-color:#94a3b833;box-shadow:0 24px 56px #00000080,inset 0 0 0 1px #ffffff0f;color:#f1f5f9}.call-incoming-avatar{align-items:center;animation:call-avatar-pulse 2.2s ease-in-out infinite;background:linear-gradient(145deg,#3b82f6,#6366f1 45%,#8b5cf6);border-radius:50%;box-shadow:0 8px 24px #6366f173,inset 0 0 0 1px #ffffff26;display:flex;font-size:2.5rem;height:88px;justify-content:center;margin:0 auto 1rem;width:88px}@keyframes call-avatar-pulse{0%,to{box-shadow:0 8px 24px #6366f173,0 0 0 0 #6366f173,inset 0 0 0 1px #ffffff26}50%{box-shadow:0 8px 28px #6366f18c,0 0 0 14px #6366f100,inset 0 0 0 1px #ffffff26}}.call-incoming-card h2{color:#64748b;font-size:1.1rem;font-weight:600;margin:0 0 .5rem}body.dark-mode .call-incoming-card h2{color:#94a3b8}.call-incoming-name{color:#0f172a;font-size:1.35rem;font-weight:700;margin:0 0 1.75rem}body.dark-mode .call-incoming-name{color:#f8fafc}.call-incoming-actions{display:flex;gap:1rem;justify-content:center}.call-btn{border:none;border-radius:12px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;max-width:140px;padding:.85rem 1rem;transition:transform .15s ease,filter .15s ease}.call-btn:active{transform:scale(.97)}.call-btn--decline{background:#fee2e2;color:#b91c1c}body.dark-mode .call-btn--decline{background:#450a0a;color:#fca5a5}.call-btn--accept{background:#22c55e;color:#fff}.call-btn--accept:hover{filter:brightness(1.05)}.call-btn--sound{background:#3b82f6f2;color:#fff;margin:0 auto .85rem;max-width:320px;width:100%}.call-btn--sound:hover{filter:brightness(1.05)}.call-active-layout{display:flex;flex:1 1;flex-direction:column;max-width:720px;min-height:0;padding:.75rem 1rem 1.25rem;width:100%}.call-active-peer{color:#f8fafc;font-size:1.25rem;font-weight:700;margin:0;text-align:center}.call-active-status{color:#94a3b8;font-size:.9rem;margin:.25rem 0 .75rem;text-align:center}.call-video-stage{background:#020617;border-radius:16px;flex:1 1;margin-bottom:1rem;min-height:200px;overflow:hidden;position:relative}.call-video-remote{background:#0f172a;display:block;height:100%;min-height:220px;object-fit:cover;width:100%}.call-video-remote--hidden{display:none}.call-video-local{aspect-ratio:3/4;background:#1e293b;border:2px solid #ffffff59;border-radius:12px;bottom:12px;box-shadow:0 8px 24px #00000073;max-width:160px;object-fit:cover;position:absolute;right:12px;width:28%}.call-video-local--hidden{display:none}.call-toolbar{grid-gap:.75rem;align-items:stretch;box-sizing:border-box;display:grid;flex-shrink:0;gap:.75rem;grid-template-columns:1fr 1fr;justify-content:stretch;margin:0 auto;max-width:360px;padding:.5rem 0;width:100%}.call-overlay--video-call .call-toolbar{max-width:min(420px,100%);padding-bottom:max(.2rem,env(safe-area-inset-bottom,0px))}.call-tool{align-items:center;background:#ffffff1a;border:1px solid #ffffff14;border-radius:14px;box-shadow:0 2px 8px #0003;color:#e2e8f0;cursor:pointer;display:flex;flex-direction:column;gap:.35rem;min-width:72px;padding:.65rem .5rem;transition:background .15s ease,transform .15s ease,box-shadow .15s ease}.call-tool:disabled{cursor:not-allowed;opacity:.35}.call-tool:not(:disabled):hover{background:#ffffff29;box-shadow:0 4px 12px #00000040}.call-tool:active:not(:disabled){transform:scale(.96)}.call-tool-icon{font-size:1.5rem;line-height:1}.call-tool-label{color:#94a3b8;font-size:.65rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.call-tool--cam.is-off,.call-tool--mic.is-off{background:#ef444459!important;border-color:#f8717173;color:#fecaca}.call-tool--mic.is-on{background:#06b6d461;border-color:#22d3ee8c;color:#cffafe}.call-overlay--video-call .call-tool--mic.is-on{background:#06b6d452}.call-tool--cam.is-on{background:#8b5cf661;border-color:#a78bfa8c;color:#ede9fe}.call-overlay--video-call .call-tool--cam.is-on{background:#8b5cf64d}.call-tool--flip.is-active{background:#6366f159;border-color:#818cf880;color:#e0e7ff}.call-overlay--video-call .call-tool--flip.is-active{background:#6366f147}.call-tool--route-toggle.is-earpiece{background:#3b82f66b;border-color:#60a5fa99;color:#dbeafe}.call-tool--route-toggle.is-speaker{background:#f59e0b6b;border-color:#fbbf248c;color:#fef3c7}.call-overlay--video-call .call-tool--route-toggle.is-earpiece{background:#3b82f652}.call-overlay--video-call .call-tool--route-toggle.is-speaker{background:#f59e0b4d}.call-tool--end{background:#dc2626d9;color:#fff;grid-column:1/-1}.call-tool--end:hover{background:#b91c1cf2}.call-tool--debug.is-on{background:#10b98147;border-color:#34d39973;color:#d1fae5}.call-debug-overlay{align-items:center;background:#0000008c;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10050}.call-debug-panel{background:#0b1220;border:1px solid #94a3b838;border-radius:12px;box-shadow:0 24px 60px #0000008c;color:#e5e7eb;display:flex;flex-direction:column;max-height:min(82vh,720px);overflow:hidden;width:min(760px,96vw)}.call-debug-header{align-items:center;border-bottom:1px solid #94a3b829;display:flex;gap:.75rem;justify-content:space-between;padding:.6rem .75rem}.call-debug-actions{display:inline-flex;gap:.5rem}.call-debug-actions button{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:10px;color:#e5e7eb;cursor:pointer;padding:.35rem .55rem}.call-debug-actions button:hover{background:#ffffff1a}.call-debug-body{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.78rem;line-height:1.35;margin:0;overflow:auto;padding:.75rem;white-space:pre-wrap;word-break:break-word}@media (max-width:480px){.call-toolbar{gap:.5rem}.call-tool{min-width:64px;padding:.5rem .35rem}.call-video-local{max-width:120px;width:32%}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:2rem;width:100%}.login-box h2{color:#333;margin-bottom:1.5rem;text-align:center}.login-box h2.login-heading-phone{font-size:1.1rem;font-weight:600;line-height:1.35;margin-bottom:1.25rem}.login-apk-link{background:#edf2f7;border:1px solid #cbd5e0;border-radius:5px;box-sizing:border-box;color:#2d3748;display:block;font-size:1rem;margin-bottom:.75rem;margin-top:.75rem;padding:.75rem;text-align:center;text-decoration:none;transition:background .2s,border-color .2s;width:100%}.login-apk-link:hover{background:#e2e8f0;border-color:#a0aec0;color:#1a202c}.auth-method-switch{display:flex;gap:.5rem;margin-bottom:1rem}.auth-method-switch button{background:#e9ecff;color:#2f3f8f;font-size:.9rem;margin:0;padding:.55rem .7rem}.auth-method-switch button.active{background:#667eea;color:#fff}.form-label{color:#374151;display:block;font-size:.88rem;font-weight:600;margin-bottom:.35rem}.required-star{color:#b91c1c}.form-group{margin-bottom:1rem}.form-group input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.form-group input:focus{border-color:#667eea;outline:none}button{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem;transition:background .3s;width:100%}button:hover:not(:disabled){background:#5568d3}button:disabled{cursor:not-allowed;opacity:.6}.error{color:#e74c3c;font-size:.9rem;margin-bottom:1rem;text-align:center}.toggle-auth{color:#666;margin-top:1rem;text-align:center}.toggle-auth span{color:#667eea;cursor:pointer;text-decoration:underline}.toggle-auth span:hover{color:#5568d3}.login-options-loading{color:#555;font-size:.95rem;padding:2rem 1rem;text-align:center}.phone-help{color:#333;margin-bottom:1rem;text-align:center}.call-phone{font-size:1.1rem;font-weight:700;margin-top:.35rem}.call-phone-link{color:#2f3f8f;text-decoration:underline}.call-phone-link:hover{color:#1e2a6a}.call-phone-missing{color:#b45309;display:block;font-size:.88rem;font-weight:500;line-height:1.35}.secondary-button{background:#8a90ad;margin-top:.5rem}.call-now-button{margin-bottom:.5rem}.secondary-button:hover:not(:disabled){background:#727a98}body.dark-mode .login-container{background:linear-gradient(135deg,#2d3748,#1a202c)}body.dark-mode .login-box{background:#2d3748;box-shadow:0 10px 25px #00000080}body.dark-mode .login-box h2{color:#e0e0e0}body.dark-mode .login-options-loading{color:#9ca3af}body.dark-mode .login-apk-link{background:#3b4364;border-color:#4a5568;color:#e2e8f0}body.dark-mode .login-apk-link:hover{background:#4a5568;border-color:#718096;color:#f7fafc}body.dark-mode .form-label{color:#d1d5db}body.dark-mode .form-group input{background:#1a202c;border-color:#4a5568;color:#e0e0e0}body.dark-mode .form-group input:focus{border-color:#667eea}body.dark-mode .toggle-auth{color:#a0a0a0}body.dark-mode .toggle-auth span{color:#667eea}body.dark-mode .auth-method-switch button{background:#3b4364;color:#dbe2ff}body.dark-mode .auth-method-switch button.active{background:#667eea;color:#fff}body.dark-mode .phone-help{color:#e0e0e0}.ptr-indicator{align-items:center;color:#6b7280;display:flex;font-size:.85rem;height:2rem;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;text-align:center;top:-2.4rem}.ptr-indicator.ready{color:#1d4ed8;font-weight:600}.ptr-indicator.refreshing{color:#3b82f6}body.dark-mode .ptr-indicator{color:#9ca3af}body.dark-mode .ptr-indicator.ready{color:#93c5fd}.contacts-container{background:#fff;border-right:1px solid #ddd;display:flex;flex-direction:column;height:100%;min-height:0;width:300px}.contacts-header{border-bottom:1px solid #ddd;padding:1rem}.contacts-header h2{color:#333;margin:0 0 1rem}.search-container{position:relative}.search-container input{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:.9rem;padding:.5rem;width:100%}.global-search-divider{background:#f9fafb;border-top:1px solid #e5e7eb;color:#6b7280;font-size:.78rem;font-weight:600;padding:.4rem .75rem}.search-results{background:#fff;border:1px solid #ddd;border-radius:5px;box-shadow:0 4px 6px #0000001a;left:0;margin-top:.25rem;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.search-result-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;padding:.75rem}.search-result-item:hover{background:#f5f5f5}.search-result-item:last-child{border-bottom:none}.search-user-info{display:flex;flex-direction:column}.user-email{color:#666;font-size:.8rem;margin-top:.25rem}.add-btn{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:30px;justify-content:center;width:30px}.add-btn:hover{background:#5568d3}.no-contacts,.no-results{color:#666;padding:2rem;text-align:center}.contacts-list{flex:1 1;overflow-y:auto}.contacts-version-footer{align-items:stretch;background:#ffffffd9;border-top:1px solid #e5e7eb;color:#64748b;display:flex;flex-direction:column;flex-shrink:0;font-size:.82rem;gap:.5rem;justify-content:flex-start;padding:.5rem .75rem}.contacts-version-text{line-height:1.25;min-width:0}.contacts-update-btn{align-self:flex-start;background:#16a34a;border:1px solid #15803d;border-radius:6px;color:#fff;cursor:pointer;flex:0 0 auto;font-size:.82rem;font-weight:600;padding:.35rem .6rem;white-space:nowrap}.contacts-update-btn:hover{background:#15803d}.contact-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;padding:1rem;transition:background .2s}.contact-item:hover{background:#f5f5f5}.contact-item.selected{background:#e8eaf6;border-left:3px solid #667eea}.contact-avatar{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;font-weight:700;height:40px;justify-content:center;margin-right:.75rem;width:40px}.contact-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.contact-name-row{align-items:center;display:flex;gap:.5rem;justify-content:space-between;min-width:0}.unread-badge{align-items:center;background:#e53e3e;border-radius:999px;color:#fff;display:inline-flex;font-size:.75rem;height:18px;justify-content:center;margin-left:6px;min-width:18px;padding:0 6px;vertical-align:middle}.contact-info strong{color:#333}.contact-status{font-size:.7rem}.contact-email{color:#666;font-size:.8rem;margin-top:.25rem}.contact-last-message{color:#6b7280;font-size:.82rem;margin-top:.2rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-last-message-prefix,body.dark-mode .contact-last-message{color:#9ca3af}body.dark-mode .contact-last-message-prefix{color:#6b7280}.contacts-header-actions{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:.4rem;margin-left:auto}.contacts-settings-btn,.contacts-test-push-btn,.contacts-theme-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1.05rem;height:32px;justify-content:center;padding:0;width:32px}.contacts-settings-btn:hover,.contacts-test-push-btn:hover,.contacts-theme-btn:hover{background:#0f172a14}body.dark-mode .contacts-settings-btn:hover,body.dark-mode .contacts-test-push-btn:hover,body.dark-mode .contacts-theme-btn:hover{background:#ffffff14}.topbar-search-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1.1rem;height:36px;justify-content:center;width:36px}.topbar-search-btn:hover{background:#ffffff26}body.dark-mode .contacts-container{background:#2d3748;border-right-color:#4a5568}body.dark-mode .contacts-header{background:#1a202c;border-bottom-color:#4a5568}body.dark-mode .contacts-header h2{color:#e0e0e0}body.dark-mode .search-container input{background:#2d3748;border-color:#4a5568;color:#e0e0e0}body.dark-mode .global-search-divider{background:#1f2937;border-top-color:#4a5568;color:#cbd5e1}body.dark-mode .search-results{background:#2d3748;border-color:#4a5568}body.dark-mode .search-result-item{border-bottom-color:#4a5568;color:#e0e0e0}body.dark-mode .search-result-item:hover{background:#4a5568}body.dark-mode .contact-item{border-bottom-color:#4a5568;color:#e0e0e0}body.dark-mode .contact-item:hover{background:#4a5568}body.dark-mode .contact-item.selected{background:#4c51bf;border-left-color:#667eea}body.dark-mode .contact-info strong{color:#e0e0e0}body.dark-mode .contact-email,body.dark-mode .no-contacts,body.dark-mode .no-results,body.dark-mode .user-email{color:#a0a0a0}body.dark-mode .contacts-version-footer{background:#111827e6;border-top-color:#374151;color:#9ca3af}body.dark-mode .contacts-update-btn{background:#22c55e;border-color:#16a34a}.contacts-header-top{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:1rem}.contacts-header-top h2{margin:0}.new-group-btn{background:#eef2ff;border:1px solid #c7d2fe;border-radius:8px;color:#4338ca;cursor:pointer;flex-shrink:0;font-size:.82rem;font-weight:600;padding:.35rem .65rem}.new-group-btn:hover{background:#e0e7ff}body.dark-mode .new-group-btn{background:#312e81;border-color:#4c1d95;color:#e0e7ff}.contacts-group-block{border-bottom:1px solid #e5e7eb;flex-shrink:0;max-height:40vh;overflow-y:auto;padding:0 0 .35rem}.contacts-group-heading{color:#64748b;font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:.35rem 1rem .25rem;text-transform:uppercase}.contacts-group-empty{color:#94a3b8;font-size:.85rem;padding:.5rem 1rem .75rem}.group-item .group-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6);font-size:1.1rem}body.dark-mode .contacts-group-block{border-bottom-color:#374151}body.dark-mode .contacts-group-heading{color:#9ca3af}.group-modal-backdrop{align-items:center;background:#0f172a8c;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:20000}.group-modal{background:#fff;border-radius:16px;box-shadow:0 24px 48px #0003;display:flex;flex-direction:column;max-height:90vh;max-width:400px;overflow:hidden;padding:1.25rem;width:100%}body.dark-mode .group-modal{background:#1e293b;color:#f1f5f9}.group-modal h3{font-size:1.1rem;margin:0 0 1rem}.group-modal-label{display:flex;flex-direction:column;font-size:.88rem;font-weight:600;gap:.35rem;margin-bottom:.75rem}.group-modal-label input{border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.5rem .65rem}body.dark-mode .group-modal-label input{background:#0f172a;border-color:#334155;color:#f8fafc}.group-modal-hint{color:#64748b;font-size:.82rem;margin:0 0 .35rem}body.dark-mode .group-modal-hint{color:#94a3b8}.group-modal-members{border:1px solid #e5e7eb;border-radius:8px;flex:1 1;margin-bottom:1rem;max-height:220px;min-height:120px;overflow-y:auto;padding:.35rem}body.dark-mode .group-modal-members{border-color:#334155}.group-modal-member-row{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.5rem;padding:.4rem .35rem}.group-modal-member-row:hover{background:#f8fafc}body.dark-mode .group-modal-member-row:hover{background:#334155}.group-modal-empty{color:#94a3b8;font-size:.9rem;padding:1rem}.group-modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.group-modal-cancel,.group-modal-submit{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.5rem 1rem}.group-modal-cancel{background:#f1f5f9;color:#475569}.group-modal-submit{background:#6366f1;color:#fff}body.dark-mode .group-modal-cancel{background:#334155;color:#e2e8f0}.contact-presence-text{color:#6b7280;display:block;font-size:.78rem;margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.dark-mode .contact-presence-text{color:#9ca3af}.forward-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1100}.forward-modal{background:#fff;border-radius:12px;box-shadow:0 16px 32px #00000040;display:flex;flex-direction:column;max-height:80vh;overflow:hidden;width:min(420px,92vw)}.forward-header{align-items:center;border-bottom:1px solid #00000014;display:flex;font-size:1rem;justify-content:space-between;padding:.75rem 1rem}.forward-close{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.4rem;padding:0 .25rem}.forward-preview{background:#3b82f60f;border-bottom:1px solid #0000000f;border-left:3px solid #3b82f6b3;border-radius:0 6px 6px 0;margin:.5rem .75rem 0;padding:.5rem 1rem .75rem}.forward-preview-author{color:#1d4ed8;font-size:.78rem;font-weight:600;margin-bottom:2px}.forward-preview-text{color:#374151;font-size:.9rem;white-space:pre-wrap;word-break:break-word}.forward-search{border:1px solid #00000026;border-radius:8px;font-size:.95rem;margin:.75rem 1rem;outline:none;padding:.5rem .75rem}.forward-search:focus{border-color:#3b82f6}.forward-list{flex:1 1;min-height:0;overflow-y:auto;padding:0 .5rem .75rem}.forward-empty{color:#6b7280;font-size:.9rem;padding:1.5rem 1rem;text-align:center}.forward-section{color:#6b7280;font-size:.78rem;font-weight:600;letter-spacing:.05em;padding:.5rem .75rem .25rem;text-transform:uppercase}.forward-row{align-items:center;background:#0000;border:none;border-radius:8px;color:#1f2937;cursor:pointer;display:flex;font-size:.95rem;gap:.6rem;padding:.55rem .75rem;text-align:left;width:100%}.forward-row:hover{background:#3b82f614}.forward-avatar{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:.85rem;font-weight:600;height:32px;justify-content:center;width:32px}.forward-avatar.group{background:#6366f1}.forward-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.forward-confirm{border-top:1px solid #0000000f;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.forward-confirm-text{color:#1f2937;font-size:.95rem;text-align:center}.forward-confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}.forward-confirm-actions button{background:#f3f4f6;border:1px solid #00000026;border-radius:8px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.forward-confirm-btn{background:#3b82f6!important;border-color:#3b82f6!important;color:#fff}.forward-confirm-btn:hover{background:#2563eb!important}body.dark-mode .forward-modal{background:#1f2937;color:#e5e7eb}body.dark-mode .forward-header{border-bottom-color:#ffffff14}body.dark-mode .forward-preview{background:#3b82f62e;border-bottom-color:#ffffff14}body.dark-mode .forward-preview-author{color:#93c5fd}body.dark-mode .forward-preview-text{color:#e5e7eb}body.dark-mode .forward-search{background:#111827;border-color:#374151;color:#e5e7eb}body.dark-mode .forward-row{color:#e5e7eb}body.dark-mode .forward-row:hover{background:#60a5fa2e}body.dark-mode .forward-confirm-actions button{background:#374151;border-color:#4b5563;color:#e5e7eb}body.dark-mode .forward-close,body.dark-mode .forward-empty,body.dark-mode .forward-section{color:#9ca3af}@media (max-width:600px){.forward-overlay{align-items:stretch;padding:0}.forward-modal{border-radius:0!important;height:100vh;max-height:100vh!important;padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top);width:100%!important}.forward-list{flex:1 1}}.voice-player{align-items:center;background:#3b82f614;border-radius:16px;display:flex;gap:.6rem;max-width:360px;min-width:220px;padding:.4rem .5rem}.voice-player-btn{align-items:center;background:#3b82f6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:inline-flex;flex:0 0 auto;font-size:1.05rem;height:40px;justify-content:center;line-height:1;padding:0;width:40px}.voice-player-btn:hover{background:#2563eb}.voice-player-btn.playing{background:#1d4ed8}.voice-player-body{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.voice-player-progress{background:#3b82f640;border-radius:2px;cursor:pointer;height:4px;position:relative}.voice-player-progress-fill{background:#3b82f6;border-radius:2px;bottom:0;left:0;position:absolute;top:0;transition:width .08s linear}.voice-player-progress-thumb{background:#fff;border:2px solid #3b82f6;border-radius:50%;box-shadow:0 1px 4px #0003;height:12px;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}.voice-player-meta{align-items:center;color:#1f2937;display:flex;font-size:.78rem;gap:.5rem}.voice-player-time{font-feature-settings:"tnum";color:#1d4ed8;font-variant-numeric:tabular-nums;font-weight:600}.voice-player-filename{color:#6b7280;flex:1 1;font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.voice-player-rate{background:#3b82f62e;border:none;border-radius:8px;color:#1d4ed8;cursor:pointer;font-size:.72rem;font-weight:700;margin-left:auto;padding:.15rem .4rem}body.dark-mode .voice-player{background:#3b82f626}body.dark-mode .voice-player-time{color:#93c5fd}body.dark-mode .voice-player-filename{color:#9ca3af}body.dark-mode .voice-player-rate{background:#60a5fa38;color:#93c5fd}body.dark-mode .voice-player-progress{background:#93c5fd40}body.dark-mode .voice-player-progress-fill{background:#60a5fa}body.dark-mode .voice-player-progress-thumb{background:#1f2937;border-color:#60a5fa}.voice-player-waveform{align-items:center;display:flex;gap:2px;height:28px;pointer-events:none;width:100%}.voice-player-wave-bar{background:#3b82f652;border-radius:1px;flex:1 0 auto;min-height:4px;width:2px}.voice-player-wave-bar.played{background:#2563eb}body.dark-mode .voice-player-wave-bar{background:#93c5fd4d}body.dark-mode .voice-player-wave-bar.played{background:#60a5fa}.pinned-note-overlay{align-items:center;background:#0f172a73;box-sizing:border-box;display:flex;inset:0;justify-content:center;padding:12px;position:fixed;z-index:2000}.pinned-note-modal{background:#fff;border-radius:12px;box-shadow:0 14px 40px #0f172a4d;display:flex;flex-direction:column;max-height:80vh;max-width:480px;overflow:hidden;width:100%}.pinned-note-header{align-items:center;border-bottom:1px solid #0f172a14;display:flex;justify-content:space-between;padding:10px 14px}.pinned-note-title{color:#1f2937;font-size:.95rem;font-weight:600}.pinned-note-close{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.4rem;line-height:1;padding:0 4px}.pinned-note-close:hover{color:#ef4444}.pinned-note-pinned-preview{background:#60a5fa14;border-bottom:1px solid #60a5fa2e;display:flex;flex-direction:column;gap:2px;padding:8px 14px}.pinned-note-pinned-label{color:#6b7280;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}.pinned-note-pinned-text{color:#1f2937;font-size:.85rem;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pinned-note-textarea{background:#fffefa;border:none;box-sizing:border-box;color:#1f2937;flex:1 1 auto;font-family:inherit;font-size:.95rem;line-height:1.45;min-height:200px;outline:none;padding:12px 14px;resize:vertical}.pinned-note-footer{align-items:center;border-top:1px solid #0f172a14;display:flex;gap:8px;justify-content:space-between;padding:10px 14px}.pinned-note-status{color:#6b7280;font-size:.78rem}.pinned-note-actions{display:flex;flex-wrap:wrap;gap:8px}.pinned-note-action{background:#0f172a0f;border:none;border-radius:8px;color:#1f2937;cursor:pointer;font-size:.85rem;padding:8px 12px}.pinned-note-action:hover{background:#0f172a1f}.pinned-note-action.primary{background:#3b82f6;color:#fff}.pinned-note-action.primary:hover{background:#2563eb}body.dark-mode .pinned-note-modal{background:#1f2937;color:#e5e7eb}body.dark-mode .pinned-note-header{border-bottom-color:#ffffff14}body.dark-mode .pinned-note-title{color:#e5e7eb}body.dark-mode .pinned-note-close{color:#cbd5e1}body.dark-mode .pinned-note-pinned-preview{background:#60a5fa1f;border-bottom-color:#60a5fa40}body.dark-mode .pinned-note-pinned-text{color:#e5e7eb}body.dark-mode .pinned-note-textarea{background:#111827;color:#e5e7eb}body.dark-mode .pinned-note-footer{border-top-color:#ffffff14}body.dark-mode .pinned-note-action{background:#ffffff14;color:#e5e7eb}body.dark-mode .pinned-note-action:hover{background:#ffffff29}.chat-emoji-gif-panel{background:#fff;background:var(--chat-panel-bg,#fff);border:1px solid #0000001f;border-radius:12px;bottom:100%;box-shadow:0 -4px 24px #0000001f;display:flex;flex-direction:column;left:0;margin-bottom:6px;max-height:min(320px,50vh);overflow:hidden;position:absolute;right:0;z-index:30}body.dark-mode .chat-emoji-gif-panel{--chat-panel-bg:#2a2a2a;border-color:#ffffff1f;box-shadow:0 -4px 24px #0006}.chat-emoji-gif-tabs{align-items:center;border-bottom:1px solid #00000014;display:flex;gap:4px;padding:8px 8px 4px}body.dark-mode .chat-emoji-gif-tabs{border-bottom-color:#ffffff14}.chat-emoji-gif-tabs button{background:#0000;border:none;border-radius:8px;cursor:pointer;font-size:.9rem;padding:6px 12px}.chat-emoji-gif-tabs button.active{background:#4a9eff33;color:#1a6bcb}body.dark-mode .chat-emoji-gif-tabs button.active{color:#8ec5ff}.chat-emoji-gif-close{font-size:1.25rem;line-height:1;margin-left:auto;opacity:.7}.chat-emoji-cat-row{-webkit-overflow-scrolling:touch;border-bottom:1px solid #0000000f;display:flex;flex-wrap:nowrap;gap:4px;justify-content:space-between;overflow-x:auto;padding:6px 8px;scrollbar-width:thin}.chat-emoji-cat-btn{align-items:center;background:#0000000d;border:none;border-radius:10px;cursor:pointer;display:inline-flex;flex:0 0 auto;height:2.5rem;justify-content:center;line-height:1;min-width:2.5rem;padding:0;width:2.5rem}body.dark-mode .chat-emoji-cat-btn{background:#ffffff14}.chat-emoji-cat-icon{display:block;font-size:1.35rem;line-height:1}.chat-emoji-cat-btn:hover{background:#00000017}body.dark-mode .chat-emoji-cat-btn:hover{background:#ffffff1f}.chat-emoji-cat-btn.active{background:#4a9eff47;box-shadow:inset 0 0 0 1.5px #4a9eff8c}body.dark-mode .chat-emoji-cat-btn.active{background:#4a9eff38;box-shadow:inset 0 0 0 1.5px #4a9eff73}.chat-emoji-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(8,1fr);max-height:220px;overflow-y:auto;padding:8px}.chat-emoji-cell{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:1.35rem;line-height:1.2;padding:6px 4px}.chat-emoji-cell:hover{background:#0000000f}body.dark-mode .chat-emoji-cell:hover{background:#ffffff14}.chat-gif-tab{display:flex;flex-direction:column;min-height:0}.chat-gif-hint{font-size:.72rem;line-height:1.35;opacity:.85;padding:6px 10px}.chat-gif-hint code{font-size:.68rem}.chat-gif-search-row{display:flex;gap:6px;padding:6px 8px}.chat-gif-search{border:1px solid #00000026;border-radius:8px;flex:1 1;font-size:.9rem;padding:6px 10px}body.dark-mode .chat-gif-search{background:#1e1e1e;border-color:#ffffff26;color:#eee}.chat-gif-search-row button{background:#4a9eff;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:6px 12px}.chat-gif-loading{opacity:.7;padding:16px;text-align:center}.chat-gif-grid{grid-gap:6px;align-content:start;align-items:start;display:grid;gap:6px;grid-template-columns:repeat(4,minmax(0,1fr));max-height:240px;overflow-x:hidden;overflow-y:auto;padding:8px}.chat-gif-cell-wrap{box-sizing:border-box;height:0;min-width:0;padding-bottom:100%;position:relative;width:100%}.chat-gif-cell{align-items:center;background:#0000000f;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;margin:0;overflow:hidden;padding:0}.chat-gif-cell,.chat-gif-cell img{height:100%;inset:0;position:absolute;width:100%}.chat-gif-cell img{display:block;object-fit:cover;object-position:center;pointer-events:none}.chat-gif-fallback{font-size:.75rem;font-weight:600;opacity:.75;position:relative;z-index:1}.chat-gif-cell-wrap:hover .chat-gif-cell{outline:2px solid #4a9eff;outline-offset:0}@media (max-width:500px){.chat-emoji-grid{grid-template-columns:repeat(7,1fr)}.chat-gif-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.chat-container{background:#f5f5f5;display:flex;flex:1 1;flex-direction:column;height:100%;min-height:0}.chat-header{background:#fff;border-bottom:1px solid #ddd;box-shadow:0 2px 4px #0000001a;padding:1rem}.chat-header h3{color:#0f172a;font-weight:700;margin:0}.chat-contact-title{color:inherit;cursor:pointer}.chat-contact-title:hover{text-decoration:underline}.group-chat-header-top{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between}.group-chat-attachments-btn{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;color:#0f172a;cursor:pointer;flex-shrink:0;font-size:.85rem;font-weight:600;padding:.4rem .7rem}.group-chat-attachments-btn:active{transform:scale(.98)}body.dark-mode .group-chat-attachments-btn{background:#334155;border-color:#475569;color:#e2e8f0}.connection-badge{font-size:.85rem;margin-top:.4rem;opacity:.9}.connection-badge.online{color:#2f855a}.connection-badge.offline{color:#c53030}.messages-container{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:.5rem;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain;padding:1rem;touch-action:pan-y}.message{word-wrap:break-word;border-radius:10px;max-width:70%;padding:.75rem 1rem}.message.sent{align-self:flex-end;background:#667eea;color:#fff}.message.received{align-self:flex-start;background:#fff;box-shadow:0 1px 2px #0000001a;color:#333}.message-content{word-wrap:break-word;margin-bottom:.25rem;overflow-wrap:break-word}.message-image{border-radius:8px;cursor:zoom-in;display:block;max-height:300px;max-width:100%}.message-audio-wrap,.message-image,.message-video-wrap{margin-top:.5rem}.message-video-preview-frame,.message-video-wrap{display:inline-block;max-width:100%;position:relative}.message-video-preview-frame{margin-top:.5rem}.message-video-preview-thumb{display:block;margin-top:0!important}.message-video-fullscreen-btn{align-items:center;background:#0000008c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;height:36px;justify-content:center;line-height:1;padding:0;position:absolute;right:8px;top:8px;width:36px;z-index:2}.message-video-fullscreen-btn:active{transform:scale(.96)}.message-video{background:#000;border-radius:8px;max-width:360px;width:100%}.message-video-upload-overlay{align-items:center;background:#0000008c;border-radius:8px;color:#fff;display:flex;flex-direction:column;gap:.6rem;inset:0;justify-content:center;pointer-events:none;position:absolute;z-index:3}.message-video-upload-overlay-label{font-size:.9rem;font-weight:500;padding:0 .75rem;text-align:center;text-shadow:0 1px 2px #0009}.message-video-upload-overlay-bar{background:#ffffff40;border-radius:4px;height:4px;overflow:hidden;width:75%}.message-video-upload-overlay-bar-inner{background:#4ade80;border-radius:4px;height:100%;transition:width .4s ease-out}.message-file-with-overlay{display:inline-block;min-height:60px;min-width:220px;position:relative}.message-audio{max-width:320px;width:100%}.chat-outbox-banner{background:#ffc10733;border-bottom:1px solid #85640440;color:#856404;font-size:.85rem;padding:.45rem .75rem;text-align:center}.message-pending-warn{align-items:center;color:#c62828;display:inline-flex;font-size:1rem;font-weight:800;justify-content:center;line-height:1;margin-right:4px;min-width:1.1rem}.image-preview-modal{background:#000000d9;inset:0;padding:1rem;position:fixed;z-index:9999}.image-preview-modal,.image-preview-modal-inner{align-items:center;display:flex;justify-content:center}.image-preview-modal-inner{overflow:hidden}.image-preview-modal-content,.image-preview-modal-inner{max-height:90vh;max-width:min(96vw,1200px);touch-action:none}.image-preview-modal-content{-webkit-user-drag:none;border-radius:8px;object-fit:contain;-webkit-user-select:none;user-select:none}video.image-preview-modal-video{background:#000;max-height:90vh;touch-action:manipulation;width:min(96vw,1200px)}.image-preview-close{background:#0006;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:2rem;height:44px;line-height:1;position:fixed;right:16px;top:12px;width:44px}.profile-modal-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10000}.profile-modal{background:#fff;border-radius:10px;max-height:90vh;overflow:auto;padding:.9rem;width:min(680px,96vw)}.profile-modal-header{align-items:center;margin-bottom:.6rem}.profile-modal-header,.profile-row{display:flex;justify-content:space-between}.profile-row{gap:.75rem;padding:.25rem 0}.profile-attachments-divider{border-top:1px solid #e5e7eb;font-weight:600;margin-top:.8rem;padding-top:.65rem}.profile-tabs{display:flex;gap:.4rem;margin-top:.45rem}.profile-tabs button{background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;cursor:pointer;padding:.35rem .6rem}.profile-tabs button.active{background:#dbeafe;border-color:#93c5fd}.profile-attachments-list{margin-top:.5rem}.profile-attachment-item{border-bottom:1px solid #f1f5f9;display:flex;font-size:.9rem;gap:.75rem;justify-content:space-between;padding:.45rem 0}.profile-attachment-link{align-items:center;background:#0000;border:none;color:#1d4ed8;cursor:pointer;display:inline-flex;gap:.35rem;max-width:min(65vw,420px);padding:0;text-align:left}.profile-attachment-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-empty{color:#64748b;padding:.75rem 0}.message-file{margin-top:.5rem}.file-link{align-items:center;background:#fff3;border-radius:5px;color:inherit;display:inline-flex;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:background .2s}.file-link:hover{background:#ffffff4d}body.dark-mode .chat-container{background:#2d3748}body.dark-mode .chat-header{background:#1a202c;border-bottom-color:#4a5568}body.dark-mode .chat-contact-title,body.dark-mode .chat-header h3{color:#f1f5f9}body.dark-mode .chat-contact-title:hover{color:#fff}body.dark-mode .connection-badge.online{color:#68d391}body.dark-mode .connection-badge.offline{color:#fc8181}body.dark-mode .messages-container{background:#2d3748}body.dark-mode .message.received{background:#4a5568;color:#e0e0e0}body.dark-mode .message.sent{background:#4c51bf}body.dark-mode .profile-modal{background:#1f2937;color:#e5e7eb}body.dark-mode .profile-attachments-divider{border-top-color:#374151}body.dark-mode .profile-tabs button{background:#111827;border-color:#374151;color:#e5e7eb}body.dark-mode .profile-tabs button.active{background:#1e3a8a;border-color:#2563eb}body.dark-mode .profile-attachment-item{border-bottom-color:#374151}body.dark-mode .profile-attachment-link{color:#93c5fd}body.dark-mode .profile-empty{color:#9ca3af}body.dark-mode .chat-input{background:#1a202c;border-top-color:#4a5568}body.dark-mode .attach-btn,body.dark-mode .chat-input input[type=text]{background:#2d3748;border-color:#4a5568;color:#e0e0e0}body.dark-mode .attach-btn:hover:not(:disabled){background:#4a5568}.message-footer{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin-top:.25rem}.message-time{font-size:.75rem;opacity:.7}.message-status{font-size:.75rem;margin-left:auto;opacity:.8}.message-status-delivered{opacity:.65}.message-status-read{color:#4a9eff;opacity:1}body.dark-mode .message-status-read{color:#6eb3ff}.typing-indicator{align-self:flex-start;display:flex;gap:.25rem;padding:.5rem}.typing-indicator span{animation:typing 1.4s infinite;background:#999;border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.chat-input-wrap{display:flex;flex-direction:column;flex-shrink:0;position:relative;width:100%}.message-text-wrap{overflow-wrap:anywhere;word-break:break-word}.chat-inline-gif{border-radius:8px;display:block;margin-top:4px;max-height:220px;max-width:min(280px,100%);object-fit:contain}a.chat-text-link{color:#1976d2;text-decoration:underline;word-break:break-all}body.dark-mode a.chat-text-link{color:#64b5f6}.chat-input{align-items:stretch;background:#fff;border-top:1px solid #ddd;box-sizing:border-box;display:flex;flex-direction:column;flex-shrink:0;gap:.45rem;padding:1rem 1rem calc(1rem + env(safe-area-inset-bottom, 0px));width:100%}.pending-upload-preview{background:#fafafa;border:1px solid #d8d8d8;border-radius:8px;display:flex;flex-direction:column;gap:.6rem;max-height:280px;overflow:auto;padding:.75rem}.pending-upload-title{color:#333;font-size:.9rem}.pending-preview-image{border-radius:8px;max-height:220px;max-width:220px;object-fit:cover}.pending-preview-video{background:#000;border-radius:8px;display:block;height:auto;max-height:160px;object-fit:contain}.pending-preview-audio,.pending-preview-video{max-width:360px;width:100%}.pending-upload-actions{display:flex;gap:.5rem}.upload-progress-wrap{margin-top:.35rem}.upload-progress-wrap--standalone{background:#3b82f614;border-radius:10px;margin:.5rem .75rem;padding:.5rem .65rem}.upload-progress-label{color:#555;font-size:.82rem;margin-bottom:.25rem}.upload-progress-bar{background:#e9e9e9;border-radius:999px;height:8px;overflow:hidden;width:100%}.upload-progress-bar-inner{background:#3b82f6;height:100%;transition:width .2s ease}.message-attachment-loading{background:#0f172a0f;border-radius:8px;margin-top:.35rem;max-width:280px;padding:.5rem .65rem}.message.sent .message-attachment-loading{background:#fff3}.message-attachment-loading-title{font-size:.8rem;font-weight:600;margin-bottom:.35rem;opacity:.9}.message-attachment-loading-meta{font-size:.78rem;margin-bottom:.35rem;opacity:.85}.message-attachment-loading-hint{font-size:.78rem;opacity:.8}.message-attachment-loading-bar-wrap{background:#0f172a1f;border-radius:999px;height:6px;overflow:hidden;width:100%}.message.sent .message-attachment-loading-bar-wrap{background:#ffffff40}.message-attachment-loading-bar{background:#6366f1;border-radius:999px;height:100%;transition:width .2s ease}.message.sent .message-attachment-loading-bar{background:#ffffffd9}.chat-input-actions{display:flex;flex-wrap:nowrap;gap:.5rem;justify-content:flex-end}.chat-input-actions.mobile-actions{justify-content:space-between}.attach-btn{align-items:center;background:#f0f0f0;border:1px solid #ddd;border-radius:5px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;justify-content:center;min-width:72px;padding:.75rem;transition:background .2s;visibility:visible;white-space:nowrap}.attach-btn:hover:not(:disabled){background:#e0e0e0}.attach-btn:disabled{cursor:not-allowed;opacity:.5}.attach-menu-wrap{align-self:center;display:inline-flex;position:relative;vertical-align:middle}.attach-menu-popup{background:#fff;background:var(--chat-panel-bg,#fff);border:1px solid #0000001f;border-radius:10px;bottom:100%;box-shadow:0 -4px 24px #0000001f;box-sizing:border-box;direction:ltr;display:flex;flex-direction:column;left:0;margin-bottom:6px;max-width:min(280px,calc(100vw - 24px));min-width:200px;padding:4px 0;position:absolute;right:auto;z-index:35}body.dark-mode .attach-menu-popup{--chat-panel-bg:#2a2a2a;border-color:#ffffff1f;box-shadow:0 -4px 24px #0006}.attach-menu-item{background:#0000;border:none;box-sizing:border-box;color:inherit;cursor:pointer;display:block;font-family:inherit;font-size:.95rem;margin:0;padding:10px 14px;text-align:left;width:100%}.attach-menu-item:hover{background:#0000000f}body.dark-mode .attach-menu-item:hover{background:#ffffff14}.chat-input textarea{border:1px solid #ddd;border-radius:5px;font-family:inherit;font-size:1rem;line-height:1.35;max-height:140px;min-height:42px;min-width:0;overflow-y:auto;padding:.75rem;resize:none;width:100%}.chat-input textarea:focus{border-color:#667eea;outline:none}.chat-input-actions button{-webkit-tap-highlight-color:transparent;background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;min-width:100px;padding:.75rem 1.5rem;touch-action:manipulation}.chat-input-actions button:hover:not(:disabled){background:#5568d3}.chat-input-actions button:disabled{cursor:not-allowed;opacity:.5}.chat-input-actions button:active{transform:scale(.98)}@media (max-width:900px){.chat-input{gap:.35rem;padding:.5rem}.attach-btn{flex:0 0 38px;font-size:1rem;height:38px;min-width:38px;padding:0;width:38px}.chat-input textarea{font-size:16px;padding:.6rem .55rem}.chat-input-actions button{flex:0 0 auto;font-size:.9rem;min-width:64px;padding:.6rem .7rem}}body.android-app .chat-input{gap:.3rem!important;padding:.45rem .45rem calc(.45rem + env(safe-area-inset-bottom, 0px))!important}body.android-app .chat-input textarea{min-width:0!important;width:100%!important}body.android-app .chat-input-actions button{min-width:60px!important;padding:.55rem .65rem!important}body.android-app .attach-btn{display:inline-flex!important;min-width:72px!important;visibility:visible!important}body.android-app .file-btn-prominent{background:#eef2ff!important;border:1px solid #c7d2fe!important;color:#1f2937!important;font-weight:700!important;min-width:92px!important}.group-settings-modal .group-settings-member-list{list-style:none;margin:.35rem 0 0;padding:0}.group-settings-modal .group-settings-member-list li{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:.5rem;justify-content:space-between;padding:.35rem 0}.group-kick-btn{background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;color:#b91c1c;cursor:pointer;font-size:.8rem;padding:.25rem .5rem}.group-add-members{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.35rem}.group-add-member-btn{background:#eff6ff;border:1px solid #93c5fd;border-radius:8px;color:#1e40af;cursor:pointer;font-size:.85rem;padding:.35rem .55rem}.group-danger-btn{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#b91c1c;margin-top:.5rem}.group-danger-btn,.group-leave-btn{cursor:pointer;font-weight:600;padding:.55rem;width:100%}.group-leave-btn{background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;margin-top:.35rem}body.dark-mode .group-settings-modal .group-settings-member-list li{border-bottom-color:#374151}body.dark-mode .group-kick-btn{background:#450a0a;border-color:#7f1d1d;color:#fecaca}body.dark-mode .group-add-member-btn{background:#1e3a8a;border-color:#3b82f6;color:#dbeafe}body.dark-mode .group-danger-btn{background:#450a0a;border-color:#991b1b;color:#fecaca}body.dark-mode .group-leave-btn{background:#1f2937;border-color:#4b5563;color:#e5e7eb}.message.deleted .message-content{opacity:.7}.message-deleted-marker{color:#6b7280;font-style:italic}body.dark-mode .message-deleted-marker{color:#9ca3af}.chat-edit-banner{align-items:center;background:#3b82f61f;border:1px solid #3b82f659;border-radius:8px;color:#1d4ed8;display:flex;font-size:.85rem;gap:.5rem;justify-content:space-between;margin:0 .25rem .25rem;padding:.4rem .75rem}body.dark-mode .chat-edit-banner{background:#3b82f626;border-color:#93c5fd73;color:#93c5fd}.chat-edit-cancel{background:#0000;border:none;color:inherit;cursor:pointer;font-size:1.1rem;padding:0 .25rem}.message-actions-menu{background:#fff;border:1px solid #0000001a;border-radius:10px;box-shadow:0 8px 24px #0000002e;display:flex;flex-direction:column;min-width:160px;padding:.25rem}.message-actions-menu button{background:#0000;border:none;border-radius:6px;color:#1f2937;cursor:pointer;font-size:.95rem;padding:.55rem .75rem;text-align:left}.message-actions-menu button:hover{background:#3b82f61a}body.dark-mode .message-actions-menu{background:#111827;border-color:#374151}body.dark-mode .message-actions-menu button{color:#e5e7eb}body.dark-mode .message-actions-menu button:hover{background:#60a5fa2e}@media (max-width:600px){.message-actions-menu{animation:bottom-sheet-up .18s ease-out;border-radius:16px 16px 0 0!important;bottom:0!important;box-shadow:0 -8px 16px #00000040!important;left:0!important;min-width:0!important;padding:.5rem .5rem max(.75rem,env(safe-area-inset-bottom))!important;position:fixed!important;right:0!important;top:auto!important;width:100%!important}.message-actions-menu button{border-radius:8px!important;font-size:1rem!important;padding:1rem!important;text-align:center!important}}@keyframes bottom-sheet-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.message-cited{background:#3b82f614;border-left:3px solid #3b82f6b3;border-radius:0 6px 6px 0;cursor:pointer;display:block;font-size:.85rem;margin-bottom:4px;max-width:100%;overflow:hidden;padding:4px 8px}.message-cited:hover{background:#3b82f626}.message-cited-author{color:#1d4ed8;font-size:.78rem;font-weight:600;margin-bottom:1px}.message-cited-text{color:#374151;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.dark-mode .message-cited{background:#3b82f62e;border-left-color:#93c5fdb3}body.dark-mode .message-cited-author{color:#93c5fd}body.dark-mode .message-cited-text{color:#e5e7eb}.chat-reply-banner{align-items:stretch;background:#3b82f61a;border-radius:8px;color:#1d4ed8;display:flex;font-size:.85rem;gap:.5rem;margin:0 .25rem .25rem;min-height:38px;padding:.4rem .5rem .4rem .65rem}.chat-reply-banner-bar{background:#3b82f6bf;border-radius:3px;flex:0 0 3px;width:3px}.chat-reply-banner-icon{align-items:center;color:#3b82f6d9;display:flex;flex:0 0 auto;font-size:1rem;justify-content:center;width:18px}.chat-reply-banner-body{display:flex;flex:1 1 auto;flex-direction:column;justify-content:center;min-width:0;overflow:hidden}.chat-reply-banner-label{font-size:.78rem;font-weight:600;line-height:1.15}.chat-reply-banner-label,.chat-reply-banner-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-reply-banner-text{color:#374151;line-height:1.2}.chat-reply-banner-close{-webkit-tap-highlight-color:transparent;align-items:center;align-self:center;background:#0000;border:none;border-radius:50%;color:#475569;cursor:pointer;display:inline-flex;flex:0 0 28px;font-size:1.25rem;height:28px;justify-content:center;line-height:1;padding:0;width:28px}.chat-reply-banner-close:hover{background:#0f172a14}body.dark-mode .chat-reply-banner{background:#3b82f62e;color:#93c5fd}body.dark-mode .chat-reply-banner-bar{background:#93c5fd}body.dark-mode .chat-reply-banner-icon{color:#93c5fd}body.dark-mode .chat-reply-banner-text{color:#e5e7eb}body.dark-mode .chat-reply-banner-close{color:#cbd5e1}body.dark-mode .chat-reply-banner-close:hover{background:#ffffff1a}@keyframes message-flash-anim{0%{background-color:#3b82f659}to{background-color:initial}}.message-flash{animation:message-flash-anim 1.2s ease-out}@keyframes message-slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.messages-container .message:last-of-type:not(.deleted){animation:message-slide-in .16s ease-out}.message{position:relative;touch-action:pan-y}.message-swipe-reply-icon{align-items:center;background:#3b82f62e;border-radius:50%;color:#1d4ed8;display:flex;font-size:1rem;height:28px;justify-content:center;pointer-events:none;position:absolute;right:-36px;top:50%;transform:translateY(-50%);transition:transform .15s ease-out,background .15s ease-out;width:28px}.message-swipe-reply-icon.ready{background:#3b82f6;color:#fff;transform:translateY(-50%) scale(1.1)}body.dark-mode .message-swipe-reply-icon{background:#60a5fa40;color:#93c5fd}body.dark-mode .message-swipe-reply-icon.ready{background:#60a5fa;color:#0b1220}.chat-input-actions .send-btn{align-items:center;background:#3b82f6;border:none;border-radius:50%;box-sizing:border-box;color:#fff;display:inline-flex;flex-grow:0;flex-shrink:0;font-size:1.1rem;height:44px;justify-content:center;line-height:1;max-width:44px;min-width:44px!important;padding:0!important;width:44px}.chat-input-actions .send-btn:hover:not(:disabled){background:#2563eb}.chat-input-actions .send-btn:disabled{background:#9ca3af;cursor:not-allowed;opacity:.7}.send-btn-icon{display:inline-block;font-size:1.05rem;transform:translateX(1px)}.send-btn-text{font-size:.9rem}body.dark-mode .chat-input-actions .send-btn:disabled{background:#374151}.chat-input-actions .voice-btn{background:#6366f1}.chat-input-actions .voice-btn:hover:not(:disabled){background:#4f46e5}.voice-record-bar{align-items:center;animation:slide-up .18s ease-out;background:linear-gradient(180deg,#ef444414,#ef44442e);border-top:1px solid #ef444466;display:flex;gap:.75rem;padding:.75rem 1rem}@keyframes slide-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.voice-cancel{align-items:center;background:#fffffff2;border:none;border-radius:50%;box-shadow:0 2px 6px #0000001f;color:#dc2626;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:1.4rem;height:44px;justify-content:center;width:44px}.voice-cancel:active{transform:scale(.94)}.voice-time{font-feature-settings:"tnum";align-items:center;color:#b91c1c;display:flex;flex:1 1;font-size:1.15rem;font-variant-numeric:tabular-nums;font-weight:700;gap:.6rem}.voice-dot{animation:voice-pulse 1.4s ease-out infinite;background:#ef4444;border-radius:50%;box-shadow:0 0 0 0 #ef444499;display:inline-block;height:14px;width:14px}@keyframes voice-pulse{0%{box-shadow:0 0 0 0 #ef44448c}70%{box-shadow:0 0 0 14px #ef444400}to{box-shadow:0 0 0 0 #ef444400}}.voice-record-bar .voice-send{background:#16a34a!important;box-shadow:0 3px 10px #16a34a66;font-size:1.25rem!important;height:48px!important;max-width:48px!important;width:48px!important}.voice-record-bar .voice-send:hover:not(:disabled){background:#15803d!important}.voice-record-bar .voice-send:active{transform:scale(.94)}body.dark-mode .voice-record-bar{background:linear-gradient(180deg,#ef44441f,#ef444438);border-top-color:#fca5a566}body.dark-mode .voice-cancel{background:#fffffff2}.voice-waveform{align-items:center;display:flex;flex:1 1;gap:2px;height:28px;min-width:60px;overflow:hidden}.voice-wave-bar{background:#ef4444;border-radius:2px;flex:0 0 3px;transition:height .08s linear;width:3px}body.dark-mode .voice-wave-bar{background:#f87171}.voice-hint{color:#b91c1cbf;font-size:.75rem;margin-right:.25rem;pointer-events:none;-webkit-user-select:none;user-select:none;white-space:nowrap}body.dark-mode .voice-hint{color:#fca5a5d9}.voice-record-bar.cancel-hint{background:linear-gradient(180deg,#ef444459,#ef444480)}.voice-record-bar.cancel-hint .voice-cancel{animation:voice-shake .3s ease-in-out infinite}@keyframes voice-shake{0%,to{transform:translateX(0)}50%{transform:translateX(-3px)}}.voice-record-bar.locked .voice-time:after{content:" 🔒";font-size:.85rem}.image-preview-nav{background:#0000008c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:2rem;height:60px;line-height:1;position:absolute;top:50%;transform:translateY(-50%);width:44px;z-index:1100}.image-preview-nav-prev{left:1rem}.image-preview-nav-next{right:1rem}.image-preview-counter{background:#0000008c;border-radius:12px;bottom:1rem;color:#fff;font-size:.85rem;left:50%;padding:4px 10px;position:absolute;transform:translateX(-50%);z-index:1100}.message-day-separator{display:flex;justify-content:center;margin:.6rem 0 .4rem;pointer-events:none}.message-day-separator span{background:#1f29378c;border-radius:12px;color:#fff;font-size:.78rem;font-weight:500;padding:.2rem .7rem}body.dark-mode .message-day-separator span{background:#ffffff1f;color:#e5e7eb}.scroll-to-bottom-btn{align-items:center;background:#1f2937d9;border:none;border-radius:50%;bottom:5rem;box-shadow:0 6px 14px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:42px;justify-content:center;position:absolute;right:1rem;transition:opacity .18s ease;width:42px;z-index:50}.scroll-to-bottom-btn:hover{background:#1f2937}.scroll-to-bottom-btn .scroll-unread-badge{background:#ef4444;border-radius:9px;color:#fff;font-size:.7rem;font-weight:600;height:18px;line-height:18px;min-width:18px;padding:0 5px;position:absolute;right:-4px;text-align:center;top:-4px}body.dark-mode .scroll-to-bottom-btn{background:#ffffff2e;color:#e5e7eb}.selection-bar{align-items:center;background:#3b82f61f;border-bottom:1px solid #3b82f64d;display:flex;gap:.5rem;padding:.5rem .75rem}.selection-bar-close{background:#0000;border:none;color:#1d4ed8;cursor:pointer;font-size:1.4rem;padding:0 .25rem}.selection-bar-count{color:#1f2937;flex:1 1;font-weight:600}.selection-bar-action{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem}.selection-bar-action:hover{background:#0000000d}.selection-bar-danger{color:#dc2626}body.dark-mode .selection-bar{background:#3b82f626;border-bottom-color:#93c5fd66}body.dark-mode .selection-bar-count{color:#e5e7eb}body.dark-mode .selection-bar-close{color:#93c5fd}body.dark-mode .selection-bar-action:hover{background:#ffffff14}.message.in-selection{cursor:pointer;-webkit-user-select:none;user-select:none}.message.selected{background:#3b82f62e!important}body.dark-mode .message.selected{background:#60a5fa38!important}.message-select-checkbox{align-items:center;background:#fff;border:2px solid #3b82f6;border-radius:50%;color:#3b82f6;display:flex;font-size:.85rem;font-weight:700;height:22px;justify-content:center;left:-28px;position:absolute;top:50%;transform:translateY(-50%);width:22px}.message.selected .message-select-checkbox{background:#3b82f6;color:#fff}body.dark-mode .message-select-checkbox{background:#1f2937}.chat-search-toggle{background:#0000;border:none;border-radius:6px;color:inherit;cursor:pointer;font-size:1.2rem;margin-left:.5rem;padding:.25rem .5rem}.chat-search-toggle:hover{background:#0000000d}body.dark-mode .chat-search-toggle:hover{background:#ffffff14}.chat-search-bar{background:#3b82f60f;border-bottom:1px solid #3b82f633;padding:.4rem .75rem}.chat-search-input{border:1px solid #3b82f666;border-radius:8px;font-size:.95rem;outline:none;padding:.5rem .75rem;width:100%}.chat-search-input:focus{border-color:#3b82f6}body.dark-mode .chat-search-bar{background:#3b82f61f}body.dark-mode .chat-search-input{background:#111827;border-color:#374151;color:#e5e7eb}.pinned-banner{grid-gap:8px;align-items:center;background:#60a5fa1f;border-bottom:1px solid #60a5fa40;box-sizing:border-box;cursor:pointer;display:grid;font-size:.85rem;gap:8px;grid-template-columns:auto minmax(0,1fr) auto;padding:6px 10px;width:100%}.pinned-banner:hover{background:#60a5fa2e}.pinned-banner-icon{font-size:1rem;line-height:1}.pinned-banner-text{color:#1f2937;min-width:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}body.dark-mode .pinned-banner-text{color:#e5e7eb}.pinned-banner-close{background:#0000;border:none;color:#6b7280;cursor:pointer;font-size:1.2rem;line-height:1;margin-left:auto;padding:0 4px}.pinned-banner-close:hover{color:#ef4444}.chat-mute-toggle{background:#0000;border:none;cursor:pointer;font-size:1.1rem;margin-left:4px;padding:4px 8px}.toast-host{align-items:center;bottom:1rem;display:flex;flex-direction:column;gap:.5rem;left:50%;pointer-events:none;position:fixed;transform:translateX(-50%);width:min(90vw,420px);z-index:2000}.toast{animation:toast-in .18s ease-out;background:#1f2937f2;border-radius:10px;box-shadow:0 8px 16px #00000040;color:#f3f4f6;font-size:.9rem;line-height:1.35;max-width:100%;padding:.6rem 1rem;pointer-events:auto;text-align:center;white-space:pre-wrap}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{background:#166534f2;color:#ecfdf5}.toast-error{background:#7f1d1df2;color:#fef2f2}.confirm-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1800}.confirm-modal{background:#fff;border-radius:12px;box-shadow:0 16px 32px #00000040;padding:1rem 1.1rem;width:min(380px,100%)}.confirm-title{color:#1f2937;font-size:1rem;margin:0 0 .4rem}.confirm-message{color:#374151;font-size:.92rem;line-height:1.4;margin:0 0 1rem;white-space:pre-wrap}.confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}.confirm-btn{background:#f3f4f6;border:1px solid #00000026;border-radius:8px;color:#1f2937;cursor:pointer;font-size:.9rem;padding:.5rem 1rem}.confirm-btn:hover{background:#e5e7eb}.confirm-ok{background:#3b82f6;border-color:#3b82f6;color:#fff}.confirm-ok:hover{background:#2563eb}.confirm-danger{background:#dc2626!important;border-color:#dc2626!important;color:#fff!important}.confirm-danger:hover{background:#b91c1c!important}body.dark-mode .confirm-modal{background:#1f2937}body.dark-mode .confirm-title{color:#f3f4f6}body.dark-mode .confirm-message{color:#d1d5db}body.dark-mode .confirm-btn{background:#374151;border-color:#4b5563;color:#e5e7eb}body.dark-mode .confirm-btn:hover{background:#4b5563}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{background:#1a1a1a;height:100%;min-height:100%}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;overflow:hidden}.loading{align-items:center;color:#64748b;display:flex;flex-direction:column;font-size:1.1rem;gap:1rem;height:100vh;justify-content:center;letter-spacing:.02em}.loading:before{animation:loading-spin .75s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;content:"";height:36px;width:36px}@keyframes loading-spin{to{transform:rotate(1turn)}}body.dark-mode .loading{color:#94a3b8}body.dark-mode .loading:before{border-color:#818cf8 #334155 #334155}.app{display:flex;flex-direction:column;height:100dvh;height:var(--app-height,100dvh);min-height:100dvh;min-height:var(--app-height,100dvh);overflow:hidden}body.android-app .app{height:100dvh!important;height:var(--app-height,100dvh)!important;min-height:100dvh!important;min-height:var(--app-height,100dvh)!important;padding-bottom:env(safe-area-inset-bottom,0)}.app-header{align-items:center;background:#667eea;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;flex-shrink:0;gap:.75rem;justify-content:space-between;min-height:56px;padding:1rem 2rem}.app-header h1{flex:1 1;font-size:1.5rem;margin:0}.app-header h1,.user-info{align-items:center;display:flex;gap:.5rem;min-width:0}.user-info{flex-wrap:nowrap}.user-info>span{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.download-apk-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;font-size:.9rem;padding:.5rem .75rem;text-decoration:none;white-space:nowrap}.download-apk-btn:hover{background:#ffffff4d}.update-app-btn{background:#16a34a;border:1px solid #15803d;border-radius:5px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem .75rem;white-space:nowrap}.update-app-btn:hover{background:#15803d}.theme-toggle-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;justify-content:center;min-width:40px;padding:.5rem;transition:background .3s}.theme-toggle-btn:hover{background:#ffffff4d}.sound-toggle-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;justify-content:center;min-width:40px;padding:.5rem;transition:background .3s}.sound-toggle-btn:hover{background:#ffffff4d}.settings-gear-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;justify-content:center;line-height:1;min-width:40px;padding:.5rem .6rem;transition:background .3s}.settings-gear-btn:hover{background:#ffffff4d}.settings-modal-overlay{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:10000}.settings-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;color:#1e293b;max-width:400px;overflow:hidden;width:100%}body.dark-mode .settings-modal{background:#1e293b;color:#e2e8f0}.settings-modal-header{align-items:center;border-bottom:1px solid #00000014;display:flex;gap:.75rem;justify-content:space-between;padding:1rem 1rem .75rem}body.dark-mode .settings-modal-header{border-bottom-color:#ffffff1a}.settings-modal-header h2{font-size:1.15rem;font-weight:600;margin:0}.settings-modal-close{background:#0000;border:none;color:inherit;cursor:pointer;font-size:1.75rem;line-height:1;opacity:.75;padding:0 .25rem}.settings-modal-close:hover{opacity:1}.settings-modal-body{padding:1rem 1rem 1.25rem}.settings-modal-section-label{color:#475569;font-size:.9rem;font-weight:600;margin:0 0 .35rem}body.dark-mode .settings-modal-section-label{color:#94a3b8}.settings-modal-hint{color:#64748b;font-size:.85rem;line-height:1.45;margin:0 0 1rem}body.dark-mode .settings-modal-hint{color:#94a3b8}.settings-modal-danger-btn{background:#dc26261a;border:1px solid #dc262673;border-radius:8px;color:#b91c1c;cursor:pointer;font-size:.95rem;font-weight:500;padding:.65rem 1rem;transition:background .2s;width:100%}body.dark-mode .settings-modal-danger-btn{background:#dc262633;border-color:#f8717166;color:#fca5a5}.settings-modal-danger-btn:hover:not(:disabled){background:#dc26262e}.settings-modal-danger-btn:disabled{cursor:not-allowed;opacity:.65}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background .3s;white-space:nowrap}.logout-btn:hover{background:#ffffff4d}.call-header-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;line-height:1;padding:.4rem .6rem}.call-header-btn:hover{background:#ffffff4d}.app-content{overflow:hidden}.app-content,.app-content.single-pane,.main-content{display:flex;flex:1 1;min-height:0}.main-content{flex-direction:column;overflow:hidden}.app-content.single-pane .main-content{width:100%}.app-content.single-pane .contacts-container{border-right:none;flex:1 1;width:100%}.app-content.single-pane .main-content,.app-content.single-pane.chat-open .contacts-container{display:none}.app-content.single-pane.chat-open .main-content{display:flex;flex:1 1;min-height:0}body.android-app .app-content{display:flex!important;flex-direction:column;height:100%!important;min-height:0!important;overflow:hidden!important}body.android-app .chat-container,body.android-app .contacts-container,body.android-app .main-content{max-width:100%!important;min-width:0!important;width:100%!important}body.android-app .app-content .main-content,body.android-app .app-content.chat-open .contacts-container{display:none!important}body.android-app .app-content.chat-open .main-content{display:flex!important;flex:1 1 auto!important}body.android-app .app-content.chat-open,body.android-app .app-content.chat-open .main-content{background:#0000!important;height:100%!important;min-height:0!important}body.android-app.dark-mode .app-content.chat-open,body.android-app.dark-mode .app-content.chat-open .main-content{background:#1a1a1a!important}@media (max-width:900px){.app-header{padding:.6rem .8rem}.app-header h1{font-size:1.05rem}.settings-gear-btn,.sound-toggle-btn,.theme-toggle-btn{font-size:1rem;min-width:34px;padding:.35rem}.download-apk-btn,.logout-btn{font-size:.75rem;padding:.35rem .5rem}.user-info>span{font-size:.85rem;max-width:80px}}@media (max-width:700px){.app-header{min-height:48px;padding:.45rem .6rem}.app-header h1{font-size:.95rem}.download-apk-btn,.user-info>span{display:none}.logout-btn{font-size:.72rem;padding:.3rem .45rem}.back-btn{align-items:center;background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;height:32px;justify-content:center;width:32px}.back-btn:active{background:#ffffff40}}.no-contact-selected{align-items:center;color:#666;display:flex;font-size:1.2rem;height:100%;justify-content:center}body.dark-mode{background:#1a1a1a;color:#e0e0e0}body.dark-mode,body.dark-mode #root,body.dark-mode .app,body.dark-mode .app-content,body.dark-mode .main-content{background:#1a1a1a!important}body.dark-mode .app{background:#1a1a1a}body.dark-mode .app-header{background:linear-gradient(135deg,#2d3748,#1e293b 55%,#312e81);box-shadow:0 4px 16px #00000073}body.dark-mode .app-content{background:#1a1a1a}body.dark-mode .no-contact-selected{color:#a0a0a0}body.dark-mode .update-app-btn{background:#22c55e;border-color:#16a34a}
/*# sourceMappingURL=main.39b1d648.css.map*/