*{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}.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}.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{max-width:80%;padding:8px 12px;border-radius:12px;font-size:14px;word-break:break-word;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}.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}
