@import url(https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&display=swap);.phx-auth-page{background:#121212;bottom:0;color:#e0e0e0;font-family:Inter,sans-serif;justify-content:center;left:0;overflow-y:auto;padding:calc(24px + env(safe-area-inset-top, 0px)) 16px calc(24px + env(safe-area-inset-bottom, 0px));position:fixed;right:0;top:0}.phx-auth-page,.phx-logo-section{align-items:center;display:flex;flex-direction:column}.phx-logo-section{animation:phxFadeUp .6s ease .1s forwards;margin-bottom:28px;opacity:0;transform:translateY(12px)}.phx-logo-title{color:#fff;font-size:22px;font-weight:800;letter-spacing:10px;margin:0 0 14px;text-indent:10px}.phx-logo-img{height:120px;object-fit:contain;width:120px}.phx-logo-subtitle{color:#ffffff59;font-size:13px;font-weight:400;letter-spacing:.2px;margin:12px 0 0}.phx-form-wrap{animation:phxFadeUp .6s ease .3s forwards;gap:14px;max-width:90vw;opacity:0;transform:translateY(12px);width:340px}.phx-form-wrap,.phx-input-group{display:flex;flex-direction:column}.phx-input-group{gap:5px}.phx-label{color:#ffffff73;font-size:12px;font-weight:500;letter-spacing:.3px;padding-left:2px}.phx-input-wrap{align-items:center;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:16px;display:flex;position:relative;transition:border-color .25s ease,background .25s ease,box-shadow .25s ease}.phx-input-wrap:focus-within{background:#2c6bed05;border-color:#2c6bed80;box-shadow:0 0 0 4px #2c6bed14}.phx-input-icon{color:#fff3;left:14px;pointer-events:none;position:absolute;transition:color .25s ease}.phx-input-wrap:focus-within .phx-input-icon{color:#2c6bed80}.phx-input{background:#0000;border:none;box-sizing:border-box;color:#e0e0e0;font-family:Inter,sans-serif;font-size:14px;font-weight:400;outline:none;padding:12px 16px 12px 44px;width:100%}.phx-input::placeholder{color:#ffffff26;font-weight:300}.phx-input--has-toggle{padding-right:44px}.phx-eye-btn{align-items:center;background:none;border:none;color:#ffffff2e;cursor:pointer;display:flex;padding:4px;position:absolute;right:12px;transition:color .2s}.phx-eye-btn:hover{color:#ffffff80}.phx-checkbox-row{align-items:center;cursor:pointer;display:flex;gap:10px;margin-top:2px;-webkit-user-select:none;user-select:none}.phx-checkbox{align-items:center;background:#ffffff08;border:1.5px solid #ffffff26;border-radius:5px;display:flex;flex-shrink:0;height:18px;justify-content:center;transition:all .2s ease;width:18px}.phx-checkbox--checked{background:linear-gradient(135deg,var(--accent),var(--accent));border-color:#0000}.phx-checkbox-text{color:#ffffff73;font-size:13px;font-weight:400}.phx-error{align-items:center;animation:phxShake .35s ease-out;background:#dc26260f;border:1px solid #dc26261f;border-radius:10px;color:#f87171;display:flex;font-size:12px;font-weight:500;gap:8px;padding:10px 14px}@keyframes phxShake{0%{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:translateX(0)}}.phx-submit{background:linear-gradient(135deg,var(--accent),var(--accent));border:none;border-radius:12px;box-shadow:0 4px 20px #ff980026;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:14px;font-weight:600;letter-spacing:.3px;margin-top:4px;padding:12px;transition:all .25s ease;width:100%}.phx-submit:hover:not(:disabled){box-shadow:0 8px 32px #ff980040;transform:translateY(-1px)}.phx-submit:active:not(:disabled){transform:translateY(0)}.phx-submit:disabled{cursor:not-allowed;opacity:.3;transform:none}.phx-spinner{height:18px;width:18px}.phx-switch{align-items:center;border-top:1px solid #ffffff0f;display:flex;gap:8px;justify-content:center;margin-top:16px;padding-top:14px}.phx-switch-text{color:#ffffff40;font-size:12px}.phx-switch-btn{background:none;border:none;color:#fff6;cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:500;padding:0;transition:color .2s}.phx-switch-btn:hover{color:var(--accent)}.phx-footer{align-items:center;color:#ffffff1a;display:flex;font-size:10px;font-weight:400;gap:5px;justify-content:center;letter-spacing:1px;margin-top:14px;text-transform:uppercase}@keyframes phxFadeUp{to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.phx-logo-title{font-size:18px;letter-spacing:7px;text-indent:7px}.phx-logo-img{height:96px;width:96px}.phx-form-wrap{max-width:100vw;width:100%}.phx-input{font-size:15px;padding:11px 14px 11px 40px}.phx-input-icon{height:18px;width:18px}.phx-submit{font-size:15px;padding:13px}}.phx-recovery-box{padding:20px 0;text-align:center}.phx-recovery-text{color:#aaa;font-size:14px;line-height:1.6;margin:0 0 16px}.phx-recovery-code{background:#1a1a1a;border-radius:10px;color:#ff9800;display:block;font-family:Courier New,monospace;font-size:14px;letter-spacing:1px;margin:12px 0;padding:14px 16px;-webkit-user-select:all;user-select:all;word-break:break-all}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;min-width:320px;padding-bottom:env(safe-area-inset-bottom,0);padding-top:env(safe-area-inset-top,0);width:320px}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;padding:16px}.sidebar-header,.user-info{align-items:center;display:flex}.user-info{border-radius:10px;cursor:pointer;gap:10px;margin:-4px -8px;padding:4px 8px;position:relative;transition:background .15s}.user-info:hover{background:#ffffff0a}.chevron-icon{color:#ffffff40;flex-shrink:0;transition:transform .2s}.user-info:hover .chevron-icon{color:#ffffff80}.user-text{display:flex;flex-direction:column}.user-handle{color:var(--text-muted);font-size:11px}.avatar{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:36px;justify-content:center;overflow:hidden;width:36px}.avatar-img{height:100%;object-fit:cover;width:100%}.avatar.small{font-size:18px;height:40px;width:40px}.username{color:var(--text-primary);font-size:14px;font-weight:600}.icon-btn{align-items:center;background:#ffffff14;border:none;border-radius:50%;color:#ffffff80;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .2s;width:36px}.icon-btn:hover{background:#ffffff24;color:#f6f6f6}.dropdown-menu{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:10px;box-shadow:0 8px 24px #00000080;left:0;min-width:180px;padding:4px;position:absolute;top:calc(100% + 4px);z-index:100}.dropdown-item{align-items:center;background:none;border:none;border-radius:6px;color:#ffffff80;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;gap:10px;padding:10px 14px;text-align:left;transition:all .15s;width:100%}.dropdown-item svg{flex-shrink:0}.dropdown-divider{background:#ffffff0f;height:1px;margin:4px 8px}.menu-backdrop{inset:0;position:fixed;z-index:99}.dropdown-item:hover{background:#ffffff0f;color:var(--text-primary)}.logout-item:hover{background:#dc262614;color:#f87171}.sidebar-search{border-bottom:1px solid #ffffff0f;display:flex;gap:8px;padding:12px 16px;position:relative}.sidebar-search input{background:#ffffff0f;border:none;border-radius:24px;color:#f6f6f6;flex:1 1;font-family:Inter,sans-serif;font-size:14px;outline:none;padding:10px 36px 10px 16px;transition:background .2s}.sidebar-search input:focus{background:#ffffff1a}.sidebar-search input::placeholder{color:#ffffff26}.sidebar-search input:focus{border-color:#ff980059}.add-btn{font-size:20px;font-weight:700}.add-contact-form{border-bottom:1px solid #ffffff0f;display:flex;gap:8px;padding:8px 16px}.add-contact-form input{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;color:#e0e0e0;flex:1 1;font-family:Inter,sans-serif;font-size:13px;outline:none;padding:8px 12px}.add-contact-form input::placeholder{color:#ffffff26}.add-contact-form input:focus{border-color:#ff980059}.add-contact-form button{background:linear-gradient(135deg,var(--accent),var(--accent));border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:600;padding:8px 16px}.contact-list{flex:1 1;overflow-y:auto}.contact-item{align-items:center;border-bottom:1px solid #ffffff08;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:background .15s}.contact-item:hover{background:#ffffff08}.contact-item.active{background:#ff98000f;border-left:3px solid var(--accent)}.contact-info{flex:1 1;min-width:0}.contact-name{color:var(--text-primary);display:block;font-size:14px;font-weight:500}.contact-last{color:#ffffff40;display:block;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-dot{background:#ffffff1a;border-radius:50%;flex-shrink:0;height:8px;width:8px}.status-dot.online{background:#22c55e}.no-contacts{color:#fff3;font-size:13px;padding:24px;text-align:center}.search-results{border-bottom:1px solid #ffffff0f;max-height:240px;overflow-y:auto}.search-results-title{color:#ffffff40;font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 16px 4px;text-transform:uppercase}.search-icon{align-items:center;color:#ffffff4d;display:flex;pointer-events:none;position:absolute;right:28px;top:50%;transform:translateY(-50%)}.phx-spinner-sm{animation:phxSpinSm .5s linear infinite;border:2px solid #ffffff26;border-radius:50%;border-top-color:#ffffff80;display:inline-block;height:14px;width:14px}@keyframes phxSpinSm{to{transform:rotate(1turn)}}.add-label{color:var(--accent);font-size:11px;font-weight:600;white-space:nowrap}.sidebar-tabs{border-bottom:1px solid #ffffff0f;display:flex;padding:0 16px}.sidebar-tab{background:none;border:none;border-bottom:2px solid #0000;color:#ffffff59;cursor:pointer;flex:1 1;font-family:Inter,sans-serif;font-size:13px;font-weight:500;padding:10px 0;transition:all .2s}.sidebar-tab:hover{color:#fff9}.sidebar-tab.active{border-bottom-color:var(--accent);color:var(--accent)}.contact-letter{color:#fff3;font-size:11px;font-weight:700;letter-spacing:1px;padding:8px 16px 4px;text-transform:uppercase;-webkit-user-select:none;user-select:none}.contact-directory-item{gap:10px}.contact-directory-item .contact-info{cursor:pointer}.contact-actions{align-items:center;display:flex;gap:8px}.contact-remove-btn{align-items:center;background:none;border:none;border-radius:4px;color:#ffffff26;cursor:pointer;display:flex;padding:4px;transition:all .15s}.contact-remove-btn:hover{background:#dc262614;color:#f87171}.create-group-btn{align-items:center;background:#ff98000f;border:1px dashed #ff980040;border-radius:10px;color:var(--accent);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;font-weight:500;gap:8px;margin:12px 16px;padding:10px 14px;transition:all .2s;width:calc(100% - 32px)}.create-group-btn:hover{background:#ff98001a;border-color:#ff980066}.create-group-modal{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:20px;box-shadow:0 16px 48px #0009;display:flex;flex-direction:column;left:50%;max-height:80vh;max-width:90vw;position:fixed;top:50%;transform:translate(-50%,-50%);width:360px;z-index:200}.modal-title{color:var(--text-primary);font-size:18px;font-weight:700;padding:24px 24px 12px}.modal-input{background:#ffffff14;border:none;border-radius:24px;color:#f6f6f6;font-family:Inter,sans-serif;font-size:14px;margin:0 20px;outline:none;padding:12px 18px}.modal-input:focus{border-color:#ff980066}.modal-input::placeholder{color:#fff3}.modal-section-title{color:#ffffff4d;font-size:11px;font-weight:600;letter-spacing:.5px;padding:16px 20px 8px;text-transform:uppercase}.modal-members-list{flex:1 1;max-height:300px;overflow-y:auto;padding:0 8px}.modal-member-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:8px 12px;transition:background .15s}.modal-member-item:hover{background:#ffffff0a}.modal-member-item.selected{background:#ff98000f}.member-check{align-items:center;background:#ffffff08;border:1.5px solid #ffffff26;border-radius:6px;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .15s;width:20px}.member-check.checked{border-color:#0000}.member-check.checked,.modal-create-btn{background:linear-gradient(135deg,var(--accent),var(--accent))}.modal-create-btn{border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:14px;font-weight:600;margin:12px 20px 20px;padding:12px;transition:all .2s}.modal-create-btn:hover:not(:disabled){box-shadow:0 4px 16px #ff980040}.modal-create-btn:disabled{cursor:not-allowed;opacity:.3}.note-to-self-item{background:#ff98000a;border-bottom:1px solid #ff980014}.note-self-avatar{background:#ff98001f!important}.chat-window{display:flex;flex:1 1;flex-direction:column;height:100vh;position:relative}.chat-header{background:var(--bg-primary);border-bottom:1px solid #ffffff14;flex-wrap:wrap;justify-content:space-between;padding:calc(12px + env(safe-area-inset-top, 0px)) 20px 12px}.chat-header,.chat-search-bar{align-items:center;display:flex}.chat-search-bar{gap:8px;padding:8px 0 0;width:100%}.chat-search-bar input{background:#ffffff14;border:none;border-radius:24px;color:#f6f6f6;flex:1 1;font-family:Inter,sans-serif;font-size:14px;outline:none;padding:10px 16px}.chat-search-bar input:focus{border-color:#f59e0b;border-color:var(--accent,#f59e0b)}.search-count{color:#ffffff80;font-size:12px;min-width:36px;text-align:center}.search-nav-btn{align-items:center;background:none;border:none;border-radius:4px;color:#fff9;cursor:pointer;display:flex;padding:4px}.search-nav-btn:hover{color:#fff}.search-nav-btn:disabled{cursor:default;opacity:.3}.search-highlight{background:#f59e0b4d}.search-highlight,.search-highlight-active{border-radius:2px;color:inherit;padding:0 1px}.search-highlight-active{background:#f59e0b99}.chat-header-left{align-items:center;display:flex;gap:12px}.chat-header-contact{-webkit-tap-highlight-color:transparent;align-items:center;background:none;border:none;border-radius:8px;color:inherit;cursor:pointer;display:flex;font-family:inherit;gap:10px;min-height:44px;padding:4px 8px;text-align:left;-webkit-user-select:none;user-select:none}.chat-header-contact:active{background:#ffffff0f}.chat-header-text{display:flex;flex-direction:column}.chat-header-name{font-size:14px}.back-btn{background:none;border:none;color:var(--accent);cursor:pointer;display:none;margin-right:4px;padding:4px}.chat-header-name{color:var(--text-primary);display:block;font-size:15px;font-weight:600}.status-text{color:#ffffff4d;display:block;font-size:12px}.status-text.online{color:#22c55e}.fingerprint-box{background:#ff980014;border:1px solid #ff980033;border-radius:6px;color:#fff9;font-family:monospace;font-size:10px;letter-spacing:.5px;line-height:1.6;margin-top:4px;max-width:320px;padding:6px 10px;-webkit-user-select:all;user-select:all;word-break:break-all}.chat-header-actions{display:flex;gap:8px;position:relative}.timer-menu{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:12px;box-shadow:0 8px 24px #00000080;min-width:180px;padding:6px;position:absolute;right:0;top:40px;z-index:100}.timer-menu-title{color:#ffffff4d;font-size:11px;font-weight:600;letter-spacing:.5px;padding:6px 12px 4px;text-transform:uppercase}.timer-menu-item{background:none;border:none;border-radius:6px;color:#fff9;cursor:pointer;display:block;font-family:Inter,sans-serif;font-size:13px;padding:8px 12px;text-align:left;transition:all .15s;width:100%}.timer-menu-item:hover{background:#ffffff0f;color:var(--text-primary)}.timer-menu-item.active{color:var(--accent);font-weight:600}.chat-messages{background:var(--bg-chat);display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:20px}.system-message{display:flex;justify-content:center;margin:4px 0;padding:6px 0}.system-message-text{background:#ffffff0d;border-radius:10px;color:#ffffff73;font-size:12px;line-height:1.4;padding:4px 14px;text-align:center}.message{align-self:flex-start;display:flex;flex-direction:column;max-width:65%}.message.own{align-self:flex-end}.message-bubble{background:#2c2c2e;border-radius:18px;color:#f6f6f6;font-size:14px;line-height:1.5;padding:10px 14px;position:relative;word-break:break-word}.message.own .message-bubble{background:var(--accent);border-bottom-left-radius:18px;border-bottom-right-radius:4px;border-top-left-radius:18px;border-top-right-radius:18px;color:#fff}.message:not(.own) .message-bubble{border-bottom-left-radius:4px;border-bottom-right-radius:18px;border-top-left-radius:18px;border-top-right-radius:18px}.message-text{white-space:pre-wrap}.message-link{color:#fff;text-decoration:underline;text-underline-offset:2px;word-break:break-all}.message.own .message-link{color:#fff}.link-preview-card{background:#0003;border-radius:10px;color:inherit;display:flex;flex-direction:column;margin-top:8px;max-width:280px;overflow:hidden;text-decoration:none}.link-preview-img{max-height:150px;object-fit:cover;width:100%}.link-preview-text{display:flex;flex-direction:column;gap:2px;padding:8px 10px}.link-preview-title{color:#fff;font-size:13px;font-weight:600}.link-preview-desc,.link-preview-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.link-preview-desc{color:#ffffff80;font-size:11px}.message-timer{color:#f59e0b;display:inline-block;font-size:11px;margin-left:8px;opacity:.8}.message.own .message-timer{color:#ffffffb3}.message-timer-icon{align-items:center;color:#f59e0b;color:var(--accent,#f59e0b);display:inline-flex;margin-left:6px;opacity:.5}.message-timer-countdown{color:#f59e0b;display:inline-block;font-size:10px;font-weight:600;margin-left:8px}.message.own .message-timer-countdown{color:#ffffffb3}.message.fading{filter:blur(4px);opacity:0;transform:scale(.96) translateY(-4px);transition:all .8s ease-out}.message-time{align-items:center;color:#fff3;display:flex;font-size:11px;gap:4px;margin-top:2px;padding:0 4px}.message.own .message-time{justify-content:flex-end;text-align:right}.msg-checks{align-items:center;display:inline-flex;margin-left:2px}.message-image-naked{border:none!important;border-radius:14px;box-shadow:none!important;cursor:pointer;display:block;max-height:320px;max-width:260px;object-fit:cover;outline:none!important}.message-image-naked,.message.own .message-image-naked{background-color:initial!important;margin:2px 0}.message-video-naked{cursor:pointer;position:relative}.video-play-overlay{align-items:center;background:#0000004d;border-radius:14px;display:flex;inset:0;justify-content:center;pointer-events:none;position:absolute}.message-loading{color:#ffffff4d;font-size:12px}.message-file{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;gap:8px;opacity:.85;padding:4px 0;text-decoration:none;transition:opacity .2s}.message-file:hover{opacity:1}.message-file span{word-break:break-all}.chat-input-area{background:var(--bg-primary);border-top:1px solid #ffffff14;padding:12px 20px calc(12px + env(safe-area-inset-bottom, 0px));position:relative}.timer-badge{background:#ff980014;border:1px solid #ff980026;border-radius:6px;color:var(--accent);font-size:12px;margin-bottom:8px;padding:4px 10px;text-align:center}.chat-input-row{align-items:flex-end;display:flex;gap:8px}.attach-btn,.send-btn{flex-shrink:0}.send-btn{align-items:center;background:var(--accent);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:42px;justify-content:center;transition:opacity .2s;width:42px}.send-btn:hover{opacity:.9}.send-btn:disabled{cursor:not-allowed;opacity:.4}.chat-empty{color:#ffffff4d;flex:1 1;flex-direction:column}.chat-empty,.empty-icon{align-items:center;display:flex;justify-content:center}.empty-icon{background:#ff980014;border:1px solid #ff980026;border-radius:18px;height:72px;margin-bottom:16px;width:72px}.chat-empty h2{color:#ffffff80;font-size:18px;font-weight:600;margin:0 0 4px}.chat-empty p{color:#ffffff40;font-size:14px}.chat-page{background:var(--bg-primary);overflow:hidden}.chat-main,.chat-page{display:flex;height:100vh;height:100dvh}.chat-main{flex:1 1;flex-direction:column;min-width:0}.phx-spinner{animation:phxSpin .5s linear infinite;border:2px solid #fff3;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}@keyframes phxSpin{to{transform:rotate(1turn)}}.context-menu{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:10px;box-shadow:0 8px 24px #00000080;min-width:160px;padding:4px;position:fixed;z-index:150}.context-menu--enhanced{min-width:200px}.context-menu-item{align-items:center;background:none;border:none;border-radius:6px;color:#fff9;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;gap:10px;padding:10px 14px;text-align:left;transition:all .15s;width:100%}.context-menu-item:hover{background:#ffffff0f;color:var(--text-primary)}.context-menu-item.danger{color:#f87171}.context-menu-item.danger:hover{background:#dc26261a}.context-menu-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.reply-quote{cursor:pointer;display:flex;gap:6px;margin-bottom:6px;padding:4px 0}.reply-quote-bar{background:var(--accent);border-radius:1px;flex-shrink:0;width:2px}.reply-quote-text{color:#ffffff73;font-size:12px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message.own .reply-quote-text{color:#ffffffa6}.reply-preview-bar{align-items:center;background:#ff98000f;border:1px solid #ff980026;border-radius:8px;display:flex;gap:8px;margin-bottom:8px;padding:8px 12px}.reply-preview-accent{background:var(--accent);border-radius:1px;flex-shrink:0;height:28px;width:2px}.reply-preview-content{flex:1 1;min-width:0}.reply-preview-label{color:var(--accent);font-size:11px;font-weight:600;margin-bottom:1px}.reply-preview-text{color:#fff6;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reply-preview-close{align-items:center;background:none;border:none;color:#ffffff4d;cursor:pointer;display:flex;justify-content:center;padding:4px}.reply-preview-close:hover{color:#fff9}.edit-mode-bar{align-items:center;background:#3b82f60f;border:1px solid #3b82f626;border-radius:8px;display:flex;gap:8px;margin-bottom:8px;padding:8px 12px}.edit-mode-accent{background:#3b82f6;border-radius:1px;flex-shrink:0;height:20px;width:2px}.edit-mode-content{flex:1 1}.edit-mode-label{color:#3b82f6;font-size:12px;font-weight:500}.edited-label{color:#fff3;font-size:10px;font-style:italic;margin-left:4px}.message.own .edited-label{color:#ffffff80}.message{position:relative}.message.selected{background:#ff98000f;border-radius:12px}.msg-checkbox{align-items:center;background:#0000;border:2px solid #fff3;border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;height:22px;justify-content:center;left:-32px;position:absolute;top:50%;transform:translateY(-50%);transition:all .15s;width:22px}.msg-checkbox.checked{background:var(--accent);border-color:var(--accent)}.multiselect-bar{align-items:center;background:var(--bg-primary);border-bottom:1px solid #ffffff14;display:flex;gap:12px;padding:12px 20px}.multiselect-btn{align-items:center;background:none;border:none;color:#fff9;cursor:pointer;display:flex;padding:4px}.multiselect-count{color:var(--text-primary);flex:1 1;font-size:14px;font-weight:600}.multiselect-actions{display:flex;gap:8px}.multiselect-action-btn{align-items:center;background:none;border:none;border-radius:6px;color:#fff9;cursor:pointer;display:flex;padding:6px;transition:all .15s}.multiselect-action-btn:hover{background:#ffffff0f;color:var(--text-primary)}.multiselect-action-btn.danger{color:#f87171}.multiselect-action-btn.danger:hover{background:#dc26261a}.forward-modal{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:20px;box-shadow:0 16px 48px #0009;display:flex;flex-direction:column;left:50%;max-height:80vh;max-width:90vw;position:fixed;top:50%;transform:translate(-50%,-50%);width:360px;z-index:200}.forward-search{background:#ffffff14;border:none;border-radius:24px;color:#f6f6f6;font-family:Inter,sans-serif;font-size:14px;margin:12px 16px 8px;outline:none;padding:12px 18px}.forward-modal-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;justify-content:space-between;padding:16px 20px}.forward-modal-title{color:var(--text-primary);font-size:16px;font-weight:600}.forward-search:focus{border-color:#ff980059}.forward-search::placeholder{color:#ffffff26}.forward-list{flex:1 1;overflow-y:auto;padding:4px 8px 12px}.forward-empty{color:#ffffff40;font-size:14px;padding:24px;text-align:center}.forward-item{align-items:center;background:none;border:none;border-radius:8px;color:#ffffffb3;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;gap:10px;padding:10px 12px;transition:all .15s;width:100%}.forward-item:hover{background:#ffffff0f;color:var(--text-primary)}.forward-item:disabled{cursor:not-allowed;opacity:.5}.forward-item-name{flex:1 1;text-align:left}@media (max-width:768px){.chat-page{position:relative}.back-btn{display:flex}.sidebar{inset:0;min-width:100%;position:absolute;transition:transform .25s ease;width:100%;z-index:10}.sidebar--hidden,.sidebar--hidden-mobile{transform:translateX(-100%)}.chat-main,.chat-window{width:100%}.chat-messages{padding:12px}.message{max-width:85%}.message-image{max-height:220px;max-width:220px}.chat-input-area{padding:10px 12px calc(10px + env(safe-area-inset-bottom, 0px))}.chat-input-row textarea{font-size:16px}.chat-empty{padding:24px}.chat-header{padding:calc(10px + env(safe-area-inset-top, 0px)) 12px 10px}.chat-header-actions{gap:4px}.icon-btn{height:36px;width:36px}.context-menu--enhanced{box-shadow:0 -4px 24px #00000080;left:50%!important;top:auto!important;transform:translateX(-50%)}.context-menu--enhanced,.forward-modal{border-radius:16px 16px 0 0;bottom:0;max-width:100%;width:100%}.forward-modal{left:0;max-height:70vh;top:auto;transform:none}.msg-checkbox{left:-28px}.chat-messages{padding-left:36px}.group-info-fullscreen,.group-info-panel{width:100%}}@media (max-width:480px){.send-btn{padding:10px 12px}.message-bubble{font-size:15px}.header-dropdown-menu,.timer-menu{border-radius:16px 16px 0 0!important;bottom:0!important;box-shadow:0 -4px 24px #00000080!important;left:0!important;max-width:100%!important;padding:12px 8px calc(12px + env(safe-area-inset-bottom, 0px))!important;position:fixed!important;right:0!important;top:auto!important;width:100%!important}}.message-sender{color:var(--accent);display:block;font-size:11px;font-weight:600;margin-bottom:2px}.group-avatar{align-items:center;background:linear-gradient(135deg,#2d2d3a,#1e1e28)!important;display:flex;justify-content:center}.group-info-panel{background:var(--bg-panel);border-left:1px solid #ffffff14;box-shadow:-8px 0 24px #0000004d;height:100vh;overflow-y:auto;padding-bottom:calc(20px + env(safe-area-inset-bottom, 0px));padding-top:env(safe-area-inset-top,0);position:fixed;right:0;top:0;width:320px;z-index:150}.group-info-overlay{background:#0006;display:flex;inset:0;justify-content:flex-end;position:fixed;z-index:300}.group-info-fullscreen{animation:slideInRight .2s ease-out;background:var(--bg-panel);display:flex;flex-direction:column;height:100vh;max-width:100%;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,0);padding-top:env(safe-area-inset-top,0);width:380px}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.group-info-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:12px;padding:16px}.group-info-header-title{font-size:16px;font-weight:600}.group-info-hero{align-items:center;border-bottom:1px solid #ffffff14;display:flex;flex-direction:column;padding:24px 16px}.group-info-avatar{align-items:center;background:linear-gradient(135deg,#2d2d3a,#1e1e28);border-radius:50%;display:flex;height:72px;justify-content:center;width:72px}.group-info-name-row{align-items:center;cursor:pointer;display:flex;gap:8px;margin-top:12px}.group-info-name{font-size:18px;font-weight:700}.group-info-edit-hint{color:#fff3;font-size:10px}.group-info-member-count{color:#fff6;font-size:13px;margin-top:4px}.group-info-section{border-bottom:1px solid #ffffff14;padding:8px 0}.group-info-row{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;gap:12px;padding:12px 16px;position:relative;text-align:left;width:100%}.group-info-row:hover{background:#ffffff0a}.group-info-row-text{display:flex;flex-direction:column;gap:2px}.group-info-row-value{color:#fff6;font-size:12px}.group-info-section-header{align-items:center;color:#fff6;display:flex;font-size:13px;justify-content:space-between;padding:8px 16px}.group-info-add-btn{align-items:center;background:none;border:none;color:var(--accent);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;gap:4px}.group-info-member-item{align-items:center;cursor:default;display:flex;gap:10px;padding:8px 16px}.group-info-member-item:hover{background:#ffffff05}.group-info-remove-btn{align-items:center;background:none;border:none;border-radius:4px;cursor:pointer;display:flex;padding:4px}.group-info-remove-btn:hover{background:#f871711a}.group-info-add-member{border-bottom:1px solid #ffffff0a;padding:8px 16px}.group-info-add-member input{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:13px;margin-bottom:8px;outline:none;padding:8px 12px;width:100%}.group-info-add-member input:focus{border-color:var(--accent)}.group-info-danger-btn{align-items:center;background:none;border:none;color:#f87171;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;gap:8px;padding:12px 16px;width:100%}.group-info-danger-btn:hover{background:#f8717114}.group-info-actions-row{border-bottom:1px solid #ffffff14;display:flex;gap:4px;justify-content:center;padding:12px 16px}.group-info-action-btn{align-items:center;background:#ffffff0a;border:none;border-radius:10px;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;font-family:Inter,sans-serif;font-size:10px;gap:4px;min-width:72px;padding:10px 14px;transition:background .15s}.group-info-action-btn:hover{background:#ffffff14}.group-info-action-btn.active{background:#ff98001f;color:var(--accent)}.wallpaper-menu{display:flex;flex-wrap:wrap;gap:8px;padding:8px 12px;position:relative}.wallpaper-menu-item{align-items:center;background:none;border:2px solid #0000;border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;font-family:Inter,sans-serif;font-size:11px;gap:4px;padding:6px;transition:border-color .15s}.wallpaper-menu-item.active{border-color:var(--accent)}.wallpaper-menu-item:hover{border-color:#fff3}.wallpaper-preview{border:1px solid #ffffff1a;border-radius:6px;height:48px;width:48px}.chat-item-meta{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:4px;margin-left:auto}.chat-item-time{color:#ffffff4d;font-size:11px}.unread-badge{align-items:center;background:#ff9800;background:var(--accent,#ff9800);border-radius:10px;color:#fff;display:flex;font-size:11px;font-weight:600;height:18px;justify-content:center;min-width:18px;padding:0 5px}.chat-item-time-only{align-self:center;color:#ffffff4d;flex-shrink:0;font-size:11px;margin-left:auto}.header-dropdown-menu{background:var(--bg-panel);border:1px solid #ffffff1a;border-radius:8px;box-shadow:0 8px 24px #0006;min-width:200px;padding:4px 0;position:absolute;right:8px;top:48px;z-index:160}.header-dropdown-item{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;gap:10px;padding:10px 14px;text-align:left;width:100%}.header-dropdown-item:hover{background:#ffffff0f}.header-dropdown-item.danger{color:#f87171}.owner-badge{background:#ff98001a;border-radius:4px;color:var(--accent);font-size:10px;font-weight:500;margin-left:6px;padding:1px 6px}.group-name-edit{background:#ffffff0f;border:1px solid #ff98004d;border-radius:6px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:14px;font-weight:600;outline:none;padding:2px 8px;width:150px}.media-viewer-backdrop{align-items:center;background:#000;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.media-viewer{background:#0000;display:flex;flex-direction:column;height:100%;position:relative;width:100%}.media-viewer-fab{position:absolute;top:calc(14px + env(safe-area-inset-top, 0px));z-index:5}.media-viewer-fab.left{left:12px}.media-viewer-fab.right{right:12px}.media-viewer-round-btn{align-items:center;background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:background .2s;width:40px}.media-viewer-round-btn:hover{background:#ffffff40}.media-viewer-menu-wrap{flex-shrink:0}.media-viewer-dropdown{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e1e20f2;border:1px solid #ffffff14;border-radius:12px;box-shadow:0 4px 16px #0006;min-width:180px;padding:4px;position:absolute;right:0;top:44px;z-index:10}.media-viewer-dropdown-item{align-items:center;background:none;border:none;border-radius:8px;color:#fffc;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;gap:10px;padding:10px 14px;text-align:left;width:100%}.media-viewer-dropdown-item:hover{background:#ffffff14;color:#fff}.media-viewer-dropdown-item.danger{color:#f87171}.media-viewer-dropdown-item.danger:hover{background:#f871711f}.media-viewer-body{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:200px;overflow:auto}.media-viewer-image,.media-viewer-video{display:block;height:100vh;height:100dvh;object-fit:contain;width:100vw}.media-viewer-text{background:#111115;border-radius:8px;color:#d0d0d5;font-family:Courier New,monospace;font-size:13px;margin:16px;max-height:70vh;overflow:auto;padding:16px;white-space:pre-wrap;width:70vw;word-break:break-all}.media-viewer-file-placeholder{align-items:center;color:#ffffff80;display:flex;flex-direction:column;font-size:14px;gap:16px;padding:40px 60px;word-break:break-all}.media-viewer-dl-btn{border:none;border-radius:8px;color:#111;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .2s}.media-viewer-dl-btn,.media-viewer-dl-btn:hover{background:var(--accent)}.mic-btn{background:#ffffff14!important;padding:0}.mic-btn:hover{background:#ffffff24!important}.recording-indicator{align-items:center;display:flex;gap:8px;padding:0 8px}.recording-dot{animation:recordingPulse 1s ease-in-out infinite;background:#ef4444;border-radius:50%;height:8px;width:8px}@keyframes recordingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.recording-time{font-feature-settings:"tnum";color:#ef4444;font-size:14px;font-variant-numeric:tabular-nums;font-weight:600;min-width:40px}.recording-waveform-mini{align-items:center;display:flex;flex:1 1;gap:2px;height:32px;overflow:hidden}.recording-bar{background:#ef444480;border-radius:1.5px;min-height:4px;transition:height .15s ease;width:3px}.recording-cancel-btn{border-color:#f8717133!important;color:#f87171!important}.recording-send-btn{animation:recordingSendPulse 1.5s ease-in-out infinite}@keyframes recordingSendPulse{0%,to{box-shadow:0 0 0 0 #ff98004d}50%{box-shadow:0 0 0 6px #ff980000}}.voice-message{gap:8px;min-width:180px;padding:4px 0}.voice-message,.voice-play-btn{align-items:center;display:flex}.voice-play-btn{background:#ffffff1f;border:none;border-radius:50%;color:inherit;cursor:pointer;flex-shrink:0;height:32px;justify-content:center;transition:background .2s;width:32px}.message.own .voice-play-btn,.voice-play-btn:hover{background:#fff3}.voice-play-btn.playing{background:#ffffff40}.voice-waveform{align-items:center;display:flex;flex:1 1;gap:1.5px;height:28px;overflow:hidden}.voice-bar{background:#ffffff40;border-radius:1.25px;min-height:3px;transition:background .3s;width:2.5px}.voice-bar.active{animation:voiceBarPulse .6s ease-in-out infinite alternate;background:#ffffff80}@keyframes voiceBarPulse{0%{opacity:.3}to{opacity:1}}.voice-duration{font-feature-settings:"tnum";color:#ffffff80;font-size:11px;font-variant-numeric:tabular-nums;min-width:32px;text-align:right;white-space:nowrap}.textarea-wrapper{align-items:flex-end;display:flex;flex:1 1;position:relative}.textarea-wrapper textarea{background:#ffffff14;border:none;border-radius:24px;color:#f6f6f6;flex:1 1;font-family:Inter,sans-serif;font-size:14px;line-height:1.4;max-height:120px;outline:none;padding:11px 40px 11px 18px;resize:none;transition:background .2s}.textarea-wrapper textarea:focus{background:#ffffff1f;border-color:#ff980059}.textarea-wrapper textarea::placeholder{color:#ffffff26}.textarea-emoji-btn{align-items:center;background:none;border:none;border-radius:6px;bottom:6px;color:#ffffff4d;cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;position:absolute;right:6px;transition:all .15s;width:32px}.textarea-emoji-btn:hover{background:#ffffff0f;color:#fff9}.textarea-emoji-btn.active{background:#ff98001f;color:var(--accent)}.emoji-picker{background:var(--bg-panel);border:1px solid #ffffff14;border-radius:12px 12px 0 0;bottom:100%;box-shadow:0 -4px 24px #0006;left:0;margin-bottom:4px;max-height:280px;overflow-y:auto;padding:8px;position:absolute;right:0;z-index:100}.emoji-categories{display:flex;flex-direction:column;gap:8px}.emoji-category-title{color:#ffffff4d;font-size:11px;font-weight:600;letter-spacing:.5px;padding:2px 4px;text-transform:uppercase}.emoji-grid{display:flex;flex-wrap:wrap;gap:2px}.emoji-item{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:20px;height:34px;justify-content:center;line-height:1;padding:0;transition:background .1s;width:34px}.emoji-item:hover{background:#ffffff14}.emoji-item:active{background:#ff980026;transform:scale(1.2)}.phx-fingerprint-modal{width:90vw}.phx-fingerprint-code{font-size:13px}.phx-fingerprint-divider{margin:11px 0}.phx-fingerprint-verified svg{flex-shrink:0}.chat-security-btn{align-items:center;background:#0000;border:none;border-radius:50%;color:#888;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .15s;width:28px}.chat-security-btn:hover{background:#ffffff14;color:#fff}.contact-info-overlay{animation:fadeIn .15s ease-out;background:#0006;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:9999}.contact-info-sheet{animation:slideInRight .2s ease-out;background:var(--bg-panel);display:flex;flex-direction:column;height:100%;max-width:85%;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,0);padding-top:env(safe-area-inset-top,0);position:relative;width:380px}.contact-info-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:12px;padding:12px 16px}.contact-info-header-title{font-size:16px;font-weight:600}.contact-info-hero{align-items:center;border-bottom:1px solid #ffffff14;display:flex;flex-direction:column;padding:28px 16px 20px}.large-contact-avatar{background:var(--accent);border-radius:50%;font-size:32px;font-weight:700;height:80px;margin-bottom:12px;width:80px}.contact-info-name-row{align-items:center;display:flex;gap:8px}.contact-info-name{color:var(--text-primary);font-size:18px;font-weight:700}.contact-info-status{color:#fff6;font-size:13px;margin-top:4px}.contact-info-actions-row{border-bottom:1px solid #ffffff14;display:flex;gap:4px;justify-content:center;padding:16px}.contact-info-action-btn{align-items:center;background:#ffffff0f;border:1.5px solid #ffffff14;border-radius:14px;color:#fff9;cursor:pointer;display:flex;flex-direction:column;font-family:Inter,sans-serif;font-size:11px;gap:6px;min-width:76px;padding:10px 16px;transition:all .2s}.contact-info-action-btn:hover{background:#ffffff1a;color:#f6f6f6}.contact-info-action-btn.active{background:#2c6bed33;border-color:#2c6bed4d;color:var(--accent)}.contact-info-section{border-bottom:1px solid #ffffff14;padding:4px 0}.contact-info-row{align-items:center;background:none;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:14px;gap:12px;padding:12px 16px;text-align:left;width:100%}.contact-info-row:hover{background:#ffffff0a}.contact-info-row.danger{color:#f87171}.contact-info-row.danger:hover{background:#f871710f}.contact-info-row-text{display:flex;flex-direction:column;gap:2px}.contact-info-row-value{color:#fff6;font-size:12px}.contact-info-timer-list{padding:0 16px 8px}.contact-info-timer-item{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;justify-content:space-between;padding:10px 12px;text-align:left;width:100%}.contact-info-timer-item:hover{background:#ffffff0a}.contact-info-timer-item.active{color:var(--accent)}.contact-info-shield{flex-shrink:0;height:36px;position:relative;width:36px}.contact-info-shield,.contact-info-shield-check{align-items:center;display:flex;justify-content:center}.contact-info-shield-check{background:#1e1e22;border-radius:50%;bottom:2px;height:18px;position:absolute;right:2px;width:18px}.contact-info-delete-menu{padding:4px 16px 8px}.contact-info-delete-item{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-primary);cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:13px;padding:10px 12px;text-align:left;width:100%}.contact-info-delete-item:hover{background:#ffffff0a}.contact-info-delete-item.delete-all{color:#f87171}.contact-info-delete-item.delete-all:hover{background:#f871710f}.contact-info-delete-divider{background:#ffffff0f;height:1px;margin:2px 0}@media (max-width:768px){.contact-info-sheet{max-width:100%}}.chat-security-btn.verified{color:#4caf50}.typing-bubble{align-items:center;display:inline-flex!important;gap:5px;min-height:38px;padding:10px 16px!important}.typing-dot{animation:typingBounce 1.2s ease-in-out infinite;background:#ffffff80;border-radius:50%;height:6px;width:6px}.typing-dot:first-child{animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.phx-modal-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:50000}.phx-modal{animation:slideUp .2s ease-out;background:var(--bg-panel);border:1px solid #ffffff14;border-radius:16px;max-height:85vh;max-width:95vw;overflow-y:auto;padding:24px;width:400px}.phx-fingerprint-modal{max-width:460px}.phx-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.phx-modal-header h3{font-size:18px;font-weight:700;margin:0}.phx-modal-close{background:none;border:none;border-radius:6px;color:#fff6;cursor:pointer;font-size:24px;line-height:1;padding:4px 8px}.phx-modal-close:hover{background:#ffffff0f;color:#fff}.phx-fingerprint-content{padding:0 4px}.phx-fingerprint-desc{color:#aaa;font-size:13px;line-height:1.5;margin:0 0 20px}.phx-fingerprint-rows{background:#1a1a1a;border-radius:12px;margin-bottom:20px;padding:16px}.phx-fingerprint-row{display:flex;flex-direction:column;gap:6px}.phx-fingerprint-label{color:#888;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.phx-fingerprint-code{background:#0d0d0d;border-radius:8px;color:#fff;font-family:Courier New,monospace;font-size:12px;letter-spacing:2px;padding:10px 12px;-webkit-user-select:all;user-select:all;word-break:break-all}.phx-fingerprint-divider{background:#2a2a2a;height:1px;margin:12px 0}.phx-fingerprint-verified{color:#4caf50;font-weight:500;gap:10px}.phx-btn,.phx-fingerprint-verified{align-items:center;display:flex;font-size:14px;justify-content:center}.phx-btn{border:none;border-radius:10px;cursor:pointer;font-family:Inter,sans-serif;font-weight:600;gap:8px;padding:12px;width:100%}.phx-btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent));color:#fff}.phx-btn-primary:hover{box-shadow:0 4px 16px #ff980040}@media (max-width:768px){.phx-modal{border-radius:16px;max-height:80vh;padding:20px;width:92vw}.phx-fingerprint-modal,.phx-modal{max-width:92vw}.phx-fingerprint-code{font-size:11px;letter-spacing:1px}}.cropper-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:300}.cropper-modal{animation:slideUp .2s cubic-bezier(.16,1,.3,1);background:var(--bg-panel);border:1px solid #ffffff0f;border-radius:20px;max-width:95vw;padding:24px;width:380px}.cropper-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.cropper-header h2{color:var(--text-primary);font-family:Sora,sans-serif;font-size:18px;font-weight:700;margin:0}.cropper-close{background:none;border:none;border-radius:6px;color:#ffffff4d;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .15s}.cropper-close:hover{background:#ffffff0f;color:var(--text-primary)}.cropper-canvas-wrap{display:flex;justify-content:center;margin-bottom:16px}.cropper-canvas{border-radius:50%;height:auto;max-width:100%;-webkit-user-select:none;user-select:none}.cropper-controls{margin-bottom:20px}.cropper-zoom-label{align-items:center;color:#fff6;display:flex;gap:10px;padding:0 4px}.cropper-zoom-slider{-webkit-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;flex:1 1;height:4px;outline:none}.cropper-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--accent);border:2px solid var(--bg-panel);border-radius:50%;box-shadow:0 0 6px #ff980066;cursor:pointer;height:16px;width:16px}.cropper-zoom-slider::-moz-range-thumb{background:var(--accent);border:2px solid var(--bg-panel);border-radius:50%;box-shadow:0 0 6px #ff980066;cursor:pointer;height:16px;width:16px}.cropper-actions{display:flex;gap:10px}.cropper-btn{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:Sora,sans-serif;font-size:14px;font-weight:600;padding:11px;transition:all .2s}.cropper-btn-cancel{background:#ffffff0f;color:#fff9}.cropper-btn-cancel:hover{background:#ffffff1a;color:var(--text-primary)}.cropper-btn-confirm{background:linear-gradient(135deg,var(--accent),var(--accent));color:#fff}.cropper-btn-confirm:hover{box-shadow:0 4px 16px #ff980040}.profile-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#0009;display:flex;inset:0;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0);padding-top:env(safe-area-inset-top,0);position:fixed;z-index:200}.profile-panel{animation:slideUp .2s cubic-bezier(.16,1,.3,1);background:var(--bg-panel);border:1px solid #ffffff0f;border-radius:20px;max-width:95vw;padding:28px;width:380px}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.profile-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.profile-header h2{color:var(--text-primary);font-family:Sora,sans-serif;font-size:18px;font-weight:700;margin:0}.close-btn{background:none;border:none;border-radius:6px;color:#ffffff4d;cursor:pointer;font-size:18px;padding:4px 8px;transition:all .15s}.close-btn:hover{background:#ffffff0f;color:var(--text-primary)}.profile-avatar-section{align-items:center;display:flex;flex-direction:column;margin-bottom:24px}.avatar-editable{align-items:center;background:linear-gradient(135deg,var(--accent),var(--accent));border-radius:50%;cursor:pointer;display:flex;height:96px;justify-content:center;overflow:hidden;position:relative;transition:transform .15s;width:96px}.avatar-editable:hover{transform:scale(1.05)}.avatar-image{border-radius:50%;height:100%;object-fit:cover;width:100%}.avatar-letter{color:#fff;font-size:36px;font-weight:700}.avatar-overlay{align-items:center;background:#00000080;border-radius:50%;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s}.avatar-editable:hover .avatar-overlay{opacity:1}.remove-avatar{background:none;border:none;color:#ffffff4d;cursor:pointer;font-family:Sora,sans-serif;font-size:12px;margin-top:10px}.remove-avatar:hover{color:#f87171}.profile-fields{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.profile-field label{color:#fff6;display:block;font-family:Sora,sans-serif;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.profile-field input{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;box-sizing:border-box;color:#e0e0e0;font-family:Sora,sans-serif;font-size:14px;outline:none;padding:11px 14px;transition:all .2s;width:100%}.profile-field input::placeholder{color:#ffffff26}.profile-field input:focus{background:#ff980008;border-color:#ff980059}.profile-field input:disabled{cursor:not-allowed;opacity:.4}.field-hint{color:#ffffff26;display:block;font-size:11px;margin-top:4px}.profile-error{background:#dc26260f;border:1px solid #dc26261f;border-radius:8px;color:#f87171;font-size:13px;margin-bottom:12px;padding:8px 12px}.save-btn{background:linear-gradient(135deg,var(--accent),var(--accent));border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:Sora,sans-serif;font-size:14px;font-weight:600;padding:12px;transition:all .2s;width:100%}.save-btn:hover:not(:disabled){box-shadow:0 4px 16px #ff980040}.save-btn:disabled{cursor:not-allowed;opacity:.4}.settings-overlay{align-items:center;animation:fadeIn .15s ease-out;background:#0009;display:flex;inset:0;justify-content:center;padding-bottom:env(safe-area-inset-bottom,0);padding-top:env(safe-area-inset-top,0);position:fixed;z-index:200}.settings-panel{-webkit-overflow-scrolling:touch;animation:slideUp .2s cubic-bezier(.16,1,.3,1);background:var(--bg-panel);border:1px solid var(--border);border-radius:20px;max-height:85vh;max-width:95vw;overflow-y:auto;padding:24px;width:400px}.settings-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.settings-header h2{color:var(--text-primary);font-family:Inter,sans-serif;font-size:18px;font-weight:700;margin:0}.settings-close{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:18px;padding:4px 8px;transition:all .15s}.settings-close:hover{background:var(--bg-input);color:var(--text-primary)}.settings-section{margin-bottom:24px}.settings-section-title{color:var(--text-muted);font-family:Inter,sans-serif;font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.accent-colors{display:flex;flex-wrap:wrap;gap:10px}.accent-swatch{border:3px solid #0000;border-radius:50%;cursor:pointer;height:36px;position:relative;transition:all .15s;width:36px}.accent-swatch:hover{transform:scale(1.1)}.accent-swatch.active{border-color:var(--text-primary)}.accent-swatch.active:after{align-items:center;color:#fff;content:"✓";display:flex;font-size:14px;font-weight:700;inset:0;justify-content:center;position:absolute;text-shadow:0 1px 2px #0006}.font-size-options{display:flex;gap:8px}.font-size-btn{align-items:center;background:var(--bg-input);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;flex:1 1;justify-content:center;padding:12px 0;text-align:center;transition:all .15s}.font-size-btn:hover{border-color:var(--text-muted)}.font-size-btn.active{background:var(--bg-panel);border-color:var(--accent)}.font-size-label{color:var(--text-secondary);font-family:Inter,sans-serif;font-weight:700;transition:color .15s}.font-size-btn.active .font-size-label{color:var(--accent)}.wallpaper-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.wallpaper-item{align-items:center;aspect-ratio:1;border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;justify-content:center;overflow:hidden;transition:all .15s}.wallpaper-item:hover{border-color:var(--text-muted)}.wallpaper-item.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.wallpaper-label{color:var(--text-muted);font-family:Inter,sans-serif;font-size:10px;font-weight:600}.wallpaper-upload{background:var(--bg-input);border-color:var(--text-muted);border-style:dashed}.wallpaper-upload svg{color:var(--text-muted)}.update-section{display:flex;flex-direction:column;gap:10px}.update-version{color:var(--text-muted);font-size:12px}.update-btn{background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:600;padding:10px 16px;transition:opacity .15s}.update-btn:hover{opacity:.85}.update-btn-install{background:#4caf50}.update-status-text{color:var(--text-secondary);font-size:13px}.update-success{color:#4caf50}.update-error{color:#f44336}.update-available,.update-downloading{display:flex;flex-direction:column;gap:8px}.update-progress-bar{background:var(--bg-input);border-radius:3px;height:6px;overflow:hidden;width:100%}.update-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s ease}@media (max-width:480px){.settings-panel{border-radius:16px;max-height:90vh;padding:18px}.settings-header h2{font-size:16px}.wallpaper-grid{grid-template-columns:repeat(3,1fr)}}.settings-section-hint{color:#888;font-size:12px;margin:0 0 8px}.settings-fingerprint{background:#1a1a1a;border-radius:8px;color:#fff;cursor:pointer;display:block;font-family:Courier New,monospace;font-size:13px;letter-spacing:2px;padding:10px 12px;position:relative;transition:background .15s;-webkit-user-select:all;user-select:all;word-break:break-all}.settings-fingerprint:hover{background:#222}.copied-hint{background:#4caf50;border-radius:4px;color:#fff;font-family:inherit;font-size:11px;letter-spacing:0;padding:2px 8px;position:absolute;right:8px;top:-28px}.call-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000d9;display:flex;inset:0;justify-content:center;position:fixed;z-index:300}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.call-card{align-items:center;display:flex;flex-direction:column;gap:12px}.call-incoming{animation:callPulse 1.5s ease-in-out infinite}@keyframes callPulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.call-avatar{align-items:center;background:linear-gradient(135deg,var(--accent),var(--accent));border-radius:50%;color:#fff;display:flex;font-size:32px;font-weight:700;height:80px;justify-content:center;overflow:hidden;width:80px}.call-avatar img{height:100%;object-fit:cover;width:100%}.call-name{color:#fff;font-size:18px;font-weight:600}.call-type-label{color:#fff6;font-size:13px}.call-actions{display:flex;gap:32px;margin-top:16px}.call-btn{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;height:56px;justify-content:center;transition:transform .15s;width:56px}.call-btn:hover{transform:scale(1.1)}.call-accept{background:#22c55e}.call-reject{background:#dc2626}.call-active{height:100%;justify-content:center;width:100%}.call-video-area{background:#000;height:calc(100% - 140px);position:relative;width:100%}.remote-video{height:100%;object-fit:cover;width:100%}.local-video{border:2px solid #fff3;border-radius:12px;bottom:16px;height:100px;object-fit:cover;position:absolute;right:16px;width:140px}.call-avatar-large{align-items:center;background:linear-gradient(135deg,var(--accent),var(--accent));border-radius:50%;color:#fff;display:flex;font-size:48px;font-weight:700;height:120px;justify-content:center;overflow:hidden;width:120px}.call-avatar-large img{height:100%;object-fit:cover;width:100%}.call-status-text{font-feature-settings:"tnum";color:#ffffff80;font-size:14px;font-variant-numeric:tabular-nums}.call-controls{display:flex;gap:16px;margin-top:20px}.call-ctrl-btn{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;transition:all .15s;width:48px}.call-ctrl-btn:hover{background:#fff3}.call-ctrl-btn.active{background:#ffffff40}.call-hangup-btn{background:#dc2626;height:56px;width:56px}.call-hangup-btn:hover{background:#ef4444}#root,body,html{height:100vh;height:100dvh;margin:0;overflow:hidden;padding:0;width:100%}:root{--accent:#2c6bed;--bg-primary:#121212;--bg-sidebar:#121212;--bg-panel:#1c1c1e;--bg-input:#ffffff14;--bg-bubble:#2c2c2e;--bg-bubble-out:#2c6bed;--border:#ffffff14;--text-primary:#f6f6f6;--text-secondary:#ffffff80;--text-muted:#fff3;--font-size-base:14px;--bg-chat:#0000;--scrollbar:#2a2a3a;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-pill:24px}*{-webkit-tap-highlight-color:transparent;box-sizing:border-box}body{background:#121212;background:var(--bg-primary);color:#f6f6f6;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;font-size:var(--font-size-base);overscroll-behavior:none;touch-action:manipulation}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{border-radius:3px}::-webkit-scrollbar-thumb,::-webkit-scrollbar-thumb:hover{background:#2a2a3a;background:var(--scrollbar)}::selection{background:#2c6bed;background:var(--accent);color:#fff}input::placeholder,textarea::placeholder{color:#fff3;color:var(--text-muted)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.e0db2151.css.map*/