:root{--bg: #0e0e10;--bg-elev: #161618;--bg-elev-2: #1d1d20;--bg-input: #202024;--border: #2a2a2e;--border-strong: #38383d;--text: #ececee;--text-dim: #a0a0a8;--text-faint: #6c6c74;--accent: #c96442;--accent-hover: #d9755340;--accent-fg: #ffffff;--green: #45b86a;--amber: #d9a441;--red: #e0604f;--blue: #5b8bf5;--radius: 10px;--radius-sm: 7px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--mono: "SF Mono", ui-monospace, "JetBrains Mono", Menlo, Consolas, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}.muted{color:var(--text-dim)}.brand{display:inline-flex;align-items:center;gap:8px;border:none;background:none;color:var(--text);padding:0}.brand-dot{width:12px;height:12px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}.brand-name{font-weight:650;letter-spacing:-.01em;font-size:16px}.brand-sm .brand-name{font-size:14px}.btn{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:500;transition:background .12s ease,border-color .12s ease}.btn:hover:not(:disabled){background:#26262b}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 10px;font-size:12px}.btn-primary{background:var(--accent);border-color:var(--accent);color:var(--accent-fg)}.btn-primary:hover:not(:disabled){background:#d4734f}.btn-block{width:100%;padding:11px;font-size:14px}.btn-link{background:none;border:none;color:var(--text-dim);font-size:12px;padding:2px 4px;text-decoration:none}.btn-link:hover{color:var(--text);text-decoration:underline}.landing{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1200px 600px at 50% -10%,#1b1b1f 0%,transparent 60%),var(--bg)}.landing-card{width:100%;max-width:440px;background:var(--bg-elev);border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:0 24px 64px #0006}.landing-title{font-size:24px;font-weight:650;letter-spacing:-.02em;margin:20px 0 8px}.landing-sub{color:var(--text-dim);margin:0 0 24px;font-size:14px}.landing-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;color:var(--text-dim);font-weight:500}.input{background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);padding:10px 12px;font-size:14px;font-family:inherit;outline:none;transition:border-color .12s ease}.input:focus{border-color:var(--accent)}.form-error{color:var(--red);font-size:13px;background:#2a1715;border:1px solid #4a241f;border-radius:var(--radius-sm);padding:8px 10px}.landing-foot{margin-top:22px;color:var(--text-faint);font-size:12px}.room{height:100%;display:flex;flex-direction:column}.room-header{display:grid;grid-template-columns:minmax(360px,.9fr) 1.3fr;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);background:var(--bg-elev);flex:0 0 auto}.room-header-left,.room-header-right{display:flex;align-items:center;gap:12px;min-width:0}.room-header-left{padding:0 12px 0 16px}.room-header-right{padding:0 16px 0 12px;justify-content:flex-end}.room-title{font-weight:550;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.token-usage{display:inline-flex;align-items:baseline;gap:6px;flex:0 0 auto;margin-left:auto;font-size:11px;color:var(--text-faint);font-variant-numeric:tabular-nums;white-space:nowrap}.token-usage-in,.token-usage-out{font-family:var(--mono)}.token-usage-sep{opacity:.6}.state-badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:3px 9px;border-radius:999px;border:1px solid var(--border-strong)}.state-idle{color:var(--text-faint)}.state-generating{color:var(--amber);border-color:#4a3a1c;background:#2a2212}.state-error{color:var(--red);border-color:#4a241f;background:#2a1715}.pulse-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.7)}}.conn-dot{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-faint)}.conn-dot-circle{width:8px;height:8px;border-radius:50%;background:var(--text-faint)}.conn-open .conn-dot-circle{background:var(--green);box-shadow:0 0 8px var(--green)}.conn-open .conn-dot-label{display:none}.conn-connecting .conn-dot-circle,.conn-reconnecting .conn-dot-circle{background:var(--amber);animation:pulse 1s ease-in-out infinite}.conn-closed .conn-dot-circle{background:var(--red)}.ws-error-banner{background:#2a1715;color:var(--red);border-bottom:1px solid #4a241f;padding:8px 16px;font-size:13px;flex:0 0 auto}.room-body{flex:1 1 auto;display:grid;grid-template-columns:minmax(360px,.9fr) 1.3fr;min-height:0}.pane{min-height:0;min-width:0;display:flex;flex-direction:column}.pane-left{border-right:1px solid var(--border);background:var(--bg)}.pane-right{background:var(--bg-elev)}.thread{display:flex;flex-direction:column;height:100%;min-height:0}.thread-scroll{flex:1 1 auto;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:16px}.thread-empty{margin:auto 0;text-align:left;padding:12px}.thread-empty-title{font-size:16px;font-weight:600;margin:0 0 6px}.msg{display:flex;gap:10px;align-items:flex-start}.msg-avatar{width:28px;height:28px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:650;color:#fff}.msg-avatar-ai{background:#5b5bd6}.msg-main{min-width:0;flex:1 1 auto}.msg-meta{display:flex;align-items:center;gap:8px;margin-bottom:3px}.msg-author{font-weight:600;font-size:13px}.msg-time{font-size:11px;color:var(--text-faint)}.msg-building{font-size:12px;color:var(--amber)}.msg-content{font-size:14px;white-space:pre-wrap;word-break:break-word;color:var(--text)}.msg-assistant .msg-content{color:var(--text-dim)}.msg-system{text-align:center;font-size:12px;color:var(--text-faint);font-style:italic}.msg-status{font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:999px;font-weight:600}.status-queued{color:var(--amber);background:#2a2212;border:1px solid #4a3a1c}.status-failed{color:var(--red);background:#2a1715;border:1px solid #4a241f}.building-indicator{display:flex;align-items:center;gap:8px;padding:6px 2px}.building-label{font-size:13px;color:var(--text-dim)}.building-dots{display:inline-flex;gap:5px}.building-dots .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:bounce 1.2s ease-in-out infinite}.building-dots .dot:nth-child(2){animation-delay:.15s}.building-dots .dot:nth-child(3){animation-delay:.3s}.live-thinking{display:flex;gap:5px;padding:8px 2px}.live-thinking .dot{width:6px;height:6px;border-radius:50%;background:var(--text-faint);animation:bounce 1.2s ease-in-out infinite}.live-thinking .dot:nth-child(2){animation-delay:.15s}.live-thinking .dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}.queue-block{border:1px dashed var(--border-strong);border-radius:var(--radius);padding:10px 12px;background:#15130f}.queue-head{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--amber);margin-bottom:8px;font-weight:600}.queue-item{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px}.queue-pos{color:var(--text-faint);font-variant-numeric:tabular-nums;flex:0 0 auto}.queue-body{display:flex;gap:6px;min-width:0;flex:1 1 auto}.queue-author{font-weight:600;flex:0 0 auto}.queue-prompt{color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.queue-cancel{flex:0 0 auto}.composer{flex:0 0 auto;border-top:1px solid var(--border);padding:6px 16px 7px;background:var(--bg-elev)}.composer-top{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 16px 0;background:var(--bg-elev)}.composer-building{display:inline-flex;align-items:center;gap:6px;min-height:18px;font-size:12px;color:var(--text-dim)}.model-select{display:inline-flex;background:var(--bg-elev-2);border-radius:var(--radius-sm);padding:2px;gap:2px;flex:0 0 auto}.model-select .tab{padding:3px 10px;font-size:12px}.composer-note{font-size:12px;color:var(--amber);margin-bottom:8px}.composer-box{display:flex;gap:8px;align-items:flex-end;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:var(--radius);padding:8px;transition:border-color .12s ease}.composer-box:focus-within{border-color:var(--accent)}.composer-box-disabled{opacity:.6}.composer-input{flex:1 1 auto;background:none;border:none;outline:none;resize:none;color:var(--text);font-family:inherit;font-size:14px;line-height:1.45;max-height:180px}.composer-send{flex:0 0 auto}.viewer-note{margin-top:8px;font-size:12px;color:var(--text-dim)}.attach-input{display:none}.attach-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:var(--radius-sm);color:var(--text-dim);transition:background .12s ease,color .12s ease}.attach-btn:hover:not(:disabled){background:var(--bg-elev-2);color:var(--text)}.attach-btn:disabled{opacity:.5;cursor:not-allowed}.attach-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.attach-chip{display:inline-flex;align-items:center;gap:6px;max-width:240px;background:var(--bg-input);border:1px solid var(--border-strong);border-radius:999px;padding:4px 6px 4px 8px;font-size:12px;color:var(--text)}.attach-chip-error{border-color:#4a241f;background:#2a1715}.attach-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-chip-errmsg{color:var(--red);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.attach-chip-remove{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;background:none;color:var(--text-faint);font-size:15px;line-height:1;border-radius:50%;padding:0}.attach-chip-remove:hover{color:var(--text);background:var(--bg-elev-2)}.attach-kind{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:16px;padding:0 4px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.04em;color:#fff;background:var(--text-faint)}.attach-kind-text{background:#4a6a8a}.attach-kind-spreadsheet{background:#3f7d52}.attach-kind-pdf{background:#b5503f}.attach-kind-image{background:#7a5fb0}.attach-kind-err{background:var(--red);min-width:16px}.attach-spinner{flex:0 0 auto;width:13px;height:13px;border-radius:50%;border:2px solid var(--border-strong);border-top-color:var(--accent);animation:spin .8s linear infinite}.msg-attachments{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.msg-attach-chip{display:inline-flex;align-items:center;gap:6px;max-width:220px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 8px 3px 5px;font-size:12px;color:var(--text-dim)}.msg-attach-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.preview-tabs{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--border);flex:0 0 auto}.tabs{display:inline-flex;background:var(--bg-elev-2);border-radius:var(--radius-sm);padding:3px;gap:2px}.tab{background:none;border:none;color:var(--text-dim);padding:5px 14px;font-size:13px;border-radius:5px;font-weight:500}.tab-active{background:var(--bg-input);color:var(--text)}.preview-type{font-family:var(--mono);font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em}.preview-stage{position:relative;flex:1 1 auto;min-height:0;background:#fff}.preview-iframe{width:100%;height:100%;border:none;display:block;background:#fff}.code-view{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;background:var(--bg)}.code-block{margin:0;padding:16px;font-family:var(--mono);font-size:12.5px;line-height:1.55;color:#d8d8df;white-space:pre;-moz-tab-size:2;tab-size:2}.preview-empty-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg)}.preview-empty{text-align:center;max-width:320px;padding:24px}.preview-empty-title{font-size:15px;font-weight:600;color:var(--text);margin:0 0 6px}.preview-building-badge{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:7px;background:#14120ceb;color:var(--amber);border:1px solid #4a3a1c;border-radius:999px;padding:5px 12px;font-size:12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.render-error-banner{position:absolute;left:12px;right:12px;bottom:12px;display:flex;flex-direction:column;gap:3px;background:#2a1715;border:1px solid #4a241f;color:#f0c0b8;border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;box-shadow:0 8px 24px #00000080}.render-error-banner strong{color:var(--red);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.render-error-msg{font-family:var(--mono);word-break:break-word}.history{flex:0 0 auto;max-height:16%;display:flex;flex-direction:column;border-top:1px solid var(--border);background:var(--bg-elev)}.history-expanded{max-height:32%}.history-toggle{display:inline-flex;align-items:center;gap:8px;background:none;border:none;padding:0;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit}.history-caret{display:inline-block;font-size:13px;line-height:1;transition:transform .12s ease;color:var(--text-dim)}.history-caret-down{transform:rotate(180deg)}.history-count{font-size:10px}.history-head{display:flex;align-items:center;justify-content:space-between;padding:9px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-weight:600;flex:0 0 auto}.history-empty-note{padding:0 14px 12px;font-size:13px}.history-list{overflow-y:auto;padding:0 8px 8px}.history-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer}.history-item:hover{background:var(--bg-elev-2)}.history-item-active{background:var(--bg-input);outline:1px solid var(--border-strong)}.history-item-main{display:flex;align-items:center;gap:8px;min-width:0}.history-ver{font-family:var(--mono);font-size:11px;color:var(--accent);flex:0 0 auto}.history-title{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-current-tag{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--green);border:1px solid #234d31;background:#122017;border-radius:999px;padding:1px 6px;flex:0 0 auto}.history-model-tag{font-size:10px;letter-spacing:.02em;color:var(--text-faint);border:1px solid var(--border-strong);border-radius:999px;padding:1px 6px;flex:0 0 auto}.history-item-meta{display:flex;align-items:center;gap:10px;flex:0 0 auto;font-size:12px}.ctx-menu{position:fixed;z-index:1000;min-width:150px;padding:4px;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);box-shadow:0 8px 24px #00000073;display:flex;flex-direction:column}.ctx-menu-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;text-align:left;padding:7px 10px;border-radius:var(--radius-sm);font-size:13px;color:var(--text);cursor:pointer}.ctx-menu-item:hover{background:var(--bg-input)}.ctx-menu-danger{color:var(--red, #f87171)}.ctx-menu-danger:hover{background:#2a1416;color:#fca5a5}.presence{display:flex;align-items:center;gap:8px}.presence-avatars{display:flex}.presence-avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:650;color:#fff;border:2px solid var(--bg-elev);margin-left:-7px}.presence-avatar:first-child{margin-left:0}.presence-more{background:var(--bg-elev-2);color:var(--text-dim)}.presence-count{font-size:12px}.room-loading,.room-error{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--border-strong);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 820px){.room-body{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.pane-left{border-right:none;border-bottom:1px solid var(--border)}}.app-root{height:100%;display:flex;flex-direction:column;min-height:0}.app-shell{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:264px 1fr}.app-main{min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--bg)}.sidebar{display:flex;flex-direction:column;min-height:0;background:var(--bg-elev);border-right:1px solid var(--border)}.sidebar-top{display:flex;flex-direction:column;gap:12px;padding:16px 14px 12px;flex:0 0 auto}.sidebar-new{width:100%}.sidebar-nav{display:flex;flex-direction:column;padding:0 8px 8px;gap:2px;flex:0 0 auto}.sidebar-nav-item{text-align:left;background:none;border:none;color:var(--text-dim);font-size:13px;font-weight:500;padding:8px 10px;border-radius:var(--radius-sm)}.sidebar-nav-item:hover{background:var(--bg-elev-2);color:var(--text)}.sidebar-nav-active{background:var(--bg-input);color:var(--text)}.sidebar-section-label{padding:10px 14px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-weight:600;flex:0 0 auto;border-top:1px solid var(--border)}.sidebar-rooms{flex:1 1 auto;overflow-y:auto;padding:0 8px 8px}.sidebar-empty,.sidebar-error{padding:8px 10px;font-size:13px}.sidebar-error{color:var(--red)}.room-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;text-align:left;background:none;border:none;color:var(--text);padding:8px 10px;border-radius:var(--radius-sm)}.room-row:hover{background:var(--bg-elev-2)}.room-row-active{background:var(--bg-input);outline:1px solid var(--border-strong)}.room-row-main{display:flex;flex-direction:column;min-width:0;gap:2px}.room-row-title{font-size:13px;font-weight:550;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-row-meta{font-size:11px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-badge{flex:0 0 auto;font-size:9px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:2px 6px;border-radius:999px;border:1px solid var(--border-strong);color:var(--text-faint)}.role-owner{color:var(--accent);border-color:#4a3128;background:#221512}.role-editor{color:var(--blue);border-color:#25365a;background:#121826}.role-viewer{color:var(--text-faint)}.user-menu{position:relative;flex:0 0 auto;border-top:1px solid var(--border);padding:8px}.user-menu-trigger{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;padding:6px 8px;border-radius:var(--radius-sm);color:var(--text)}.user-menu-trigger:hover{background:var(--bg-elev-2)}.user-menu-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:0 0 auto}.user-menu-label{display:flex;flex-direction:column;min-width:0}.user-menu-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-email{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-pop{position:absolute;bottom:calc(100% + 4px);left:8px;right:8px;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius);padding:8px;box-shadow:0 12px 32px #00000080}.user-menu-id{padding:6px 8px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}.user-menu-admin{margin-top:4px;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);font-weight:700}.user-menu-logout{width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:13px;padding:7px 8px;border-radius:var(--radius-sm)}.user-menu-logout:hover{background:var(--bg-input);color:var(--red)}.auth-switch{display:block;margin:16px auto 0;font-size:13px}.empty-state{flex:1 1 auto;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(1000px 500px at 50% -10%,#1b1b1f 0%,transparent 60%),var(--bg)}.empty-state-card{max-width:460px;text-align:center}.empty-state-title{font-size:26px;font-weight:650;letter-spacing:-.02em;margin:0 0 10px}.empty-state-sub{color:var(--text-dim);margin:0 0 24px}.empty-state-error{margin-top:14px}.btn-lg{padding:12px 22px;font-size:15px}.panel{flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.panel-header{flex:0 0 auto;padding:16px 24px;border-bottom:1px solid var(--border);background:var(--bg-elev)}.panel-title{margin:0;font-size:18px;font-weight:650;letter-spacing:-.01em}.panel-body{flex:1 1 auto;overflow-y:auto;padding:20px 24px 40px;max-width:760px;width:100%}.friend-add{display:flex;gap:8px;margin-bottom:10px}.friend-add .input{flex:1 1 auto}.friend-notice-ok{color:var(--green);background:#122017;border:1px solid #234d31;border-radius:var(--radius-sm);padding:8px 10px;font-size:13px;margin-bottom:12px}.friend-section{margin-top:22px}.friend-section-title{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);font-weight:600;margin:0 0 10px}.friend-rows{display:flex;flex-direction:column;gap:6px}.friend-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius)}.friend-row-main{display:flex;align-items:center;gap:10px;min-width:0}.friend-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-elev-2);color:var(--text);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:0 0 auto}.friend-id{display:flex;flex-direction:column;min-width:0}.friend-name{font-size:14px;font-weight:600}.friend-email{font-size:12px}.friend-row-actions{display:flex;gap:6px;flex:0 0 auto;align-items:center}.friend-pending-tag{font-size:12px;font-style:italic}.admin-section{margin-top:26px}.admin-table-wrap{border:1px solid var(--border);border-radius:var(--radius);overflow:auto}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.admin-table thead th{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-faint);background:var(--bg-elev)}.admin-table tbody tr:last-child td{border-bottom:none}.admin-table .num{text-align:right;font-variant-numeric:tabular-nums}.admin-owner-name{display:block}.admin-owner-email{display:block;font-size:11px}.admin-flag{color:var(--accent);font-weight:700;text-transform:uppercase;font-size:11px;letter-spacing:.04em}.room-title-btn{background:none;border:none;font:inherit;font-weight:550;color:var(--text);padding:2px 4px;border-radius:var(--radius-sm);text-align:left}.room-title-btn:hover:not(:disabled){background:var(--bg-elev-2)}.room-title-btn:disabled{cursor:default}.room-title-input{font-weight:550;padding:4px 8px;max-width:320px}.invite-friend{position:relative}.invite-friend-pop{position:absolute;top:calc(100% + 6px);right:0;width:260px;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius);padding:6px;box-shadow:0 12px 32px #00000080;z-index:20;max-height:320px;overflow-y:auto}.invite-friend-empty{padding:10px;font-size:13px}.invite-friend-item{display:flex;flex-direction:column;width:100%;text-align:left;background:none;border:none;color:var(--text);padding:8px 10px;border-radius:var(--radius-sm);font-size:13px;gap:1px}.invite-friend-item:hover{background:var(--bg-input)}.invite-friend-item .muted{font-size:11px}.invite-friend-notice{padding:8px 10px;font-size:12px;color:var(--green);border-top:1px solid var(--border);margin-top:4px}@media (max-width: 820px){.app-shell{grid-template-columns:1fr;grid-template-rows:auto 1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:42vh}}.field-hint{font-size:11px;color:var(--text-faint)}.invite-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.invite-head .friend-section-title{margin:0}.invite-reveal{display:flex;align-items:center;gap:10px;background:#122017;border:1px solid #234d31;border-radius:var(--radius);padding:10px 12px;margin-bottom:14px}.invite-reveal-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--green);font-weight:600;flex:0 0 auto}.invite-reveal-code{font-family:var(--mono);font-size:15px;letter-spacing:.06em;color:var(--text);flex:1 1 auto;-webkit-user-select:all;user-select:all}.invite-copy{flex:0 0 auto}.invite-code-cell{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;color:var(--text)}.invite-status{font-size:10px;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid var(--border-strong);color:var(--text-faint)}.invite-status-unused{color:var(--green);border-color:#234d31;background:#122017}.invite-status-used{color:var(--text-dim);border-color:var(--border-strong);background:var(--bg-elev-2)}.invite-status-revoked{color:var(--red);border-color:#4a241f;background:#2a1715}.invite-gen-form{display:flex;gap:8px;align-items:center}.invite-email-input{width:220px;max-width:48vw}.app-header{flex:0 0 auto;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:6px 16px;background:var(--bg-elev);border-bottom:1px solid var(--border)}.app-header-right{display:flex;align-items:center;justify-content:flex-end;gap:8px}.header-nav-btn{background:none;border:1px solid transparent;color:var(--text-dim);font-size:13px;font-weight:500;padding:7px 12px;border-radius:var(--radius-sm);transition:background .12s ease,color .12s ease}.header-nav-btn:hover{background:var(--bg-elev-2);color:var(--text)}.header-nav-active{background:var(--bg-input);color:var(--text);border-color:var(--border-strong)}.account-menu{position:relative}.account-menu-trigger{display:flex;align-items:center;gap:9px;background:none;border:1px solid var(--border-strong);padding:5px 10px 5px 6px;border-radius:999px;color:var(--text)}.account-menu-trigger:hover{background:var(--bg-elev-2)}.account-menu-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex:0 0 auto}.account-menu-label{display:flex;flex-direction:column;min-width:0;max-width:180px}.account-menu-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-menu-email{font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-menu-pop{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:var(--bg-elev-2);border:1px solid var(--border-strong);border-radius:var(--radius);padding:8px;box-shadow:0 12px 32px #00000080;z-index:30}.account-menu-id{padding:6px 8px 10px;border-bottom:1px solid var(--border);margin-bottom:6px}.account-menu-admin{margin-top:4px;font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);font-weight:700}.account-menu-logout{width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:13px;padding:7px 8px;border-radius:var(--radius-sm)}.account-menu-logout:hover{background:var(--bg-input);color:var(--red)}.project-files{flex:0 0 auto;display:flex;flex-direction:column;height:84px;border-top:1px solid var(--border);background:var(--bg-elev);padding:5px 16px 6px}.project-files-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.project-files-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-faint);font-weight:600}.project-files-input{display:none}.project-files-error{color:var(--red);font-size:12px;margin-bottom:6px}.project-files-list{flex:1 1 auto;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.project-files-empty{font-size:12px;padding:6px 2px;line-height:1.45}.project-file-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px}.project-file-name{flex:0 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.project-file-preview{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:11px}.project-file-remove{flex:0 0 auto;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:none;color:var(--text-faint);font-size:15px;line-height:1;border-radius:4px}.project-file-remove:hover{background:var(--bg-elev-2);color:var(--red)}.preview-processing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;padding:24px;background:radial-gradient(600px 300px at 50% 40%,#1b1b1f 0%,transparent 70%),var(--bg);color:var(--amber)}.preview-processing-title{margin:4px 0 0;font-size:15px;font-weight:600;color:var(--text)}.invite-row-actions{display:inline-flex;gap:6px;justify-content:flex-end}.activity-log .activity-detail-col{white-space:normal;max-width:420px}.activity-detail{display:inline-block;max-width:420px;white-space:pre-wrap;word-break:break-word;color:var(--text)}.activity-type{display:inline-block;font-size:11px;font-weight:600;text-transform:capitalize;padding:2px 8px;border-radius:999px;border:1px solid var(--border-strong);color:var(--text-dim);white-space:nowrap}.activity-type-prompt_submitted{color:var(--blue);border-color:#25365a;background:#121826}.activity-type-generation_succeeded,.activity-type-room_created,.activity-type-register,.activity-type-friend_accepted{color:var(--green);border-color:#234d31;background:#122017}.activity-type-generation_failed{color:var(--red);border-color:#4a241f;background:#2a1715}.activity-type-invite_issued,.activity-type-invite_used,.activity-type-room_invite{color:var(--accent);border-color:#4a3128;background:#221512}.project-files{position:relative;transition:background .12s ease,box-shadow .12s ease}.project-files-dragging{background:#d977570f;box-shadow:inset 0 0 0 2px var(--accent, #d97757);border-radius:8px}.project-files-drop-hint{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;align-items:center;justify-content:center;gap:8px;background:#141416d1;border-radius:8px;font-size:13px;font-weight:600;color:var(--accent, #d97757);pointer-events:none}.room-header-divider{width:1px;align-self:stretch;margin:2px;background:var(--border)}.code-actions{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;background:var(--bg-elev);border-bottom:1px solid var(--border)}.code-actions-name{font-family:var(--mono);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-actions-btns{display:flex;gap:6px;flex:0 0 auto}.collab-logo{--core-color: #ffffff;--node-1: #10b981;--node-2: #a855f7;--node-3: #e56b55;display:inline-flex;line-height:0}.collab-logo .base-line{stroke:#fff3;stroke-width:3;stroke-linecap:round}.collab-logo .stream-line{fill:none;stroke-width:6;stroke-linecap:round;stroke-dasharray:30;stroke-dashoffset:80;opacity:0}.collab-logo .stream-1{stroke:var(--node-1)}.collab-logo .stream-2{stroke:var(--node-2)}.collab-logo .stream-3{stroke:var(--node-3)}.collab-logo .core-diamond{fill:var(--core-color);transform-origin:50px 50px;transform:rotate(45deg);transition:all .3s ease}@keyframes pulse-white{0%{transform:rotate(45deg) scale(1);filter:drop-shadow(0 0 2px rgba(255,255,255,.3))}50%{transform:rotate(45deg) scale(1.4);filter:drop-shadow(0 0 15px rgba(255,255,255,1)) drop-shadow(0 0 30px rgba(255,255,255,.6))}to{transform:rotate(45deg) scale(1);filter:drop-shadow(0 0 2px rgba(255,255,255,.3))}}.collab-logo.is-building .core-diamond,.collab-logo.is-collaborating .core-diamond{animation:pulse-white 1.5s ease-in-out infinite}@keyframes flow-inward{0%{stroke-dashoffset:80;opacity:0}20%{opacity:1}80%{opacity:1}to{stroke-dashoffset:-80;opacity:0}}.collab-logo.is-building .stream-line,.collab-logo.is-collaborating .stream-line{animation:flow-inward 1.5s linear infinite}.collab-logo .delay-1{animation-delay:0s}.collab-logo .delay-2{animation-delay:.4s}.collab-logo .delay-3{animation-delay:.8s}
