.auth-page{min-height:100%;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 20% 50%,rgba(0,122,255,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(0,122,255,.05) 0%,transparent 50%),var(--bg);padding:20px;padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom));overflow-y:auto}@media (max-width: 768px){.auth-card{padding:28px 20px;border-radius:12px}.auth-logo h1{font-size:24px}}.auth-card{width:100%;max-width:400px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:16px;padding:40px 32px;box-shadow:0 8px 32px #00000014}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-size:28px;font-weight:700;background:linear-gradient(135deg,var(--accent),#5856d6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-logo p{color:var(--text-muted);font-size:14px;margin-top:6px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:500;color:var(--text-muted)}.auth-form input{width:100%}.auth-switch{text-align:center;margin-top:20px;font-size:14px;color:var(--text-muted)}.auth-switch button{color:var(--accent);font-weight:500}.auth-switch button:hover{text-decoration:underline}.auth-card-wide{max-width:420px}.auth-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg);border-radius:10px;padding:4px}.auth-tab{flex:1;padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-muted);transition:background .15s,color .15s}.auth-tab.active{background:var(--bg-secondary);color:var(--text);box-shadow:0 1px 3px #00000014}.qr-login-panel{display:flex;flex-direction:column;align-items:center;gap:16px}.qr-login-hint{font-size:13px;color:var(--text-muted);text-align:center;line-height:1.5}.qr-login-frame{width:260px;height:260px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;border:1px solid var(--border)}.qr-login-image{width:100%;height:100%;border-radius:12px}.qr-login-placeholder{color:var(--text-muted);font-size:14px;text-align:center;padding:20px}.qr-login-status{font-size:13px;color:var(--accent);animation:qr-pulse 1.5s ease-in-out infinite}@keyframes qr-pulse{0%,to{opacity:1}50%{opacity:.5}}.qr-login-refresh{width:100%}.qr-scan-overlay{z-index:10000}.qr-scan-modal{max-width:400px;width:calc(100% - 32px)}.qr-scan-body{display:flex;flex-direction:column;gap:16px}.qr-scanner-view{width:100%;min-height:280px;border-radius:12px;overflow:hidden;background:#000}.qr-scanner-view video{border-radius:12px}.qr-scan-actions{display:flex;gap:12px;justify-content:flex-end}.qr-scan-success{text-align:center;color:#34c759;font-size:15px;font-weight:500;padding:12px 0}.messenger.tg-theme{--bg: #ffffff;--bg-secondary: #ffffff;--bg-tertiary: #f2f2f7;--bg-hover: #f2f2f7;--border: #e5e5ea;--text: #000000;--text-muted: #8e8e93;--accent: #007aff;--accent-hover: #0066d6;--accent-glow: rgba(0, 122, 255, .15);--success: #34c759;--danger: #ff3b30;--msg-out: #effdde;--msg-in: #ffffff;--msg-out-text: #000000;--msg-meta: rgba(0, 0, 0, .45);--nav-bg: rgba(255, 255, 255, .92);--header-bg: rgba(255, 255, 255, .82);--chat-header-bg: rgba(255, 255, 255, .78);--input-bar-bg: rgba(255, 255, 255, .88)}.messenger{display:flex;height:100%;height:100dvh;overflow:hidden;position:relative;background:var(--bg)}.main-panel{width:100%;max-width:420px;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;z-index:10;overflow:hidden;min-height:0}.main-panel-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.tg-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;padding-top:max(10px,env(safe-area-inset-top));background:var(--header-bg);border-bottom:1px solid var(--border);min-height:52px;flex-shrink:0}.tg-header-center{flex:1;text-align:center;display:flex;flex-direction:column;gap:1px}.tg-header-title{font-size:17px;font-weight:600;color:var(--text)}.tg-header-status{font-size:12px;color:var(--accent)}.tg-header-status:empty,.messenger:not(.online) .tg-header-status{color:var(--text-muted)}.tg-header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--accent);border-radius:8px}.tg-header-btn:active{background:var(--bg-hover)}.tg-header-muted{font-size:15px;color:var(--accent);width:auto;padding:0 4px}.tg-header-actions{display:flex;gap:2px}.tg-header-muted:disabled{opacity:.35;pointer-events:none}.tg-chat-item.is-editing{padding-left:8px}.tg-chat-item.is-selected{background:#007aff14}.tg-chat-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;transition:background .15s,border-color .15s}.tg-chat-check.checked{background:var(--accent);border-color:var(--accent)}.chat-edit-toolbar{position:fixed;bottom:0;left:0;right:0;z-index:50;display:flex;align-items:stretch;background:var(--bg);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom,0px)}.chat-edit-action{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;color:var(--accent);font-size:12px;font-weight:500}.chat-edit-action:disabled{opacity:.35;pointer-events:none}.chat-edit-action.danger{color:var(--danger)}.chat-edit-action:active:not(:disabled){background:var(--bg-hover)}.tg-search-wrap{padding:8px 12px;background:var(--header-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.tg-search-icon{flex-shrink:0;color:var(--text-muted)}.tg-search{flex:1;width:100%;background:var(--bg-tertiary);border:none;border-radius:10px;padding:8px 12px;font-size:16px;color:var(--text)}.tg-search::placeholder{color:var(--text-muted)}.panel-list{flex:1;overflow-y:auto;min-height:0}.panel-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:15px}.tg-chat-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg);transition:background .12s}.tg-chat-item:active,.tg-chat-item.active{background:var(--bg-hover)}.tg-chat-item-body{flex:1;min-width:0}.tg-chat-item-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tg-chat-name{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-chat-time{font-size:14px;color:var(--text-muted);flex-shrink:0}.tg-chat-preview{font-size:15px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;flex:1}.tg-badge{background:var(--accent);color:#fff;font-size:13px;font-weight:600;min-width:22px;height:22px;padding:0 6px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.tg-fab:not(.dock-fab){position:absolute;right:16px;bottom:calc(88px + env(safe-area-inset-bottom));width:52px;height:52px;border-radius:50%;background:var(--bg);box-shadow:0 2px 12px #00000026;color:var(--text-muted);display:flex;align-items:center;justify-content:center;z-index:5}.tg-fab:active{transform:scale(.95)}.bottom-dock{position:fixed;bottom:0;left:8px;right:8px;z-index:50;display:flex;align-items:flex-end;pointer-events:none;padding-bottom:env(safe-area-inset-bottom,0px)}.bottom-dock .bottom-nav{pointer-events:auto}.bottom-nav{flex:1;position:relative;display:flex;padding:5px 6px;min-width:0;border-radius:28px;background:#ffffff9e;backdrop-filter:blur(28px) saturate(190%);-webkit-backdrop-filter:blur(28px) saturate(190%);border:1px solid rgba(255,255,255,.85);box-shadow:0 6px 28px #0000001a,inset 0 1px #fffffff2;touch-action:none;user-select:none;-webkit-user-select:none;cursor:grab}.bottom-nav.is-dragging{cursor:grabbing}.bottom-nav-item{flex:1;position:relative;display:flex;align-items:center;justify-content:center;min-height:54px;padding:0;border:none;border-radius:22px;background:transparent;color:var(--text-muted);font-size:10px;font-weight:500;overflow:visible;transition:color .2s ease;z-index:1}.bottom-nav-item:active:not(.active) .bottom-nav-content{transform:scale(.94)}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-bubble{position:absolute;border-radius:22px;overflow:hidden;pointer-events:none;z-index:0;isolation:isolate;will-change:transform,left,width,border-radius;transition:left .32s cubic-bezier(.32,.72,0,1),width .32s cubic-bezier(.32,.72,0,1),top .32s cubic-bezier(.32,.72,0,1),height .32s cubic-bezier(.32,.72,0,1),transform .4s cubic-bezier(.34,1.45,.64,1),border-radius .4s cubic-bezier(.34,1.45,.64,1),filter .3s ease;box-shadow:0 4px 14px #003c8c1a,0 1px 4px #0000000d,inset 0 0 0 1px #ffffff8c}.bottom-nav-bubble.is-dragging{transition:none}.bubble-glass{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(145deg,#ffffffb8,#ffffff2e 38%,#c8dcff1f 62%,#ffffff61);backdrop-filter:blur(14px) saturate(220%) brightness(1.12);-webkit-backdrop-filter:blur(14px) saturate(220%) brightness(1.12)}.bubble-shine{position:absolute;top:6%;left:10%;width:58%;height:42%;border-radius:50%;background:radial-gradient(ellipse 80% 70% at 35% 28%,rgba(255,255,255,.98) 0%,rgba(255,255,255,.45) 28%,rgba(255,255,255,.08) 55%,transparent 72%);pointer-events:none}.bubble-shine-secondary{position:absolute;bottom:10%;right:12%;width:32%;height:24%;border-radius:50%;background:radial-gradient(ellipse at 50% 50%,rgba(255,255,255,.55) 0%,rgba(255,255,255,.12) 45%,transparent 70%);pointer-events:none}.bubble-rim{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,#fffffff2,#b4d2ff73 18%,#ffb4dc40 42%,#a0ffe633 68%,#ffffffb3);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;pointer-events:none;opacity:.85}.bubble-caustic{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse 90% 60% at 75% 85%,rgba(0,140,255,.09) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 20% 75%,rgba(255,100,180,.06) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 60% 30%,rgba(255,255,255,.15) 0%,transparent 60%);mix-blend-mode:soft-light;pointer-events:none}.bottom-nav-bubble.on-chats .bubble-glass{background:linear-gradient(145deg,#ffffffad,#007aff14 40%,#64b4ff24 65%,#ffffff59)}.bottom-nav-bubble.on-chats{box-shadow:0 4px 18px #007aff29,0 1px 4px #0050c814,inset 0 0 0 1px #fff9}.bottom-nav-bubble.on-chats .bubble-rim{background:linear-gradient(135deg,#fffffff2,#64b4ff8c,#007aff59,#b4dcff66,#fffc)}.bottom-nav-bubble.on-chats .bubble-caustic{background:radial-gradient(ellipse 90% 60% at 75% 85%,rgba(0,122,255,.14) 0%,transparent 55%),radial-gradient(ellipse 70% 50% at 20% 75%,rgba(100,200,255,.1) 0%,transparent 50%),radial-gradient(ellipse 50% 40% at 60% 30%,rgba(255,255,255,.2) 0%,transparent 60%)}@keyframes nav-bubble-in{0%{opacity:0;transform:scale(.86)}to{opacity:1;transform:scale(1)}}.bottom-nav-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px 4px;transition:transform .15s ease}.bottom-nav-item svg{width:26px;height:26px;opacity:.55}.bottom-nav-item.active svg{opacity:1}.bottom-nav-badge{position:absolute;top:-4px;left:calc(50% + 4px);background:var(--danger);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;padding:0 5px;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #ff3b3066;z-index:2;border:2px solid rgba(255,255,255,.9)}.tg-fab.dock-fab{position:static;flex-shrink:0;width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff9e;backdrop-filter:blur(28px) saturate(190%);-webkit-backdrop-filter:blur(28px) saturate(190%);border:1px solid rgba(255,255,255,.85);box-shadow:0 6px 28px #0000001a,inset 0 1px #fffffff2;color:var(--text-muted)}.settings-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.settings-panel-scroll{flex:1;overflow-y:auto}.settings-profile{display:flex;align-items:center;gap:16px;width:100%;padding:20px 16px;text-align:left;border-bottom:1px solid var(--border)}.settings-name{font-size:20px;font-weight:600}.settings-sub{font-size:15px;color:var(--text-muted);margin-top:2px}.settings-group{margin-top:24px;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;font-size:16px;border-bottom:1px solid var(--border);width:100%;text-align:left}.settings-row:last-child{border-bottom:none}.settings-btn{color:var(--text)}.settings-value,.settings-chevron{color:var(--text-muted)}.status-online{color:var(--accent)}.status-offline{color:var(--danger)}.settings-logout{flex-shrink:0;display:block;width:calc(100% - 32px);margin:12px 16px 16px;padding:14px;text-align:center;color:var(--danger);font-size:16px;font-weight:500;border-radius:12px;background:var(--bg-tertiary)}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:10px;padding:10px 16px;font-size:16px;font-weight:500}.confirm-modal{max-width:340px}.confirm-modal .modal-body p{margin:0;font-size:16px;color:var(--text-muted)}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-tertiary);min-width:0;min-height:0;overflow:hidden}.chat-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;will-change:transform}.chat-body.is-animating{transition:transform .22s cubic-bezier(.32,.72,0,1)}.chat-body.is-swiping:not(.is-animating){transition:none;box-shadow:-4px 0 16px #0000001a}.chat-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.desktop-only,.desktop-side-nav{display:none}.tg-chat-header{background:var(--chat-header-bg);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:none;padding:8px 12px;padding-top:max(8px,env(safe-area-inset-top,0px));display:flex;align-items:center;gap:10px;flex-shrink:0;z-index:10}.chat-header-info{flex:1;min-width:0}.chat-header-info h3{font-size:16px;font-weight:600}.chat-header-info p{font-size:13px;color:var(--text-muted)}.back-btn{display:none;width:36px;height:36px;font-size:28px;line-height:1;color:var(--accent);align-items:center;justify-content:center;flex-shrink:0}.tg-messages{flex:1;overflow-y:auto;padding:8px 10px 12px;display:flex;flex-direction:column;gap:2px;min-height:0;overscroll-behavior:contain}.msg-date-sep{display:flex;justify-content:center;margin:10px 0 6px;pointer-events:none}.msg-date-sep span{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500;color:#fff;background:#00000038;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.message{max-width:82%;display:flex;flex-direction:column;margin-bottom:2px}.message.own{align-self:flex-end}.message.other{align-self:flex-start}.message-sender{font-size:13px;color:var(--accent);margin-bottom:2px;font-weight:600;padding-left:12px}.message-bubble{position:relative;padding:6px 10px 5px;border-radius:18px;font-size:16px;line-height:1.35;word-break:break-word;box-shadow:0 1px 1px #0000000f}.message.own .message-bubble{background:var(--msg-out);color:var(--msg-out-text);border-bottom-right-radius:4px}.message.own .message-bubble.image-only{background:transparent;box-shadow:none;padding:0}.message.other .message-bubble{background:var(--msg-in);color:var(--text);border-bottom-left-radius:4px}.message.other .message-bubble.image-only{background:transparent;box-shadow:none;padding:0}.message-bubble.has-image{overflow:hidden}.message-bubble.image-only{padding:0}.message-bubble.has-image:not(.image-only){padding-top:4px}.message-bubble.has-image:not(.image-only) .message-image{display:block;margin:0 -10px 4px;max-width:calc(100% + 20px);width:calc(100% + 20px);border-radius:14px 14px 4px 4px}.message-text{display:inline;white-space:pre-wrap}.message-meta{display:inline-flex;align-items:center;gap:3px;float:right;margin:4px 0 -2px 8px;vertical-align:bottom;font-size:11px;line-height:1;color:var(--msg-meta);-webkit-user-select:none;user-select:none}.message-meta time{font-variant-numeric:tabular-nums}.message-edited{font-size:10px;opacity:.75}.message-checks{display:inline-flex;color:#53a6e8;margin-left:1px}.message-bubble.has-meta-overlay{position:relative}.message-bubble.has-meta-overlay .message-meta{position:absolute;right:8px;bottom:6px;float:none;margin:0;padding:2px 6px;border-radius:10px;background:#00000061;color:#fffffff2}.message-bubble.has-meta-overlay .message-checks{color:#7ec8ff}.message-time{display:none}.message-image{display:block;max-width:min(280px,78vw);width:100%;height:auto;border-radius:18px}.message.own .message-bubble.image-only .message-image{border-bottom-right-radius:4px}.message.other .message-bubble.image-only .message-image{border-bottom-left-radius:4px}.message-bubble.has-image a{display:block;line-height:0}.message-image-btn{display:block;padding:0;border:none;background:none;line-height:0;cursor:zoom-in}.message-image-btn:active{opacity:.92}.image-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:max(16px,env(safe-area-inset-top)) 16px max(16px,env(safe-area-inset-bottom));touch-action:none;overflow:hidden}.image-viewer-img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;touch-action:none;will-change:transform;transform-origin:center center}.image-viewer-img.is-animating{transition:transform .22s cubic-bezier(.32,.72,0,1)}.tg-input-area{background:var(--input-bar-bg);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-top:none;padding:6px 8px;padding-bottom:max(6px,env(safe-area-inset-bottom,0px));flex-shrink:0}.tg-input-row{align-items:center;gap:6px}.tg-attach-btn,.tg-mic-btn{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:#8e8e93;border-radius:50%;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}body.voice-recording-active,body.voice-recording-active *{-webkit-user-select:none!important;user-select:none!important;-webkit-touch-callout:none!important}body.voice-recording-active .messages,body.voice-recording-active .tg-input-compose textarea{pointer-events:none}body.voice-recording-active .chat-input-row,body.voice-recording-active .tg-mic-btn,body.voice-recording-active .voice-hold-overlay,body.voice-recording-active .voice-recording-bar{pointer-events:auto}.tg-attach-btn:active,.tg-mic-btn:active{background:#0000000f}.tg-mic-btn:disabled{opacity:.45}.voice-recording-bar{display:flex;align-items:center;gap:10px;padding:4px 0;min-height:42px}.voice-recording-cancel{width:40px;height:40px;border-radius:50%;color:var(--text-muted);font-size:18px;flex-shrink:0}.voice-recording-center{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:22px;min-height:42px}.voice-recording-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:voice-pulse 1.2s ease-in-out infinite}@keyframes voice-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.voice-recording-time{font-size:16px;font-weight:500;font-variant-numeric:tabular-nums;color:var(--text)}.voice-recording-send{flex-shrink:0}.chat-input-row.voice-locked-mode{gap:0}.voice-recording-bar.voice-recording-locked{flex:1 1 100%;width:100%;padding:4px 2px}.voice-lock-icon{font-size:14px;line-height:1}.tg-mic-btn.is-holding{background:#e539351f;color:var(--danger)}.voice-hold-overlay{position:fixed;left:0;right:0;bottom:calc(var(--bottom-nav-h, 56px) + env(safe-area-inset-bottom,0px) + 72px);z-index:120;display:flex;align-items:flex-end;justify-content:space-between;padding:0 20px 8px;pointer-events:none}.chat-area.active .voice-hold-overlay{bottom:calc(env(safe-area-inset-bottom,0px) + 72px)}.voice-hold-hint{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:22px;color:var(--text-muted);opacity:.55;transition:opacity .15s,transform .15s}.voice-hold-hint span{font-size:11px;font-weight:500}.voice-hold-hint.active{opacity:1;color:var(--danger);transform:scale(1.08)}.voice-hold-hint.up.active{color:var(--accent)}.voice-hold-timer{display:flex;align-items:center;gap:8px;padding:10px 18px;background:#000000b8;color:#fff;border-radius:24px;font-size:16px;font-weight:500;font-variant-numeric:tabular-nums}.voice-hold-timer .voice-recording-dot{background:#fff}.pinned-bar{flex-shrink:0;border-bottom:1px solid rgba(0,0,0,.06);background:#fffffff5}.pinned-item{display:flex;align-items:stretch;border-bottom:1px solid rgba(0,0,0,.04)}.pinned-item:last-child{border-bottom:none}.pinned-item-body{flex:1;display:flex;align-items:center;gap:10px;padding:8px 12px 8px 14px;text-align:left;min-width:0}.pinned-item-body:active{background:#0000000a}.pinned-icon{flex-shrink:0;font-size:14px;opacity:.7}.pinned-content{display:flex;flex-direction:column;gap:2px;min-width:0}.pinned-label{font-size:12px;font-weight:600;color:var(--accent)}.pinned-text{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pinned-unpin{width:44px;flex-shrink:0;color:var(--text-muted);font-size:16px}.pinned-unpin:active{background:#0000000a}.message-highlight{animation:msg-highlight 1.5s ease-out}@keyframes msg-highlight{0%{background:#3390ec47}to{background:transparent}}.message-bubble.has-audio{min-width:200px}.message-bubble.voice-only{padding-bottom:4px}.voice-player{display:flex;align-items:center;gap:10px;min-width:180px;max-width:min(260px,72vw);padding:2px 0}.voice-play-btn{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message.own .voice-play-btn{background:#6ab04c}.voice-wave-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.voice-wave{height:4px;border-radius:2px;background:#0000001f;overflow:hidden;cursor:pointer}.message.own .voice-wave{background:#0000001a}.voice-wave-fill{height:100%;border-radius:2px;background:var(--accent)}.message.own .voice-wave-fill{background:#6ab04c}.voice-duration{font-size:12px;color:var(--msg-meta);font-variant-numeric:tabular-nums}.voice-unsupported{flex-direction:column;align-items:flex-start;gap:6px;min-width:180px}.voice-unsupported-text{font-size:13px;line-height:1.3}.voice-download-link{font-size:13px;color:var(--accent);text-decoration:underline}.tg-input-compose{flex:1;min-width:0;display:flex;align-items:flex-end;gap:4px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:22px;padding:0 4px 0 14px;min-height:42px}.tg-input-compose textarea{flex:1;min-width:0;background:transparent!important;border:none!important;border-radius:0!important;padding:10px 0;min-height:40px;max-height:120px;font-size:16px;line-height:1.35;resize:none}.tg-emoji-btn{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#8e8e93;border-radius:50%;margin-bottom:3px}.tg-send-btn{flex-shrink:0;background:var(--accent)!important;border-radius:50%!important;width:40px!important;height:40px!important;display:flex;align-items:center;justify-content:center;color:#fff!important}.file-btn{color:var(--text-muted);width:36px;height:36px}.message-bubble-wrap{position:relative;display:flex;align-items:center;gap:4px}.message-actions-desktop{display:flex;gap:2px;opacity:0;flex-shrink:0}.message-bubble-wrap:hover .message-actions-desktop{opacity:1}.message-actions-desktop button{width:28px;height:28px;border-radius:6px;font-size:13px}.action-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:flex-end}.action-sheet{width:100%;background:var(--bg);border-radius:16px 16px 0 0;padding:12px 16px;padding-bottom:max(16px,env(safe-area-inset-bottom))}.input-preview{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;margin-bottom:8px;background:var(--bg-tertiary);border-radius:10px;border-left:3px solid var(--accent)}.chat-input-row{display:flex;align-items:flex-end;gap:8px}.chat-input-row textarea{flex:1;resize:none;max-height:120px;font-size:16px;scroll-margin-bottom:0}.send-btn:disabled{opacity:.4}.typing-indicator{font-size:13px;color:var(--text-muted);font-style:italic;padding:4px 12px}.load-more{text-align:center;padding:8px}.load-more button{color:var(--accent);font-size:14px}.chat-search{padding:8px 12px;background:var(--bg);border-bottom:1px solid var(--border)}.chat-search input{width:100%;border:none;background:var(--bg-tertiary);border-radius:10px}.search-toggle{margin-left:auto}.reaction-chip{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:2px 8px;font-size:12px}.reaction-chip.mine{border-color:var(--accent);background:var(--accent-glow)}.message-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.message-reply{border-left:3px solid #6ab04c;padding-left:8px;margin-bottom:4px;opacity:.9}.message.own .message-reply{border-left-color:#6ab04c}.message.other .message-reply{border-left-color:var(--accent)}.deleted-text{font-style:italic;opacity:.7}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:var(--bg);border-radius:16px;width:100%;max-width:440px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 40px #00000026}.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-body{padding:16px 20px;overflow-y:auto}.modal-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.recovery-modal-overlay{z-index:300}.recovery-modal .modal-body{display:flex;flex-direction:column;gap:12px}.recovery-hint{margin:0;font-size:14px;line-height:1.45;color:var(--text-muted)}.recovery-input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;font-size:16px;background:var(--bg)}.recovery-submit{width:100%;margin-top:4px}.btn-primary{background:var(--accent);color:#fff;padding:10px 20px;border-radius:10px;font-weight:500}.btn-ghost{color:var(--accent);padding:10px 16px}.profile-notif-row,.profile-field,.profile-body{width:100%}.notif-toggle.on{background:var(--accent)}.install-banner{position:relative;z-index:30;margin:8px 12px 0;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.tg-theme .online-dot{border-color:var(--bg)}@media (min-width: 1025px){.main-panel{width:360px;max-width:360px}.main-panel.hidden-panel{display:flex}.chat-area{display:flex!important}.desktop-only{display:flex}.back-btn{display:none!important}.bottom-dock{display:none}.panel-list{padding-bottom:0}.tg-fab,.action-sheet-overlay{display:none}.desktop-side-nav{display:flex;flex-shrink:0;align-items:center;justify-content:space-around;gap:4px;padding:8px 12px 12px;border-top:1px solid var(--border);background:var(--header-bg)}.desktop-side-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border-radius:10px;font-size:11px;font-weight:500;color:var(--text-muted);position:relative;min-width:0}.desktop-side-nav-item:hover{background:var(--bg-hover);color:var(--text)}.desktop-side-nav-item.active{color:var(--accent);background:var(--accent-glow)}.desktop-side-nav-badge{position:absolute;top:4px;right:calc(50% - 24px);min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent);color:#fff;font-size:11px;font-weight:600;line-height:18px;text-align:center}}@media (max-width: 1024px){.messenger{display:block;position:relative;height:100dvh;height:100%;overflow:hidden}.main-panel{position:absolute;top:0;right:0;bottom:0;left:0;max-width:none;width:100%;height:100%;z-index:10}.main-panel-body{padding-bottom:calc(68px + env(safe-area-inset-bottom,0px))}.main-panel.hidden-panel{display:none!important}.chat-area{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100dvh;z-index:5;display:none!important;overflow:hidden}.chat-area.active{display:flex!important;z-index:30}html.ios .chat-area.ios-chat-open{left:0;right:0;width:100%}html.ios body.ios-chat-active{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;overflow:hidden}html.ios .chat-area.ios-chat-open.keyboard-open .tg-chat-header{padding-top:8px}html.ios .chat-area.ios-chat-open.keyboard-open .tg-input-area{padding-bottom:6px}.chat-search{flex-shrink:0}html.ios .main-panel-body{padding-bottom:calc(52px + env(safe-area-inset-bottom,0px))}html.ios .bottom-dock{left:10px;right:10px}html.ios .bottom-nav{padding:2px 4px 4px;border-radius:24px}html.ios .bottom-nav-item{min-height:42px}html.ios .bottom-nav-content{padding:3px 2px 2px;gap:1px}html.ios .bottom-nav-item svg{width:23px;height:23px}html.ios .bottom-nav-item .avatar-sm{width:24px!important;height:24px!important;font-size:11px!important}.back-btn{display:flex}.message-actions-desktop{display:none!important}.message-bubble:not(.deleted){cursor:pointer}.message{max-width:88%}.modal-overlay{align-items:flex-end;padding:0}.modal{max-width:100%;border-radius:16px 16px 0 0}.modal-footer{padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}}.search-results{max-height:200px;overflow-y:auto;margin-top:8px}.search-result-item{padding:10px 12px;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:2px}.search-result-item:active{background:var(--bg-hover)}.search-result-meta{font-size:12px;color:var(--text-muted)}.message-reply-author{display:block;font-size:12px;font-weight:600}.message-reply-text{display:block;font-size:13px;opacity:.85}.message-file{display:flex;align-items:center;gap:10px;min-width:200px;max-width:min(280px,72vw);padding:4px 0;position:relative}.message-file-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#0000000f;border-radius:8px}.message-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.message-file-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-file-link{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.input-preview-text{flex:1;min-width:0;font-size:14px}.input-preview-text span{display:block;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.action-sheet-reactions{display:flex;justify-content:center;gap:8px;padding:8px 0 12px}.action-sheet-emoji{font-size:28px;padding:4px 8px}.action-sheet-item{display:block;width:100%;padding:14px;text-align:center;font-size:17px;border-top:1px solid var(--border)}.action-sheet-item.danger{color:var(--danger)}.action-sheet-cancel{display:block;width:100%;padding:14px;text-align:center;font-size:17px;font-weight:600;color:var(--accent);margin-top:8px;background:var(--bg-tertiary);border-radius:12px}.modal-tabs{display:flex;gap:8px;margin-bottom:16px}.modal-tab{flex:1;padding:10px;border-radius:10px;background:var(--bg-tertiary);font-weight:500;color:var(--text-muted)}.modal-tab.active{background:var(--accent);color:#fff}.user-list-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 0;border-bottom:1px solid var(--border);text-align:left}.user-list-item.selected{color:var(--accent)}.group-name-input{width:100%;margin-bottom:12px}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:16px}.profile-username{text-align:center;color:var(--text-muted);margin-bottom:16px}.profile-field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-size:13px;color:var(--text-muted)}.profile-notif-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-top:1px solid var(--border)}.profile-notif-title{font-weight:500;color:var(--text)}.profile-notif-hint{font-size:13px;color:var(--text-muted)}.notif-toggle{width:50px;height:30px;border-radius:15px;background:var(--border);position:relative;transition:background .2s}.notif-toggle:after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:transform .2s}.notif-toggle.on:after{transform:translate(20px)}.avatar-upload-btn{font-size:14px}.install-banner-content{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.install-banner-icon{width:40px;height:40px;border-radius:10px}.install-banner-text{font-size:14px;line-height:1.3}.install-banner-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.install-btn{padding:8px 14px;font-size:13px}.install-ios-help{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;padding:20px}.install-ios-card{background:var(--bg);border-radius:16px;padding:24px;width:100%}.bottom-nav-item .avatar-sm{width:28px;height:28px;font-size:11px;box-shadow:0 1px 4px #0000001f}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--bg-secondary: #ffffff;--bg-tertiary: #f2f2f7;--bg-hover: #f2f2f7;--border: #e5e5ea;--text: #000000;--text-muted: #8e8e93;--accent: #007aff;--accent-hover: #0066d6;--accent-glow: rgba(0, 122, 255, .15);--success: #34c759;--danger: #ff3b30;--msg-out: #007aff;--msg-in: #f2f2f7;--radius: 12px;--radius-sm: 8px}html{height:100%;height:-webkit-fill-available}html,body,#root{height:100%;min-height:100dvh;min-height:-webkit-fill-available;font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow:hidden;overscroll-behavior:none;touch-action:manipulation;-webkit-text-size-adjust:100%;text-size-adjust:100%}button,input,textarea{font-family:inherit}button{cursor:pointer;border:none;background:none;color:inherit}input,textarea{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:10px 14px;outline:none;transition:border-color .2s;font-size:16px}input:focus,textarea:focus{border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:500;font-size:14px;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 0 20px var(--accent-glow)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--bg-hover)}.error-text{color:var(--danger);font-size:13px;margin-top:8px}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:#fff;flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:13px}.avatar-lg{width:54px;height:54px;font-size:20px}.avatar-xl{width:64px;height:64px;font-size:24px}.online-dot{width:10px;height:10px;border-radius:50%;background:var(--success);border:2px solid var(--bg-secondary);position:absolute;bottom:0;right:0}.scrollbar{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.scrollbar::-webkit-scrollbar{width:6px}.scrollbar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
