:root{color-scheme:light dark;--bg: #f4f5f7;--surface: #ffffff;--surface-2: #f0f1f4;--border: #e3e5ea;--text: #1c1e22;--text-muted: #707682;--primary: #3478f6;--primary-strong: #2a63d0;--primary-contrast: #ffffff;--danger: #c0392b;--ok: #2e9e4f;--warn: #c08a00;--bubble-in: #eceef1;--bubble-in-text: #1c1e22;--bubble-out: #3478f6;--bubble-out-text: #ffffff;--radius: 8px;--radius-lg: 14px;--radius-pill: 999px;--shadow: 0 1px 2px rgba(0, 0, 0, .06), 0 4px 12px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--ring: 0 0 0 3px rgba(52, 120, 246, .35);--font: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}@media(prefers-color-scheme:dark){:root{--bg: #0f1115;--surface: #171a21;--surface-2: #1f232c;--border: #2a2f3a;--text: #e7e9ee;--text-muted: #9099a8;--primary: #4d8bff;--primary-strong: #6ba0ff;--primary-contrast: #0f1115;--danger: #ff6b5e;--ok: #43c46b;--warn: #e0b341;--bubble-in: #232833;--bubble-in-text: #e7e9ee;--bubble-out: #3d7bf0;--bubble-out-text: #ffffff;--shadow: 0 1px 2px rgba(0, 0, 0, .4), 0 6px 18px rgba(0, 0, 0, .35);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--radius)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-pill)}.app-shell{max-width:880px;margin:0 auto;padding:1.25rem;min-height:100%;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:1rem;margin-bottom:1rem;border-bottom:1px solid var(--border)}.header-actions{display:flex;align-items:center;gap:1rem}.muted{color:var(--text-muted);font-size:.9rem}button:not(.link-btn):not(.seg button){background:var(--primary);color:var(--primary-contrast);border:none;border-radius:var(--radius);padding:.5rem .9rem;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .15s ease,opacity .15s ease,transform .05s ease}button:not(.link-btn):not(.seg button):hover:not(:disabled){background:var(--primary-strong)}button:not(.link-btn):not(.seg button):active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.875rem;padding:0}.link-btn:hover:not(:disabled){color:var(--primary-strong);text-decoration:underline}.link-btn:disabled{color:var(--text-muted);cursor:default}input{font-family:inherit;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:.55rem .65rem;font-size:1rem}input:focus-visible{border-color:var(--primary)}.avatar{flex:none;display:grid;place-items:center;width:38px;height:38px;border-radius:var(--radius-pill);background:var(--surface-2);color:var(--text-muted);font-size:.72rem;font-weight:600;border:1px solid var(--border)}.auth-card{max-width:360px;width:100%;margin:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.75rem;display:flex;flex-direction:column;gap:1rem}.auth-card h1{margin:0;font-size:1.4rem}.auth-form{display:flex;flex-direction:column;gap:.85rem}.auth-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:500;color:var(--text-muted)}.auth-form button{margin-top:.25rem}.auth-error{color:var(--danger);margin:0;font-size:.85rem}.auth-switch{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.85rem;padding:0;align-self:flex-start}.auth-switch:hover{text-decoration:underline}.chat-list{display:flex;flex-direction:column;gap:1rem}.chat-list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.chat-list-actions{display:flex;align-items:center;gap:.85rem}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-pill);padding:2px}.seg button{border:none;background:transparent;color:var(--text-muted);padding:.3rem .85rem;border-radius:var(--radius-pill);cursor:pointer;font-size:.85rem;font-weight:500;transition:background .15s ease,color .15s ease}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.chat-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.chat-row{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.6rem .85rem;transition:border-color .15s ease,transform .05s ease}.chat-row:hover{border-color:var(--primary)}.chat-open{flex:1;text-align:left;background:none!important;color:var(--text)!important;border:none;cursor:pointer;font-size:1rem;font-weight:500;padding:0!important}.pager{display:flex;align-items:center;justify-content:center;gap:1rem}.new-chat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:.85rem;display:flex;flex-direction:column;gap:.65rem}.new-chat-head{display:flex;align-items:center;justify-content:space-between}.user-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.user-results li{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.4rem .5rem;border-radius:var(--radius)}.user-results li:hover{background:var(--surface-2)}.chat-view{display:flex;flex-direction:column;gap:.75rem;flex:1;min-height:0}.chat-view-head{display:flex;align-items:center;gap:.85rem}.messages{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem;padding:.85rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.load-older{align-self:center;margin-bottom:.25rem}.msg{display:flex;flex-direction:column;max-width:78%;animation:msg-in .14s ease-out}@keyframes msg-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.msg.mine{align-self:flex-end;align-items:flex-end}.msg.theirs{align-self:flex-start;align-items:flex-start}.msg-bubble{padding:.5rem .75rem;border-radius:var(--radius-lg);background:var(--bubble-in);color:var(--bubble-in-text);word-break:break-word;white-space:pre-wrap;line-height:1.35}.msg.mine .msg-bubble{background:var(--bubble-out);color:var(--bubble-out-text);border-bottom-right-radius:4px}.msg.theirs .msg-bubble{border-bottom-left-radius:4px}.msg-failed{font-style:italic;opacity:.7}.msg-meta{font-size:.7rem;color:var(--text-muted);margin:.15rem .25rem 0}.composer{display:flex;gap:.5rem}.composer input{flex:1}.ws-status{margin-left:auto;font-size:.75rem;font-weight:500;padding:.15rem .6rem;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--border)}.ws-open{color:var(--ok)}.ws-connecting{color:var(--warn)}.ws-closed{color:var(--danger)}@media(max-width:600px){.app-shell{padding:.85rem}.msg{max-width:88%}.auth-card{padding:1.25rem}}
