/* ── Filters ── */
.filter-group { display: flex; flex-direction: column; gap: 2px; margin-bottom: 4px; }
.filter-btn { display: flex; align-items: center; justify-content: space-between; padding: 5px 10px; border-radius: 4px; cursor: pointer; font-size: 12px; font-weight: 600; transition: background .1s; user-select: none; }
.filter-btn:hover { background: var(--bg3); }
.filter-btn.active { background: var(--bg4); }
.filter-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.filter-count { font-family: var(--font-mono); font-size: 11px; color: var(--text3); margin-left: auto; }
.filter-name { margin-left: 8px; flex: 1; }

/* Level / group dot colours */
.dot-INFO    { background: var(--info); }
.dot-WARN    { background: var(--warn); }
.dot-ERROR   { background: var(--err); }
.dot-DEBUG   { background: var(--debug); }
.dot-strategy  { background: var(--strategy); }
.dot-trade   { background: var(--trade); }
.dot-assistant    { background: var(--assistant); }
.dot-system  { background: var(--system); }

/* ── Aggregates panel ── */
#agg-panel { flex: 1; overflow-y: auto; padding: 0 16px 16px; }
.agg-card { background: var(--bg3); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 12px; margin-bottom: 8px; }
.agg-card-title { font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text3); margin-bottom: 8px; }
.agg-row { display: flex; justify-content: space-between; align-items: baseline; padding: 2px 0; border-bottom: 1px solid var(--border); }
.agg-row:last-child { border-bottom: none; }
.agg-key { font-size: 11px; color: var(--text2); }
.agg-val { font-family: var(--font-mono); font-size: 12px; font-weight: 500; color: var(--text); }
.agg-val.pos  { color: var(--accent); }
.agg-val.neg  { color: var(--err); }
.agg-val.warn { color: var(--warn); }

/* ── Log table ── */
#log-wrap { flex: 1; overflow: auto; position: relative; }
#log-table { width: 100%; border-collapse: collapse; font-family: var(--font-mono); font-size: 12px; }
#log-table thead { position: sticky; top: 0; z-index: 5; background: var(--bg3); }
#log-table th { padding: 8px 12px; text-align: left; font-size: 10px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text3); border-bottom: 1px solid var(--border); white-space: nowrap; cursor: pointer; user-select: none; }
#log-table th:hover { color: var(--text); }
#log-table td { padding: 5px 12px; border-bottom: 1px solid var(--border); color: var(--text2); white-space: nowrap; max-width: 320px; overflow: hidden; text-overflow: ellipsis; vertical-align: middle; }
#log-table tr { transition: background .05s; cursor: pointer; }
#log-table tr:hover td { background: var(--bg3); }
#log-table tr.selected td { background: var(--bg4); }
.td-time   { color: var(--text3); font-size: 11px; }
.td-level  { font-weight: 500; }
.td-level.INFO  { color: var(--info); }
.td-level.WARN  { color: var(--warn); }
.td-level.ERROR { color: var(--err); }
.td-level.DEBUG { color: var(--debug); }
.td-group.signal { color: var(--signal); }
.td-group.trade  { color: var(--trade); }
.td-group.risk   { color: var(--risk); }
.td-group.system { color: var(--system); }
.td-module { color: var(--text); }
.td-event  { color: var(--text); font-weight: 500; }
.td-fields { color: var(--text3); }

/* ── Trace highlight rows ── */
#log-table tr.hl-htf td   { background: #4fffb012 !important; }
#log-table tr.hl-ifvg td  { background: #4fc3ff12 !important; }
#log-table tr.hl-smt td   { background: #ffc84512 !important; }
#log-table tr.hl-trace td { background: #a78bfa12 !important; }

/* left-edge colour bar — priority: htf > ifvg > smt > trace */
#log-table tr[class*="hl-"] td:first-child { border-left: 3px solid transparent; }
#log-table tr.hl-trace td:first-child  { border-left-color: var(--debug); }
#log-table tr.hl-smt   td:first-child  { border-left-color: var(--risk); }
#log-table tr.hl-ifvg  td:first-child  { border-left-color: var(--trade); }
#log-table tr.hl-htf   td:first-child  { border-left-color: var(--signal); }

/* anchor: white outline ring on top of the row's background colour */
#log-table tr.hl-anchor td { outline: 1px solid rgba(255,255,255,0.25); outline-offset: -1px; }
#log-table tr.hl-anchor td:first-child { border-left-color: var(--text) !important; }

