*{box-sizing:border-box}body{margin:0;font-family:system-ui,Segoe UI,Roboto,Arial,sans-serif;background:#0b0c10;color:#eaeaea;overflow-x:hidden;touch-action:manipulation}a{color:inherit}input,button{font:inherit}.container{max-width:1100px;margin:0 auto;padding:16px}.appShell{height:100dvh;display:flex;flex-direction:column;overflow:hidden}.appShell .layout{flex:1;min-height:0;height:100%}.appShell .sidebar,.appShell .chat{height:100%;min-height:0;min-width:0}.appShell .sidebar{overflow:auto}.card{background:#111217;border:1px solid #23242d;border-radius:14px;padding:16px}.row{display:flex;gap:12px;flex-wrap:wrap}.col{flex:1;min-width:260px}.btn{background:#2b5cff;border:0;color:#fff;padding:10px 12px;border-radius:12px;cursor:pointer}.btn:disabled{opacity:.6;cursor:not-allowed}.btn2{background:#1f2028;border:1px solid #2a2b35}.input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid #2a2b35;background:#0f1016;color:#eaeaea}.small{opacity:.8;font-size:12px;overflow-wrap:anywhere;word-break:break-word}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.badge{font-size:12px;padding:4px 8px;border:1px solid #2a2b35;border-radius:999px;opacity:.9}.layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:12px}.sidebar{height:calc(100vh - 32px);overflow:auto;min-width:0}.chat{height:calc(100vh - 32px);display:flex;flex-direction:column;min-width:0;position:relative}.listItem{padding:10px;border-radius:12px;border:1px solid #23242d;background:#0f1016;margin-bottom:8px;cursor:pointer}.listItem:hover,.listItemActive{border-color:#2b5cff}.msgs{flex:1;min-width:0;overflow-y:auto;overflow-x:hidden;padding:12px;border-radius:12px;border:1px solid #23242d;background:#0f1016}.msgRow{display:flex;margin-bottom:10px}.msgRow{min-width:0}.msgRowMe{justify-content:flex-end}.msgRowOther{justify-content:flex-start}.msgBubble{max-width:86%;min-width:0;padding:6px 12px 6px 10px;border-radius:16px;border:1px solid #23242d;background:#111217;position:relative}.msgBubbleMe{border-color:#2b5cff;background:#10162a}.msgBubbleOther{background:#111217}.msgMeta{display:flex;gap:8px;align-items:center}.msgMeta .grow{flex:1}.msgText{white-space:pre-wrap;line-height:1.28;margin-top:2px;overflow-wrap:anywhere;word-break:break-word}.msgQuote{margin-top:5px;padding:6px 10px;border-radius:12px;border:1px dashed #2a2b35;background:#0f1016}.msgQuoteTitle{font-size:12px;opacity:.85;font-weight:700;margin-bottom:2px}.msgQuoteText{font-size:12px;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msgTag{font-size:11px;padding:2px 6px;border:1px solid #2a2b35;border-radius:999px;opacity:.85}.msgMenuBtn{background:transparent;border:1px solid #23242d;color:#eaeaea;border-radius:10px;padding:2px 8px;cursor:pointer;opacity:.9}.jumpUnreadBtn{position:absolute;right:14px;bottom:76px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:#1f2028eb;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;z-index:80;box-shadow:0 10px 24px #00000059}.jumpUnreadBtn:active{transform:scale(.98)}@media (max-width: 900px){.jumpUnreadBtn{bottom:84px;right:12px}}.msgMenuBtn:hover{border-color:#2b5cff;opacity:1}.msgMenu{position:absolute;top:32px;right:10px;background:#111217;border:1px solid #23242d;border-radius:12px;min-width:170px;z-index:20;overflow:hidden;box-shadow:0 10px 30px #00000059}.msgMenuFixed{position:fixed;right:auto;top:auto;max-height:calc(100vh - 16px);overflow:auto}.msgMenuItem{padding:10px 12px;cursor:pointer;font-size:13px}.msgMenuItem:hover{background:#0f1016}.msgMenuItem.danger{color:#ff6b6b}.msgSender{font-size:12px;opacity:.85;font-weight:700;margin-bottom:4px}.msgMenuBtnAbs{position:absolute;top:6px;right:6px;background:#0000002e}.msgTime{float:right;font-size:10px;opacity:.65;margin-left:8px;white-space:nowrap;position:relative;top:2px}.dateSep{display:flex;justify-content:center;margin:12px 0}.dateSep span{font-size:12px;padding:4px 10px;border:1px solid #23242d;border-radius:999px;background:#0b0c10;opacity:.85}.chipFull{width:100%}.chipTextWrap{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}.chipTitle{font-size:11px;opacity:.75;font-weight:700;line-height:1}.chipBody{font-size:12px;opacity:.92;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.forwardPreview{margin-bottom:10px;padding:10px;border-radius:12px;border:1px dashed #2a2b35;background:#0f1016;max-height:96px;overflow:auto;overflow-wrap:anywhere;word-break:break-word}.forwardPreviewText{font-size:13px;line-height:1.3;overflow-wrap:anywhere;word-break:break-word}.hiddenDesktop{display:none!important}.msgText{white-space:pre-wrap;line-height:1.35;margin-top:4px;overflow-wrap:anywhere;word-break:break-word}.composer{display:flex;gap:8px;margin-top:10px;align-items:flex-end}.composer input[type=file]{display:none}.fileBtn{padding:10px 12px;border-radius:12px;border:1px dashed #2a2b35;background:#0f1016;cursor:pointer}.attachment{margin-top:6px;font-size:13px;opacity:.95;overflow-wrap:anywhere;word-break:break-word}.iconBtn{background:transparent;border:1px solid #23242d;color:#eaeaea;border-radius:10px;padding:4px 8px;cursor:pointer;opacity:.9}.iconBtn:hover{border-color:#2b5cff;opacity:1}.emojiBtn{padding:10px 12px;border-radius:12px;border:1px solid #23242d;background:#0f1016;cursor:pointer}.emojiPicker{position:absolute;bottom:52px;right:58px;width:320px;max-width:90vw;background:#111217;border:1px solid #23242d;border-radius:14px;padding:10px;z-index:30}.emojiGrid{display:grid;grid-template-columns:repeat(10,1fr);gap:6px;max-height:220px;overflow:auto}.emojiCell{padding:6px;border-radius:10px;border:1px solid #23242d;background:#0f1016;cursor:pointer;text-align:center}.emojiCell:hover{border-color:#2b5cff}.topBar{display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:999px;border:1px solid #2a2b35;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#0f1016}.avatar img{width:100%;height:100%;object-fit:cover}.modalOverlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal{width:520px;max-width:96vw;max-height:calc(100dvh - 32px);overflow-y:auto;-webkit-overflow-scrolling:touch;background:#111217;border:1px solid #23242d;border-radius:16px;padding:16px}.modalHeader{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modalFooter{display:flex;gap:8px;justify-content:flex-end;margin-top:12px}@media (max-width: 640px){.modalOverlay{align-items:flex-start;padding:10px}.modal{width:100%;max-width:100%;max-height:calc(100dvh - 20px);border-radius:14px;padding:12px}.modalHeader{position:sticky;top:0;background:#111217;padding-bottom:10px;margin-bottom:10px;z-index:1}}.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px dashed #2a2b35;border-radius:12px;background:#0f1016;max-width:100%;min-width:0}.chipBtn{background:transparent;border:1px solid #23242d;color:#eaeaea;border-radius:10px;padding:2px 8px;cursor:pointer}@media (max-width: 900px){.layout{grid-template-columns:1fr}.sidebar{height:auto}.chat{height:auto;min-height:60vh}}.searchWrap{position:relative;width:320px;min-width:240px}.searchInput{padding-right:52px}.searchHint{position:absolute;top:12px;right:12px;font-size:12px;opacity:.7}.searchDropdown{position:absolute;top:46px;left:0;right:0;background:#111217;border:1px solid #23242d;border-radius:14px;max-height:320px;overflow:auto;z-index:60;box-shadow:0 10px 30px #00000059}.searchItem{padding:10px 12px;cursor:pointer}.searchItem:hover{background:#0f1016}.chatHeader{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.groupMenu{position:absolute;top:44px;right:0;background:#111217;border:1px solid #23242d;border-radius:12px;min-width:200px;z-index:60;overflow:hidden;box-shadow:0 10px 30px #00000059}.groupMenuItem{padding:10px 12px;cursor:pointer;font-size:13px}.groupMenuItem:hover{background:#0f1016}.groupMenuItem.danger{color:#ff6b6b}@media (max-width: 900px){.searchWrap{width:100%}}html,body,#root{height:100%;width:100%;overflow-x:hidden}body{overscroll-behavior-y:none}.avatarBtn{background:transparent;border:0;padding:0;cursor:pointer}.headerWrap{flex-wrap:wrap;gap:10px}.headerActions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;min-width:0}.containerMobile{max-width:100%;padding:0}.mobileTop{position:sticky;top:0;z-index:45;background:#0b0c10;border-bottom:1px solid #23242d;padding:10px 12px;position:relative}.mobileTopRow{display:flex;align-items:center;gap:12px}.mobileTopTitle{font-size:18px;font-weight:900;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobileTopActions{display:flex;gap:8px;align-items:center}.mobileMenu{position:absolute;right:12px;top:52px;background:#111217;border:1px solid #23242d;border-radius:12px;min-width:220px;z-index:60;overflow:hidden;box-shadow:0 10px 30px #00000059}.mobileMenuItem{padding:12px;cursor:pointer;font-size:13px}.mobileMenuItem:hover{background:#0f1016}.mobileMenuItem.danger{color:#ff6b6b}.listTopBar{display:flex;gap:8px;align-items:center;margin-bottom:10px}.searchWrapMobile{width:100%;min-width:0}.hiddenMobile{display:none!important}.composerInput{width:100%;padding:10px 12px;border-radius:18px;border:1px solid #2a2b35;background:#0f1016;color:#eaeaea;resize:none;line-height:1.25;max-height:240px;overflow:hidden;font-size:16px}textarea.input{border-radius:18px;resize:none;max-height:260px;overflow:hidden;line-height:1.25}@media (max-width: 900px){.container{padding:0;max-width:100%}.input{font-size:16px}.card{border-radius:0;border-left:0;border-right:0}.layout{grid-template-columns:1fr;gap:0}.sidebar{height:calc(100vh - 56px);overflow:auto;border-bottom:1px solid #23242d}.layoutChat{height:100%}.layoutChat .chat{height:100%;display:flex;flex-direction:column}.layoutChat .msgs{flex:1;border-radius:0;border:0;overflow-y:auto;background:transparent;padding:12px 10px 4px}.chatHeaderMobile{position:sticky;top:0;z-index:40;background:#0b0c10;border-bottom:1px solid #23242d;padding:10px 12px;margin-bottom:0}.chatHeaderMobileNew{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;background:#00000040;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.06)}.mobileBackCircle{width:40px;height:40px;border-radius:50%;background:#0f1016;border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}.mobileTitlePill{position:absolute;left:50%;transform:translate(-50%);max-width:calc(100% - 110px);background:#0f1016;border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:8px 14px;display:flex;flex-direction:column;gap:2px;align-items:center;text-align:center}.mobileTitleName{font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1;max-width:100%}.mobileTitleStatus{font-size:12px;color:#ffffffb8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.1;max-width:100%}.mobileAvatarBtn{width:40px;height:40px;border-radius:50%;background:#0f1016;border:1px solid rgba(255,255,255,.08);overflow:hidden;display:flex;align-items:center;justify-content:center;padding:0}.backBtn{padding:4px 10px;border-radius:12px}.composerFixed{position:sticky;left:0;right:0;bottom:0;z-index:50;margin:0;border-radius:0;border:0;background:transparent;padding:0 12px env(safe-area-inset-bottom);max-width:100vw}.appShell .chatInner{width:100%;margin:0;padding:0}.layoutChat .chat{padding:0}.composerInner{max-width:none;width:100%}.composerRow textarea{font-size:17px;line-height:20px}.composerRow .iconBtn{width:40px;height:40px;border-radius:20px}.composerMobile{gap:8px}.emojiPicker{right:12px;bottom:70px}}.layoutSingle{grid-template-columns:1fr}@media (min-width: 901px){:root{--tg-sidebar: rgba(24,26,32,.92);--tg-topbar: rgba(20,22,28,.92);--tg-border: rgba(255,255,255,.08);--tg-hover: rgba(255,255,255,.04);--tg-active: rgba(122,90,245,.35);--tg-accent: #7a5af5;--tg-text: #eaeaea;--tg-muted: rgba(234,234,234,.72);--tg-wallpaper: radial-gradient(1200px 800px at 30% -10%, rgba(122,90,245,.18), transparent 60%), radial-gradient(900px 700px at 80% 10%, rgba(90,167,255,.1), transparent 55%), url(data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20width%3D%27260%27%20height%3D%27260%27%20viewBox%3D%270%200%20260%20260%27%3E%3Cg%20fill%3D%27none%27%20stroke%3D%27%23ffffff%27%20stroke-opacity%3D%270.07%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27%3E%3Cpath%20d%3D%27M34%2058c10-14%2024-14%2034%200s24%2014%2034%200%27%20/%3E%3Cpath%20d%3D%27M170%2042c6%2010%206%2022%200%2032s-6%2022%200%2032%27%20/%3E%3Cpath%20d%3D%27M52%20160c18-10%2040-10%2058%200%27%20/%3E%3Cpath%20d%3D%27M200%20150c-10%2014-24%2014-34%200s-24-14-34%200%27%20/%3E%3Ccircle%20cx%3D%2770%27%20cy%3D%2788%27%20r%3D%2710%27%20/%3E%3Ccircle%20cx%3D%27204%27%20cy%3D%2792%27%20r%3D%278%27%20/%3E%3Cpath%20d%3D%27M118%20118l18%2018-18%2018-18-18z%27%20/%3E%3Cpath%20d%3D%27M48%20214h36m-18-18v36%27%20/%3E%3Cpath%20d%3D%27M188%20208c8%200%2014%206%2014%2014s-6%2014-14%2014-14-6-14-14%206-14%2014-14z%27%20/%3E%3Cpath%20d%3D%27M120%20212c0%2010-8%2018-18%2018s-18-8-18-18%208-18%2018-18%27%20/%3E%3C/g%3E%3C/svg%3E)}.container.appShell{max-width:none;padding:0;margin:0}.appShell .layout{grid-template-columns:360px minmax(0,1fr);gap:0;height:100%}.appShell .sidebar.card,.appShell .chat.card{border:0;border-radius:0;padding:0;background:transparent;box-shadow:none}.appShell .sidebar{height:100%;overflow:hidden;background:var(--tg-sidebar);border-right:1px solid var(--tg-border)}.appShell .chat{height:100%;overflow:hidden;display:flex;flex-direction:column;background-color:#0b0c10;background-image:var(--tg-wallpaper);background-repeat:repeat}.sidebarTop{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:10px;padding:10px 12px;background:#181a20f5;border-bottom:1px solid var(--tg-border)}.burgerBtn{height:38px;width:38px;border-radius:999px;border:0;background:#ffffff0f;color:var(--tg-text);cursor:pointer}.burgerBtn:hover{background:#ffffff17}.sidebarSearchWrap{flex:1;min-width:0;position:relative}.sidebarSearchInput{height:38px;border:0;border-radius:999px;background:#ffffff0f;color:var(--tg-text);padding:9px 14px}.sidebarSearchInput::placeholder{color:#eaeaea8c}.pinnedAvatars{display:flex;gap:6px;align-items:center}.pinnedAvatarBtn{border:0;background:transparent;padding:0;cursor:pointer;border-radius:999px}.pinnedAvatarBtn:hover{filter:brightness(1.08)}.desktopMenu{position:absolute;left:12px;top:54px;background:#111217;border:1px solid #23242d;border-radius:12px;min-width:220px;z-index:60;overflow:hidden;box-shadow:0 10px 30px #00000059}.desktopMenuItem{padding:12px;cursor:pointer;font-size:13px}.desktopMenuItem:hover{background:#0f1016}.desktopMenuItem.danger{color:#ff6b6b}.appShell .sidebar{overflow:auto}.appShell .listItem{border:0;border-radius:0;margin:0;padding:10px 12px;background:transparent}.appShell .listItem:hover{background:var(--tg-hover);border-color:transparent}.appShell .listItemActive{background:var(--tg-active);border-color:transparent}.appShell .listItemActive:hover{background:#7a5af56b}.appShell .chatHeader{position:sticky;top:0;z-index:25;margin:0;padding:10px 14px;background:var(--tg-topbar);border-bottom:1px solid var(--tg-border)}.chatHeaderActions{gap:6px!important}.tgIconBtn{height:36px;width:36px;border-radius:999px;border:0;background:#ffffff0f;color:var(--tg-text);cursor:pointer}.tgIconBtn:hover{background:#ffffff17}.tgIconBtn:disabled{opacity:.6;cursor:not-allowed}.appShell .msgs{flex:1;min-height:0;overflow:auto;padding:18px 18px 12px;background:transparent;border:0;border-radius:0}.appShell .composer{margin:0;border:0;border-radius:0;padding:12px 14px;background:#14161ceb;border-top:1px solid var(--tg-border);display:flex;gap:10px;align-items:flex-end}.appShell .composer .input{border:0;outline:none;background:#ffffff0f;border-radius:22px;padding:10px 12px;max-height:220px;overflow-y:auto;scrollbar-width:none}.appShell .composer .input::-webkit-scrollbar{width:0;height:0}.appShell .emojiBtn,.appShell .fileBtn{height:40px;width:40px;border-radius:999px;border:0;background:#ffffff0f;display:flex;align-items:center;justify-content:center;padding:0}.appShell .emojiBtn:hover,.appShell .fileBtn:hover{background:#ffffff17}.appShell .composer .btn{height:40px;width:40px;border-radius:999px;padding:0;background:#7a5af5e0;display:flex;align-items:center;justify-content:center;font-size:0}.appShell .composer .btn:before{content:"➤";font-size:16px;line-height:1}.desktopEmpty{flex:1;min-height:0}:root{--tg-chat-max:680px}.appShell .msgs{padding:18px 0 12px}.appShell .chatInner{width:min(100%,var(--tg-chat-max));margin:0 auto;padding:0 18px}.appShell .composerDesktop{background:transparent;border-top:0;padding:10px 0 16px;display:block}.appShell .composerDesktop .composerInner{width:min(100%,var(--tg-chat-max));margin:0 auto;padding:0 18px;display:flex;flex-direction:column;gap:10px;position:relative}.appShell .composerRowDesktop{display:flex;align-items:flex-end;gap:10px;background:#12141ae6;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:10px 12px}.appShell .composerRowDesktop textarea{flex:1;min-width:0;background:transparent;border:0;outline:none;padding:2px 0;color:#e8e8ef;font-size:16px;line-height:1.25;font-family:inherit;min-height:24px;max-height:160px;resize:none}.appShell .composerRowDesktop .emojiBtn,.appShell .composerRowDesktop .fileBtn{height:34px;width:34px;min-width:34px;border:0;background:transparent;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#e8e8ef;opacity:.9;cursor:pointer}.appShell .composerRowDesktop .emojiBtn:hover,.appShell .composerRowDesktop .fileBtn:hover{background:#ffffff0f;opacity:1}.appShell .composerRowDesktop .emojiBtn.active{background:#ffffff14}.appShell .composerDesktop .emojiPicker{right:0;bottom:72px}.appShell .replyToPill{background:#12141ad9;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:10px 12px;position:relative}.appShell .replyToTitle{font-size:12px;opacity:.75;margin-bottom:4px}.appShell .replyToText{font-size:13px;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:26px}.appShell .replyToClose{position:absolute;right:10px;top:8px;border:0;background:transparent;color:#e8e8ef;opacity:.7;font-size:18px;line-height:1;cursor:pointer}.appShell .replyToClose:hover{opacity:1}}.composerInner{width:100%;display:flex;flex-direction:column;gap:8px;position:relative}.composerRow{display:flex;gap:10px;align-items:flex-end}.composerMobile{display:block}.composerMobile .composerInner{padding:0 10px}.composerRowMobile{background:transparent;border:0;padding:0;align-items:flex-end}.composerRowMobile textarea{background:transparent;border:0;outline:none;resize:none}.fileBtnCircle,.emojiBtnCircle,.sendBtnMobile{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0f1016;border:1px solid rgba(255,255,255,.08);color:#fff}.fileBtnCircle{cursor:pointer}.emojiBtnCircle{opacity:.9}.sendBtnMobile{opacity:.95}.mobileInputPill{background:#0f1016;border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:10px 14px;min-height:44px;display:flex;flex:1;min-width:0}.mobileInputPill textarea{width:100%;color:#fff;font-size:16px;line-height:20px;max-height:120px;padding:0}.composerRowMobile.idle .mobileInputPill{flex:0 1 72%}.composerRowMobile.typing .mobileInputPill{flex:1 1 auto}
