*{box-sizing:border-box}:root{--bg: #0f1115;--panel: #1a1d24;--line: #2a2f3a;--accent: #4f8cff;--text: #e6e8ec;--muted: #8b93a1}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,PingFang SC,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text)}.gate{height:100%;display:grid;place-items:center}.card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:32px;width:360px;text-align:center}.card h1{margin:0 0 4px;font-size:28px}.avatar-pick{margin:8px 0 14px}.big-avatar{font-size:48px;line-height:1;margin-bottom:8px}.avatar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.av{padding:4px 0;font-size:20px;background:#0f1218;border:1px solid var(--line);border-radius:8px;cursor:pointer}.av.sel{border-color:var(--accent);background:#1e3a5f}.card input{margin-top:10px}.card .primary{margin-top:14px}.people{display:flex;flex-wrap:wrap;gap:8px;padding:8px 14px;border-bottom:1px solid var(--line)}.person{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);background:#1a1d24;border:1px solid var(--line);border-radius:999px;padding:3px 10px}.person.me{color:var(--text);border-color:var(--accent)}.pa{font-size:16px}.grid{display:grid;gap:8px;padding:10px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-content:start;max-height:46%;overflow:auto}.grid.has-focus{grid-template-columns:1fr}.tile{position:relative;background:#000;border:1px solid var(--line);border-radius:10px;overflow:hidden;aspect-ratio:16/9;cursor:pointer}.tile.focused{aspect-ratio:auto;height:70vh}.tile video{width:100%;height:100%;object-fit:contain}.tile-label{position:absolute;bottom:6px;left:8px;font-size:12px;color:#fff;background:#0000008c;padding:1px 7px;border-radius:5px}.row{display:flex;gap:8px;align-items:flex-start}.row.mine{flex-direction:row-reverse}.msg-av{font-size:22px;line-height:1.2;flex:0 0 auto}.msg-body{display:flex;flex-direction:column;min-width:0;max-width:76%;align-items:flex-start}.row.mine .msg-body{align-items:flex-end}.msg-name{font-size:11px;color:var(--muted);margin:0 2px 2px}.sub{color:var(--muted);margin:0 0 24px;font-size:14px}.hint{color:var(--muted);margin:16px 0 0;font-size:13px;min-height:18px}input{width:100%;padding:12px 14px;background:#0f1218;border:1px solid var(--line);border-radius:10px;color:var(--text);font-size:15px;outline:none}input:focus{border-color:var(--accent)}button{padding:10px 16px;border:1px solid var(--line);background:#232732;color:var(--text);border-radius:10px;cursor:pointer;font-size:14px}button:hover{border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.ghost{background:transparent}button.on{background:#1e3a5f;border-color:var(--accent)}.card button{width:100%;margin-top:14px}.sp-connect{margin-top:8px;font-size:13px;background:transparent;color:var(--muted)}.sp-connect:hover{color:#1db954;border-color:#1db954}.app{height:100%;display:flex;flex-direction:column}header,footer{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--line)}footer{border-top:1px solid var(--line);border-bottom:none;gap:12px;justify-content:center}.status{color:var(--muted)}.stage{flex:1;display:flex;min-height:0}.chat-col{flex:1;display:flex;flex-direction:column;min-width:0}.log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px;width:100%;max-width:820px;margin:0 auto}.composer{max-width:820px;width:100%;margin:0 auto}.bubble{width:fit-content;max-width:100%;padding:8px 12px;border-radius:12px;font-size:14px;overflow-wrap:anywhere;white-space:pre-wrap}.bubble.me{align-self:flex-end;background:var(--accent);color:#fff}.bubble.them{align-self:flex-start;background:#232732}.bubble.media{padding:4px}.bubble img,.bubble video{max-width:240px;max-height:240px;border-radius:8px;display:block}.bubble img{cursor:pointer}.bubble .ph{display:block;padding:6px 8px;font-size:13px;color:var(--muted)}.file-dl{display:block;padding:8px 10px;font-size:14px;color:inherit;text-decoration:none}.file-dl:hover{text-decoration:underline}.composer{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}.composer input[type=text],.composer input:not([type]){flex:1}.attach{padding:10px 12px;flex:0 0 auto}.audio-unlock{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:70;background:var(--accent);color:#fff;border:none;padding:10px 18px;border-radius:999px;font-size:14px;box-shadow:0 6px 20px #0006;animation:toast-in .3s ease}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.np-panel{position:fixed;z-index:46;width:300px;background:linear-gradient(180deg,#1c2028f5,#12141af5);border:1px solid rgba(255,255,255,.08);border-radius:18px;box-shadow:0 16px 44px #0009;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);overflow:hidden;touch-action:none;transition:transform .26s cubic-bezier(.22,.61,.36,1);-webkit-user-select:none;user-select:none}.np-panel.tucked{cursor:pointer;opacity:.96;height:76px}.np-panel.tucked .np-body{display:none}.np-arrow{position:absolute;top:50%;transform:translateY(-50%);font-size:15px;color:var(--text);z-index:2}.tuck-left .np-arrow{right:7px}.tuck-right .np-arrow{left:7px}.np-body{display:flex;flex-direction:column;overflow:hidden}.np-head{display:flex;align-items:center;gap:12px;padding:12px;cursor:grab}.np-head:active{cursor:grabbing}.np-cover{width:52px;height:52px;border-radius:10px;object-fit:cover;flex:0 0 auto;box-shadow:0 4px 12px #00000080;-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.np-info{min-width:0;flex:1}.np-btns{display:flex;flex-direction:column;gap:4px;flex:0 0 auto}.np-mini{width:22px;height:22px;padding:0;display:grid;place-items:center;border:1px solid var(--line);border-radius:6px;background:#ffffff0d;color:var(--muted);font-size:13px;line-height:1;cursor:pointer}.np-mini:hover{color:var(--text);border-color:var(--accent)}.np-mini.on{background:#1e3a5f;border-color:var(--accent)}.marquee{overflow:hidden}.marquee>div{display:inline-block;white-space:nowrap}.marquee-run{animation-name:mq;animation-timing-function:linear;animation-iteration-count:infinite;animation-direction:alternate}@keyframes mq{0%{transform:translate(0)}to{transform:translate(var(--mq))}}.np-title{font-size:14px;font-weight:700}.np-artist{font-size:12px;color:var(--muted);margin-top:2px}.np-lyrics{height:0;overflow:hidden;padding:0 16px;border-top:1px solid rgba(255,255,255,0);transition:height .4s cubic-bezier(.22,.61,.36,1),padding .4s,border-color .4s;-webkit-mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent);mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent)}.np-lyrics.open{height:240px;padding:14px 16px;border-top-color:#ffffff0f}.lrc-line{font-size:15px;line-height:1.5;padding:5px 0;color:#ffffff57;transition:color .25s,transform .25s,opacity .25s}.lrc-line.past{color:#ffffff42}.lrc-line.active{color:#fff;font-weight:700;font-size:17px;transform:translate(2px)}.lrc-empty{color:var(--muted);font-size:13px;text-align:center;margin-top:96px}.music-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;border-top:1px solid var(--line);background:#14171d}.music-btn{width:38px;height:38px;border-radius:50%;padding:0;flex:0 0 auto;display:grid;place-items:center;font-size:15px}.music-name{flex:0 1 auto;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;color:var(--text)}.music-time{font-size:12px;color:var(--muted);flex:0 0 auto;font-variant-numeric:tabular-nums}.music-seek{flex:1;min-width:80px;accent-color:var(--accent)}.music-tap{flex:0 0 auto;background:var(--accent);border-color:var(--accent);color:#fff;padding:6px 12px}.share-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:50;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.share-viewer.open{opacity:1;pointer-events:auto}.share-viewer video{width:100%;height:100%;object-fit:contain}.viewer-back{position:absolute;top:16px;left:16px;z-index:3;background:#14161cd9;border:1px solid var(--line)}.danmaku-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:2}.danmaku{position:absolute;left:0;white-space:nowrap;font-size:22px;font-weight:600;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.9),0 0 6px rgba(0,0,0,.7);transform:translate(100vw);animation:danmaku-move 8s linear forwards}.danmaku.me{color:#9ecbff}@keyframes danmaku-move{0%{transform:translate(100vw)}to{transform:translate(-100%)}}.viewer-bar{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:3;display:flex;align-items:center;gap:10px;background:#14161ccc;border:1px solid var(--line);border-radius:999px;padding:8px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.vbtn{width:44px;height:44px;border-radius:50%;font-size:18px;padding:0;display:grid;place-items:center}.vbtn.on{background:#1e3a5f;border-color:var(--accent)}.viewer-input{width:300px;max-width:50vw;background:#0f1218;border:1px solid var(--line);border-radius:999px;padding:10px 16px}.share-toast{position:fixed;top:64px;right:18px;z-index:60;display:flex;align-items:center;gap:8px;background:var(--accent);color:#fff;border:none;padding:12px 16px;border-radius:12px;font-size:14px;box-shadow:0 8px 24px #0006;animation:toast-in .35s cubic-bezier(.18,.89,.32,1.28),toast-pulse 2.4s ease-in-out .5s infinite}.share-toast:hover{filter:brightness(1.08)}.share-toast .dot{width:9px;height:9px;border-radius:50%;background:#fff;animation:blink 1.1s ease-in-out infinite}@keyframes toast-in{0%{transform:translate(120%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-pulse{0%,to{box-shadow:0 8px 24px #4f8cff59}50%{box-shadow:0 8px 32px #4f8cffbf}}@keyframes blink{0%,to{opacity:1}50%{opacity:.25}}.self-preview{position:fixed;bottom:84px;right:18px;width:200px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#000;box-shadow:0 6px 20px #0006;z-index:40;display:none}.self-preview.on{display:block}.self-preview video{width:100%;display:block}.self-preview video.mirror{transform:scaleX(-1)}.self-tag{position:absolute;bottom:6px;left:8px;font-size:11px;color:#fff;background:#0000008c;padding:1px 6px;border-radius:5px}.person.speaking{border-color:#3ddc84;box-shadow:0 0 0 1px #3ddc84}
