:root{--bg: #060814;--bg-2: #0a0e20;--bg-3: #0e1430;--glass: rgba(255, 255, 255, .045);--glass-2: rgba(255, 255, 255, .07);--glass-strong: rgba(255, 255, 255, .1);--stroke: rgba(255, 255, 255, .08);--stroke-2: rgba(255, 255, 255, .14);--text: #eaedf7;--text-dim: #9aa3bd;--text-faint: #626b86;--brand-1: #6366f1;--brand-2: #a855f7;--brand-3: #ec4899;--accent: #8b5cf6;--accent-soft: rgba(139, 92, 246, .16);--grad: linear-gradient(135deg, #6366f1 0%, #a855f7 50%, #ec4899 100%);--grad-soft: linear-gradient(135deg, rgba(99, 102, 241, .85), rgba(168, 85, 247, .85));--success: #2dd4a7;--danger: #fb5c72;--online: #34e3a4;--r-sm: 10px;--r-md: 14px;--r-lg: 20px;--r-xl: 28px;--r-full: 999px;--shadow-sm: 0 4px 16px rgba(0, 0, 0, .3);--shadow-md: 0 16px 48px rgba(0, 0, 0, .45);--shadow-glow: 0 12px 40px rgba(124, 92, 246, .35);--font-display: "Space Grotesk", "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}button,input,textarea{font-family:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}::selection{background:#a855f759}*::-webkit-scrollbar{width:9px;height:9px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:#ffffff17;border-radius:999px;border:2px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:#ffffff2e;background-clip:padding-box}.aurora{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;background:radial-gradient(120% 120% at 100% 0%,rgba(99,102,241,.16),transparent 45%),radial-gradient(120% 120% at 0% 100%,rgba(236,72,153,.13),transparent 45%),var(--bg)}.aurora:before,.aurora:after{content:"";position:absolute;width:60vw;height:60vw;border-radius:50%;filter:blur(120px);opacity:.55;will-change:transform}.aurora:before{top:-20vw;left:-10vw;background:radial-gradient(circle,#5b3fe0,transparent 60%);animation:drift1 22s ease-in-out infinite}.aurora:after{bottom:-25vw;right:-10vw;background:radial-gradient(circle,#ec4899,transparent 60%);animation:drift2 26s ease-in-out infinite}.aurora .orb{position:absolute;top:30%;left:45%;width:36vw;height:36vw;border-radius:50%;filter:blur(120px);opacity:.4;background:radial-gradient(circle,#06b6d4,transparent 60%);animation:drift3 30s ease-in-out infinite}.aurora .grain{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}@keyframes drift1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(8vw,6vw) scale(1.12)}}@keyframes drift2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-7vw,-5vw) scale(1.15)}}@keyframes drift3{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-6vw,4vw) scale(1.1)}66%{transform:translate(5vw,-6vw) scale(.95)}}.glass{background:var(--glass);border:1px solid var(--stroke);backdrop-filter:blur(22px) saturate(140%);-webkit-backdrop-filter:blur(22px) saturate(140%)}.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:50px;padding:0 22px;border-radius:var(--r-md);font-weight:600;font-size:15px;letter-spacing:.2px;transition:transform .15s ease,box-shadow .25s ease,opacity .2s ease;-webkit-user-select:none;user-select:none}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover:not(:disabled){box-shadow:0 16px 50px #7c5cf680;transform:translateY(-1px)}.btn-ghost{background:var(--glass-2);border:1px solid var(--stroke);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--glass-strong)}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:8px}.field label{font-size:13px;font-weight:500;color:var(--text-dim);letter-spacing:.3px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap .icon{position:absolute;left:16px;color:var(--text-faint);display:flex;pointer-events:none}.input{width:100%;height:52px;padding:0 16px;border-radius:var(--r-md);background:#ffffff09;border:1px solid var(--stroke);color:var(--text);font-size:15px;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.input::placeholder{color:var(--text-faint)}.input:focus{outline:none;border-color:#a855f799;background:#ffffff0f;box-shadow:0 0 0 4px #8b5cf624}.input.has-icon{padding-left:46px}.error-text{color:var(--danger);font-size:13px;min-height:18px}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-screen{position:relative;z-index:1;height:100%;display:grid;grid-template-columns:1.05fr 1fr}.auth-hero{position:relative;padding:56px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:700;font-size:22px;letter-spacing:.5px}.brand .mark{width:40px;height:40px;border-radius:12px;background:var(--grad);display:grid;place-items:center;box-shadow:var(--shadow-glow)}.hero-copy h1{font-family:var(--font-display);font-size:clamp(34px,4vw,56px);line-height:1.05;font-weight:700;letter-spacing:-1px;margin-bottom:20px}.hero-copy p{color:var(--text-dim);font-size:17px;line-height:1.6;max-width:460px}.hero-badges{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:var(--r-full);font-size:13px;color:var(--text-dim);background:var(--glass);border:1px solid var(--stroke)}.hero-dot{width:7px;height:7px;border-radius:50%;background:var(--grad)}.auth-panel{display:grid;place-items:center;padding:40px;position:relative}.auth-card{width:100%;max-width:420px;padding:38px;border-radius:var(--r-xl);background:var(--glass);border:1px solid var(--stroke);backdrop-filter:blur(28px) saturate(150%);-webkit-backdrop-filter:blur(28px) saturate(150%);box-shadow:var(--shadow-md)}.auth-card h2{font-family:var(--font-display);font-size:27px;font-weight:700;margin-bottom:6px}.auth-card .sub{color:var(--text-dim);font-size:14.5px;margin-bottom:26px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-foot{margin-top:22px;text-align:center;color:var(--text-dim);font-size:14px}.auth-foot a{color:var(--text);font-weight:600}.auth-foot a:hover{color:var(--brand-2)}.code-row{display:flex;gap:10px;justify-content:space-between}.code-box{width:56px;height:64px;border-radius:var(--r-md);background:#ffffff09;border:1px solid var(--stroke);text-align:center;font-size:26px;font-weight:700;font-family:var(--font-display);color:var(--text);transition:border-color .2s,box-shadow .2s,background .2s}.code-box:focus{outline:none;border-color:#a855f7b3;background:#ffffff12;box-shadow:0 0 0 4px #8b5cf629}@media (max-width: 920px){.auth-screen{grid-template-columns:1fr}.auth-hero{display:none}}.app-shell{position:relative;z-index:1;height:100%;display:grid;grid-template-columns:78px 360px 1fr;gap:0}.rail{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 0;background:#080b1899;border-right:1px solid var(--stroke);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.rail-logo{width:44px;height:44px;border-radius:13px;background:var(--grad);display:grid;place-items:center;box-shadow:var(--shadow-glow);margin-bottom:8px}.rail-btn{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;color:var(--text-dim);position:relative;transition:background .2s,color .2s,transform .15s}.rail-btn:hover{background:var(--glass-2);color:var(--text)}.rail-btn.active{background:var(--accent-soft);color:#fff}.rail-btn.active:before{content:"";position:absolute;left:-20px;width:3px;height:24px;border-radius:3px;background:var(--grad)}.rail-spacer{flex:1}.sidebar{background:#090c1a8c;border-right:1px solid var(--stroke);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column;min-height:0}.sidebar-head{padding:22px 20px 14px}.sidebar-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sidebar-title h1{font-family:var(--font-display);font-size:23px;font-weight:700}.icon-btn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;color:var(--text-dim);background:var(--glass-2);border:1px solid var(--stroke);transition:background .2s,color .2s,transform .15s}.icon-btn:hover{background:var(--glass-strong);color:var(--text)}.icon-btn:active{transform:scale(.94)}.search{position:relative;display:flex;align-items:center}.search .icon{position:absolute;left:14px;color:var(--text-faint);display:flex}.search input{width:100%;height:44px;padding:0 14px 0 42px;border-radius:var(--r-full);background:#ffffff0a;border:1px solid var(--stroke);color:var(--text);font-size:14.5px;transition:border-color .2s,background .2s}.search input:focus{outline:none;border-color:#a855f780;background:#ffffff12}.chat-list{flex:1;overflow-y:auto;padding:6px 12px 16px;min-height:0}.list-label{font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--text-faint);padding:14px 10px 8px;font-weight:600}.chat-item{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:var(--r-md);cursor:pointer;transition:background .16s ease;position:relative}.chat-item:hover{background:var(--glass)}.chat-item.active{background:var(--glass-2)}.chat-item.active:after{content:"";position:absolute;right:0;top:18%;height:64%;width:3px;border-radius:3px;background:var(--grad)}.chat-meta{flex:1;min-width:0}.chat-row1{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.chat-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{font-size:11.5px;color:var(--text-faint);flex-shrink:0}.chat-row2{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:3px}.chat-preview{font-size:13.5px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{min-width:20px;height:20px;padding:0 6px;border-radius:var(--r-full);background:var(--grad);color:#fff;font-size:11.5px;font-weight:700;display:grid;place-items:center;flex-shrink:0}.avatar{position:relative;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;color:#fff;overflow:visible}.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.avatar .presence{position:absolute;right:-1px;bottom:-1px;width:32%;height:32%;min-width:9px;min-height:9px;border-radius:50%;background:var(--online);border:2.5px solid var(--bg-2);box-shadow:0 0 8px #34e3a4b3}.pane{display:flex;flex-direction:column;min-height:0;background:radial-gradient(80% 60% at 50% 0%,rgba(124,92,246,.06),transparent 60%)}.pane-empty{flex:1;display:grid;place-items:center;text-align:center;padding:40px}.pane-empty .glow{width:120px;height:120px;border-radius:32px;background:var(--grad);display:grid;place-items:center;margin:0 auto 26px;box-shadow:var(--shadow-glow);animation:float 5s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.pane-empty h2{font-family:var(--font-display);font-size:26px;margin-bottom:10px}.pane-empty p{color:var(--text-dim);max-width:380px}.conv-head{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--stroke);background:#090c1a80;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.conv-head .who{flex:1;min-width:0}.conv-head .who .nm{font-weight:600;font-size:16px}.conv-head .who .st{font-size:12.5px;color:var(--text-dim);display:flex;align-items:center;gap:6px}.conv-head .who .st.online{color:var(--online)}.conv-actions{display:flex;gap:8px}.messages{flex:1;overflow-y:auto;padding:22px clamp(16px,6%,90px);display:flex;flex-direction:column;gap:3px;min-height:0}.day-sep{align-self:center;margin:16px 0 12px;padding:5px 14px;border-radius:var(--r-full);font-size:12px;color:var(--text-dim);background:var(--glass);border:1px solid var(--stroke)}.msg-row{display:flex;gap:10px;align-items:flex-end;max-width:74%;position:relative}.msg-row.out{align-self:flex-end;flex-direction:row-reverse}.msg-row.in{align-self:flex-start}.msg-row.grouped{margin-top:2px}.msg-row.fresh{margin-top:12px}.bubble{position:relative;padding:10px 14px;border-radius:20px;font-size:14.5px;line-height:1.45;word-wrap:break-word;white-space:pre-wrap;max-width:100%}.msg-row.in .bubble{background:var(--glass-2);border:1px solid var(--stroke);border-bottom-left-radius:7px}.msg-row.out .bubble{background:var(--grad-soft);color:#fff;border-bottom-right-radius:7px;box-shadow:0 6px 20px #7c5cf640}.msg-row.grouped.in .bubble{border-bottom-left-radius:20px;border-top-left-radius:7px}.msg-row.grouped.out .bubble{border-bottom-right-radius:20px;border-top-right-radius:7px}.bubble .reply-quote{border-left:3px solid rgba(255,255,255,.5);padding:4px 10px;margin-bottom:6px;border-radius:6px;background:#0000002e;font-size:13px}.bubble .reply-quote .q-name{font-weight:600;opacity:.9;font-size:12px}.bubble .reply-quote .q-text{opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.bubble .meta{display:inline-flex;align-items:center;gap:5px;float:right;margin:6px 0 -2px 12px;font-size:11px;opacity:.75;-webkit-user-select:none;user-select:none}.bubble .meta .edited{font-style:italic}.tick{display:inline-flex}.tick.read{color:#6ee7ff}.bubble .fwd{font-size:11.5px;opacity:.7;margin-bottom:4px;display:flex;align-items:center;gap:5px}.bubble.media{padding:5px}.bubble.media img,.bubble.media video{max-width:320px;max-height:360px;width:100%;border-radius:15px;display:block}.bubble .file-att{display:flex;align-items:center;gap:12px;padding:4px 4px 4px 0;min-width:220px}.file-ic{width:42px;height:42px;border-radius:12px;background:#ffffff29;display:grid;place-items:center;flex-shrink:0}.file-att .fn{font-weight:600;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.file-att .fs{font-size:11.5px;opacity:.7}.reactions{display:flex;gap:5px;margin-top:5px;flex-wrap:wrap}.msg-row.out .reactions{justify-content:flex-end}.reaction{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-full);background:var(--glass-2);border:1px solid var(--stroke);font-size:13px;cursor:pointer;transition:transform .12s,background .18s}.reaction:hover{transform:scale(1.06)}.reaction.mine{background:var(--accent-soft);border-color:#a855f780}.reaction .cnt{font-size:11.5px;font-weight:600;color:var(--text-dim)}.msg-tools{position:absolute;top:-14px;display:flex;gap:4px;padding:4px;border-radius:var(--r-full);background:#0e1226eb;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;z-index:4;box-shadow:var(--shadow-sm)}.msg-row:hover .msg-tools{opacity:1;transform:translateY(0)}.msg-row.out .msg-tools{right:6px}.msg-row.in .msg-tools{left:46px}.tool{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:var(--text-dim);transition:background .15s,color .15s}.tool:hover{background:var(--glass-strong);color:var(--text)}.emoji-pop{position:absolute;top:-52px;display:flex;gap:4px;padding:7px 9px;border-radius:var(--r-full);background:#0e1226f2;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-md);z-index:6}.msg-row.out .emoji-pop{right:6px}.msg-row.in .emoji-pop{left:46px}.emoji-pop button{font-size:20px;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;transition:transform .12s,background .15s}.emoji-pop button:hover{transform:scale(1.25) translateY(-2px);background:var(--glass-2)}.typing-row{align-self:flex-start;display:flex;align-items:center;gap:10px;margin-top:6px}.typing-bubble{background:var(--glass-2);border:1px solid var(--stroke);border-radius:18px 18px 18px 7px;padding:13px 16px;display:flex;gap:5px}.typing-bubble span{width:7px;height:7px;border-radius:50%;background:var(--text-dim);animation:typing 1.3s infinite ease-in-out}.typing-bubble span:nth-child(2){animation-delay:.18s}.typing-bubble span:nth-child(3){animation-delay:.36s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-5px);opacity:1}}.composer{padding:14px clamp(16px,6%,90px) 20px;position:relative}.emoji-picker{position:absolute;bottom:calc(100% - 6px);left:clamp(16px,6%,90px);width:min(360px,calc(100% - (2*clamp(16px,6%,90px))));height:320px;display:flex;flex-direction:column;background:var(--surface, #1a1330);border:1px solid var(--stroke);border-radius:var(--r-lg);box-shadow:0 18px 50px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:50;overflow:hidden;animation:emojiPop .14s ease-out}@keyframes emojiPop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.emoji-tabs{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid var(--stroke);overflow-x:auto;flex:0 0 auto}.emoji-tab{background:transparent;border:none;cursor:pointer;font-size:20px;line-height:1;padding:6px;border-radius:8px;opacity:.55;transition:opacity .15s,background .15s}.emoji-tab:hover{opacity:.9}.emoji-tab.active{opacity:1;background:#8b5cf62e}.emoji-title{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-dim);padding:8px 12px 4px;flex:0 0 auto}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:2px;padding:4px 8px 10px;overflow-y:auto;flex:1 1 auto}.emoji-cell{background:transparent;border:none;cursor:pointer;font-size:22px;line-height:1;padding:5px 0;border-radius:8px;transition:background .12s,transform .08s}.emoji-cell:hover{background:#8b5cf629;transform:scale(1.15)}.icon-btn.active{color:var(--brand-2)}.reply-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:10px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--stroke);border-left:3px solid var(--accent)}.reply-bar .rb-body{flex:1;min-width:0}.reply-bar .rb-name{font-size:12.5px;font-weight:600;color:var(--brand-2)}.reply-bar .rb-text{font-size:13px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.composer-box{display:flex;align-items:flex-end;gap:10px;padding:8px 10px 8px 8px;border-radius:var(--r-lg);background:var(--glass);border:1px solid var(--stroke);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);transition:border-color .2s,box-shadow .2s}.composer-box:focus-within{border-color:#a855f773;box-shadow:0 0 0 4px #8b5cf61a}.composer textarea{flex:1;resize:none;border:none;background:transparent;color:var(--text);font-size:15px;line-height:1.4;max-height:160px;padding:10px 4px}.composer textarea:focus{outline:none}.composer textarea::placeholder{color:var(--text-faint)}.send-btn{width:46px;height:46px;border-radius:14px;background:var(--grad);display:grid;place-items:center;color:#fff;flex-shrink:0;box-shadow:var(--shadow-glow);transition:transform .15s,box-shadow .2s,opacity .2s}.send-btn:hover{transform:translateY(-1px)}.send-btn:disabled{opacity:.45;box-shadow:none;cursor:not-allowed}.composer .upload-chip{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:8px 12px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--stroke);font-size:13px;color:var(--text-dim)}.search-result{display:flex;align-items:center;gap:13px;padding:11px 12px;border-radius:var(--r-md);cursor:pointer;transition:background .16s}.search-result:hover{background:var(--glass)}.search-result .nick{font-size:13px;color:var(--text-faint)}.empty-hint{text-align:center;color:var(--text-faint);font-size:14px;padding:40px 20px}.menu{position:absolute;min-width:180px;padding:7px;border-radius:var(--r-md);background:#0e1226f5;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow-md);z-index:40}.menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border-radius:var(--r-sm);font-size:14px;color:var(--text);transition:background .14s}.menu-item:hover{background:var(--glass-2)}.menu-item.danger{color:var(--danger)}.menu-sep{height:1px;margin:5px 6px;background:var(--stroke)}.toast-wrap{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:100;display:flex;flex-direction:column;gap:10px;align-items:center}.toast{padding:12px 18px;border-radius:var(--r-full);background:#0e1226f5;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-md);font-size:14px;display:flex;align-items:center;gap:10px}.toast.error{border-color:#fb5c7266}.center-load{flex:1;display:grid;place-items:center}.skeleton{background:linear-gradient(100deg,#ffffff0a 30%,#ffffff17,#ffffff0a 70%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--r-md)}@keyframes shimmer{to{background-position:-200% 0}}@media (max-width: 860px){.app-shell{grid-template-columns:64px 1fr}.app-shell.has-conv .sidebar{display:none}.app-shell:not(.has-conv) .pane{display:none}}.rail-badge{position:absolute;top:4px;right:4px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--grad);color:#fff;font-size:10.5px;font-weight:700;display:grid;place-items:center;border:2px solid var(--bg)}.tag-pill{display:inline-flex;align-items:center;margin-left:7px;padding:2px 8px;border-radius:var(--r-full);font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--brand-2);background:var(--accent-soft);border:1px solid rgba(168,92,246,.4);vertical-align:middle}.sender-name{font-size:12.5px;font-weight:700;margin-bottom:3px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#0406109e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;place-items:center;padding:24px}.modal{width:100%;border-radius:var(--r-xl);background:#101428eb;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);box-shadow:var(--shadow-md);max-height:88vh;display:flex;flex-direction:column;overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 14px;border-bottom:1px solid var(--stroke)}.modal-head h3{font-family:var(--font-display);font-size:19px;font-weight:700}.modal-body{padding:22px;overflow-y:auto}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--stroke)}.avatar-edit{position:relative;border-radius:50%;flex-shrink:0}.avatar-edit-badge{position:absolute;right:-2px;bottom:-2px;width:26px;height:26px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;border:3px solid var(--bg-2)}.toggle-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 15px;border-radius:var(--r-md);background:var(--glass);border:1px solid var(--stroke);text-align:left}.toggle-title{font-weight:600;font-size:14.5px}.toggle-sub{font-size:12.5px;color:var(--text-dim);margin-top:2px}.switch{width:46px;height:27px;border-radius:var(--r-full);background:#ffffff1f;position:relative;flex-shrink:0;transition:background .2s}.switch.on{background:var(--accent)}.switch .knob{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;transition:transform .2s}.switch.on .knob{transform:translate(19px)}.chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 6px 4px 4px;border-radius:var(--r-full);background:var(--glass-2);border:1px solid var(--stroke);font-size:13px}.chip button{display:grid;place-items:center;width:18px;height:18px;border-radius:50%;color:var(--text-dim)}.chip button:hover{background:var(--glass-strong);color:var(--text)}.member-results{margin-top:8px;max-height:220px;overflow-y:auto;border-radius:var(--r-md);background:#0000002e;border:1px solid var(--stroke);padding:4px}.add-ic{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:var(--brand-2);background:var(--accent-soft)}.channel-feed{align-items:stretch;gap:16px;max-width:760px;width:100%;margin:0 auto}.post-card{background:var(--glass);border:1px solid var(--stroke);border-radius:var(--r-lg);padding:16px 18px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.post-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.post-author{font-weight:600;font-size:15px}.post-time{font-size:12px;color:var(--text-faint)}.post-text{font-size:15px;line-height:1.55;white-space:pre-wrap;word-break:break-word}.post-media img,.post-media video{width:100%;max-height:460px;object-fit:cover;border-radius:var(--r-md)}.post-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px}.post-reactions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.post-comment-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:var(--r-full);background:var(--glass-2);border:1px solid var(--stroke);color:var(--text-dim);font-size:13.5px;font-weight:500;transition:background .18s,color .18s}.post-comment-btn:hover{background:var(--glass-strong);color:var(--text)}.react-add{position:relative}.react-trigger{width:34px;height:34px}.react-pop{position:absolute;bottom:42px;left:0;display:flex;gap:4px;padding:7px 9px;border-radius:var(--r-full);background:#0e1226f5;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .15s,transform .15s;z-index:8}.react-add:hover .react-pop{opacity:1;pointer-events:auto;transform:translateY(0)}.react-pop button{font-size:20px;width:32px;height:32px;border-radius:50%;display:grid;place-items:center;transition:transform .12s,background .15s}.react-pop button:hover{transform:scale(1.25) translateY(-2px);background:var(--glass-2)}.comment-row{display:flex;gap:11px;padding:10px 6px}.comment-body{flex:1;min-width:0}.comment-meta{display:flex;align-items:baseline;gap:8px}.comment-meta b{font-size:13.5px}.comment-meta span{font-size:11.5px;color:var(--text-faint)}.comment-text{font-size:14px;color:var(--text);margin-top:2px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.story-ring{padding:2.5px;border-radius:50%;background:#ffffff1f;flex-shrink:0}.story-ring.unviewed{background:conic-gradient(from 200deg,#6366f1,#a855f7,#ec4899,#6366f1)}.story-ring.big{padding:3px}.story-add-ring{width:51px;height:51px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--grad);flex-shrink:0}.story-add-ring.big{width:82px;height:82px}.story-tray{flex:1;display:flex;flex-wrap:wrap;align-content:flex-start;gap:22px;padding:36px;overflow-y:auto}.story-tile{display:flex;flex-direction:column;align-items:center;gap:10px;width:100px}.story-tile span{font-size:13px;color:var(--text-dim);max-width:92px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.story-tile.add .story-add-ring{border:2px dashed rgba(255,255,255,.25);background:var(--glass-2);color:var(--brand-2)}.story-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#03040ceb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:grid;place-items:center}.story-nav-side{position:absolute;top:0;bottom:0;width:30%;z-index:2;background:transparent}.story-nav-side.left{left:0;cursor:w-resize}.story-nav-side.right{right:0;cursor:e-resize}.story-stage{position:relative;width:min(440px,94vw);height:min(86vh,780px);background:#0a0e1a;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-md);border:1px solid var(--stroke)}.story-bars{position:absolute;top:12px;left:12px;right:12px;display:flex;gap:5px;z-index:4}.story-bar{flex:1;height:3px;border-radius:3px;background:#ffffff47;overflow:hidden}.story-bar-fill{height:100%;background:#fff;border-radius:3px}.story-top{position:absolute;top:26px;left:14px;right:14px;z-index:4;display:flex;align-items:center;justify-content:space-between}.story-owner{display:flex;align-items:center;gap:10px}.story-name{font-weight:600;font-size:14px;color:#fff}.story-when{font-size:12px;color:#ffffffb3}.story-icon{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;background:#0000004d}.story-icon:hover{background:#00000080}.story-media{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:1}.story-media img,.story-media video{width:100%;height:100%;object-fit:contain}.story-caption{position:absolute;bottom:70px;left:18px;right:18px;z-index:4;color:#fff;font-size:15px;text-align:center;text-shadow:0 2px 12px rgba(0,0,0,.8)}.story-viewers-btn{position:absolute;bottom:18px;left:50%;transform:translate(-50%);z-index:5;padding:9px 18px;border-radius:var(--r-full);background:#00000073;color:#fff;font-size:13.5px;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.story-viewers-sheet{position:absolute;left:0;right:0;bottom:0;z-index:6;max-height:55%;background:#0e1226f7;border-top:1px solid var(--stroke-2);border-radius:var(--r-xl) var(--r-xl) 0 0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;flex-direction:column}.story-viewers-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 10px}.story-viewers-list{overflow-y:auto;padding:0 12px 14px}.story-dropzone{width:100%;min-height:220px;border-radius:var(--r-lg);border:2px dashed var(--stroke-2);background:var(--glass);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-dim);transition:background .2s,border-color .2s}.story-dropzone:hover{background:var(--glass-2);border-color:#a85cf680}.story-preview{text-align:center}.story-preview img,.story-preview video{max-width:100%;max-height:360px;border-radius:var(--r-lg)}.settings-modal{width:100%;max-width:780px;height:600px;max-height:90vh;display:grid;grid-template-columns:220px 1fr;border-radius:var(--r-xl);background:#101428f0;border:1px solid var(--stroke-2);-webkit-backdrop-filter:blur(30px) saturate(150%);backdrop-filter:blur(30px) saturate(150%);box-shadow:var(--shadow-md);overflow:hidden}.settings-nav{display:flex;flex-direction:column;gap:4px;padding:18px 12px;border-right:1px solid var(--stroke);background:#080b1866}.settings-me{display:flex;align-items:center;gap:11px;padding:8px 10px 16px}.settings-me .chat-name{font-size:14.5px}.settings-tab{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:var(--r-md);color:var(--text-dim);font-size:14.5px;font-weight:500;text-align:left;transition:background .16s,color .16s}.settings-tab:hover{background:var(--glass);color:var(--text)}.settings-tab.active{background:var(--accent-soft);color:#fff}.settings-tab.danger{color:var(--danger)}.settings-content{display:flex;flex-direction:column;min-height:0}.settings-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 14px;border-bottom:1px solid var(--stroke)}.settings-head h3{font-family:var(--font-display);font-size:19px}.settings-scroll{overflow-y:auto;padding:22px 24px}.settings-pane{display:block}.settings-group-label{font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-faint);font-weight:600;margin-bottom:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--stroke)}.settings-row.col{flex-direction:column;align-items:stretch;gap:10px}.settings-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--accent-soft);color:var(--brand-2)}.status-dot{font-size:12px;font-weight:600;padding:4px 12px;border-radius:var(--r-full);background:var(--glass-2);color:var(--text-dim);border:1px solid var(--stroke)}.status-dot.on{color:var(--success);border-color:#2dd4a766}.segmented{display:flex;gap:4px;padding:4px;border-radius:var(--r-md);background:#0003;border:1px solid var(--stroke)}.segmented button{flex:1;padding:8px;border-radius:var(--r-sm);font-size:13px;font-weight:500;color:var(--text-dim);transition:background .15s,color .15s}.segmented button.active{background:var(--grad);color:#fff}.lang-grid{display:flex;flex-wrap:wrap;gap:8px}.lang-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r-full);background:var(--glass-2);border:1px solid var(--stroke);font-size:13.5px;color:var(--text-dim);transition:background .15s,color .15s,border-color .15s}.lang-chip.active{background:var(--accent-soft);color:#fff;border-color:#a85cf680}.switch{cursor:pointer}@media (max-width: 640px){.settings-modal{grid-template-columns:1fr;height:90vh}.settings-nav{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--stroke)}.settings-me{display:none}}.poll-card{min-width:260px;max-width:340px}.poll-card.loading{display:grid;place-items:center;padding:24px}.poll-top{display:flex;gap:8px;margin-bottom:6px}.poll-kind{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--brand-2)}.poll-kind.dim{color:var(--text-faint)}.poll-q{font-weight:600;font-size:15px;margin-bottom:12px;line-height:1.35}.poll-options{display:flex;flex-direction:column;gap:8px}.poll-option{position:relative;display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--r-md);border:1px solid var(--stroke);background:#ffffff0a;overflow:hidden;text-align:left;transition:border-color .15s,background .15s}.msg-row.out .poll-option{background:#00000029;border-color:#ffffff2e}.poll-option:not(:disabled):hover{border-color:#a85cf680}.poll-option.sel{border-color:var(--brand-2)}.poll-bar{position:absolute;left:0;top:0;bottom:0;background:var(--accent-soft);z-index:0;transition:width .5s cubic-bezier(.16,1,.3,1)}.poll-option.correct .poll-bar{background:#2dd4a738}.poll-check{position:relative;z-index:1;width:20px;height:20px;border-radius:50%;border:2px solid var(--stroke-2);display:grid;place-items:center;color:#fff;flex-shrink:0}.poll-option.sel .poll-check{background:var(--grad);border-color:transparent}.poll-option.correct .poll-check{background:var(--success);border-color:transparent}.poll-otext{position:relative;z-index:1;flex:1;font-size:14px}.poll-pct{position:relative;z-index:1;font-size:13px;font-weight:600;color:var(--text-dim)}.poll-explain{margin-top:10px;padding:9px 12px;border-radius:var(--r-sm);background:#f5c8421f;border:1px solid rgba(245,200,66,.25);font-size:13px;color:#f5d77a}.poll-foot{display:flex;align-items:center;justify-content:space-between;margin-top:12px}.poll-count{font-size:12.5px;color:var(--text-dim)}.poll-count-btn{text-decoration:underline;cursor:pointer;background:none;border:none;padding:0;font-size:12.5px;color:var(--text-dim);transition:color .15s}.poll-count-btn:hover{color:var(--brand-2)}.poll-vote-btn{padding:8px 20px;border-radius:var(--r-full);background:var(--grad);color:#fff;font-weight:600;font-size:13.5px;transition:opacity .2s}.poll-vote-btn:disabled{opacity:.45;cursor:not-allowed}.poll-retract{font-size:13px;color:var(--brand-2);text-decoration:underline}.poll-option-wrap{display:flex;flex-direction:column;gap:5px}.poll-voters{display:flex;align-items:center;gap:3px;padding-left:4px}.poll-voters .avatar{border-radius:50%;border:1.5px solid var(--bg-2);margin-left:-4px;flex-shrink:0}.poll-voters .avatar:first-child{margin-left:0}.poll-voter-more{font-size:11px;color:var(--text-faint);margin-left:4px}.poll-voters-loading{display:grid;place-items:center;padding:32px}.poll-voters-anon{padding:24px 0;text-align:center;color:var(--text-faint);font-size:14px}.poll-voters-list{display:flex;flex-direction:column;gap:16px}.poll-voters-group{display:flex;flex-direction:column;gap:6px}.poll-voters-option-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint)}.poll-voters-row{display:flex;align-items:center;gap:10px;padding:5px 0}.poll-voters-name{font-size:14px}.poll-opt-input{display:flex;align-items:center;gap:8px;margin-bottom:8px}.poll-correct{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;border:2px solid var(--stroke-2);color:transparent;flex-shrink:0;transition:background .15s,border-color .15s,color .15s}.poll-correct.on{background:var(--success);border-color:transparent;color:#fff}.poll-add-opt{display:inline-flex;align-items:center;gap:7px;color:var(--brand-2);font-weight:600;font-size:13.5px;padding:6px 4px}.reels-pane{padding:0;overflow:hidden}.reels-feed{height:100%;overflow-y:auto;scroll-snap-type:y mandatory;scrollbar-width:none}.reels-feed::-webkit-scrollbar{display:none}.reel-slide{height:100%;scroll-snap-align:start;display:grid;place-items:center;padding:18px}.reel-card{position:relative;height:100%;max-height:860px;aspect-ratio:9 / 16;max-width:100%;border-radius:var(--r-xl);overflow:hidden;background:#05060f;box-shadow:var(--shadow-md);border:1px solid var(--stroke)}.reel-card>video{width:100%;height:100%;object-fit:cover;cursor:pointer}.reel-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 38%);pointer-events:none}.reel-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#ffffffd9;z-index:3}.reel-mute{position:absolute;top:16px;right:16px;z-index:4;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;background:#0006;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.reel-info{position:absolute;left:18px;right:80px;bottom:22px;z-index:4;color:#fff}.reel-creator{display:flex;align-items:center;gap:10px;margin-bottom:10px}.reel-name{font-weight:700;font-size:15px;text-shadow:0 1px 6px rgba(0,0,0,.6)}.reel-follow{margin-left:4px;padding:5px 14px;border-radius:var(--r-full);border:1.5px solid #fff;color:#fff;font-size:12.5px;font-weight:600}.reel-caption{font-size:14px;line-height:1.45;text-shadow:0 1px 6px rgba(0,0,0,.7);margin-bottom:6px}.reel-tags{display:flex;flex-wrap:wrap;gap:8px}.reel-tags span{color:#7fd4ff;font-weight:600;font-size:13.5px}.reel-music{font-size:13px;margin-top:8px;opacity:.9}.reel-actions{position:absolute;right:14px;bottom:26px;z-index:4;display:flex;flex-direction:column;gap:20px}.reel-act{display:flex;flex-direction:column;align-items:center;gap:5px;color:#fff;font-size:12.5px;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.6);transition:transform .15s}.reel-act:active{transform:scale(.88)}.reel-act.liked{color:#ff4d6d}.call-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:radial-gradient(120% 120% at 50% 0%,rgba(99,102,241,.2),transparent 55%),#04050ef5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:grid;place-items:center}.call-remote-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;background:#05060f}.call-stage{position:relative;z-index:2;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px}.call-stage.video{justify-content:flex-end;padding-bottom:40px;background:linear-gradient(to top,rgba(0,0,0,.55),transparent 40%)}.call-peer{text-align:center}.call-avatar-ring{display:inline-block;padding:5px;border-radius:50%;background:var(--grad);margin-bottom:22px;box-shadow:var(--shadow-glow);animation:callpulse 2s ease-in-out infinite}@keyframes callpulse{0%,to{box-shadow:0 0 #7c5cf680}50%{box-shadow:0 0 0 18px #7c5cf600}}.call-peer h2{font-family:var(--font-display);font-size:28px;color:#fff}.call-peer p{color:var(--text-dim);margin-top:8px;font-size:15px}.call-local-video{position:absolute;top:22px;right:22px;width:180px;aspect-ratio:9/16;max-height:240px;object-fit:cover;border-radius:var(--r-md);border:2px solid var(--stroke-2);background:#05060f;z-index:3;box-shadow:var(--shadow-md)}.call-controls{display:flex;gap:22px;align-items:center;z-index:3}.call-btn{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;color:#fff;transition:transform .15s,background .18s}.call-btn:active{transform:scale(.92)}.call-btn.ctrl{background:#ffffff24;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.call-btn.ctrl.active{background:#fff;color:#0a0e1a}.call-btn.accept{background:var(--success);box-shadow:0 8px 28px #2dd4a780}.call-btn.decline{background:var(--danger);box-shadow:0 8px 28px #fb5c7273}.call-btn.decline svg{transform:rotate(135deg)}.row-menu{position:absolute;right:8px;top:10px}.row-menu-btn{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--text-dim);background:#0e1226b3;opacity:0;transition:opacity .15s,background .15s,color .15s}.chat-item:hover .row-menu-btn{opacity:1}.row-menu-btn:hover{background:var(--glass-strong);color:var(--text)}.row-menu .menu{min-width:168px}.fwd-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--stroke-2);display:grid;place-items:center;color:#fff;flex-shrink:0;transition:background .15s,border-color .15s}.fwd-check.on{background:var(--grad);border-color:transparent}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;background:#03040ceb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:grid;place-items:center;padding:40px;cursor:zoom-out}.lightbox img{max-width:min(92vw,900px);max-height:88vh;border-radius:var(--r-lg);box-shadow:var(--shadow-md);object-fit:contain;cursor:default}.lightbox-close{position:absolute;top:24px;right:28px;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;color:#fff;background:#ffffff1f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2;transition:background .18s}.lightbox-close:hover{background:#ffffff38}
