*{box-sizing:border-box;margin:0;padding:0}:root{--bg1:#1e1b4b;--bg2:#312e81;--accent:#818cf8;--accent-strong:#6366f1;--card:hsla(0,0%,100%,.06);--panel:rgba(0,0,0,.22);--border:hsla(0,0%,100%,.12);--text:#f1f5f9;--muted:#a5b4fc}body,html{height:100%}body{color:var(--text);background:radial-gradient(1200px 800px at 20% 0,var(--bg2),var(--bg1)) fixed;-webkit-font-smoothing:antialiased}.page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;gap:18px}.card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px 28px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 60px rgba(0,0,0,.35)}.join{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}.logo{width:76px;height:76px;display:grid;place-items:center;border-radius:22px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-strong));box-shadow:0 12px 30px rgba(99,102,241,.5)}.join h1{font-size:26px;font-weight:700}.subtitle{font-size:14px;margin-bottom:6px}.foot,.subtitle{color:var(--muted)}.foot{font-size:12px;opacity:.7}.error{color:#fca5a5;font-size:13px;line-height:1.5}.room-page{height:100dvh;width:100vw}.room-shell{width:100%;height:100dvh;display:flex;flex-direction:column;background:var(--card);overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.room-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.15)}.brand{width:40px;height:40px;flex-shrink:0;display:grid;place-items:center;border-radius:12px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-strong))}.brand-title{font-size:16px;font-weight:700}.brand-sub{font-size:12px;color:var(--muted)}.banner{text-align:center;font-size:13px;font-weight:600;color:#fde68a;background:rgba(234,179,8,.15);border-bottom:1px solid rgba(234,179,8,.4);padding:8px 14px}.room-body{flex:1 1;display:flex;min-height:0}.room-aside{width:240px;flex-shrink:0;border-right:1px solid var(--border);background:rgba(0,0,0,.12);flex-direction:column}.room-aside,.room-main{display:flex;min-height:0}.room-main{flex:1 1;flex-direction:column;min-width:0;padding:14px;gap:12px}.room-main.with-share{flex-direction:row}.room-main.with-share .chat-panel{width:360px;flex:none;flex-shrink:0}.room-error{padding:0 18px 12px}.member-panel{display:flex;flex-direction:column;min-height:0;height:100%}.panel-title{display:flex;align-items:center;gap:6px;padding:14px 16px 8px;font-size:13px;font-weight:600;color:var(--muted)}.member-scroll{flex:1 1;min-height:0}.member-row{padding:8px 10px;border-radius:12px;background:rgba(0,0,0,.18);border:1px solid transparent}.member-row.me{background:rgba(129,140,248,.14);border-color:rgba(129,140,248,.4)}.member-name{flex:1 1;min-width:0}.sharing-icon{color:#fbbf24;flex-shrink:0}.dot{width:9px;height:9px;flex-shrink:0;border-radius:50%;background:#4ade80;box-shadow:0 0 8px #4ade80}.chat-panel{flex:1 1;display:flex;flex-direction:column;min-height:0;background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden}.chat-scroll{flex:1 1;min-height:0}.chat-empty{height:100%;min-height:160px;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:13px;opacity:.7}.bubble-row,.chat-empty{display:flex;flex-direction:column}.bubble-row{align-items:flex-start;max-width:80%;gap:2px}.bubble-row.self{align-self:flex-end;align-items:flex-end}.bubble-name{font-size:12px;color:var(--muted);padding:0 4px}.bubble{padding:9px 13px;font-size:14px;line-height:1.5;border-radius:14px;color:var(--text);background:hsla(0,0%,100%,.08);border:1px solid var(--border);word-break:break-word;white-space:pre-wrap}.bubble-row.self .bubble{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-strong));border-color:transparent}.bubble-time{font-size:11px;color:var(--muted);opacity:.6;padding:0 4px}.chat-input{display:flex;align-items:center;gap:8px;padding:10px;border-top:1px solid var(--border);background:rgba(0,0,0,.2)}.share-view{position:relative;flex:1 1;min-width:0;min-height:0;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:#000;cursor:zoom-in}.share-view video{display:block;width:100%;height:100%;object-fit:contain;background:#000}.share-view.expanded{position:fixed;inset:0;z-index:100;border:none;border-radius:0;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;cursor:zoom-out}.share-view.expanded video{width:100%;height:100%;max-height:100dvh}.share-label{left:8px;bottom:8px;gap:5px}.share-label,.share-zoom{position:absolute;display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:#fff;background:rgba(0,0,0,.55);padding:4px 10px;border-radius:999px}.share-zoom{right:8px;top:8px;gap:4px;pointer-events:none}.chat-msgs{width:100%;max-width:860px;margin:0 auto}@media (max-width:820px){.room-header{flex-wrap:wrap}.room-body{flex-direction:column}.room-aside{width:100%;border-right:none;border-bottom:1px solid var(--border);max-height:132px}.member-scroll{max-height:84px}.room-main.with-share{flex-direction:column}.room-main.with-share .chat-panel{width:100%;flex:1 1;min-height:0}}@media (max-width:600px){.room-header{padding:10px 12px}.brand-sub{display:none}.brand{width:36px;height:36px}.brand-title{font-size:15px}.room-main{padding:10px;gap:10px}.bubble-row{max-width:88%}.member-name{font-size:14px}}