@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;700&family=Manrope:wght@400;500;700;800&display=swap";:root{--font:"Manrope",system-ui,sans-serif;--display:"Space Grotesk",sans-serif;--bg:#020617;--shell:rgba(15,23,42,.84);--panel:rgba(15,23,42,.88);--card:rgba(255,255,255,.045);--hover:rgba(255,255,255,.06);--line:rgba(255,255,255,.08);--text:#f8fafc;--muted:#94a3b8;--subtle:#64748b;--accent:#3b82f6;--accent-rgb:59,130,246;--bubble-in:rgba(30,41,59,.9);--bubble-out:linear-gradient(135deg,rgba(59,130,246,.95),rgba(56,189,248,.78));--radius:22px;--density:1;--font-scale:1;--wall:.12 }*{box-sizing:border-box;margin:0;padding:0}html,body,#root{font-family:var(--font);font-size:calc(15px * var(--font-scale));min-height:100vh;overflow:hidden;color:var(--text);width:100%;height:100%;background:radial-gradient(circle at top left,rgba(59,130,246,.18),transparent 28%),radial-gradient(circle at bottom right,rgba(168,85,247,.12),transparent 24%),linear-gradient(180deg,#020617,#020817 45%,#030712)}button,input,textarea,select{font:inherit;color:inherit;border:0;outline:0;background:none}button{cursor:pointer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:999px}::-webkit-scrollbar-track{background:transparent}.app-root{display:flex;flex-direction:column;height:100vh;width:100%;overflow:hidden}.app{flex:1;width:100%;display:grid;grid-template-columns:68px var(--sidebar-w,360px) 1fr 0;background:linear-gradient(180deg,#0f172ad1,#020617eb);border:0;border-radius:0;overflow:hidden;margin:0}.app.show-rightbar{grid-template-columns:68px var(--sidebar-w,360px) 1fr 330px}.app.sidebar-collapsed{grid-template-columns:68px 0 1fr 0}.app.sidebar-collapsed.show-rightbar{grid-template-columns:68px 0 1fr 330px}.app.sidebar-collapsed .sidebar{display:none}.loading-screen{width:100%;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px}.loading-logo{animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.loading-dots{display:flex;gap:6px}.loading-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dot-b 1.4s infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.loading-dots.sm span{width:5px;height:5px}@keyframes dot-b{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.3)}}.login-root{width:100%;height:100vh;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.login-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.login-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:orb-f 20s ease-in-out infinite}.login-orb-1{width:600px;height:600px;background:radial-gradient(circle,#3b82f6 0%,#2563eb 40%,transparent 70%);top:-150px;left:-100px}.login-orb-2{width:500px;height:500px;background:radial-gradient(circle,#a855f7 0%,#7c3aed 40%,transparent 70%);bottom:-100px;right:-100px;animation-delay:-7s}.login-orb-3{width:400px;height:400px;background:radial-gradient(circle,#38bdf8 0%,#0284c7 40%,transparent 70%);top:40%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s;opacity:.3}@keyframes orb-f{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(20px,10px) scale(1.02)}}.login-grid-pattern{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px}.login-center{position:relative;z-index:10;animation:glass-in .8s cubic-bezier(.16,1,.3,1) both}@keyframes glass-in{0%{transform:translateY(30px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.login-card{width:420px;max-width:90vw;background:var(--panel);border:1px solid var(--line);border-radius:28px;overflow:hidden;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.login-card-inner{padding:48px 40px;text-align:center}.login-title{font-family:var(--display);font-size:28px;font-weight:700;margin:0 0 8px;letter-spacing:-.5px}.login-subtitle{color:var(--muted);font-size:14px;margin:0 0 32px}.login-input{width:100%;padding:14px 18px;margin-bottom:12px;background:var(--card);border:1px solid var(--line);border-radius:14px;font-size:15px;transition:border-color .2s}.login-input::placeholder{color:var(--muted)}.login-input:focus{border-color:#60a5fa59}.login-error{color:#f87171;font-size:.8rem;margin-bottom:12px;padding:8px 12px;background:#f871711a;border:1px solid rgba(248,113,113,.2);border-radius:10px}.login-btn-primary{display:flex;align-items:center;justify-content:center;width:100%;padding:16px 24px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.95),#38bdf8d1);border:none;border-radius:14px;font-size:15px;font-weight:600;color:#eff6ff;cursor:pointer;transition:all .2s;box-shadow:0 12px 28px rgba(var(--accent-rgb),.24)}.login-btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 32px rgba(var(--accent-rgb),.3)}.login-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--line)}.login-divider span{font-size:13px;color:var(--muted)}.login-btn-google{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px 24px;background:#fff;border:none;border-radius:14px;font-size:15px;font-weight:600;color:#1f1f1f;cursor:pointer;transition:all .2s}.login-btn-google:hover{transform:translateY(-2px);box-shadow:0 10px 30px #ffffff1f}.login-footer-note{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px;padding:12px 16px;background:rgba(var(--accent-rgb),.08);border:1px solid rgba(var(--accent-rgb),.15);border-radius:12px;font-size:13px;color:#60a5fa}.rail{border-right:1px solid rgba(255,255,255,.05);background:#0206174d;display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;min-width:0;min-height:0;overflow-y:auto}.btn{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:#ffffff08;border:1px solid transparent;color:#94a3b8;transition:.18s ease;position:relative}.btn svg{width:22px;height:22px;fill:currentColor}.btn:hover{background:var(--hover);color:var(--text);border-color:#ffffff0d}.btn.active{color:var(--text);background:#ffffff08}.btn.active:before{content:"";position:absolute;left:-2px;top:50%;transform:translateY(-50%);width:4px;height:22px;background:linear-gradient(180deg,#3b82f6,#38bdf8);border-radius:0 4px 4px 0}.spacer{flex:1}.mini-avatar{width:32px;height:32px;border-radius:50%;background:rgba(var(--accent-rgb),.16);display:grid;place-items:center;font-weight:800;color:#fff;font-size:13px}.sidebar{display:flex;flex-direction:column;border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(96,165,250,.08),transparent 24%),linear-gradient(180deg,#0f172af2,#0f172ac7);min-width:0;min-height:0;position:relative}.sidebar-resize{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:10;background:transparent;transition:background .15s}.sidebar-resize:hover,.sidebar-resize.dragging{background:rgba(var(--accent-rgb),.3)}.sidebar-toggle{position:absolute;left:69px;top:50%;transform:translateY(-50%);z-index:15;width:20px;height:44px;border-radius:0 10px 10px 0;background:#0f172ae0;border:1px solid var(--line);border-left:0;color:var(--muted);display:none;place-items:center;cursor:pointer;transition:.15s}.sidebar-toggle:hover{background:rgba(var(--accent-rgb),.2);color:var(--text)}.sidebar-toggle svg{width:14px;height:14px;fill:currentColor}.app.sidebar-collapsed .sidebar-toggle{display:grid}.header{min-height:76px;padding:18px 20px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:28px;height:28px;display:grid;place-items:center}.title{font-family:var(--display);font-weight:700;letter-spacing:-.04em}.brand .title{font-size:20px;letter-spacing:-.6px}.sub{font-size:.83rem;color:var(--muted);margin-top:3px}.row{display:flex;align-items:center;gap:8px}.icon{width:40px;height:40px;border-radius:14px;display:grid;place-items:center;background:#ffffff0a;border:1px solid var(--line);color:#cbd5e1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:.18s ease}.icon svg{width:22px;height:22px;fill:currentColor}.icon:hover{background:var(--hover);transform:translateY(-1px);border-color:#60a5fa59}.icon.active-state{color:#fbbf24}.search-wrap{padding:0 20px 12px}.search{height:48px;border-radius:18px;border:1px solid var(--line);background:var(--card);display:flex;align-items:center;gap:12px;padding:0 14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.search input{flex:1;min-width:0;font-size:13.5px}.search input::placeholder{color:var(--muted)}.filters{display:flex;gap:6px;padding:0 16px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.filters::-webkit-scrollbar{display:none}.pill{height:30px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:#ffffff0a;color:var(--muted);font-weight:600;font-size:11px;white-space:nowrap;transition:.18s ease;display:inline-flex;align-items:center}.pill.active{color:#eff6ff;background:linear-gradient(135deg,rgba(var(--accent-rgb),.95),#38bdf8d9);border-color:transparent;box-shadow:0 8px 20px rgba(var(--accent-rgb),.2)}.pill:hover:not(.active){background:var(--hover)}.chat-list{flex:1;overflow-y:auto;padding:0 10px 14px}.chat{display:flex;align-items:center;padding:calc(12px * var(--density)) 12px;gap:14px;border-radius:20px;border:1px solid transparent;cursor:pointer;margin:0 10px 6px;position:relative;transition:background .1s}.chat:hover{background:#ffffff0d}.chat.active{background:linear-gradient(135deg,rgba(var(--accent-rgb),.16),#38bdf814);box-shadow:inset 0 0 0 1px #60a5fa2e}.chat:after{content:"";position:absolute;bottom:0;left:84px;right:12px;height:1px;background:#ffffff0a}.avatar{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.chat-main{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}.between{display:flex;align-items:center;justify-content:space-between;gap:10px}.chat-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{font-size:12px;color:var(--subtle)}.chat-time.unread{color:#22c55e}.preview{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{display:inline-flex;align-items:center;justify-content:center;height:20px;min-width:20px;padding:0 5px;border-radius:10px;font-size:11px;font-weight:700;background:#ffffff12;color:var(--muted)}.count{display:inline-flex;align-items:center;justify-content:center;height:20px;min-width:20px;padding:0 5px;border-radius:10px;font-size:11px;font-weight:700;background:#22c55e;color:#052e16}.chat-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex-shrink:0}.no-chats{padding:24px 20px;text-align:center;color:var(--muted);font-size:14px}.footer{padding:16px 20px 20px;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:center;gap:6px;background:#02061747;font-size:11px;color:var(--muted);text-align:center}.main{display:flex;flex-direction:column;position:relative;min-width:0;min-height:0;background:radial-gradient(circle at top,rgba(var(--accent-rgb),.08),transparent 30%),linear-gradient(180deg,#0206175c,#020617b8)}.main:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:32px 32px;opacity:var(--wall);pointer-events:none}.main>*{position:relative;z-index:1}.empty{flex:1;display:grid;place-items:center;padding:40px}.empty-card{max-width:480px;text-align:center}.empty h1{font-family:var(--display);font-size:36px;line-height:1;letter-spacing:-1px;margin:0 0 12px}.empty p{line-height:1.7;color:var(--muted);font-size:15px}.chat-header{height:76px;padding:0 16px 0 12px;background:#02061780;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);flex-shrink:0}.mobile-back{display:none}.head-main{display:flex;align-items:center;gap:12px;min-width:0;flex:1;padding-left:12px}.head-title{font-weight:600;font-size:16px;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;line-height:1.2;margin-top:1px}.dot{width:8px;height:8px;border-radius:999px;background:#22c55e;animation:pulse-dot 2s infinite}@keyframes pulse-dot{0%,to{box-shadow:0 0 #22c55e33}50%{box-shadow:0 0 0 5px #22c55e00}}.messages{flex:1;overflow-y:auto;padding:8px 16px;display:flex;flex-direction:column;gap:3px}.date{align-self:center;padding:5px 12px;border-radius:999px;background:#0f172ac2;font-size:11px;color:var(--muted);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);margin:8px 0}.msg{max-width:min(480px,80%);padding:7px 10px 6px;border-radius:12px;line-height:1.4;font-size:15px;position:relative;word-wrap:break-word;white-space:pre-wrap}.msg.in{align-self:flex-start;background:var(--bubble-in);border-bottom-left-radius:4px}.msg.out{align-self:flex-start;background:var(--bubble-out);border-bottom-right-radius:4px;box-shadow:0 1px 2px #0003;color:#eff6ff}.msg.with-head{margin-top:6px}.msg.with-head.in{border-top-left-radius:12px}.msg.with-head.out{border-top-right-radius:12px}.msg.pinned{border-left:3px solid #fbbf24}.msg.search-highlight{background:rgba(var(--accent-rgb),.12)!important;border-left:3px solid var(--accent)}.msg-author{font-size:13px;font-weight:600;color:#60a5fa;margin-bottom:2px;display:block}.msg.out .msg-author{color:#fffc}.msg-content{font-size:15px;line-height:1.4;word-break:break-word}.msg-emoji{display:inline;vertical-align:-4px}.msg.emoji-only{padding:0;background:none;border:none;box-shadow:none}.msg-emoji-only{display:flex;gap:4px;flex-wrap:wrap}.msg.emoji-only .msg-meta{float:none;display:flex;margin-left:0;margin-top:4px;justify-content:flex-start}.msg-link{color:#60a5fa;text-decoration:none;word-break:break-all}.msg-link:hover{text-decoration:underline}.msg.out .msg-link{color:#ffffffd9}.msg.out .msg-link:hover{color:#fff}.msg-meta{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#ffffff73;float:right;margin-left:10px;margin-top:4px;user-select:none;-webkit-user-select:none}.msg.out .msg-meta{color:#ffffff8c}.msg-edited{font-size:11px;color:#ffffff59}@keyframes rise{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}.msg-reply-ref{padding:4px 8px;margin-bottom:4px;border-left:2px solid var(--accent);background:rgba(var(--accent-rgb),.08);border-radius:0 6px 6px 0;font-size:12px;display:flex;gap:8px;align-items:center;cursor:pointer;transition:background .12s}.msg-reply-ref:hover{background:rgba(var(--accent-rgb),.14)}.msg-reply-ref>div,.msg-reply-ref>span,.msg-reply-ref>strong{display:block}.msg-reply-ref strong{color:#60a5fa;margin-bottom:1px;font-size:12px;flex:none;width:100%}.msg-reply-ref span{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.msg-reply-ref{flex-wrap:wrap}.reply-thumb{width:34px;height:34px;border-radius:4px;object-fit:cover;flex-shrink:0;order:10;margin-left:auto}.msg.out .msg-reply-ref{border-left-color:#fff6;background:#0000001a}.msg.out .msg-reply-ref:hover{background:#0000002e}.msg.out .msg-reply-ref strong{color:#ffffffd9}.msg.out .msg-reply-ref span{color:#ffffff8c}.msg.reply-flash{animation:reply-glow 5s ease}@keyframes reply-glow{0%{background:rgba(var(--accent-rgb),.25)!important;box-shadow:0 0 20px rgba(var(--accent-rgb),.2)}20%{background:rgba(var(--accent-rgb),.18)!important}to{background:inherit}}.msg-file{margin-top:6px}.msg-file-img{max-width:330px;max-height:280px;border-radius:12px;cursor:pointer;display:block}.msg.img-only{padding:0;background:none;border:none;box-shadow:none}.msg.img-only .msg-content{display:none}.msg.img-only .msg-file{margin:0}.msg.img-only .msg-file-img{border-radius:16px;max-width:420px;max-height:none}.msg.img-only .msg-meta{position:absolute;bottom:8px;right:12px;background:#0000008c;border-radius:10px;padding:2px 8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.msg.img-only .msg-meta span{color:#ffffffd9;font-size:11px}.msg.img-only .msg-author{padding:0 14px;margin-bottom:4px}.msg-file-link{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff0f;border:1px solid var(--line);border-radius:12px;color:#7dd3fc;text-decoration:none;font-size:13px;transition:background .15s}.msg-file-link:hover{background:#ffffff1a}.msg-file-size{color:var(--muted);font-size:12px}.video-preview{position:relative;display:inline-block;max-width:420px;border-radius:12px;overflow:hidden;background:#000}.video-preview-el{display:block;max-width:420px;max-height:360px;width:100%;object-fit:contain;pointer-events:none}.video-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#00000040;transition:background .15s}.video-preview:hover .video-play-overlay{background:#00000059}.video-play-overlay svg{filter:drop-shadow(0 2px 8px rgba(0,0,0,.4))}.msg.img-only .video-preview{border-radius:16px}.msg.img-only .video-preview-el{max-height:none}.voice-msg{display:flex;align-items:center;gap:8px;padding:4px 0;min-width:220px}.voice-play-btn{width:34px;height:34px;border-radius:50%;background:rgba(var(--accent-rgb),.2);display:grid;place-items:center;border:none;color:var(--accent);cursor:pointer;flex-shrink:0;transition:.12s}.voice-play-btn:hover{background:rgba(var(--accent-rgb),.3)}.msg.out .voice-play-btn{background:#fff3;color:#fff}.msg.out .voice-play-btn:hover{background:#ffffff4d}.voice-wave{flex:1;display:flex;align-items:center;gap:1.5px;height:28px;-webkit-user-select:none;user-select:none}.voice-bar{width:2.5px;border-radius:2px;background:rgba(var(--accent-rgb),.3);flex-shrink:0;transition:background .08s}.voice-bar.played{background:var(--accent)}.msg.out .voice-bar{background:#ffffff4d}.msg.out .voice-bar.played{background:#fff}.voice-dur{font-size:11px;color:var(--muted);flex-shrink:0;min-width:32px;text-align:right;font-family:Space Grotesk,monospace}.msg.out .voice-dur{color:#fff9}.rec-dot{width:10px;height:10px;border-radius:50%;background:#ef4444;animation:rec-blink 1s infinite}@keyframes rec-blink{0%,to{opacity:1}50%{opacity:.3}}.link-preview-card{display:flex;flex-direction:column;text-decoration:none;margin-top:6px;border-radius:8px;overflow:hidden;border-left:3px solid var(--accent);background:#ffffff0a}.msg.out .link-preview-card{background:#0000001f;border-left-color:#fff6}.link-preview-img{width:100%;max-height:160px;object-fit:cover}.link-preview-body{padding:8px 10px;display:flex;flex-direction:column;gap:2px}.link-preview-site{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.msg.out .link-preview-site{color:#ffffff80}.link-preview-title{font-size:13px;font-weight:600;color:#60a5fa;line-height:1.3}.msg.out .link-preview-title{color:#ffffffe6}.link-preview-desc{font-size:12px;color:var(--muted);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.msg.out .link-preview-desc{color:#ffffff8c}.pinned-banner{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#02061780;border-bottom:1px solid var(--line);cursor:pointer;flex-shrink:0;transition:background .12s}.pinned-banner:hover{background:#ffffff0a}.pinned-accent{width:3px;height:28px;border-radius:2px;background:var(--accent);flex-shrink:0}.pinned-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.pinned-label{font-size:11px;font-weight:600;color:var(--accent)}.pinned-text{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.msg-row{display:flex;align-items:flex-end;gap:8px;align-self:flex-start;max-width:min(520px,85%)}.msg-row .msg{align-self:auto;max-width:none;flex:1;min-width:0}.msg-avatar-slot{width:32px;flex-shrink:0}.msg-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,rgba(var(--accent-rgb),.8),#22d3ee99);display:grid;place-items:center;font-size:13px;font-weight:700;color:#fff;overflow:hidden}.msg-avatar img{width:100%;height:100%;object-fit:cover}.ctx-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9990}.ctx-menu{position:fixed;z-index:9991;display:flex;flex-direction:column;gap:6px;animation:ctx-in .14s ease}@keyframes ctx-in{0%{opacity:0;transform:translateY(4px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ctx-reactions{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#0f172af2;border:1px solid rgba(255,255,255,.08);border-radius:999px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 30px #0006}.ctx-reaction{width:38px;height:38px;border:none;background:none;border-radius:50%;font-size:22px;cursor:pointer;display:grid;place-items:center;transition:.12s}.ctx-reaction:hover{background:#ffffff1a;transform:scale(1.15)}.ctx-reaction-more{color:var(--muted)}.ctx-reaction-more:hover{color:var(--text)}.ctx-actions{display:flex;flex-direction:column;padding:6px;background:#0f172af2;border:1px solid rgba(255,255,255,.08);border-radius:14px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 8px 30px #0006;min-width:200px}.ctx-action{display:flex;align-items:center;gap:12px;padding:10px 14px;border:none;background:none;color:var(--text);font-size:14px;cursor:pointer;border-radius:10px;transition:background .1s;text-align:left;width:100%}.ctx-action:hover{background:#ffffff12}.ctx-action.destructive{color:#ef4444}.ctx-action-icon{width:22px;height:22px;display:grid;place-items:center;flex-shrink:0;color:var(--muted)}.ctx-action.destructive .ctx-action-icon{color:#ef4444}.usercard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9980;background:#00000080;display:grid;place-items:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.usercard{width:340px;max-height:80vh;background:#0f172af7;border:1px solid rgba(255,255,255,.08);border-radius:20px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 20px 60px #00000080;overflow-y:auto;position:relative;animation:ctx-in .14s ease;scrollbar-width:none}.usercard::-webkit-scrollbar{display:none}.usercard-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#ffffff14;color:var(--muted);cursor:pointer;display:grid;place-items:center;z-index:2;transition:.12s}.usercard-close:hover{background:#ffffff26;color:var(--text)}.usercard-header{display:flex;flex-direction:column;align-items:center;padding:32px 24px 20px;gap:6px}.usercard-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,rgba(var(--accent-rgb),.8),#22d3ee99);display:grid;place-items:center;font-size:2rem;font-weight:700;color:#fff;overflow:hidden;position:relative}.usercard-avatar img{width:100%;height:100%;object-fit:cover}.usercard-online{position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#22c55e;border:3px solid rgba(15,23,42,.97)}.usercard-name{font-size:20px;font-weight:700;font-family:var(--display);margin-top:4px}.usercard-username{font-size:13px;color:#60a5fa}.usercard-status{font-size:12px;color:var(--muted)}.usercard-actions{display:flex;gap:8px;padding:0 24px 16px;justify-content:center}.usercard-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;border:1px solid var(--line);background:#ffffff0a;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:.12s;font-family:inherit}.usercard-btn:hover{background:#ffffff14}.usercard-btn.primary{background:linear-gradient(135deg,rgba(var(--accent-rgb),.9),#38bdf8b3);border-color:transparent;color:#fff}.usercard-btn.primary:hover{opacity:.9}.usercard-menu{padding:4px 12px 12px;display:flex;flex-direction:column}.usercard-menu-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border:none;background:none;color:var(--text);font-size:14px;cursor:pointer;border-radius:12px;transition:.1s;text-align:left;width:100%}.usercard-menu-item:hover{background:#ffffff0f}.usercard-menu-item svg{color:var(--muted);flex-shrink:0}.usercard-menu-item.destructive{color:#ef4444}.usercard-menu-item.destructive svg{color:#ef4444}.usercard-blocked-banner{display:flex;align-items:center;gap:8px;margin:0 16px 12px;padding:10px 14px;border-radius:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#ef4444;font-size:13px;font-weight:500}.usercard-btn:disabled{opacity:.35;cursor:not-allowed}.usercard-media{padding:0 12px 16px}.usercard-media-empty{text-align:center;padding:16px;color:var(--muted);font-size:13px}.usercard-media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.usercard-media-item{aspect-ratio:1;border-radius:8px;overflow:hidden}.usercard-media-item img{width:100%;height:100%;object-fit:cover;transition:.12s}.usercard-media-item:hover img{transform:scale(1.05)}.notif-stack{position:fixed;top:12px;right:12px;z-index:99999;display:flex;flex-direction:column;gap:8px;max-width:360px;pointer-events:none}.notif-card{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:16px;background:#080d1cf0;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 16px 40px #02061799;font-family:var(--font);color:#f8fafc;animation:notif-slide .3s cubic-bezier(.16,1,.3,1);pointer-events:auto;cursor:pointer;transition:opacity .2s}.notif-card:hover{opacity:.92}@keyframes notif-slide{0%{opacity:0;transform:translate(40px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}.notif-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,rgba(var(--accent-rgb),.8),#22d3ee99);display:grid;place-items:center;font-size:16px;font-weight:700;color:#fff;overflow:hidden}.notif-avatar img{width:100%;height:100%;object-fit:cover}.notif-body{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:700;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-text{font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-dismiss{width:24px;height:24px;border-radius:50%;border:none;background:#ffffff0f;color:var(--muted);cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:.12s;opacity:0}.notif-card:hover .notif-dismiss{opacity:1}.notif-dismiss:hover{background:#ffffff1f;color:var(--text)}.drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;background:#020617d9;display:grid;place-items:center;animation:fade-in .15s ease;pointer-events:none}.drop-zone{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 64px;border:2px dashed rgba(var(--accent-rgb),.4);border-radius:24px;color:var(--accent)}.drop-zone span{font-size:16px;font-weight:600}.msg.in.grp-start{border-bottom-left-radius:4px}.msg.in.grp-mid{border-top-left-radius:4px;border-bottom-left-radius:4px}.msg.in.grp-end{border-top-left-radius:4px}.msg.out.grp-start{border-bottom-right-radius:4px}.msg.out.grp-mid{border-top-right-radius:4px;border-bottom-right-radius:4px}.msg.out.grp-end{border-top-right-radius:4px}.msg-edit-form input{width:100%;padding:8px 12px;background:var(--card);border:1px solid var(--accent);border-radius:12px;font-size:14px}.msg-edit-btns{display:flex;gap:8px;margin-top:6px}.msg-edit-btns button{padding:4px 12px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer}.msg-edit-btns button[type=submit]{background:linear-gradient(135deg,rgba(var(--accent-rgb),.95),#38bdf8d1);color:#eff6ff}.msg-edit-btns button[type=button]{background:var(--card);color:var(--muted)}.typing-bar{display:flex;align-items:center;gap:6px;padding:2px 16px;font-size:12px;color:var(--muted);flex-shrink:0}.typing{display:inline-flex;gap:5px}.typing span{width:7px;height:7px;border-radius:999px;background:#bfdbfe;animation:b 1.2s infinite ease-in-out}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}@keyframes b{0%,to{transform:translateY(0);opacity:.35}50%{transform:translateY(-4px);opacity:1}}.reply-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;border-radius:12px;border:1px solid var(--line);background:var(--card);margin:0 4px}.reply-bar strong{display:block;font-size:13px}.reply-bar .muted{color:var(--muted);font-size:12px}.compose{padding:8px 10px 10px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:6px;background:#02061780;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);flex-shrink:0}.compose-row{display:flex;gap:6px;align-items:center}.compose-row input[hidden]{display:none}.compose .icon{width:42px;height:42px;border-radius:50%;border:none;flex-shrink:0}.compose .send{flex-shrink:0}.compose textarea{height:42px;min-height:42px;max-height:160px;resize:none;padding:10px 14px;border-radius:20px;border:1px solid var(--line);background:#ffffff0b;line-height:1.4;font-family:var(--font);font-size:15px;overflow-y:auto;scrollbar-width:none}.compose textarea::-webkit-scrollbar{display:none}.compose textarea::placeholder{color:var(--muted)}.send{height:42px;width:42px;padding:0;border-radius:50%;font-weight:700;background:linear-gradient(135deg,rgba(var(--accent-rgb),.94),#38bdf8d1);color:#eff6ff;box-shadow:0 4px 12px rgba(var(--accent-rgb),.2);display:grid;place-items:center;transition:.15s}.send:hover{opacity:.9}.send:active{transform:scale(.92)}.send svg{width:18px;height:18px;fill:currentColor}.secondary{height:38px;padding:0 14px;border-radius:12px;font-weight:700;font-size:.84rem;background:#ffffff0a;border:1px solid var(--line);color:var(--muted);transition:.15s}.secondary:hover{background:#ffffff14}.rightbar{border-left:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.03),transparent 26%),#070c18eb;display:none;flex-direction:column;min-width:0;min-height:0}.rightbar.show{display:flex}.rightbody{padding:0 18px 18px;overflow-y:auto;display:flex;flex-direction:column;gap:14px;flex:1}.hero{display:flex;flex-direction:column;align-items:center;gap:12px;padding:12px 14px 18px}.hero .avatar{width:88px;height:88px;border-radius:28px;font-size:1.5rem}.hero .title{font-size:1.24rem}.helper{line-height:1.65;color:var(--muted);font-size:.84rem}.action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.action-grid button{min-height:84px;padding:14px 10px;border-radius:22px;border:1px solid var(--line);background:var(--card);color:var(--text);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-weight:700;font-size:.88rem;transition:.15s}.action-grid button:hover{background:var(--hover)}.action-grid button.active{border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--accent-rgb),.1)}.card{border-radius:22px;border:1px solid var(--line);background:var(--card);padding:16px}.card strong,.stat strong{display:block;margin-bottom:8px;font-size:.92rem}.stat{border-radius:22px;border:1px solid var(--line);background:var(--card);padding:16px}.detail{display:flex;align-items:center;justify-content:space-between;gap:16px}.detail+.detail{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.07)}.desc{color:var(--muted);font-size:.84rem;line-height:1.5}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#030712ad;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);opacity:0;pointer-events:none;transition:.2s ease;z-index:20}.overlay.show{opacity:1;pointer-events:auto}.modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:center;padding:26px;z-index:21}.modal.show{display:flex}.settings{width:min(1180px,100%);height:min(860px,calc(100vh - 52px));border-radius:34px;border:1px solid var(--line);background:linear-gradient(180deg,#080d1cfa,#050914fa);display:grid;grid-template-columns:280px 1fr;overflow:hidden}.settings-nav{padding:22px 18px;border-right:1px solid var(--line);background:linear-gradient(180deg,rgba(var(--accent-rgb),.08),transparent 24%),#080d1afa;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.settings-view{display:flex;flex-direction:column}.settings-head{padding:24px 24px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-body{padding:22px 24px 24px;overflow-y:auto;display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:18px;flex:1}.stack{display:flex;flex-direction:column;gap:18px}.tab{min-height:50px;border-radius:18px;padding:0 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--muted);border:1px solid transparent;background:none;cursor:pointer;font-weight:700;font-size:.88rem;transition:.15s;width:100%;text-align:left}.tab:hover{background:#ffffff0a}.tab.active{background:linear-gradient(135deg,rgba(var(--accent-rgb),.18),#22d3ee14);color:#fff;border-color:rgba(var(--accent-rgb),.16)}.tab small{font-size:.75rem;color:var(--subtle);font-weight:500}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 0}.settings-item+.settings-item{border-top:1px solid rgba(255,255,255,.07)}.choice-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.theme{border-radius:20px;border:1px solid var(--line);background:#ffffff09;padding:14px;cursor:pointer;transition:.15s;text-align:left}.theme:hover{background:var(--hover)}.theme.active{border-color:rgba(var(--accent-rgb),.34);box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.18);background:rgba(var(--accent-rgb),.1)}.theme-preview{height:96px;border-radius:16px;margin-bottom:12px;border:1px solid rgba(255,255,255,.06)}.theme strong{display:block}.switch{width:52px;height:30px;padding:4px;border-radius:999px;background:#ffffff1a;position:relative;border:none;cursor:pointer;flex-shrink:0;transition:.18s}.switch:after{content:"";position:absolute;left:4px;top:4px;width:22px;height:22px;border-radius:999px;background:#fff;transition:transform .18s ease}.switch.on{background:rgba(var(--accent-rgb),.9)}.switch.on:after{transform:translate(22px)}.device{border-radius:16px;border:1px solid var(--line);background:#ffffff09;padding:14px}.device.current{border-color:rgba(var(--accent-rgb),.34);background:rgba(var(--accent-rgb),.1)}.input{height:48px;border-radius:18px;border:1px solid var(--line);background:var(--card);display:flex;align-items:center;gap:12px;padding:0 14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.input input,.input textarea{flex:1;min-width:0}.select{height:42px;padding:0 14px;border-radius:14px;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:.84rem;cursor:pointer;min-width:160px}.primary{height:42px;padding:0 18px;border-radius:14px;font-weight:700;background:linear-gradient(135deg,rgba(var(--accent-rgb),1),#22d3eed6);color:#fff;border:none;cursor:pointer;transition:.15s}.toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(80px);padding:12px 24px;border-radius:16px;border:1px solid rgba(255,255,255,.1);background:#0f172ae0;box-shadow:0 18px 48px #02061780;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);opacity:0;pointer-events:none;transition:all .35s cubic-bezier(.2,.9,.3,1);z-index:30;font-size:13px}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.hidden{display:none!important}.new-dm-search{padding:8px 20px;border-bottom:1px solid var(--line)}.search-result{display:flex;align-items:center;gap:14px;padding:10px 14px;cursor:pointer;transition:background .1s;font-size:14px;border-radius:12px}.search-result:hover{background:var(--hover)}.search-result img{width:40px;height:40px;border-radius:14px;object-fit:cover;background:var(--card)}.online-dot{position:absolute;bottom:1px;right:1px;width:10px;height:10px;border-radius:50%;background:#22c55e;border:2px solid rgba(15,23,42,.88)}@media(max-width:1180px){.settings-body,.choice-grid{grid-template-columns:1fr}}@media(max-width:1020px){.app,.app.show-rightbar{grid-template-columns:68px 300px 1fr}.rightbar{display:none!important}.sidebar{min-width:0}.app{border-radius:24px}}@media(max-width:900px){.app{grid-template-columns:1fr;height:100vh;border-radius:0;border:0;max-width:none;box-shadow:none}.rail{display:none}.sidebar{width:100%;min-width:100%}.main{display:none}.app:not(.sidebar-only) .sidebar{display:none}.app:not(.sidebar-only) .main{display:flex;width:100%}.app.sidebar-only .sidebar{display:flex;min-height:100vh;width:100%}.app.sidebar-only .main{display:none}.mobile-back{display:grid!important}.messages{padding:8px 10px}.msg{max-width:88%}.compose{padding:6px 8px 10px}.compose-row{gap:4px}.compose textarea{min-height:40px;padding:10px 12px;font-size:16px}.compose .icon{width:36px;height:36px;border-radius:12px}.send{height:40px;width:40px;padding:0;border-radius:50%}.header{min-height:64px;padding:14px 16px 10px}.brand .title{font-size:18px}.search-wrap{padding:0 16px 10px}.search{height:44px;border-radius:14px;padding:0 12px}.filters{padding:0 16px 10px;gap:6px}.pill{min-height:32px;padding:0 12px;font-size:11px}.chat{padding:10px;gap:12px;margin:0 6px 4px;border-radius:16px}.avatar{width:44px;height:44px;border-radius:14px}.footer{padding:12px 16px 16px}.chat-header{height:50px;padding:0 8px 0 4px}.head-title{font-size:15px}.chat-header .avatar{width:36px;height:36px;border-radius:12px}.chat-header .icon{width:34px;height:34px;border-radius:10px}.empty{padding:24px 20px}.empty h1{font-size:24px}.empty p{font-size:14px}.settings{grid-template-columns:1fr;height:calc(100vh - 16px);border-radius:20px}.settings-nav{flex-direction:row;overflow-x:auto;max-height:none;padding:12px;gap:6px;border-right:0;border-bottom:1px solid var(--line)}.settings-nav .brand{display:none}.tab{min-height:38px;white-space:nowrap;font-size:.8rem;padding:0 12px}.tab small{display:none}.settings-body{grid-template-columns:1fr;padding:16px}.settings-head{padding:16px}.msg-file-img{max-width:100%}}@media(max-width:480px){.header{padding:12px 14px 8px;min-height:56px}.search{height:40px}.chat{padding:8px 10px;gap:10px;margin:0 4px 3px;border-radius:14px}.avatar{width:40px;height:40px;border-radius:12px}.chat:after{left:60px}.chat-header{min-height:54px;padding:10px 12px;gap:10px}.head-main{gap:10px}.head-title{font-size:15px;margin-bottom:2px}.chat-header .avatar{width:36px;height:36px;border-radius:12px}.chat-header .row{gap:2px}.chat-header .icon{width:32px;height:32px;border-radius:10px}.chat-header .icon svg{width:18px;height:18px}.messages{padding:12px 8px;gap:6px}.msg{max-width:90%;padding:10px 12px 8px;border-radius:18px;font-size:14px}.msg.in{border-top-left-radius:6px}.msg.out{border-top-right-radius:6px}.compose{padding:8px 10px 12px}.compose-row{gap:4px}.compose .icon{width:32px;height:32px;border-radius:10px}.compose .icon svg{width:18px;height:18px}.compose textarea{min-height:40px;padding:10px 12px;border-radius:14px;font-size:16px}.send{height:40px;width:40px;border-radius:12px}.send svg{width:18px;height:18px}.empty h1{font-size:20px}.empty p{font-size:13px}.modal{padding:8px}.settings{border-radius:16px;height:calc(100vh - 16px)}.settings-head,.settings-body{padding:12px}.toast{bottom:16px;padding:10px 16px;font-size:12px;border-radius:12px}}@media(display-mode:standalone){.app{padding-top:env(safe-area-inset-top)}.compose{padding-bottom:calc(12px + env(safe-area-inset-bottom))}}@media (hover:none)and(pointer:coarse){.icon{min-width:36px;min-height:36px}.pill{min-height:36px}}
