:root{--bg: #0b0c10;--bg-elev: #14161d;--bg-elev-2: #1c1f29;--bg-elev-3: #232734;--line: #2a2e3c;--text: #e8eaf2;--text-dim: #9aa0b4;--text-faint: #5f6578;--accent: #8b5cf6;--accent-hover: #a478f7;--accent-soft: rgba(139, 92, 246, .18);--success: #34d399;--warn: #f59e0b;--danger: #f87171;--bubble-self: #7c3aed;--bubble-peer: #232734;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 28px rgba(0, 0, 0, .45);--pad: .75rem;--font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Inter, Roboto, sans-serif;--font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace}@media (prefers-color-scheme: light){:root{--bg: #f5f6fa;--bg-elev: #ffffff;--bg-elev-2: #ffffff;--bg-elev-3: #f2f3f7;--line: #e3e5ed;--text: #1b1d24;--text-dim: #5a6075;--text-faint: #8f94a6;--bubble-peer: #e8ebf3}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}code{font-family:var(--font-mono);font-size:.85em;background:var(--bg-elev-3);padding:.1em .35em;border-radius:var(--radius-sm)}input,textarea,button,select{font:inherit;color:inherit}button{cursor:pointer;background:var(--bg-elev-3);color:var(--text);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.4em .9em;transition:background .12s,border-color .12s,transform .08s}button:hover{background:var(--bg-elev-2);border-color:var(--accent)}button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}button.ghost{background:transparent;border:1px dashed var(--line);color:var(--text-dim)}button.ghost:hover{color:var(--text);border-color:var(--accent)}button.icon{padding:.35em .55em;background:transparent;border-color:transparent}button.icon:hover{background:var(--bg-elev-3)}button.danger{color:var(--danger);border-color:var(--line)}button.danger:hover{background:#f871711a;border-color:var(--danger)}input[type=text],input[type=email],input[type=search],input:not([type]),textarea{background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:var(--radius-sm);padding:.5em .7em;outline:none;transition:border-color .12s,box-shadow .12s;width:100%}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}textarea{resize:none}label{display:block;font-size:.85em;color:var(--text-dim);margin-bottom:.35em}h1,h2,h3,h4{margin:0;line-height:1.25}h1{font-size:1.4em}h2{font-size:1.15em}h3{font-size:.78em;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint)}p{margin:.5em 0}.app-shell{display:grid;grid-template-rows:auto 1fr;height:100vh;height:100dvh;background:var(--bg)}.app-topbar{display:flex;align-items:center;gap:1em;padding:.6em 1em;background:var(--bg-elev);border-bottom:1px solid var(--line);flex-wrap:wrap}.app-topbar .brand{font-size:1.15em;font-weight:700;letter-spacing:-.01em;background:linear-gradient(120deg,var(--accent),#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}.app-topbar .proto{color:var(--text-faint);font-size:.8em;font-family:var(--font-mono)}.app-topbar .spacer{flex:1}.app-topbar .identity-tag{font-family:var(--font-mono);color:var(--text-dim);font-size:.8em;background:var(--bg-elev-3);padding:.25em .6em;border-radius:var(--radius-sm)}.app-body{display:grid;grid-template-columns:minmax(280px,340px) 1fr;gap:0;min-height:0}@media (max-width: 720px){.app-body{grid-template-columns:1fr}.app-body[data-has-selection=true] .sidebar,.app-body[data-has-selection=false] .main-panel{display:none}}.sidebar{display:flex;flex-direction:column;min-height:0;border-right:1px solid var(--line);background:var(--bg-elev)}.sidebar-section{padding:.9em 1em;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:.6em}.sidebar-section h3{margin-bottom:0}.sidebar-section .row{display:flex;align-items:center;gap:.5em}.sidebar-scroll{overflow-y:auto;flex:1 1 auto;min-height:0}.sidebar-scroll::-webkit-scrollbar{width:8px}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.profile-chip{display:flex;align-items:center;gap:.75em;padding:.5em .7em;background:var(--bg-elev-3);border-radius:var(--radius)}.avatar{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;font-weight:700;flex-shrink:0;color:#fff;font-size:.85em;background:linear-gradient(135deg,#6d28d9,#ec4899)}.avatar.sm{width:24px;height:24px;font-size:.7em}.avatar.md{width:30px;height:30px;font-size:.75em}.avatar.lg{width:44px;height:44px;font-size:.95em}.profile-chip .names{display:flex;flex-direction:column;min-width:0;flex:1}.profile-chip .names .name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-chip .names .handle{font-size:.8em;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-input{position:relative}.search-input input{padding-left:2em}.search-input:before{content:"🔍";position:absolute;left:.6em;top:50%;transform:translateY(-50%);font-size:.85em;opacity:.6}.search-results{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25em}.search-results li{display:flex;align-items:center;gap:.5em}.search-results li button.use-btn{flex:1;display:flex;align-items:center;gap:.5em;justify-content:flex-start;text-align:left;padding:.3em .5em;background:transparent;border-color:transparent}.search-results li button.use-btn:hover{background:var(--bg-elev-3);border-color:var(--line)}.conversation-list{list-style:none;padding:.4em;margin:0;display:flex;flex-direction:column;gap:.15em}.conversation-row-wrap{position:relative;display:flex;align-items:center}.conversation-row-wrap .conversation-item{flex:1;min-width:0}.conversation-row-delete{position:absolute;right:.4em;top:50%;transform:translateY(-50%);opacity:0;transition:opacity .12s;padding:.3em .5em;color:var(--text-faint)}.conversation-row-wrap:hover .conversation-row-delete,.conversation-row-wrap:focus-within .conversation-row-delete{opacity:1}.conversation-row-delete:hover{color:var(--danger);background:#f8717114}@media (pointer: coarse){.conversation-row-delete{opacity:.6}}.conversation-item{display:flex;align-items:center;gap:.7em;padding:.55em .7em;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;min-width:0;background:transparent;width:100%;text-align:left;color:var(--text)}.conversation-item:hover{background:var(--bg-elev-2);border-color:var(--line)}.conversation-item.selected{background:var(--accent-soft);border-color:var(--accent)}.conversation-item .conv-body{min-width:0;flex:1;display:flex;flex-direction:column}.conversation-item .conv-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item .conv-sub{font-size:.78em;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-note{color:var(--text-faint);font-size:.85em;font-style:italic;padding:0 .4em}.main-panel{display:flex;flex-direction:column;min-height:0;min-width:0;background:var(--bg)}.empty-lobby{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.5em;padding:2em;text-align:center}.empty-lobby h2{font-size:1.6em;background:linear-gradient(120deg,var(--accent),#ec4899);-webkit-background-clip:text;background-clip:text;color:transparent}.empty-lobby p{color:var(--text-dim);max-width:420px}.game-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1em;width:min(560px,100%)}.game-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1em;display:flex;flex-direction:column;gap:.5em;align-items:flex-start;box-shadow:var(--shadow-sm);transition:transform .14s,border-color .14s,box-shadow .14s}.game-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow)}.game-card .icon{font-size:2em}.game-card .name{font-weight:700}.game-card .desc{color:var(--text-dim);font-size:.85em}.conversation-view{display:flex;flex-direction:column;min-height:0;flex:1}.conversation-view .message-scroll{flex:1 1 auto;min-height:0}.conversation-header{display:flex;align-items:center;gap:.8em;padding:.8em 1em;border-bottom:1px solid var(--line);background:var(--bg-elev)}.conversation-header .title-stack{display:flex;flex-direction:column;min-width:0;flex:1}.conversation-header .title{font-weight:700;font-size:1.05em;cursor:text;padding:.1em .3em;border-radius:var(--radius-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-header .title:hover{background:var(--bg-elev-3)}.conversation-header .title-input{font-weight:700;font-size:1.05em}.conversation-header .subtitle{color:var(--text-dim);font-size:.82em;display:flex;align-items:center;gap:.4em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-header .member-row{display:flex;align-items:center;gap:.3em}.conversation-header .member-chip{display:inline-flex;align-items:center;gap:.35em;background:var(--bg-elev-3);padding:.15em .5em;border-radius:999px;font-size:.78em;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.message-scroll{overflow-y:auto;padding:1em 1em .5em;display:flex;flex-direction:column;gap:.4em}.message-scroll::-webkit-scrollbar{width:8px}.message-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}.day-separator{text-align:center;color:var(--text-faint);font-size:.78em;margin:.8em 0 .3em;letter-spacing:.06em}.bubble-row{display:flex;gap:.5em;max-width:min(680px,90%)}.bubble-row.self{align-self:flex-end;flex-direction:row-reverse}.bubble-row.peer{align-self:flex-start}.bubble{padding:.6em .85em;border-radius:16px;line-height:1.35;word-wrap:break-word;overflow-wrap:anywhere;white-space:pre-wrap;box-shadow:var(--shadow-sm);position:relative;min-width:0}.bubble-row.self .bubble{background:var(--bubble-self);color:#fff;border-bottom-right-radius:4px}.bubble-row.peer .bubble{background:var(--bubble-peer);color:var(--text);border-bottom-left-radius:4px}.bubble .sender{display:block;font-size:.75em;color:var(--text-dim);margin-bottom:.25em;font-weight:600}.bubble-row.self .bubble .sender{color:#ffffffb3}.bubble .timestamp{font-size:.7em;opacity:.6;margin-left:.4em}.bubble .attachment img{max-width:100%;border-radius:8px;margin-top:.4em;display:block}.bubble .attachment a{color:inherit;text-decoration:underline;display:inline-block;margin-top:.3em}.composer{border-top:1px solid var(--line);padding:.7em 1em .9em;background:var(--bg-elev);display:flex;flex-direction:column;gap:.5em}.composer .attached{display:inline-flex;align-items:center;gap:.5em;font-size:.85em;color:var(--text-dim);background:var(--bg-elev-3);padding:.2em .6em;border-radius:999px;align-self:flex-start}.composer .composer-row{display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:.4em}.composer textarea{resize:none;min-height:2.2em;max-height:8em;padding:.55em .8em;line-height:1.35}.composer .attach-btn{padding:.55em .7em}.composer .send-btn{padding:.55em 1em}.composer input[type=file]{display:none}.invite-bar{border-top:1px dashed var(--line);padding:.6em 1em;background:var(--bg-elev);display:flex;flex-direction:column;gap:.4em}.invite-bar .row{display:grid;grid-template-columns:1fr auto;gap:.4em;align-items:center}.error-banner{padding:.6em 1em;background:#f871711a;color:var(--danger);border-bottom:1px solid rgba(248,113,113,.3);font-size:.9em}.save-status{color:var(--success);font-size:.8em}.badge{display:inline-block;padding:.1em .5em;border-radius:999px;font-size:.72em;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.badge.searching{background:#f59e0b26;color:var(--warn)}.badge.online{background:#34d39926;color:var(--success)}.centered-card{max-width:420px;width:calc(100% - 2em);margin:4em auto;padding:1.8em;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.video-panel{border-bottom:1px solid var(--line);background:var(--bg-elev)}.video-panel.idle{padding:.4em 1em}.video-panel.live{padding:.6em 1em;display:flex;flex-direction:column;gap:.5em}.video-idle-row{display:flex;align-items:center;gap:.5em}.video-preview{width:100%;max-width:360px;aspect-ratio:16 / 9;background:#000;border-radius:var(--radius);align-self:center;box-shadow:var(--shadow-sm)}.video-status-row{display:flex;align-items:center;gap:.6em;flex-wrap:wrap}.video-error{color:var(--danger);font-size:.85em;margin:0}.active-game{padding:.8em 1em;background:var(--bg-elev);border-bottom:1px solid var(--line)}.active-game h4{margin:0 0 .4em;font-size:.85em;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.hstack{display:flex;align-items:center;gap:.5em}.vstack{display:flex;flex-direction:column;gap:.5em}.mono{font-family:var(--font-mono);font-size:.85em;color:var(--text-dim)}.muted{color:var(--text-dim)}.faint{color:var(--text-faint);font-size:.85em}.grow{flex:1}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
