:root{--bg: #fafbfc;--fg: #111;--muted: #666;--border: #e3e5e7;--primary: #2563eb;--primary-fg: #fff;--danger: #b91c1c;--bubble: #f1f3f5;--bubble-me: #dbeafe;--error: #b91c1c;--ok: #16a34a;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}@media(prefers-color-scheme:dark){:root{--bg: #0d1117;--fg: #e6edf3;--muted: #9da7b1;--border: #30363d;--bubble: #161b22;--bubble-me: #1e3a5f}}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);height:100%}button{background:var(--primary);color:var(--primary-fg);border:0;padding:.55rem 1rem;border-radius:6px;cursor:pointer;font:inherit}button:disabled{opacity:.5;cursor:default}button.ghost{background:transparent;color:var(--fg);border:1px solid var(--border)}input,textarea{font:inherit;padding:.55rem .7rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--fg);width:100%}textarea{resize:vertical;min-height:2.4rem}a{color:var(--primary)}.centered{display:grid;place-items:center;min-height:100vh;padding:1rem}.card{background:var(--bg);border:1px solid var(--border);padding:1.5rem;border-radius:10px;width:min(420px,100%)}.card h1{margin-top:0}.card form{display:grid;gap:.8rem}.card label{display:grid;gap:.25rem;font-size:.9rem;color:var(--muted)}.error{color:var(--error);min-height:1.2em;margin:0}.info{color:var(--muted);min-height:1.2em;margin:.5rem 0 0}.footer{margin-top:1rem;font-size:.9rem;color:var(--muted)}.room-shell{display:grid;grid-template-rows:auto 1fr auto;height:100vh}.room-header{padding:.6rem 1rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem}.room-header .title{display:flex;align-items:baseline;gap:.8rem}.status{font-size:.75rem;color:var(--muted);padding:.15rem .5rem;border-radius:999px;border:1px solid var(--border)}.status.ws{color:var(--ok);border-color:var(--ok)}.status.sse{color:#d97706;border-color:#d97706}.status.poll{color:#6b7280;border-color:#6b7280}.status.down{color:var(--danger);border-color:var(--danger)}.room-header .actions{display:flex;gap:.5rem;align-items:center}.room-header .actions input{width:220px}.room-main{display:grid;grid-template-columns:1fr 220px;overflow:hidden}.messages{overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.msg{max-width:70%;padding:.5rem .7rem;border-radius:10px;background:var(--bubble)}.msg.me{align-self:flex-end;background:var(--bubble-me)}.msg .meta{font-size:.75rem;color:var(--muted);margin-bottom:.15rem}.msg .meta .role{background:var(--primary);color:var(--primary-fg);padding:0 .35rem;border-radius:4px;font-size:.65rem;margin-left:.35rem}.msg .body{white-space:pre-wrap;word-wrap:break-word}.msg img{max-width:100%;max-height:320px;border-radius:6px;display:block;margin-top:.3rem}.msg .attach{display:inline-block;margin-top:.3rem;padding:.35rem .6rem;border:1px solid var(--border);border-radius:6px;text-decoration:none}.msg.system{align-self:center;background:transparent;color:var(--muted);font-style:italic;font-size:.85rem}.msg.deleted{font-style:italic;color:var(--muted)}.msg .delete-btn{visibility:hidden;margin-left:.5rem;background:transparent;color:var(--danger);border:0;padding:0;cursor:pointer}.msg:hover .delete-btn{visibility:visible}.presence{border-left:1px solid var(--border);padding:1rem;overflow-y:auto}.presence h3{margin:0 0 .5rem;font-size:.9rem;color:var(--muted);text-transform:uppercase}.presence ul{list-style:none;margin:0;padding:0;display:grid;gap:.35rem}.presence li{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.presence li .dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--ok)}.presence li.muted .dot{background:#d97706}.presence li button{font-size:.7rem;padding:.15rem .35rem;margin-left:auto}.composer{border-top:1px solid var(--border);padding:.6rem;display:flex;gap:.5rem;align-items:end}.composer textarea{flex:1}.composer #attach{background:transparent;color:var(--fg);border:1px solid var(--border)}.admin-header{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.2rem;border-bottom:1px solid var(--border)}.admin-main{padding:1.2rem;display:grid;gap:1.5rem;max-width:1100px;margin:0 auto}.admin-main section{border:1px solid var(--border);border-radius:8px;padding:1rem}.admin-main h2{margin-top:0}.admin-main form{display:flex;flex-wrap:wrap;gap:.5rem}.admin-main form input{width:auto;flex:1 1 200px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.4rem .5rem;border-bottom:1px solid var(--border);font-size:.9rem}td .row-actions{display:flex;gap:.4rem}td button{font-size:.8rem;padding:.25rem .5rem}.closed{color:var(--muted)}
