*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:dark;--bg: #0d1117;--bg-surface: #161b22;--bg-hover: #1c2333;--border: #30363d;--text: #e6edf3;--text-muted: #8b949e;--accent: #58a6ff;--accent-hover: #79c0ff;--level-debug: #8b949e;--level-info: #58a6ff;--level-warn: #d29922;--level-error: #f85149;--level-fatal: #ff7b72;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", "Consolas", monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif}[data-theme=light]{color-scheme:light;--bg: #ffffff;--bg-surface: #f6f8fa;--bg-hover: #eaeef2;--border: #d0d7de;--text: #1f2328;--text-muted: #656d76;--accent: #0969da;--accent-hover: #0550ae;--level-debug: #656d76;--level-info: #0969da;--level-warn: #9a6700;--level-error: #cf222e;--level-fatal: #a40e26}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.5}#root{height:100%}.app{display:flex;flex-direction:column;height:100%;max-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-surface)}.app-header-actions{display:flex;align-items:center;gap:8px}.theme-toggle{height:32px;padding:0 12px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.theme-toggle:hover{border-color:var(--accent);color:var(--text)}.app-title{font-size:18px;font-weight:600;color:var(--accent);letter-spacing:.02em}.search-bar{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--border);background:var(--bg-surface);flex-wrap:wrap}.search-input{height:34px;padding:0 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px;font-family:var(--font-mono);outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.search-input--wide{flex:1;min-width:180px}.search-input option{background:var(--bg-surface);color:var(--text)}.search-btn{height:34px;padding:0 18px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s}.search-btn:hover{background:var(--accent-hover)}.search-btn--clear{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.search-btn--clear:hover{background:var(--bg-hover);color:var(--text)}.follow-toggle{display:flex;align-items:center;gap:6px;height:32px;padding:0 14px;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.follow-toggle:hover{border-color:var(--accent);color:var(--text)}.follow-toggle--active{background:#58a6ff1a;border-color:var(--accent);color:var(--accent)}.follow-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);transition:background .15s}.follow-dot--live{background:#3fb950;box-shadow:0 0 6px #3fb95099;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.log-viewer{flex:1;display:flex;flex-direction:column;overflow:hidden}.log-summary{padding:6px 20px;font-size:12px;color:var(--text-muted);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.log-list{flex:1;overflow-y:auto;padding:0}.log-empty{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:14px}.log-error{padding:10px 20px;background:#f851491a;color:var(--level-error);font-size:13px;border-bottom:1px solid rgba(248,81,73,.2)}.log-loading{padding:10px 20px;text-align:center;color:var(--text-muted);font-size:13px}.load-more-btn{display:block;width:calc(100% - 40px);margin:10px 20px;padding:8px;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-size:13px;cursor:pointer;transition:all .15s}.load-more-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.load-more-btn:disabled{opacity:.5;cursor:default}.expand-toggle-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--text-muted);font-size:11px;padding:2px 8px;cursor:pointer}.expand-toggle-btn:hover{border-color:var(--accent);color:var(--text)}.expand-toggle-btn--active{border-color:var(--accent);color:var(--accent)}.log-entry{border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.log-entry:hover{background:var(--bg-hover)}.log-entry--debug{background:#8b949e12}.log-entry--info{background:#58a6ff12}.log-entry--warn{background:#d2992217}.log-entry--error{background:#f8514917}.log-entry--fatal{background:#ff7b7221}.log-entry--debug:hover{background:#8b949e24}.log-entry--info:hover{background:#58a6ff24}.log-entry--warn:hover{background:#d2992229}.log-entry--error:hover{background:#f8514929}.log-entry--fatal:hover{background:#ff7b7238}[data-theme=light] .log-service{color:#6f3fb5}[data-theme=light] .log-id{color:#0969da}[data-theme=light] .log-caller{color:#bc4c00}[data-theme=light] .level--fatal{background:#a40e261a}[data-theme=light] .log-entry--debug{background:#656d7614}[data-theme=light] .log-entry--info{background:#0969da12}[data-theme=light] .log-entry--warn{background:#9a670014}[data-theme=light] .log-entry--error{background:#cf222e12}[data-theme=light] .log-entry--fatal{background:#a40e261a}[data-theme=light] .log-entry--debug:hover{background:#656d7626}[data-theme=light] .log-entry--info:hover{background:#0969da21}[data-theme=light] .log-entry--warn:hover{background:#9a670024}[data-theme=light] .log-entry--error:hover{background:#cf222e21}[data-theme=light] .log-entry--fatal:hover{background:#a40e262b}.log-entry-row{display:flex;align-items:baseline;gap:12px;padding:6px 20px;font-family:var(--font-mono);font-size:12.5px;line-height:1.6}.log-copy-btn{margin-left:auto;flex-shrink:0;opacity:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text);cursor:pointer;font-size:12px;font-family:var(--font-sans);padding:2px 8px;line-height:1.5;transition:opacity .1s,background .1s,border-color .1s}.log-entry:hover .log-copy-btn{opacity:1}.log-copy-btn:hover{background:var(--bg-hover);border-color:var(--accent)}.log-copy-btn--copied{background:var(--bg-surface);color:var(--accent)!important;border-color:var(--accent)}.log-ts{flex-shrink:0;color:var(--text-muted);font-size:12px;width:190px}.log-ts--clickable{cursor:pointer}.log-ts--clickable:hover{color:var(--accent);text-decoration:underline}.log-level{flex-shrink:0;width:52px;font-weight:700;font-size:11px;text-align:center;padding:1px 0;border-radius:3px}.level--debug{color:var(--level-debug)}.level--info{color:var(--level-info)}.level--warn{color:var(--level-warn)}.level--error{color:var(--level-error)}.level--fatal{color:var(--level-fatal);background:#ff7b7226}.log-service{flex-shrink:0;color:#bc8cff;white-space:nowrap}.log-id{flex-shrink:0;width:90px;font-family:monospace;font-size:.8em;color:#58a6ff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:default}.log-service+.log-id{margin-left:12px}.log-caller{flex-shrink:0;width:160px;font-family:monospace;font-size:.85em;color:#f0883e;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:default}.log-message{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-detail{padding:8px 20px 12px;margin:0;font-family:var(--font-mono);font-size:12px;line-height:1.5;color:var(--text-muted);background:var(--bg);border-top:1px solid var(--border);overflow-x:auto;white-space:pre-wrap;word-break:break-all}.tail-loader{display:flex;align-items:center;justify-content:center;gap:5px;padding:14px 20px}.tail-loader__dot{width:6px;height:6px;border-radius:50%;background:#3fb950;box-shadow:0 0 6px #3fb95080;animation:tail-bounce 1.2s ease-in-out infinite}.tail-loader__dot:nth-child(2){animation-delay:.2s}.tail-loader__dot:nth-child(3){animation-delay:.4s}@keyframes tail-bounce{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.log-list::-webkit-scrollbar{width:8px}.log-list::-webkit-scrollbar-track{background:var(--bg)}.log-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.log-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
