:root{--bg: #0a1020;--bg-2: #0e1628;--bg-3: #131d33;--panel: #0f1a30;--panel-2: #162441;--line: rgba(255,255,255,.06);--line-2: rgba(255,255,255,.1);--ink: #e8edf7;--ink-2: #aab3c8;--ink-3: #6b748c;--accent: #4cc9ff;--accent-2: #7dd3fc;--accent-ink: #041020;--danger: #ff6b7a;--good: #3ddc97;--warn: #ffc857;--bubble-in: #1a2744;--bubble-out: #4cc9ff;--bubble-out-ink: #041020;--radius: 14px;--radius-lg: 20px;--radius-sm: 8px;--shadow-1: 0 1px 0 rgba(255,255,255,.04) inset, 0 10px 30px rgba(0,0,0,.35);--shadow-2: 0 30px 80px rgba(0,0,0,.6);--font: "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01";letter-spacing:-.005em}button{font-family:inherit}input,textarea{font-family:inherit;color:inherit}::selection{background:var(--accent);color:var(--accent-ink)}.scroll::-webkit-scrollbar{width:10px;height:10px}.scroll::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:10px}.scroll::-webkit-scrollbar-track{background:transparent}.app{width:100%;height:100%;display:grid;grid-template-columns:72px 300px 1fr 320px;background:var(--bg);color:var(--ink);overflow:hidden}.rail{background:#07101f;border-right:1px solid var(--line);padding:18px 0;display:flex;flex-direction:column;align-items:center;gap:10px}.rail .logo{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--accent) 0%,#7dd3fc 100%);display:grid;place-items:center;color:var(--accent-ink);font-weight:800;letter-spacing:-.02em;font-size:17px;box-shadow:0 6px 16px #4cc9ff47;margin-bottom:6px}.rail .divider{width:28px;height:1px;background:var(--line-2);margin:4px 0}.rail .pill{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:#0d1730;color:var(--ink-2);border:1px solid var(--line);cursor:pointer;position:relative;font-weight:700;transition:all .15s ease}.rail .pill:hover{background:var(--panel-2);color:var(--ink)}.rail .pill.active{background:var(--accent);color:var(--accent-ink);border-color:transparent;box-shadow:0 0 0 3px #4cc9ff29}.rail .pill.active:before{content:"";position:absolute;left:-14px;top:10px;bottom:10px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.rail .add{background:transparent;color:var(--ink-3);border:1px dashed var(--line-2)}.rail .add:hover{color:var(--accent);border-color:var(--accent)}.rail .dot{position:absolute;bottom:4px;right:4px;width:10px;height:10px;border-radius:50%;background:var(--good);border:2px solid #07101f}.sidebar{background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;min-width:0}.sidebar .sb-head{padding:18px 18px 12px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:12px}.sb-title-row{display:flex;align-items:center;justify-content:space-between}.sb-title{font-size:17px;font-weight:700;letter-spacing:-.01em}.sb-title .muted{color:var(--ink-3);font-weight:500;margin-left:6px;font-size:13px}.sb-actions{display:flex;gap:6px}.icon-btn{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:transparent;color:var(--ink-2);border:1px solid transparent;cursor:pointer;transition:all .15s ease}.icon-btn:hover{background:var(--bg-3);color:var(--ink)}.icon-btn.accent{color:var(--accent)}.search-box{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;color:var(--ink-2)}.search-box input{background:transparent;border:none;outline:none;color:var(--ink);width:100%;font-size:13px}.search-box kbd{font-family:var(--font-mono);font-size:11px;color:var(--ink-3);padding:2px 5px;border:1px solid var(--line-2);border-radius:4px;background:var(--bg)}.sb-section{padding:14px 12px 6px;display:flex;align-items:center;justify-content:space-between;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);font-weight:600}.sb-section .count{color:var(--ink-3);font-weight:500}.channels{padding:0 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1 1 auto}.channel{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;cursor:pointer;color:var(--ink-2);transition:background .12s ease,color .12s ease;position:relative}.channel:hover{background:var(--bg-3);color:var(--ink)}.channel.active{background:var(--panel-2);color:var(--ink)}.channel.active:before{content:"";position:absolute;left:-8px;top:10px;bottom:10px;width:3px;border-radius:3px;background:var(--accent)}.channel .ch-avatar{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;color:#fff;letter-spacing:-.02em}.channel .ch-body{min-width:0;flex:1}.channel .ch-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.channel .ch-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel .ch-time{font-size:11px;color:var(--ink-3);flex-shrink:0}.channel .ch-last{font-size:12.5px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.channel .ch-lock{color:var(--ink-3);font-size:11px}.channel.unread .ch-last{color:var(--ink)}.channel .ch-badge{background:var(--accent);color:var(--accent-ink);font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px;margin-left:6px}.channel .presence{position:absolute;left:34px;top:32px;width:10px;height:10px;border-radius:50%;border:2px solid var(--panel);background:var(--ink-3)}.channel .presence.online{background:var(--good)}.channel .presence.idle{background:var(--warn)}.sb-foot{padding:10px 12px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}.me-avatar{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px;flex-shrink:0;position:relative}.me-avatar .presence{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:var(--good);border:2px solid var(--panel)}.me-info{flex:1;min-width:0}.me-name{font-size:13px;font-weight:600}.me-status{font-size:11px;color:var(--ink-3)}.me-actions{display:flex;gap:2px}.main{display:flex;flex-direction:column;background:var(--bg-2);min-width:0}.chat-head{height:64px;padding:0 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;background:#0f1a3099;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0}.ch-head-left{display:flex;align-items:center;gap:14px;min-width:0}.chat-avatar{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px;flex-shrink:0}.chat-title-wrap{min-width:0}.chat-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}.chat-title .lock{font-size:10px;color:var(--ink-3);border:1px solid var(--line-2);padding:2px 6px;border-radius:6px;font-family:var(--font-mono);letter-spacing:0;display:inline-flex;align-items:center;gap:4px}.chat-sub{font-size:12px;color:var(--ink-3);margin-top:2px;display:flex;align-items:center;gap:10px}.chat-sub .dot-sep{width:3px;height:3px;background:var(--ink-3);border-radius:50%}.chat-sub .online{color:var(--good);display:inline-flex;align-items:center;gap:5px}.chat-sub .online:before{content:"";width:6px;height:6px;background:var(--good);border-radius:50%;display:inline-block}.ch-head-right{display:flex;align-items:center;gap:4px}.pinned-strip{padding:10px 22px;background:#4cc9ff0a;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;font-size:12.5px;color:var(--ink-2)}.pinned-strip .ps-label{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-weight:600}.messages{flex:1;overflow-y:auto;padding:24px 28px 8px;display:flex;flex-direction:column;gap:4px}.day-sep{display:flex;align-items:center;gap:14px;margin:18px 0 10px;color:var(--ink-3);font-size:11.5px;text-transform:uppercase;letter-spacing:.14em;font-weight:600}.day-sep:before,.day-sep:after{content:"";flex:1;height:1px;background:var(--line)}.msg{display:grid;grid-template-columns:44px 1fr;gap:14px;padding:8px 10px;border-radius:10px;margin:2px -10px;position:relative}.msg:hover{background:#ffffff04}.msg.own{grid-template-columns:1fr 44px}.msg .avatar{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px;align-self:start;letter-spacing:-.02em}.msg.own .avatar{order:2}.msg.own .msg-body{order:1;text-align:right}.msg-head{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.msg.own .msg-head{justify-content:flex-end}.msg-name{font-weight:600;font-size:13.5px}.msg-time{font-size:11px;color:var(--ink-3)}.msg-stack{display:flex;flex-direction:column;gap:4px;max-width:560px}.msg.own .msg-stack{margin-left:auto;align-items:flex-end}.bubble{padding:10px 14px;border-radius:18px;background:var(--bubble-in);color:var(--ink);font-size:14.5px;line-height:1.5;word-wrap:break-word;max-width:560px;text-align:left}.msg.own .bubble{background:var(--bubble-out);color:var(--bubble-out-ink)}.bubble.first{border-top-left-radius:18px}.bubble.mid{border-radius:18px}.msg:not(.own) .msg-stack>.bubble:first-child{border-top-left-radius:6px}.msg:not(.own) .msg-stack>.bubble:last-child{border-bottom-left-radius:6px}.msg.own .msg-stack>.bubble:first-child{border-top-right-radius:6px}.msg.own .msg-stack>.bubble:last-child{border-bottom-right-radius:6px}.msg-footer{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:11px;color:var(--ink-3)}.msg.own .msg-footer{justify-content:flex-end}.msg-footer .read{color:var(--accent);display:inline-flex;align-items:center;gap:2px}.reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.msg.own .reactions{justify-content:flex-end}.reaction{background:var(--bg-3);border:1px solid var(--line-2);border-radius:20px;padding:3px 10px;font-size:12px;display:inline-flex;align-items:center;gap:5px;cursor:pointer;transition:all .15s ease}.reaction:hover{border-color:var(--accent)}.reaction.mine{background:#4cc9ff1f;border-color:#4cc9ff59;color:var(--accent)}.reaction .count{font-weight:600}.msg-tools{position:absolute;top:-14px;right:14px;background:var(--panel-2);border:1px solid var(--line-2);border-radius:10px;padding:3px;display:none;gap:2px;box-shadow:var(--shadow-1);z-index:2}.msg:hover .msg-tools{display:flex}.msg.own .msg-tools{right:auto;left:14px}.msg-tools .icon-btn{width:28px;height:28px;border-radius:6px}.media-photo{border-radius:16px;overflow:hidden;max-width:420px;border:1px solid var(--line);cursor:zoom-in;background:var(--bg-3);display:block;line-height:0;position:relative}.media-photo img{width:100%;display:block}.media-photo .meta{position:absolute;bottom:8px;right:8px;background:#041020b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:4px 8px;border-radius:8px;font-size:11px;color:var(--ink);font-family:var(--font-mono)}.media-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3px;border-radius:16px;overflow:hidden;max-width:420px;border:1px solid var(--line)}.media-grid .cell{cursor:zoom-in;aspect-ratio:1;position:relative}.media-grid .cell img{width:100%;height:100%;object-fit:cover}.media-grid .cell.overlay:after{content:"+" attr(data-more);position:absolute;top:0;right:0;bottom:0;left:0;background:#0a1020a6;display:grid;place-items:center;font-size:22px;color:#fff;font-weight:600}.media-video{border-radius:16px;overflow:hidden;max-width:420px;border:1px solid var(--line);position:relative;cursor:zoom-in;background:var(--bg-3)}.media-video .thumb{width:100%;aspect-ratio:16/10;background-size:cover;background-position:center}.media-video .play{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none}.media-video .play .btn{width:56px;height:56px;border-radius:50%;background:#041020b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.18)}.media-video .duration{position:absolute;bottom:10px;right:10px;background:#041020bf;padding:4px 8px;border-radius:8px;font-size:11px;font-family:var(--font-mono)}.media-video .duration.left{left:10px;right:auto}.voice{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--bubble-in);border-radius:18px;min-width:260px;max-width:360px}.msg.own .voice{background:var(--bubble-out);color:var(--bubble-out-ink)}.voice .play-btn{width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0}.msg.own .voice .play-btn{background:var(--accent-ink);color:var(--accent)}.voice .waveform{flex:1;display:flex;align-items:center;gap:2px;height:28px}.voice .wave-bar{width:2.5px;background:var(--ink-3);border-radius:2px;transition:background .2s ease}.voice .wave-bar.played{background:var(--accent)}.msg.own .voice .wave-bar{background:#04102059}.msg.own .voice .wave-bar.played{background:var(--accent-ink)}.voice .duration{font-size:12px;font-family:var(--font-mono);color:var(--ink-3);flex-shrink:0}.msg.own .voice .duration{color:#041020bf}.file-att{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bubble-in);border-radius:16px;border:1px solid var(--line);max-width:340px;cursor:pointer}.file-att:hover{border-color:var(--line-2)}.file-icon{width:40px;height:40px;border-radius:10px;background:#4cc9ff1f;color:var(--accent);display:grid;place-items:center;flex-shrink:0;font-family:var(--font-mono);font-size:10px;font-weight:700}.file-meta{min-width:0}.file-name{font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-size:11.5px;color:var(--ink-3);margin-top:2px;font-family:var(--font-mono)}.reply-quote{border-left:2px solid var(--accent);padding:4px 10px;margin-bottom:6px;font-size:12.5px;opacity:.8;border-radius:2px}.reply-quote .rq-name{color:var(--accent);font-weight:600;font-size:11.5px}.msg.own .reply-quote{border-left-color:var(--accent-ink)}.msg.own .reply-quote .rq-name{color:var(--accent-ink)}.typing{display:flex;align-items:center;gap:10px;padding:8px 10px 12px;color:var(--ink-3);font-size:12.5px}.typing .dots{display:inline-flex;gap:3px;padding:6px 10px;background:var(--bubble-in);border-radius:14px}.typing .dots span{width:6px;height:6px;border-radius:50%;background:var(--ink-3);animation:blink 1.2s infinite}.typing .dots span:nth-child(2){animation-delay:.15s}.typing .dots span:nth-child(3){animation-delay:.3s}@keyframes blink{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}.composer-wrap{padding:14px 22px 20px;border-top:1px solid var(--line);background:var(--bg-2);flex-shrink:0}.reply-ctx{display:flex;align-items:center;gap:10px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);padding:8px 12px;border-radius:10px;margin-bottom:8px;font-size:12.5px}.reply-ctx .rc-name{color:var(--accent);font-weight:600}.reply-ctx .rc-text{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.composer{display:flex;align-items:flex-end;gap:8px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:6px 6px 6px 12px;transition:border-color .15s ease}.composer:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #4cc9ff14}.composer-tools{display:flex;gap:2px;padding-bottom:4px}.composer textarea{flex:1;background:transparent;border:none;outline:none;color:var(--ink);font-size:14.5px;resize:none;padding:10px 4px;min-height:22px;max-height:140px;line-height:1.5}.composer textarea::placeholder{color:var(--ink-3)}.send-btn{width:40px;height:40px;border-radius:12px;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:all .15s ease}.send-btn:hover{filter:brightness(1.1)}.send-btn.disabled{background:var(--bg-3);color:var(--ink-3);cursor:default}.send-btn.disabled:hover{filter:none}.composer.recording{border-color:var(--danger);background:#ff6b7a0f}.rec-strip{display:flex;align-items:center;gap:12px;flex:1;padding:8px 4px}.rec-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.3)}}.rec-timer{font-family:var(--font-mono);font-size:13px}.rec-wave{flex:1;display:flex;align-items:center;gap:2px;height:24px}.rec-wave .b{width:2px;background:var(--danger);border-radius:2px}.details{background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column;overflow-y:auto;min-width:0}.det-head{padding:20px 20px 16px;border-bottom:1px solid var(--line);text-align:center}.det-avatar{width:80px;height:80px;border-radius:22px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:28px;margin:10px auto;letter-spacing:-.02em}.det-name{font-size:17px;font-weight:700;letter-spacing:-.01em}.det-sub{font-size:12px;color:var(--ink-3);margin-top:4px}.det-actions{display:flex;gap:6px;margin-top:16px;justify-content:center}.det-action{flex:1;max-width:80px;padding:10px 8px;background:var(--bg-3);border:1px solid var(--line);border-radius:10px;color:var(--ink-2);font-size:11px;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .15s ease}.det-action:hover{background:var(--panel-2);color:var(--ink);border-color:var(--line-2)}.det-action.accent{color:var(--accent);border-color:#4cc9ff3d;background:#4cc9ff14}.det-section{padding:16px 20px;border-top:1px solid var(--line)}.det-section h4{margin:0 0 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-3);display:flex;justify-content:space-between;align-items:center}.det-section h4 a{color:var(--accent);text-transform:none;letter-spacing:0;font-weight:500;font-size:12px;text-decoration:none;cursor:pointer}.info-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}.info-row .k{color:var(--ink-3)}.info-row .v{color:var(--ink);font-family:var(--font-mono);font-size:12px}.info-row .v.mono{font-family:var(--font-mono)}.member{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px}.member .mini-avatar{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:12px;flex-shrink:0;position:relative}.member .mini-avatar .p{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--panel);background:var(--ink-3)}.member .mini-avatar .p.online{background:var(--good)}.member .mini-avatar .p.idle{background:var(--warn)}.member-meta{flex:1;min-width:0}.member-name{font-weight:500}.member-role{font-size:11px;color:var(--ink-3)}.member-role.admin{color:var(--accent)}.media-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.media-mini .m{aspect-ratio:1;border-radius:8px;background-size:cover;background-position:center;cursor:zoom-in}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040810b8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;place-items:center;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--panel);border:1px solid var(--line-2);border-radius:18px;width:440px;max-width:92vw;box-shadow:var(--shadow-2);animation:pop .22s cubic-bezier(.2,.9,.3,1.2);overflow:hidden}@keyframes pop{0%{opacity:0;transform:translateY(10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-head{padding:20px 24px 12px;border-bottom:1px solid var(--line)}.modal-head h2{margin:0 0 4px;font-size:18px;letter-spacing:-.01em}.modal-head p{margin:0;color:var(--ink-3);font-size:13px}.modal-body{padding:20px 24px}.modal-foot{padding:14px 24px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.field{margin-bottom:14px}.field label{display:block;font-size:12px;color:var(--ink-2);margin-bottom:6px;font-weight:500}.field input,.field select,.field textarea{width:100%;background:var(--bg-2);border:1px solid var(--line-2);color:var(--ink);padding:10px 12px;border-radius:10px;font-size:14px;outline:none;transition:border-color .15s ease}.field input:focus,.field textarea:focus{border-color:var(--accent)}.field .hint{font-size:11.5px;color:var(--ink-3);margin-top:5px}.field .hint code{font-family:var(--font-mono);background:var(--bg-3);padding:1px 5px;border-radius:4px}.btn{padding:9px 18px;border-radius:10px;font-size:13.5px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .15s ease;display:inline-flex;align-items:center;gap:6px}.btn.primary{background:var(--accent);color:var(--accent-ink)}.btn.primary:hover{filter:brightness(1.1)}.btn.ghost{background:transparent;color:var(--ink-2);border-color:var(--line-2)}.btn.ghost:hover{background:var(--bg-3);color:var(--ink)}.btn.danger{background:#ff6b7a1f;color:var(--danger);border-color:#ff6b7a40}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:200;display:grid;grid-template-rows:64px 1fr 84px;animation:fadeIn .18s ease}.lb-top{display:flex;align-items:center;justify-content:space-between;padding:0 24px;color:#fff}.lb-sender{display:flex;align-items:center;gap:12px}.lb-sender .lb-avatar{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:13px}.lb-sender .lb-name{font-size:14px;font-weight:600}.lb-sender .lb-when{font-size:12px;color:#ffffff80}.lb-tools{display:flex;gap:6px}.lb-tools .icon-btn{color:#ffffffbf;width:36px;height:36px;border-radius:9px}.lb-tools .icon-btn:hover{background:#ffffff14;color:#fff}.lb-stage{display:grid;place-items:center;position:relative;padding:0 80px;min-height:0}.lb-stage img,.lb-stage video{max-width:60%;max-height:80%;width:auto;height:auto;object-fit:contain;border-radius:12px;box-shadow:0 30px 80px #00000080}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;cursor:pointer;transition:all .15s ease}.lb-nav:hover{background:#ffffff2e}.lb-nav.prev{left:24px}.lb-nav.next{right:24px}.lb-bottom{padding:12px 24px;display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(255,255,255,.06)}.lb-caption{color:#fff;font-size:13.5px;max-width:720px;margin:0 auto;text-align:center}.lb-thumbs{display:flex;justify-content:center;gap:6px}.lb-thumb{width:54px;height:40px;border-radius:6px;background-size:cover;background-position:center;cursor:pointer;opacity:.5;border:2px solid transparent;transition:opacity .15s ease}.lb-thumb.active{opacity:1;border-color:var(--accent)}.lb-thumb:hover{opacity:1}.landing{min-height:100vh;background:radial-gradient(1200px 600px at 80% 20%,rgba(76,201,255,.12),transparent 60%),radial-gradient(1000px 500px at 10% 80%,rgba(125,211,252,.08),transparent 60%),var(--bg);display:grid;place-items:center;padding:40px 20px;position:relative;overflow:hidden}.landing:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;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:64px 64px;-webkit-mask-image:radial-gradient(ellipse at center,black,transparent 70%);mask-image:radial-gradient(ellipse at center,black,transparent 70%);pointer-events:none}.landing-card{width:440px;max-width:94vw;background:linear-gradient(180deg,#142038e6,#0f1a30e6);border:1px solid var(--line-2);border-radius:22px;padding:36px 36px 28px;box-shadow:var(--shadow-2),0 0 0 1px #4cc9ff0a;position:relative;z-index:1}.landing-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px}.landing-logo .mark{width:44px;height:44px;border-radius:13px;background:linear-gradient(135deg,var(--accent),#7dd3fc);color:var(--accent-ink);display:grid;place-items:center;font-weight:800;font-size:20px;letter-spacing:-.04em;box-shadow:0 8px 20px #4cc9ff4d}.landing-logo .name{font-size:24px;font-weight:700;letter-spacing:-.02em}.landing-logo .name .acc{color:var(--accent)}.landing h1{font-size:26px;margin:0 0 8px;letter-spacing:-.02em;font-weight:700}.landing .sub{color:var(--ink-2);font-size:14px;margin:0 0 24px;line-height:1.55}.pw-field{position:relative}.pw-field input{font-family:var(--font-mono);letter-spacing:.2em;font-size:16px;padding:14px 44px 14px 16px}.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--ink-3);cursor:pointer;width:32px;height:32px;border-radius:8px}.pw-eye:hover{background:var(--bg-3);color:var(--ink)}.landing-foot{margin-top:18px;font-size:12px;color:var(--ink-3);display:flex;justify-content:space-between;align-items:center}.landing-foot a{color:var(--accent);cursor:pointer;text-decoration:none}.link-box{display:flex;align-items:center;gap:10px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;padding:10px 12px;font-family:var(--font-mono);font-size:13px;color:var(--accent);margin-bottom:10px}.link-box .copy{margin-left:auto;background:var(--bg-3);color:var(--ink-2);border:none;padding:4px 10px;border-radius:6px;font-size:11px;font-family:var(--font);font-weight:600;cursor:pointer}.link-box .copy:hover{color:var(--accent)}.success-banner{background:#3ddc9714;border:1px solid rgba(61,220,151,.25);color:var(--good);padding:8px 12px;border-radius:10px;font-size:12.5px;margin-bottom:14px;display:flex;align-items:center;gap:8px}.error-banner{background:#ff6b7a14;border:1px solid rgba(255,107,122,.25);color:var(--danger);padding:8px 12px;border-radius:10px;font-size:12.5px;margin-bottom:14px;display:flex;align-items:center;gap:8px;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}.call{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(800px 500px at 30% 20%,rgba(76,201,255,.08),transparent 60%),radial-gradient(800px 500px at 70% 80%,rgba(125,211,252,.06),transparent 60%),#050a14;z-index:150;display:flex;flex-direction:column;color:#fff;animation:fadeIn .2s ease}.call-head{padding:18px 24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.04)}.call-title{display:flex;align-items:center;gap:10px}.call-title .rec{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.6s infinite}.call-title .t{font-size:14px;font-weight:600}.call-timer{font-family:var(--font-mono);font-size:13px;color:var(--ink-2)}.call-stage{flex:1;display:grid;place-items:center;padding:40px 20px}.call-card{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:560px;width:100%}.call-avatar{width:160px;height:160px;border-radius:44px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:60px;box-shadow:0 0 0 4px #4cc9ff1f,0 20px 60px #0006;position:relative;animation:ringPulse 2.4s infinite ease-out;letter-spacing:-.03em}@keyframes ringPulse{0%{box-shadow:0 0 0 4px #4cc9ff1f,0 0 0 12px #4cc9ff00}50%{box-shadow:0 0 0 4px #4cc9ff2e,0 0 0 24px #4cc9ff0f}to{box-shadow:0 0 0 4px #4cc9ff1f,0 0 0 40px #4cc9ff00}}.call-name{font-size:28px;font-weight:700;letter-spacing:-.02em}.call-status{font-size:14px;color:var(--ink-2);display:flex;align-items:center;gap:8px}.call-status .dot{width:6px;height:6px;background:var(--good);border-radius:50%}.call-wave{display:flex;align-items:center;gap:3px;height:50px;margin:10px 0}.call-wave .b{width:4px;background:var(--accent);border-radius:2px;animation:bar 1.2s infinite ease-in-out}@keyframes bar{0%,to{height:8px;opacity:.6}50%{height:40px;opacity:1}}.call-participants{display:flex;gap:14px;justify-content:center;margin-top:24px}.cp{display:flex;flex-direction:column;align-items:center;gap:6px}.cp .cp-av{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:18px;position:relative}.cp .cp-av.speaking:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:19px;border:2px solid var(--accent);animation:glow 1.4s infinite}@keyframes glow{0%,to{opacity:.4}50%{opacity:1}}.cp .cp-name{font-size:11px;color:var(--ink-2)}.call-controls{display:flex;justify-content:center;gap:12px;padding:28px}.call-btn{width:56px;height:56px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;cursor:pointer;transition:all .15s ease}.call-btn:hover{background:#ffffff1f}.call-btn.off{background:#ffffff24}.call-btn.end{background:var(--danger);border-color:transparent}.call-btn.end:hover{background:#ff4d5f}.call-btn-group{display:flex;flex-direction:column;align-items:center;gap:6px}.call-btn-group .lbl{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em}.friends-view{display:flex;flex-direction:column;min-width:0}.friends-tabs{display:flex;gap:4px;padding:0 24px;border-bottom:1px solid var(--line)}.friends-tab{padding:16px 14px;font-size:13px;font-weight:500;color:var(--ink-2);cursor:pointer;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:8px}.friends-tab:hover{color:var(--ink)}.friends-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.friends-tab .badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.friends-list{flex:1;overflow-y:auto;padding:14px 24px}.friend-row{display:flex;align-items:center;gap:14px;padding:12px;border-radius:12px;cursor:pointer;transition:background .12s ease}.friend-row:hover{background:var(--bg-3)}.friend-row .fr-av{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:15px;flex-shrink:0;position:relative}.friend-row .fr-av .p{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-2);background:var(--ink-3)}.friend-row .fr-av .p.online{background:var(--good)}.friend-row .fr-av .p.idle{background:var(--warn)}.friend-row .fr-meta{flex:1}.friend-row .fr-name{font-size:14.5px;font-weight:600}.friend-row .fr-sub{font-size:12px;color:var(--ink-3);margin-top:2px;font-family:var(--font-mono)}.friend-row .fr-actions{display:flex;gap:4px}.add-friend-card{background:var(--panel-2);border:1px solid var(--line-2);border-radius:14px;padding:20px 22px;margin:14px 24px}.add-friend-card h3{margin:0 0 6px;font-size:15px;font-weight:700}.add-friend-card p{margin:0 0 14px;color:var(--ink-3);font-size:13px;line-height:1.5}.add-friend-input{display:flex;gap:8px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;padding:4px 4px 4px 14px}.add-friend-input:focus-within{border-color:var(--accent)}.add-friend-input input{flex:1;background:transparent;border:none;outline:none;color:var(--ink);font-size:14px;font-family:var(--font-mono);padding:10px 0}.add-friend-input button{background:var(--accent);color:var(--accent-ink);border:none;padding:0 18px;border-radius:10px;font-weight:600;font-size:13px;cursor:pointer}.add-friend-input button.disabled{background:var(--bg-3);color:var(--ink-3);cursor:default}.profile-view{display:flex;flex-direction:column;padding:0;overflow-y:auto}.profile-banner{height:120px;background:linear-gradient(135deg,#4cc9ff2e,#7dd3fc14),radial-gradient(600px 200px at 20% 80%,rgba(76,201,255,.25),transparent 60%);border-bottom:1px solid var(--line);position:relative}.profile-card{margin:-50px 32px 0;background:var(--panel);border:1px solid var(--line-2);border-radius:16px;padding:20px;display:flex;gap:18px;align-items:center}.profile-av{width:80px;height:80px;border-radius:22px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:28px;flex-shrink:0;box-shadow:0 0 0 3px var(--panel)}.profile-main{flex:1;min-width:0}.profile-name{font-size:22px;font-weight:700;letter-spacing:-.01em}.profile-handle{font-size:13px;color:var(--ink-3);font-family:var(--font-mono);margin-top:2px}.profile-status-line{font-size:13px;color:var(--ink-2);margin-top:8px;display:flex;align-items:center;gap:8px}.profile-status-line .online{color:var(--good);display:inline-flex;align-items:center;gap:6px}.profile-status-line .online:before{content:"";width:7px;height:7px;background:var(--good);border-radius:50%}.settings-block{padding:20px 32px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-top:1px solid var(--line)}.settings-row:first-child{border-top:none}.settings-row .lbl{font-size:14px;font-weight:500}.settings-row .desc{font-size:12px;color:var(--ink-3);margin-top:3px;max-width:380px}.toggle{width:40px;height:22px;border-radius:20px;background:var(--bg-3);border:1px solid var(--line-2);position:relative;cursor:pointer;transition:background .2s ease;flex-shrink:0}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--ink-2);transition:all .2s ease}.toggle.on{background:var(--accent);border-color:transparent}.toggle.on:after{left:20px;background:var(--accent-ink)}.hidden{display:none!important}.spacer{flex:1}.mono{font-family:var(--font-mono)}.muted{color:var(--ink-3)}.ic{width:18px;height:18px;flex-shrink:0}.ic-sm{width:14px;height:14px}.ic-xs{width:12px;height:12px}.ic-lg{width:22px;height:22px}.artboard-wrap{width:1440px;height:900px;background:var(--bg);overflow:hidden;position:relative;display:flex}.artboard-wrap.screen{justify-content:center;align-items:center}.dense-compact .messages{padding:12px 22px 4px;gap:2px}.dense-compact .msg{padding:4px 8px;grid-template-columns:36px 1fr;gap:10px}.dense-compact .msg.own{grid-template-columns:1fr 36px}.dense-compact .msg .avatar{width:32px;height:32px;border-radius:10px;font-size:12px}.dense-compact .bubble{padding:7px 12px;font-size:13.5px}html,body,#root{height:100%}body:has(>#root>.app){overflow:hidden;overscroll-behavior:none}.app{grid-template-columns:72px 300px 1fr auto;grid-template-rows:minmax(0,1fr)}.app>.rail,.app>.sidebar,.app>.main,.app>.details-panel{min-height:0;min-width:0}.main{overflow:hidden}.chat-head-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.chat-head-info{min-width:0}.chat-head-title{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.chat-head-sub{font-size:12px;color:var(--ink-3);margin-top:2px;display:flex;align-items:center;gap:10px}.chat-head-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.chat-head-avatar{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px;flex-shrink:0}.details-panel{animation:details-slide-in .22s ease}@keyframes details-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.main>.chat-view{flex:1;min-height:0;display:flex;flex-direction:column}.chat-view>.msgs{flex:1 1 auto;min-height:0;overflow-y:auto;padding:24px 28px 8px;display:flex;flex-direction:column;gap:4px}.chat-view>.composer{flex-direction:column;align-items:stretch;gap:6px;margin:14px 22px 20px;flex-shrink:0}.composer .composer-row{display:flex;align-items:flex-end;gap:4px}.composer .cp-btn{width:36px;height:36px;border-radius:10px;background:transparent;color:var(--ink-2);border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:background .12s ease,color .12s ease}.composer .cp-btn:hover{background:var(--bg-3);color:var(--ink)}.composer .composer-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--ink);font-family:inherit;font-size:14.5px;line-height:1.5;resize:none;padding:10px 4px;min-height:22px;max-height:140px}.composer .composer-input::placeholder{color:var(--ink-3)}.composer .cp-send{width:40px;height:40px;border-radius:12px;background:var(--accent);color:var(--accent-ink);border:none;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:filter .15s ease,background .15s ease,color .15s ease}.composer .cp-send:hover:not(:disabled){filter:brightness(1.1)}.composer .cp-send:disabled{background:var(--bg-3);color:var(--ink-3);cursor:default}.composer .reply-bar{display:flex;align-items:center;gap:10px;background:var(--panel-2);border:1px solid var(--line);border-left:3px solid var(--accent);padding:8px 12px;border-radius:10px;font-size:12.5px}.composer .reply-bar-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0;color:var(--ink-2)}.composer .reply-bar-left .reply-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--ink-2)}.composer .edit-bar .reply-bar-left{align-items:flex-start}.composer .edit-bar .edit-bar-text{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.composer .edit-bar .edit-bar-label{color:var(--accent);font-weight:700;font-size:12.5px;line-height:1.2}.composer .edit-bar .edit-bar-text .reply-text{display:block;color:var(--ink-2);font-size:12.5px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.composer .edit-bar>svg,.composer .edit-bar .reply-bar-left>svg{color:var(--accent);flex-shrink:0;margin-top:2px}.popover{background:var(--panel);border:1px solid var(--panel-2);border-radius:12px;padding:6px;min-width:200px;box-shadow:0 10px 40px #00000080;display:flex;flex-direction:column}.popover-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;background:transparent;border:none;color:var(--ink-1);cursor:pointer;text-align:left;font-size:13px}.popover-item:hover{background:var(--panel-2)}.popover-item.danger{color:var(--bad)}.popover-item.danger:hover{background:color-mix(in oklab,var(--bad) 20%,transparent)}.popover-row{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.edit-popover{min-width:320px}.edit-textarea{width:100%;background:var(--bg-2);border:1px solid var(--panel-2);border-radius:8px;padding:8px;color:var(--ink-1);font-family:inherit;font-size:13px;resize:vertical}.emoji-picker{background:var(--panel);border:1px solid var(--panel-2);border-radius:12px;width:320px;height:320px;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080;overflow:hidden}.emoji-tabs{display:flex;border-bottom:1px solid var(--panel-2);padding:4px;gap:4px}.emoji-tab{flex:1;background:transparent;border:none;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:18px;opacity:.5}.emoji-tab:hover{opacity:.9}.emoji-tab.active{background:var(--panel-2);opacity:1}.emoji-grid{flex:1;overflow-y:auto;display:grid;grid-template-columns:repeat(8,1fr);gap:2px;padding:6px}.emoji-cell{background:transparent;border:none;padding:6px 0;border-radius:6px;cursor:pointer;font-size:20px;line-height:1}.emoji-cell:hover{background:var(--panel-2)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:900}.modal-card{background:var(--panel);border:1px solid var(--panel-2);border-radius:16px;padding:20px;width:360px;max-width:calc(100vw - 40px);box-shadow:0 20px 60px #000000b3}.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-head h3{margin:0}.modal-tabs{display:flex;gap:4px;margin-bottom:12px;background:var(--bg-2);border-radius:8px;padding:3px}.modal-tabs .tab{flex:1;background:transparent;border:none;color:var(--ink-2);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600}.modal-tabs .tab.active{background:var(--panel);color:var(--ink-1)}.friends-view{padding:28px 40px;overflow-y:auto;color:var(--ink-1)}.friends-head h2{margin:0 0 4px;font-size:22px}.friends-head .add-row{display:flex;gap:8px;align-items:center;margin:14px 0 6px;background:var(--bg-2);border:1px solid var(--panel-2);border-radius:10px;padding:6px 10px}.friends-head .add-row input{flex:1;background:transparent;border:none;color:var(--ink-1);outline:none;font-size:13px}.friends-section{margin-top:28px}.friends-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:700;margin-bottom:8px}.friend-row{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:10px}.friend-row:hover{background:var(--panel-2)}.friend-meta{flex:1;min-width:0}.friend-name{font-weight:600;font-size:14px}.friend-handle{font-size:12px;color:var(--ink-3);font-family:var(--font-mono, monospace)}.friend-actions{display:flex;gap:6px}.profile-view{padding:28px 40px;overflow-y:auto;color:var(--ink-1)}.profile-head{display:flex;align-items:center;gap:16px;margin-bottom:20px}.profile-section{background:var(--panel);border:1px solid var(--panel-2);border-radius:12px;padding:20px;margin-bottom:16px;max-width:560px}.profile-section h3{margin:0 0 10px;font-size:14px;font-weight:700;color:var(--ink-1)}.details-panel{width:320px;background:var(--panel);border-left:1px solid var(--panel-2);overflow-y:auto;display:flex;flex-direction:column}.dp-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--panel-2)}.dp-title{font-weight:700;font-size:14px}.dp-hero{display:flex;flex-direction:column;align-items:center;padding:24px 20px;border-bottom:1px solid var(--panel-2);gap:10px}.dp-avatar{width:80px;height:80px;border-radius:20px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:28px}.dp-name{font-weight:700;font-size:18px}.dp-sub{font-size:12px;color:var(--ink-3);font-family:var(--font-mono, monospace)}.dp-section{padding:16px;border-bottom:1px solid var(--panel-2)}.dp-label{display:flex;align-items:center;gap:6px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3);font-weight:700;margin-bottom:10px}.dp-member{display:flex;align-items:center;gap:10px;padding:6px 4px}.dp-member-meta{flex:1;min-width:0}.dp-member-name{font-size:13px;font-weight:600}.dp-member-handle{font-size:11px;color:var(--ink-3);font-family:var(--font-mono, monospace)}.dp-role{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--acc-1);font-weight:700}.call-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1100;display:grid;place-items:center}.call-card{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px}.call-name{font-size:24px;font-weight:700;color:#fff}.call-status{font-size:14px;color:var(--ink-3)}.call-actions{display:flex;gap:16px;margin-top:24px}.call-btn{width:56px;height:56px;border-radius:50%;background:var(--panel-2);border:none;color:var(--ink-1);cursor:pointer;display:grid;place-items:center}.call-btn:hover{background:var(--panel)}.call-btn.hangup{background:var(--bad);color:#fff}.call-btn.accept{background:var(--good);color:#fff}.bubble{position:relative}.bubble .msg-text{display:block;white-space:pre-wrap}.bubble-meta{float:right;margin:6px 0 -2px 10px;display:inline-flex;align-items:center;gap:4px;font-size:11px;line-height:1;color:var(--ink-3);-webkit-user-select:none;user-select:none;white-space:nowrap}.msg.own .bubble-meta{color:color-mix(in oklab,var(--bubble-out-ink) 75%,transparent)}.bubble-meta .bubble-tick{display:inline-flex;align-items:center;margin-left:1px;color:inherit;opacity:.85}.bubble-meta .bubble-tick.read{opacity:1}.bubble-meta .edited-tag{font-style:italic;opacity:.8;margin-right:2px}.bubble.media-shell{padding:0;overflow:hidden}.bubble.media-shell .bubble-meta{position:absolute;right:8px;bottom:8px;margin:0;padding:2px 6px;background:#0000008c;color:#fff;border-radius:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.bubble .msg-photo{display:block;width:100%;max-width:260px;max-height:320px;min-height:120px;object-fit:cover;border-radius:12px;cursor:zoom-in;background:var(--bg-3, #1d2230)}.bubble.media-shell .msg-photo{border-radius:0}.bubble video.msg-photo{object-fit:contain;cursor:zoom-in}.msg-bubble-row{display:flex;align-items:flex-end;gap:8px;max-width:100%}.msg.own .msg-bubble-row{flex-direction:row-reverse;justify-content:flex-start}.react-trigger{position:relative;display:flex;align-items:center;opacity:0;pointer-events:none;transition:opacity .12s ease}.msg:hover .react-trigger,.react-trigger:hover,.react-trigger:focus-within{opacity:1;pointer-events:auto}.react-heart{width:28px;height:28px;border-radius:50%;border:1px solid var(--line, rgba(255, 255, 255, .08));background:var(--panel);color:var(--ink-1);cursor:pointer;display:grid;place-items:center;font-size:14px;line-height:1;padding:0;box-shadow:0 2px 8px #00000059;transition:transform .12s ease,background .12s ease}.react-heart:hover{transform:scale(1.08);background:var(--panel-2)}.react-strip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) scale(.94);transform-origin:bottom center;display:flex;align-items:center;gap:2px;background:var(--panel);border:1px solid var(--line, rgba(255, 255, 255, .08));border-radius:999px;padding:4px 6px;box-shadow:0 8px 24px #00000073;opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease;white-space:nowrap;z-index:5}.react-trigger:hover .react-strip,.react-trigger:focus-within .react-strip{opacity:1;pointer-events:auto;transform:translate(-50%) scale(1)}.msg.own .react-strip{left:auto;right:50%;transform:translate(50%) scale(.94)}.msg.own .react-trigger:hover .react-strip,.msg.own .react-trigger:focus-within .react-strip{transform:translate(50%) scale(1)}.react-strip-btn{width:30px;height:30px;border-radius:50%;border:none;background:transparent;color:var(--ink-1);cursor:pointer;font-size:16px;line-height:1;display:grid;place-items:center;padding:0;transition:transform .1s ease,background .1s ease}.react-strip-btn:hover{transform:scale(1.2);background:var(--panel-2)}.react-strip-btn.mine{background:color-mix(in oklab,var(--accent) 22%,transparent)}.react-strip-btn.plus{color:var(--ink-2)}.react-strip-btn.plus:hover{color:var(--ink-1)}.msg-ctxmenu{min-width:210px;padding:6px}.msg-ctxmenu .popover-item{gap:12px;padding:8px 12px;font-size:13.5px;color:var(--ink-1)}.msg-ctxmenu .popover-item:disabled{cursor:default}.msg-ctxmenu .popover-item svg{color:var(--ink-2);flex-shrink:0}.msg-ctxmenu .popover-item.danger svg{color:var(--bad)}.msg-ctxmenu .popover-item:hover svg{color:var(--ink-1)}.msg-ctxmenu .ctx-footer{display:flex;align-items:center;gap:6px;padding:8px 12px 4px;margin-top:2px;border-top:1px solid var(--panel-2);color:var(--ink-3);font-size:11.5px}.msg-ctxmenu .ctx-footer svg{color:var(--accent)}.chat-search{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--panel);border-bottom:1px solid var(--panel-2);flex-shrink:0;color:var(--ink-2)}.chat-search>svg:first-child{color:var(--ink-3);flex-shrink:0}.chat-search-input{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--ink-1);font-family:inherit;font-size:14px;padding:6px 4px}.chat-search-input::placeholder{color:var(--ink-3)}.chat-search-count{font-size:12px;color:var(--ink-3);min-width:56px;text-align:right;flex-shrink:0;font-variant-numeric:tabular-nums}.chat-search .icon-btn:disabled{opacity:.35;cursor:default}.icon-btn.active{background:color-mix(in oklab,var(--accent) 18%,transparent);color:var(--accent)}.msg-text-hl{background:#ffd25059;color:inherit;border-radius:3px;padding:0 2px;box-shadow:0 0 0 1px #ffd25059}.msg.own .msg-text-hl{background:#ffeb788c;color:#0b2434}.msg.search-current .bubble{box-shadow:0 0 0 2px var(--accent),0 6px 20px #00000059;transition:box-shadow .18s ease}.msg.search-current .msg-text-hl{background:#ffd250b3}.lightbox{display:flex;align-items:center;justify-content:center;grid-template-rows:none;padding:24px}.lb-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:12px;border:none;background:#ffffff14;color:#ffffffe6;cursor:pointer;display:grid;place-items:center;z-index:2;transition:background .15s ease}.lb-close:hover{background:#ffffff29;color:#fff}.lb-content{display:flex;align-items:center;justify-content:center;max-width:100%;max-height:100%}.lb-media{display:block;width:auto;height:auto;max-width:60vw;max-height:60vh;object-fit:contain;border-radius:12px;box-shadow:0 30px 80px #00000080}video.lb-media{max-width:70vw;max-height:70vh}.pw-summary{background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;padding:10px 12px;margin-bottom:12px;display:flex;flex-direction:column;gap:4px}.pw-summary-row{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:12.5px}.pw-summary-label{color:var(--ink-3);text-transform:uppercase;font-size:10.5px;letter-spacing:.06em;font-weight:700}.pw-summary-value{color:var(--ink-1);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}.pw-summary-value.mono{font-family:var(--font-mono, monospace);font-weight:500}.pw-note{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,var(--accent) 10%,transparent);border:1px solid color-mix(in oklab,var(--accent) 25%,transparent);color:var(--ink-2);font-size:12px;line-height:1.45;margin-bottom:12px}.pw-note svg{color:var(--accent);flex-shrink:0;margin-top:1px}.pw-note em{color:var(--ink-1);font-style:italic}.pw-row{display:flex;align-items:stretch;gap:6px}.pw-row input{flex:1}.pw-row .icon-btn{width:38px;flex-shrink:0;border-radius:10px}.field-hint{font-size:11.5px;margin-top:6px;color:var(--ink-3)}.field-hint.bad{color:var(--bad, #ff6b7a)}.ok-banner{display:flex;align-items:center;gap:8px;background:color-mix(in oklab,var(--good, #3ddc91) 12%,transparent);border:1px solid color-mix(in oklab,var(--good, #3ddc91) 30%,transparent);color:var(--good, #3ddc91);padding:8px 12px;border-radius:10px;font-size:12.5px;margin-bottom:12px}.empty-main{display:grid;place-items:center;height:100%;text-align:center;padding:40px}.empty-main h2{margin:0 0 8px;font-size:20px}.btn.danger{background:var(--bad);color:#fff;border:none}.btn.danger:hover{filter:brightness(1.1)}.composer .attach-wrap{position:relative;display:flex;align-items:flex-end}.composer .attach-menu{position:absolute;bottom:calc(100% + 8px);left:-4px;min-width:208px;padding:8px;background:var(--panel);border:1px solid var(--panel-2);border-radius:14px;box-shadow:0 16px 40px #00000080;display:flex;flex-direction:column;gap:2px;z-index:950;animation:attach-fade .14s ease-out}@keyframes attach-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.composer .attach-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border:none;background:transparent;color:var(--ink);font:inherit;font-size:14px;cursor:pointer;border-radius:10px;text-align:left;transition:background .12s ease}.composer .attach-item>svg{color:var(--ink-2);flex-shrink:0}.composer .attach-item:hover{background:var(--bg-3)}.composer .attach-item:hover>svg{color:var(--ink)}.composer .attach-item.disabled{color:var(--ink-3);cursor:not-allowed}.composer .attach-item.disabled:hover{background:transparent}.composer .attach-item.disabled>svg{color:var(--ink-3)}.emoji-picker.ep-tabs-root{width:360px;height:440px}.ep-top-tabs{display:flex;border-bottom:1px solid var(--panel-2);padding:0;gap:0;flex-shrink:0}.ep-top-tab{flex:1;background:transparent;border:none;padding:10px 0;color:var(--ink-2);font:inherit;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;transition:color .12s ease,border-color .12s ease}.ep-top-tab:hover{color:var(--ink)}.ep-top-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.gif-picker{flex:1;display:flex;flex-direction:column;min-height:0}.gif-search{display:flex;align-items:center;gap:8px;padding:8px 10px;margin:8px;background:var(--bg-3);border-radius:10px;color:var(--ink-3);flex-shrink:0}.gif-search-input{flex:1;background:transparent;border:none;outline:none;color:var(--ink);font:inherit;font-size:13px;min-width:0}.gif-search-input::placeholder{color:var(--ink-3)}.gif-grid{flex:1;overflow-y:auto;padding:0 8px 8px;columns:2 auto;column-gap:6px}.gif-cell{display:block;width:100%;margin:0 0 6px;border:none;padding:0;background:var(--bg-3);border-radius:8px;overflow:hidden;cursor:pointer;aspect-ratio:1 / 1;transition:transform .12s ease,box-shadow .12s ease;break-inside:avoid}.gif-cell:hover{transform:scale(1.02);box-shadow:0 6px 18px #0006}.gif-cell img{width:100%;height:100%;object-fit:cover;display:block}.gif-cell.sending{opacity:.5;pointer-events:none}.gif-section{break-inside:avoid;margin:10px 0 4px;padding:0 2px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);column-span:all}.gif-notice{padding:18px 12px;color:var(--ink-2);font-size:13px;line-height:1.45;text-align:center;column-span:all}.gif-load-more{column-span:all;text-align:center;padding:10px 8px 14px;font-size:12px;color:var(--ink-3, #8b949e)}.gif-notice-title{color:var(--ink);font-weight:600;margin-bottom:4px}.gif-notice code{background:var(--bg-3);padding:1px 6px;border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--ink)}.gif-notice a{color:var(--accent);text-decoration:none}.gif-notice a:hover{text-decoration:underline}.composer .cp-morph{position:relative;width:40px;height:40px;border-radius:12px;background:transparent;color:var(--ink-2);border:none;cursor:pointer;flex-shrink:0;display:grid;place-items:center;transition:background .22s ease,color .22s ease,border-radius .22s ease;overflow:hidden}.composer .cp-morph:hover:not(:disabled){background:var(--bg-3);color:var(--ink)}.composer .cp-morph.has-text,.composer .cp-morph.editing{background:var(--accent);color:var(--accent-ink)}.composer .cp-morph.has-text:hover:not(:disabled),.composer .cp-morph.editing:hover:not(:disabled){background:var(--accent);color:var(--accent-ink);filter:brightness(1.1)}.composer .cp-morph.recording{color:var(--bad)}.composer .cp-morph:disabled{cursor:default;opacity:.5}.composer .cp-morph-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;transition:transform .24s cubic-bezier(.34,1.2,.5,1),opacity .18s ease}.composer .cp-morph .cp-morph-mic{transform:scale(1) rotate(0);opacity:1}.composer .cp-morph .cp-morph-send{transform:scale(.4) rotate(-45deg);opacity:0}.composer .cp-morph.has-text .cp-morph-mic,.composer .cp-morph.editing .cp-morph-mic{transform:scale(.4) rotate(45deg);opacity:0}.composer .cp-morph.has-text .cp-morph-send,.composer .cp-morph.editing .cp-morph-send{transform:scale(1) rotate(0);opacity:1}.composer .cp-send{display:none}.bubble .reply-quote{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;width:100%;max-width:100%;margin:0 0 6px;padding:6px 10px;border:none;background:#ffffff0f;border-left:3px solid var(--accent);border-radius:8px;cursor:pointer;color:inherit;font:inherit;transition:background .12s ease}.bubble .reply-quote:hover{background:#ffffff1f}.msg.own .bubble .reply-quote{background:#0000002e;border-left-color:#00000073}.msg.own .bubble .reply-quote:hover{background:#00000047}.reply-quote-name{font-size:12px;font-weight:600;color:var(--accent);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.msg.own .reply-quote-name{color:#000000bf}.reply-quote-text{font-size:12.5px;color:var(--ink-2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;max-width:100%}.msg.own .reply-quote-text{color:#000000bf}.msg.reply-flash .bubble{animation:reply-flash-ring 1.4s ease-out}@keyframes reply-flash-ring{0%{box-shadow:0 0 #4cc9ff8c}40%{box-shadow:0 0 0 6px #4cc9ff59}to{box-shadow:0 0 #4cc9ff00}}.channel .ch-avatar{position:relative}.channel .ch-avatar .presence{position:absolute;inset:auto -2px -2px auto;width:12px;height:12px;border-radius:50%;border:2px solid var(--panel, #161b22);background:transparent;display:none}.channel .ch-avatar .presence.online{background:var(--good, #23c55e);display:block}.channel .ch-avatar .presence.idle{background:var(--warn, #f5a623);display:block}.me-avatar{position:relative}.me-avatar .presence{position:absolute;inset:auto -2px -2px auto;width:12px;height:12px;border-radius:50%;border:2px solid var(--panel, #161b22);background:var(--good, #23c55e);display:none}.me-avatar .presence.online{display:block}.sidebar .ch-top{display:flex;align-items:center;gap:6px;justify-content:space-between}.unread-badge{flex:none;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#e83f5b;color:#fff;font-size:11px;font-weight:700;line-height:20px;text-align:center;letter-spacing:.02em;box-shadow:0 0 0 2px var(--bg-2, #161b22)}.rail-pill{position:relative}.rail-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#e83f5b;color:#fff;font-size:10px;font-weight:700;line-height:18px;text-align:center;letter-spacing:.02em;box-shadow:0 0 0 2px var(--bg-1, #0d1117);animation:rail-badge-pop .22s ease-out}@keyframes rail-badge-pop{0%{transform:scale(.6);opacity:0}70%{transform:scale(1.12)}to{transform:scale(1);opacity:1}}.edit-group-pic{position:relative;width:88px;height:88px;border-radius:50%;overflow:hidden;background:var(--bg-3, #1d2230);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:#fff;margin:0 auto 16px;cursor:pointer;border:2px solid var(--border, #2a3240);transition:transform .15s ease,border-color .15s ease}.edit-group-pic:hover{transform:scale(1.03);border-color:var(--accent, #4cc9ff)}.edit-group-pic img{width:100%;height:100%;object-fit:cover}.edit-group-pic-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .15s ease;font-size:12px;font-weight:600}.edit-group-pic:hover .edit-group-pic-overlay{opacity:1}.paste-previews{display:flex;flex-wrap:wrap;gap:10px;padding:10px 10px 4px;max-height:220px;overflow-y:auto}.paste-preview{position:relative;width:180px;height:120px;border-radius:10px;background:var(--bg-3, #1d2230);border:1px solid var(--line, #2a2f3e);overflow:hidden;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.paste-preview img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;pointer-events:none}.paste-preview.status-uploading img{opacity:.7}.paste-preview.status-error img{opacity:.35;filter:grayscale(.7)}.paste-preview-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:#0f1118d9;color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 3px #00000059;transition:background .15s ease,transform .1s ease;z-index:2}.paste-preview-remove:hover{background:var(--danger, #ef4444);transform:scale(1.06)}.paste-preview-name{position:absolute;left:0;right:0;bottom:0;padding:4px 8px;font-size:11px;color:#fff;background:linear-gradient(to top,#000000bf,#0000);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}.paste-preview-progress,.paste-preview-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.paste-preview-error{color:var(--danger, #ef4444);background:#00000040}.paste-spinner{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;animation:paste-spin .8s linear infinite}@keyframes paste-spin{to{transform:rotate(360deg)}}
