:root{font-family:system-ui,-apple-system,sans-serif;color:#1a1a1a}body{margin:0;background:#f6f7f9}html,body,#root{height:100%}.app{max-width:1100px;margin:0 auto;padding:0 24px 12px;height:100vh;box-sizing:border-box;display:flex;flex-direction:column}h1{font-size:20px}.topbar{flex:0 0 auto;padding:4px 0;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar-user{display:flex;align-items:center;gap:10px;min-width:0}.user-email{font-size:13px;color:#555;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.signout-btn{font-size:13px;padding:5px 12px;border:1px solid #80868f;border-radius:6px;background:#fff;color:#1f2430;font-weight:500;cursor:pointer}.signout-btn:hover{background:#eceef1;border-color:#5f656e}.signout-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.app-loading{display:grid;place-items:center;height:100vh;color:#777}.login{display:grid;place-items:center;height:100vh;padding:24px;box-sizing:border-box}.login-card{width:320px;max-width:100%;background:#fff;border:1px solid #e3e6ea;border-radius:12px;padding:28px 24px;box-shadow:0 4px 16px #0000000f;text-align:center}.login-card h2{margin:0 0 4px}.login-sub{color:#666;font-size:14px;margin:0 0 20px}.login-input{width:100%;box-sizing:border-box;padding:9px 11px;margin-bottom:10px;border:1px solid #d0d3d8;border-radius:6px;font-size:14px}.login-btn{width:100%;padding:10px 14px;border:0;border-radius:6px;background:#2a6fdb;color:#fff;font-size:14px;font-weight:600;cursor:pointer}.login-btn:disabled{opacity:.6;cursor:default}.login-note{color:#999;font-size:12px;margin:12px 0 0}.login-error{color:#c0392b;font-size:13px;margin:14px 0 0}.home-link{display:inline-block;cursor:pointer;margin:12px 0}.home-link:hover{color:#2a6fdb}.home{flex:1 1 auto;min-height:0;overflow:auto}.viewer{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;position:relative}.log-scroll{flex:1 1 auto;min-height:0;overflow:auto;margin-top:8px;padding-right:16px}.scroll-fab{position:absolute;right:24px;bottom:18px;display:flex;flex-direction:column;gap:8px;z-index:6;opacity:0;pointer-events:none;transition:opacity .35s ease}.scroll-fab.show{opacity:1;pointer-events:auto}.scroll-fab button{width:38px;height:38px;border-radius:50%;padding:0;font-size:18px;line-height:1;box-shadow:0 2px 8px #00000040}.spacer{flex:1 1 auto}table.logs thead th{position:sticky;top:0;z-index:2;background:#fafafa;box-shadow:inset 0 -1px #e3e3e3}.controls{display:flex;flex-wrap:wrap;gap:12px;align-items:stretch;margin-top:4px}.controls .form{flex:0 1 auto}.test-send{margin-top:8px}.test-send.open{background:#fff;border:1px dashed #c0c4ca;border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:10px}.test-send-toggle{background:none;border:1px dashed #b3b8c0;color:#4a5160;font-size:12px;padding:4px 10px}.test-send-toggle:hover{background:#f0f2f5}.test-send-row{display:flex;align-items:center;gap:10px;font-size:13px}.test-send-grid{display:flex;flex-wrap:wrap;gap:12px}.test-send-grid label{display:flex;flex-direction:column;font-size:12px;color:#555;gap:4px}.test-send-grid input,.test-send-grid select{padding:6px 8px;border:1px solid #ccc;border-radius:6px;font-size:13px;box-sizing:border-box;width:200px}.test-send-ok{color:#1a7f37;font-size:13px}.msg-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.kebab-wrap{position:relative}.kebab{background:none;color:#888;font-size:16px;line-height:1;padding:0 6px;cursor:pointer}.kebab:hover{color:#333}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9}.menu{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 2px 10px #00000024;z-index:10;overflow:hidden}.menu button{display:block;width:100%;text-align:left;background:none;color:#333;border-radius:0;padding:8px 16px;white-space:nowrap;font-size:13px}.menu button:hover:not(:disabled){background:#f3f6fd}.menu button:disabled{background:none;color:#777;cursor:default}.form{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;background:#fff;padding:16px;border-radius:8px;box-shadow:0 1px 3px #00000014}.form label{display:flex;flex-direction:column;font-size:12px;color:#555;gap:4px}.form label.disabled{opacity:.5}.form input[type=text],.form input:not([type]),.form input[type=datetime-local]{padding:6px 8px;border:1px solid #ccc;border-radius:6px;font-size:13px;box-sizing:border-box}.form input[type=datetime-local]{width:180px}.form label.live{flex-direction:row;align-items:center;gap:6px}button{padding:7px 14px;border:none;border-radius:6px;background:#2a6fdb;color:#fff;font-size:13px;cursor:pointer}button:disabled{background:#aaa;cursor:default}.status{display:flex;align-items:center;gap:12px;margin:16px 0}.badge{text-transform:uppercase;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;background:#eee}.badge.live{background:#d6f5e3;color:#137a4a}.badge.historical{background:#e3ecfb;color:#2a5db0}.badge.tagged{background:#efe3fb;color:#6a2ab0;text-transform:none}.filter-row{display:flex;align-items:flex-end;gap:14px;margin:14px 0 4px;flex-wrap:wrap}.msg-filter{display:flex;flex-direction:column;font-size:12px;color:#555;gap:4px}.msg-filter input{padding:6px 8px;border:1px solid #ccc;border-radius:6px;font-size:13px;box-sizing:border-box;width:185px}.hint{font-size:12px;max-width:420px}.badge.connecting{background:#fff3d6;color:#946200}.badge.error{background:#fbe0e0;color:#b22}.muted{color:#888;font-size:13px}.error{color:#b22;font-size:13px}.loadmore{margin-bottom:8px}table.logs{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;font-size:13px;box-shadow:0 1px 3px #00000014}table.logs th,table.logs td{text-align:left;padding:7px 10px;border-bottom:1px solid #eee;vertical-align:top}table.logs th{background:#fafafa;font-size:11px;text-transform:uppercase;color:#777}td.ts{white-space:nowrap;color:#555}td.tags{color:#2a6fdb}td.msg{font-family:ui-monospace,monospace;white-space:pre-wrap;word-break:break-word}.toggle{display:flex;gap:0;margin-bottom:16px}.toggle button{background:#fff;color:#333;border:1px solid #ccc;border-radius:0}.toggle button:first-child{border-radius:6px 0 0 6px}.toggle button:last-child{border-radius:0 6px 6px 0;border-left:none}.toggle button.on{background:#2a6fdb;color:#fff;border-color:#2a6fdb}ul.cards{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;padding:10px 12px}.card-row{display:flex;align-items:center;gap:10px}.card-row.clickable{cursor:pointer;border-radius:6px;margin:-4px;padding:4px}.card-row.clickable:hover{background:#f3f6fd}.expander{background:none;color:#888;padding:0 4px;font-size:14px}.name{font-weight:600}.type{font-size:11px;text-transform:uppercase;color:#777;background:#eef;padding:1px 6px;border-radius:8px}.mono{font-family:ui-monospace,monospace}button.link{background:none;color:#2a6fdb;padding:2px 4px;font-size:12px}button.link.danger,.menu button.danger-item{color:#d23b3b}.menu button.danger-item:hover:not(:disabled){background:#fdecec}.nick-edit{display:flex;gap:6px;align-items:center}.nick-edit input{padding:4px 8px;border:1px solid #ccc;border-radius:6px}.chips{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 2px 28px}.chip{background:#eef3fc;color:#2a5db0;border:1px solid #cfe;font-family:ui-monospace,monospace;font-size:12px}.indent{margin-left:28px}.sub-id{font-size:12px;color:#888;margin-top:8px}.chip-stacked{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left}.chip-name{font-weight:600}.chip-sub{font-size:11px;color:#6a86b8}.viewer-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.viewer-head h2{font-size:16px;margin:0}