/* ── Pagination ── */
#pagination-bar { position: sticky; bottom: 0; display: flex; align-items: center; gap: 4px; padding: 8px 16px; background: var(--bg2); border-top: 1px solid var(--border); z-index: 5; flex-wrap: wrap; }
.pg-info { font-family: var(--font-mono); font-size: 11px; color: var(--text3); margin-right: 8px; }
.pg-btn { min-width: 28px; height: 26px; padding: 0 6px; background: var(--bg3); border: 1px solid var(--border); border-radius: 4px; color: var(--text2); font-family: var(--font-mono); font-size: 11px; cursor: pointer; transition: all .12s; }
.pg-btn:hover:not([disabled]) { border-color: var(--accent); color: var(--accent); }
.pg-btn:disabled { opacity: 0.3; cursor: default; }
.pg-btn.pg-active { background: var(--accent); border-color: var(--accent); color: #000; font-weight: 700; }
.pg-ellipsis { font-size: 11px; color: var(--text3); padding: 0 2px; }

/* ── Detail panel — floating resizable ── */
#detail { position: fixed; top: 56px; right: 0; bottom: 0; width: 380px; min-width: 260px; max-width: 780px; background: var(--bg); border-left: 1px solid var(--border); box-shadow: -8px 0 32px rgba(0,0,0,.5); display: none; flex-direction: column; overflow: hidden; z-index: 50; transition: box-shadow .2s; }
#detail.open { display: flex; }

#detail-resize { position: absolute; top: 0; left: -3px; bottom: 0; width: 6px; cursor: ew-resize; z-index: 10; border-radius: 3px 0 0 3px; transition: background .15s; }
#detail-resize:hover, #detail-resize.dragging { background: var(--accent); opacity: 0.5; }

#detail-header { padding: 0; flex-shrink: 0; }
#detail-hero { padding: 20px 20px 16px; background: var(--bg2); border-bottom: 1px solid var(--border); }
#detail-hero-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 12px; }
#detail-event-name { font-size: 15px; font-weight: 700; color: var(--text); letter-spacing: 0.01em; line-height: 1.3; max-width: calc(100% - 40px); word-break: break-word; }
#detail-close { cursor: pointer; color: var(--text3); font-size: 16px; line-height: 1; width: 26px; height: 26px; display: flex; align-items: center; justify-content: center; border-radius: 4px; border: 1px solid var(--border); background: var(--bg3); transition: all .15s; flex-shrink: 0; }
#detail-close:hover { color: var(--text); border-color: var(--text3); }
#detail-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.detail-badge { display: inline-flex; align-items: center; gap: 5px; padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; letter-spacing: 0.04em; font-family: var(--font-mono); }
.detail-badge-level                { background: var(--bg3); border: 1px solid var(--border2); }
.detail-badge-level.INFO           { color: var(--info);   border-color: #4fc3ff44; background: #4fc3ff0d; }
.detail-badge-level.WARN           { color: var(--warn);   border-color: #ffc84544; background: #ffc8450d; }
.detail-badge-level.ERROR          { color: var(--err);    border-color: #ff5d6e44; background: #ff5d6e0d; }
.detail-badge-level.DEBUG          { color: var(--debug);  border-color: #a78bfa44; background: #a78bfa0d; }
.detail-badge-group                { background: var(--bg3); border: 1px solid var(--border2); }
.detail-badge-group.signal         { color: var(--signal); border-color: #4fffb044; background: #4fffb00d; }
.detail-badge-group.trade          { color: var(--trade);  border-color: #4fc3ff44; background: #4fc3ff0d; }
.detail-badge-group.risk           { color: var(--risk);   border-color: #ffc84544; background: #ffc8450d; }
.detail-badge-group.system         { color: var(--system); border-color: #c0c4d644; background: #c0c4d60d; }
.detail-badge-module { color: var(--text2); background: var(--bg3); border: 1px solid var(--border); }
.detail-badge-time   { color: var(--text3); background: transparent; border: none; font-size: 10px; padding: 0; }

#detail-body { padding: 0; flex: 1; overflow-y: auto; }
.detail-section { padding: 14px 20px; border-bottom: 1px solid var(--border); }
.detail-section-title { font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text3); margin-bottom: 10px; }
.detail-kv { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--border); border-radius: 6px; overflow: hidden; border: 1px solid var(--border); }
.detail-kv-row { display: contents; }
.detail-kv-row .dk { background: var(--bg2); padding: 7px 10px; font-family: var(--font-mono); font-size: 11px; color: var(--text3); }
.detail-kv-row .dv { background: var(--bg3); padding: 7px 10px; font-family: var(--font-mono); font-size: 11px; color: var(--text); word-break: break-all; }
.dv.pos  { color: var(--accent); }
.dv.neg  { color: var(--err); }
.dv.warn { color: var(--warn); }
.detail-raw { margin: 14px 20px; background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; padding: 12px; font-family: var(--font-mono); font-size: 10px; color: var(--text3); line-height: 1.7; white-space: pre-wrap; word-break: break-all; }
