*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--color-bg:#eeecea;--color-surface:#fff;--color-surface-alt:#f5f4f1;--color-border:#e2e0dc;--color-text:#111110;--color-text-muted:#89877f;--color-accent:#111110;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 2px 12px #00000012, 0 1px 3px #0000000a;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--header-height:56px;--sidebar-width:224px;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:15px}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--color-bg:#0f1117;--color-surface:#1a1d27;--color-surface-alt:#21253a;--color-border:#2a2d3a;--color-text:#e2e4ed;--color-text-muted:#6b7280;--color-accent:#e2e4ed}body{background:var(--color-bg);color:var(--color-text);height:100vh;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex}.uplot,.uplot *,.uplot :before,.uplot :after{box-sizing:border-box}.uplot{width:min-content;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}.u-title{text-align:center;font-size:18px;font-weight:700}.u-wrap{-webkit-user-select:none;user-select:none;position:relative}.u-over,.u-under{position:absolute}.u-under{overflow:hidden}.uplot canvas{width:100%;height:100%;display:block;position:relative}.u-axis{position:absolute}.u-legend{text-align:center;margin:auto;font-size:14px}.u-inline{display:block}.u-inline *{display:inline-block}.u-inline tr{margin-right:16px}.u-legend th{font-weight:600}.u-legend th>*{vertical-align:middle;display:inline-block}.u-legend .u-marker{width:1em;height:1em;margin-right:4px;background-clip:padding-box!important}.u-inline.u-live th:after{content:":";vertical-align:middle}.u-inline:not(.u-live) .u-value{display:none}.u-series>*{padding:4px}.u-series th{cursor:pointer}.u-legend .u-off>*{opacity:.3}.u-select{pointer-events:none;background:#00000012;position:absolute}.u-cursor-x,.u-cursor-y{pointer-events:none;will-change:transform;position:absolute;top:0;left:0}.u-hz .u-cursor-x,.u-vt .u-cursor-y{border-right:1px dashed #607d8b;height:100%}.u-hz .u-cursor-y,.u-vt .u-cursor-x{border-bottom:1px dashed #607d8b;width:100%}.u-cursor-pt{pointer-events:none;will-change:transform;border:0 solid;border-radius:50%;position:absolute;top:0;left:0;background-clip:padding-box!important}.u-axis.u-off,.u-select.u-off,.u-cursor-x.u-off,.u-cursor-y.u-off,.u-cursor-pt.u-off{display:none}[data-theme=dark] .row-selected-a{outline-color:#3b82f659;background:#3b82f626!important}[data-theme=dark] .row-selected-b{outline-color:#fb923c59;background:#fb923c26!important}[data-theme=dark] .cell-rx{color:#4ade80}[data-theme=dark] .cell-tx{color:#fb923c}[data-theme=dark] .cell-id{color:#93c5fd}[data-theme=dark] .signal-decode-label{color:#86efac;background:#14532d55}[data-theme=dark] .signal-decode-grid{border-left-color:var(--color-text-muted)}[data-theme=dark] .btn-hex-toggle.active{background:var(--color-text);color:var(--color-surface)}.loading-bar{background:var(--color-border);flex-shrink:0;height:2px;position:relative;overflow:hidden}.loading-bar:after{content:"";background:var(--color-accent);width:40%;animation:1.1s ease-in-out infinite loading-slide;position:absolute;inset:0}@keyframes loading-slide{0%{left:-40%}to{left:110%}}.btn-theme-toggle{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.btn-theme-toggle:hover{color:var(--color-text);border-color:var(--color-text-muted)}.app{flex-direction:column;height:100vh;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:10;flex-shrink:0;align-items:center;gap:12px;padding:0 24px;display:flex}.header-logo{flex-shrink:0}.header-title{color:var(--color-text);letter-spacing:-.03em;font-size:16px;font-weight:700}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.btn-import{background:var(--color-accent);color:#fff;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:none;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .15s}.btn-import:hover{opacity:.75}.btn-import-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);background:0 0}.btn-import-secondary:hover{opacity:1;color:var(--color-text);border-color:var(--color-text-muted)}.dbc-badge{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:6px;max-width:220px;padding:6px 8px 6px 12px;font-size:12px;display:flex}.dbc-badge-label{color:var(--color-text-muted);letter-spacing:.06em;text-transform:uppercase;flex-shrink:0;font-size:10px;font-weight:600}.dbc-badge-name{text-overflow:ellipsis;white-space:nowrap;color:var(--color-text);font-size:12px;font-weight:500;overflow:hidden}.dbc-badge-clear{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:color .15s}.dbc-badge-clear:hover{color:var(--color-text)}.nav-tabs{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;gap:0;padding:0 24px;display:flex}.nav-tab{color:var(--color-text-muted);letter-spacing:-.01em;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 18px;font-size:13px;font-weight:500;text-decoration:none;transition:color .15s}.nav-tab:hover{color:var(--color-text)}.nav-tab-active{color:var(--color-text);border-bottom-color:var(--color-text)}.sidebar-container{flex-shrink:0;min-width:160px;max-width:480px;display:flex;overflow:hidden}.resize-handle{cursor:col-resize;z-index:1;background:0 0;flex-shrink:0;width:4px;transition:background .2s}.resize-handle:hover{background:var(--color-border)}.sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;width:100%;display:flex;overflow-y:auto}.sidebar-placeholder{color:var(--color-text-muted);padding:20px 16px;font-size:13px}.sidebar-section{border-bottom:1px solid var(--color-border);padding:14px}.sidebar-section-grow{border-bottom:none;flex:1;overflow-y:auto}.sidebar-section-title{letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:10px;font-size:10px;font-weight:600}.sidebar-info-list{flex-direction:column;gap:5px;display:flex}.sidebar-info-row{justify-content:space-between;align-items:baseline;gap:8px;font-size:12px;display:flex}.sidebar-info-row dt{color:var(--color-text-muted);flex-shrink:0}.sidebar-info-row dd{color:var(--color-text);text-align:right;text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.sidebar-filename{font-family:monospace;font-size:11px}.sidebar-id-list{flex-direction:column;gap:2px;list-style:none;display:flex}.sidebar-id-item{border-radius:var(--radius-sm);overflow:hidden}.sidebar-id-item-open{background:var(--color-surface-alt)}.sidebar-id-row{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;padding:5px 6px;font-size:12px;display:flex}.sidebar-id-row:hover{background:var(--color-surface-alt)}.sidebar-id-value{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:monospace;font-size:11px;font-weight:600;overflow:hidden}.sidebar-id-count{color:var(--color-text-muted);flex-shrink:0;font-size:11px}.sidebar-id-add{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:14px;line-height:1;transition:all .15s;display:flex}.sidebar-id-add:hover{color:var(--color-text);border-color:var(--color-text-muted);background:var(--color-surface-alt)}.sidebar-byte-picker{flex-wrap:wrap;gap:4px;padding:6px 6px 8px;display:flex}.sidebar-byte-btn{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;padding:3px 7px;font-family:monospace;font-size:11px;transition:all .15s}.sidebar-byte-btn:hover{color:var(--color-text);border-color:var(--color-text-muted)}.sidebar-signal-picker{flex-direction:column;gap:2px;padding:4px 6px 8px;display:flex}.sidebar-signal-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:6px;padding:5px 8px;font-family:monospace;font-size:11px;transition:all .15s;display:flex;overflow:hidden}.sidebar-signal-btn:hover{color:var(--color-text);border-color:var(--color-text-muted);background:var(--color-surface-alt)}.signal-mux-badge{color:#555;background:#ededed;border-radius:3px;flex-shrink:0;margin-left:auto;padding:1px 4px;font-family:monospace;font-size:9px}.main-content{flex:1;justify-content:center;align-items:center;padding:20px;display:flex;overflow-y:auto}.main-placeholder{color:var(--color-text-muted);letter-spacing:-.01em;font-size:14px}.frame-table-wrapper{flex-direction:column;gap:12px;width:100%;height:100%;display:flex}.frame-table-topbar{flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;display:flex}.frame-table-meta{align-items:baseline;gap:10px;display:flex}.frame-table-filename{color:var(--color-text);letter-spacing:-.03em;font-size:14px;font-weight:700}.frame-table-stats{color:var(--color-text-muted);font-size:12px}.frame-table-right-controls{align-items:center;gap:6px;display:flex}.frame-table-controls{position:relative}.btn-filter,.btn-hex-toggle{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;padding:6px 12px;font-size:12px;font-weight:500;transition:all .15s}.btn-filter:hover,.btn-hex-toggle:hover{border-color:var(--color-text-muted)}.btn-hex-toggle.active{background:var(--color-text);color:var(--color-surface);border-color:var(--color-text)}.filter-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:10;min-width:220px;max-height:320px;box-shadow:var(--shadow-md);flex-direction:column;gap:8px;padding:8px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.filter-panel-actions{gap:6px;display:flex}.filter-panel-actions button{background:var(--color-surface-alt);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;flex:1;padding:5px;font-size:11px;font-weight:500;transition:all .15s}.filter-panel-actions button:hover{color:var(--color-text);border-color:var(--color-text-muted)}.filter-id-list{flex-direction:column;gap:2px;list-style:none;display:flex;overflow-y:auto}.filter-id-list label{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:8px;padding:5px 6px;font-size:12px;display:flex}.filter-id-list label:hover{background:var(--color-surface-alt)}.filter-id-value{color:var(--color-text);flex:1;font-family:monospace;font-weight:600}.filter-id-count{color:var(--color-text-muted);font-size:11px}.frame-table-search-group{flex:auto;align-items:center;gap:0;min-width:160px;max-width:480px;display:flex}.frame-table-search{border-radius:var(--radius-sm) 0 0 var(--radius-sm);background:var(--color-surface);min-width:0;color:var(--color-text);border-right:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);outline:none;flex:auto;padding:7px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.frame-table-search::placeholder{color:var(--color-text-muted)}.frame-table-search:focus{border-color:var(--color-text-muted)}.search-field-toggles{flex-shrink:0;gap:2px;display:flex}.btn-search-field{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;letter-spacing:.01em;padding:6px 8px;font-family:inherit;font-size:11px;font-weight:500;transition:all .15s}.btn-search-field:first-child{border-radius:0}.btn-search-field:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.btn-search-field+.btn-search-field{border-left:none}.btn-search-field.active{background:var(--color-text);color:var(--color-surface);border-color:var(--color-text)}.btn-search-field.active+.btn-search-field{border-left:1px solid var(--color-border)}[data-theme=dark] .btn-search-field.active{background:var(--color-text);color:var(--color-surface)}.sidebar-id-cycle{color:var(--color-text-muted);flex-shrink:0;font-family:monospace;font-size:10px}.delta-bar{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);flex-shrink:0;align-items:center;gap:10px;padding:7px 12px;font-family:monospace;font-size:12px;display:flex}.delta-label{color:var(--color-text-muted);font-weight:600}.delta-ts,.delta-arrow{color:var(--color-text-muted)}.delta-value{color:var(--color-text);margin-left:auto;font-weight:700}.delta-close{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:11px;transition:color .15s}.delta-close:hover{color:var(--color-text)}.frame-table-scroll{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex:1;overflow:auto}.frame-table{border-collapse:collapse;width:100%;font-size:12px}.frame-table thead{background:var(--color-surface);z-index:1;position:sticky;top:0}.frame-table th{text-align:left;color:var(--color-text-muted);letter-spacing:.02em;border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:500}.frame-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:6px 14px}.frame-table tbody tr{cursor:pointer}.frame-table tbody tr:hover{background:var(--color-surface-alt)}.row-selected-a{outline:1px solid #bfdbfe;background:#eff6ff!important}.row-selected-b{outline:1px solid #fed7aa;background:#fff7ed!important}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.th-sortable:hover{color:var(--color-text)}.sort-icon{color:var(--color-text);font-size:10px}.sort-icon.inactive{color:var(--color-border);font-size:10px}.cell-mono{font-family:monospace}.cell-id{color:var(--color-text);font-family:monospace;font-weight:700}.cell-rx{color:#16a34a;font-weight:500}.cell-tx{color:#c2410c;font-weight:500}.cell-data{letter-spacing:.05em;color:var(--color-text-muted);font-family:monospace}.th-expand{width:28px;padding:0!important}.cell-expand{text-align:center;width:28px;padding:2px 4px!important}.btn-expand{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:3px 5px;font-size:8px;line-height:1;transition:all .15s}.btn-expand:hover{color:var(--color-text);background:var(--color-surface-alt)}.row-signals{cursor:default!important}.row-signals:hover{background:0 0!important}.row-signals>td{border-bottom:2px solid var(--color-border);padding:0!important}.signal-decode-grid{background:var(--color-surface-alt);border-left:2px solid var(--color-text);flex-wrap:wrap;gap:6px;padding:8px 12px 10px 28px;display:flex}.signal-decode-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);align-items:baseline;gap:6px;padding:3px 8px;font-size:11px;display:flex}.signal-decode-name{color:var(--color-text-muted);font-family:monospace}.signal-decode-value{color:var(--color-text);font-family:monospace;font-weight:600}.signal-decode-unit{color:var(--color-text-muted);font-size:10px}.signal-decode-label{color:#15803d;background:#dcfce7;border-radius:3px;padding:1px 5px;font-size:10px;font-weight:600}.chart-view{flex-direction:column;gap:12px;width:100%;height:100%;display:flex}.chart-topbar{flex-shrink:0;align-items:center;gap:8px;min-height:32px;display:flex}.chart-controls{flex-shrink:0;align-items:center;gap:20px;display:flex}.chart-control-group{align-items:center;gap:10px;display:flex}.chart-label{color:var(--color-text-muted);white-space:nowrap;font-size:12px;font-weight:500}.chart-select{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;min-width:180px;padding:6px 10px;font-family:monospace;font-size:13px;transition:border-color .15s}.chart-select:focus{border-color:var(--color-text);outline:none}.chart-byte-selector{gap:4px;display:flex}.btn-byte{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:4px 8px;font-family:monospace;font-size:11px;transition:all .15s}.btn-byte:hover{color:var(--color-text)}.btn-byte-active{background:var(--color-text);color:var(--color-surface);border-color:var(--color-text);font-weight:600}.btn-add-signal{background:var(--color-text);color:var(--color-surface);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;border:none;padding:6px 14px;font-size:12px;font-weight:500;transition:opacity .15s}.btn-add-signal:hover{opacity:.75}.btn-add-signal:disabled{opacity:.3;cursor:default}.signal-chips{flex-wrap:wrap;flex:1;gap:6px;display:flex}.signal-chip{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);box-shadow:var(--shadow-sm);border-radius:20px;align-items:center;gap:6px;padding:4px 10px 4px 8px;font-family:monospace;font-size:12px;display:flex}.signal-chip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.signal-chip-remove{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;margin-left:2px;padding:0;font-size:14px;line-height:1;transition:color .15s}.signal-chip-remove:hover{color:var(--color-text)}.chart-control-right{margin-left:auto}.chart-mode-selector{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);gap:2px;padding:2px;display:flex}.btn-mode{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s}.btn-mode:hover{color:var(--color-text)}.btn-mode-active{background:var(--color-surface);color:var(--color-text);box-shadow:var(--shadow-sm)}.uplot-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);flex:1;min-height:0;overflow:hidden}.uplot-container .u-wrap{height:100%}.uplot-container .u-title{color:var(--color-text-muted);font-family:inherit;font-size:12px}.uplot-container .u-legend{color:var(--color-text-muted);font-size:12px}.uplot-container .u-select{background:#0000000d;border:1px solid #00000026}.signal-chart{flex-direction:column;flex:1;gap:8px;min-height:0;display:flex}.signal-chart-title{color:var(--color-text-muted);flex-shrink:0;font-family:monospace;font-size:12px}.chart-empty{color:var(--color-text-muted);letter-spacing:-.01em;flex:1;justify-content:center;align-items:center;font-size:14px;display:flex}.analysis-view{flex-direction:column;align-self:flex-start;gap:10px;width:100%;display:flex}.signal-panel{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.signal-panel-header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:8px;padding:8px 12px;display:flex}.signal-panel-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.signal-panel-label{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.01em;flex:1;min-width:0;font-size:12px;font-weight:500;overflow:hidden}.signal-panel-value{color:var(--color-text-muted);text-align:right;min-width:40px;font-family:monospace;font-size:12px}.signal-panel-mode{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;letter-spacing:-.01em;background:0 0;flex-shrink:0;padding:2px 6px;font-size:11px;font-weight:500;transition:all .15s}.signal-panel-mode:hover{color:var(--color-text);border-color:var(--color-text-muted)}.signal-panel-remove{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:16px;line-height:1;transition:color .15s}.signal-panel-remove:hover{color:var(--color-text)}.signal-panel-chart{height:200px}.file-preview{flex-direction:column;gap:12px;width:100%;height:100%;display:flex}.file-preview-name{color:var(--color-text-muted);font-family:monospace;font-size:13px}.file-preview-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);white-space:pre;flex:1;padding:16px;font-family:monospace;font-size:12px;overflow:auto}
