:root{--text:#212121;--text-h:#000;--bg:#f5f5f5;--border:#e0e0e0;--code-bg:#263238;--accent:#1976d2;--accent-bg:#1976d21a;--accent-border:#1976d280;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:"Roboto", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--heading:"Roboto", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"Consolas", "Monaco", "Courier New", ui-monospace, monospace;font:16px/1.5 var(--sans);letter-spacing:.15px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--text:#e0e0e0;--text-h:#fff;--bg:#1e1e1e;--border:#3c3c3c;--code-bg:#1e1e1e;--accent:#64b5f6;--accent-bg:#64b5f626;--accent-border:#64b5f680;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}}body{margin:0}#root{text-align:left;box-sizing:border-box;flex-direction:column;width:100%;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2,h3{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{margin:0;font-size:1.5rem}h2{margin:0;font-size:1.25rem}h3{margin:0;font-size:.875rem}p{margin:0}code{font-family:var(--mono);color:var(--text-h);background:var(--code-bg);border-radius:4px;padding:2px 4px;font-size:.875rem;line-height:1.5;display:inline-flex}.device-selector{padding:16px}.device-selector__header{border-bottom:1px solid #0000001a;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.device-selector__header h2{flex:1;font-size:1rem}.device-selector__header .material-icons{color:var(--mdc-theme-primary)}.device-selector__content{flex-direction:column;gap:12px;display:flex}.device-selector__empty{text-align:center;color:#00000061;padding:32px 16px}.device-selector__empty .material-icons{margin-bottom:8px;font-size:48px;display:block}.device-selector__info{background-color:#1976d20a;border-radius:4px;padding:12px}.device-selector__info-item{justify-content:space-between;align-items:center;padding:4px 0;display:flex}.device-selector__label{color:#0009;font-size:.875rem}.device-selector__value{color:#000000de;font-size:.875rem;font-weight:500}.device-selector__filters{gap:8px;display:flex}.device-selector__filters .mdc-text-field{flex:1}.device-selector__actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.device-selector__actions .mdc-button{flex:1;min-width:100px}.device-selector__request-btn,.device-selector__connect-btn{background-color:var(--mdc-theme-primary);color:#fff}.device-selector__disconnect-btn{background-color:var(--status-error);color:#fff}.device-selector__error{color:var(--status-error);background-color:#f443361a;border-radius:4px;align-items:center;gap:8px;padding:12px;font-size:.875rem;display:flex}.device-selector__error .material-icons{font-size:20px}.device-selector__connected{flex-direction:column;gap:12px;display:flex}.device-selector__status{border-radius:4px;align-items:center;gap:8px;padding:8px 12px;font-weight:500;display:flex}.device-selector__status.status--connected{color:var(--status-success);background-color:#4caf501a}.device-selector__status .material-icons{font-size:20px}.device-selector__device-info{flex-direction:column;gap:12px;display:flex}.device-selector__device-info h3{color:#0009;margin:0;font-size:.875rem}.device-selector__interface-section{background-color:#00000005;border:1px solid #0000001a;border-radius:4px;padding:12px}.device-selector__interface-section h3{color:#0009;margin:0 0 8px;font-size:.875rem}.device-selector__interface-list{flex-direction:column;gap:8px;display:flex}.device-selector__interface-option{cursor:pointer;background-color:#fff;border:1px solid #0000001a;border-radius:4px;align-items:center;gap:8px;padding:10px;transition:all .2s;display:flex}.device-selector__interface-option:hover{border-color:var(--mdc-theme-primary);background-color:#1976d20a}.device-selector__interface-option.selected{border-color:var(--mdc-theme-primary);background-color:#1976d214}.device-selector__interface-option.has-bulk{border-left:3px solid var(--status-success)}.device-selector__interface-option.no-bulk{opacity:.7;border-left:3px solid #0003}.device-selector__interface-option input[type=radio]{flex-shrink:0;margin:0}.device-selector__interface-info{flex-direction:column;flex:1;gap:2px;display:flex}.device-selector__interface-number{font-size:.875rem;font-weight:500}.device-selector__interface-class{color:#0009;font-size:.75rem}.device-selector__interface-class.vendor{color:var(--mdc-theme-primary);font-weight:500}.device-selector__interface-endpoints{color:#00000061;font-size:.75rem;font-family:var(--font-mono)}.device-selector__interface-badge{background-color:var(--mdc-theme-primary);color:#fff;text-transform:uppercase;border-radius:2px;padding:2px 6px;font-size:.625rem;font-weight:600}.device-info{padding:16px}.device-info__header{border-bottom:1px solid #0000001a;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.device-info__header h2{flex:1;font-size:1rem}.device-info__header .material-icons{color:var(--mdc-theme-primary)}.device-info__status{border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;display:flex}.device-info__status .material-icons{font-size:16px}.device-info__status.connected{color:var(--status-success);background-color:#4caf501a}.device-info__status.disconnected{color:#00000061;background-color:#0000000d}.device-info__status.connected .material-icons{color:var(--status-success)}.device-info__status.disconnected .material-icons{color:#00000061}.device-info__empty{text-align:center;color:#00000061;padding:32px 16px}.device-info__empty .material-icons{margin-bottom:8px;font-size:48px;display:block}.device-info__section{margin-bottom:16px}.device-info__section:last-child{margin-bottom:0}.device-info__section h3{color:#0009;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:.875rem}.device-info__grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.device-info__item{background-color:#00000005;border-radius:4px;justify-content:space-between;align-items:center;padding:8px;display:flex}.device-info__item .device-info__label{color:#0009;font-size:.75rem}.device-info__item .device-info__value{color:#000000de;font-size:.8125rem;font-weight:500}.device-info__value.mono{font-family:var(--font-mono)}.data-sender{padding:16px}.data-sender__header{border-bottom:1px solid #0000001a;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.data-sender__header h2{flex:1;font-size:1rem}.data-sender__header .material-icons{color:var(--mdc-theme-primary)}.data-sender__content{flex-direction:column;gap:16px;display:flex}.data-sender__format{align-items:center;gap:12px;display:flex}.data-sender__format label{color:#0009}.data-sender__radio-group{gap:16px;display:flex}.data-sender__input-group{flex-direction:column;gap:4px;display:flex}.data-sender__input-group label{color:#0009}.data-sender__textarea{width:100%;min-height:80px;font-family:var(--font-mono);resize:vertical;color:#000000de;background-color:#0000;border:1px solid #0000003b;border-radius:4px;padding:8px 12px;font-size:.875rem;transition:border-color .2s}.data-sender__textarea:focus{border-color:var(--mdc-theme-primary);outline:none}.data-sender__textarea:disabled{color:#00000061;background-color:#0000000a}.data-sender__char-count{text-align:right;color:#00000061}.data-sender__preview{flex-direction:column;gap:4px;display:flex}.data-sender__preview label{color:#0009}.data-sender__hex-output{background-color:var(--debug-bg);color:var(--debug-hex);word-break:break-all;border-radius:4px;min-height:36px;padding:8px 12px;font-size:.875rem}.data-sender__error{color:var(--status-error);background-color:#f443361a;border-radius:4px;align-items:center;gap:4px;padding:8px;display:flex}.data-sender__error .material-icons{font-size:16px}.data-sender__actions{gap:8px;display:flex}.data-sender__actions .mdc-button{flex:1}.data-sender__send-btn{background-color:var(--mdc-theme-primary);color:#fff}.data-sender__warning{color:var(--status-warning);background-color:#ff98001a;border-radius:4px;align-items:center;gap:4px;padding:8px;display:flex}.data-sender__warning .material-icons{font-size:16px}.data-receiver{padding:16px}.data-receiver__header{border-bottom:1px solid #0000001a;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.data-receiver__header h2{flex:1;font-size:1rem}.data-receiver__header .material-icons{color:var(--mdc-theme-primary)}.data-receiver__status{color:#00000061;background-color:#0000000d;border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;display:flex}.data-receiver__status .material-icons{font-size:16px}.data-receiver__status.receiving{color:var(--status-info);background-color:#2196f31a}.data-receiver__status.receiving .material-icons{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.data-receiver__content{flex-direction:column;gap:16px;display:flex}.data-receiver__stats{background-color:#00000005;border-radius:4px;gap:16px;padding:8px;display:flex}.data-receiver__stat{align-items:center;gap:4px;display:flex}.data-receiver__stat-label{color:#0009}.data-receiver__stat-value{font-weight:500}.data-receiver__controls{gap:8px;display:flex}.data-receiver__controls .mdc-button{flex:1}.data-receiver__start-btn{background-color:var(--status-success);color:#fff}.data-receiver__stop-btn{background-color:var(--status-error);color:#fff}.data-receiver__display{border:1px solid #0000001a;border-radius:4px;min-height:200px;max-height:400px;overflow:auto}.data-receiver__empty{text-align:center;color:#00000061;padding:48px 16px}.data-receiver__empty .material-icons{margin-bottom:8px;font-size:48px;display:block}.data-receiver__packets{flex-direction:column;display:flex}.data-receiver__packet{background-color:#00000003;border-bottom:1px solid #0000000d;padding:12px}.data-receiver__packet:last-child{border-bottom:none}.data-receiver__packet:nth-child(odd){background-color:#00000008}.data-receiver__packet-header{gap:12px;margin-bottom:8px;display:flex}.data-receiver__packet-index{color:var(--mdc-theme-primary);font-weight:500}.data-receiver__packet-time{color:#00000061}.data-receiver__packet-size{color:#0009;margin-left:auto}.data-receiver__packet-data{flex-direction:column;gap:4px;display:flex}.data-receiver__packet-hex{font-family:var(--font-mono);color:var(--debug-hex);word-break:break-all;background-color:var(--debug-bg);border-radius:4px;padding:8px;font-size:.8125rem}.data-receiver__packet-hex label{color:#fff9;margin-bottom:4px;display:block}.data-receiver__packet-text{color:#000000de;word-break:break-all;font-size:.8125rem}.data-receiver__packet-text label{color:#0009;margin-bottom:4px;display:block}.data-receiver__export{gap:8px;display:flex}.data-receiver__export .mdc-button{flex:1}.data-receiver__warning{color:var(--status-warning);background-color:#ff98001a;border-radius:4px;align-items:center;gap:4px;padding:8px;display:flex}.data-receiver__warning .material-icons{font-size:16px}.data-receiver__format{background-color:#00000005;border-radius:4px;align-items:center;gap:12px;padding:8px;display:flex}.data-receiver__format label{color:#0009;font-size:.875rem}.data-receiver__radio-group{gap:16px;display:flex}.data-receiver__radio-group .mdc-radio{cursor:pointer;align-items:center;gap:4px;display:flex}.data-receiver__radio-group input[type=radio]{width:18px;height:18px;margin:0}.data-receiver__radio-group span{font-size:.875rem}.data-receiver__packet-text.text-unprintable{color:#00000061;font-style:italic}.log-viewer{flex-direction:column;max-height:600px;padding:16px;display:flex}.log-viewer__header{border-bottom:1px solid #0000001a;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:12px;display:flex}.log-viewer__header h2{flex:1;font-size:1rem}.log-viewer__header .material-icons{color:var(--mdc-theme-primary)}.log-viewer__count{color:#0009;background-color:#0000000d;border-radius:4px;padding:2px 8px}.log-viewer__content{flex-direction:column;flex:1;gap:12px;display:flex;overflow:hidden}.log-viewer__filters{flex-direction:column;gap:8px;display:flex}.log-viewer__level-filters{flex-wrap:wrap;gap:8px;display:flex}.log-viewer__level-chip{cursor:pointer;opacity:.5;border-radius:4px;align-items:center;gap:4px;padding:4px 8px;font-size:.75rem;transition:all .2s;display:flex}.log-viewer__level-chip input{display:none}.log-viewer__level-chip.active{opacity:1}.log-viewer__level-chip .material-icons{font-size:16px}.log-level--info{color:var(--status-info);background-color:#2196f31a}.log-level--success{color:var(--status-success);background-color:#4caf501a}.log-level--warning{color:var(--status-warning);background-color:#ff98001a}.log-level--error{color:var(--status-error);background-color:#f443361a}.log-viewer__search{border:1px solid #0000003b;border-radius:4px;align-items:center;gap:8px;padding:8px;transition:border-color .2s;display:flex}.log-viewer__search:focus-within{border-color:var(--mdc-theme-primary)}.log-viewer__search .material-icons{color:#00000061;font-size:20px}.log-viewer__search input{color:#000000de;background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.log-viewer__clear-search{cursor:pointer;color:#00000061;background:0 0;border:none;padding:0}.log-viewer__clear-search .material-icons{font-size:16px}.log-viewer__actions{gap:8px;display:flex}.log-viewer__actions .mdc-button{flex:1}.log-viewer__clear-btn{color:var(--status-error)}.log-viewer__list{border:1px solid #0000001a;border-radius:4px;flex:1;min-height:200px;overflow:auto}.log-viewer__empty{text-align:center;color:#00000061;padding:48px 16px}.log-viewer__empty .material-icons{margin-bottom:8px;font-size:48px;display:block}.log-viewer__entry{border-bottom:1px solid #0000000d;gap:8px;padding:8px 12px;transition:background-color .2s;display:flex}.log-viewer__entry:last-child{border-bottom:none}.log-viewer__entry:hover{background-color:#00000005}.log-viewer__entry-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.log-viewer__entry-icon .material-icons{font-size:18px}.log-viewer__entry-content{flex:1;min-width:0}.log-viewer__entry-header{gap:8px;margin-bottom:2px;display:flex}.log-viewer__entry-time{color:#00000061;white-space:nowrap}.log-viewer__entry-level{white-space:nowrap;border-radius:2px;padding:1px 4px;font-size:.625rem;font-weight:600}.log-viewer__entry-message{color:#000000de;word-break:break-word}.log-viewer__entry-details{color:#0009;word-break:break-word;margin-top:2px}.log-viewer__list::-webkit-scrollbar{width:8px;height:8px}.log-viewer__list::-webkit-scrollbar-track{background:#0000000d}.log-viewer__list::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.log-viewer__list::-webkit-scrollbar-thumb:hover{background:#0000004d}*{box-sizing:border-box;margin:0;padding:0}:root{--mdc-theme-primary:#1976d2;--mdc-theme-primary-dark:#115293;--mdc-theme-primary-light:#4791db;--mdc-theme-secondary:#1976d2;--mdc-theme-surface:#fff;--mdc-theme-background:#f5f5f5;--mdc-theme-error:#d32f2f;--mdc-theme-on-primary:#fff;--mdc-theme-on-surface:#212121;--debug-bg:#1e1e1e;--debug-text:#d4d4d4;--debug-border:#3c3c3c;--debug-highlight:#264f78;--debug-hex:#ce9178;--debug-string:#ce9178;--debug-number:#b5cea8;--debug-keyword:#569cd6;--status-success:#4caf50;--status-warning:#ff9800;--status-error:#f44336;--status-info:#2196f3;--font-sans:"Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"Consolas", "Monaco", "Courier New", monospace;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--shadow-1:0 2px 1px -1px #0003, 0 1px 1px 0 #00000024, 0 1px 3px 0 #0000001f;--shadow-2:0 3px 1px -2px #0003, 0 2px 2px 0 #00000024, 0 1px 5px 0 #0000001f;--shadow-4:0 2px 4px -1px #0003, 0 4px 5px 0 #00000024, 0 1px 10px 0 #0000001f}html{font-size:16px}body{font-family:var(--font-sans);background-color:var(--mdc-theme-background);color:var(--mdc-theme-on-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}.mono{font-family:var(--font-mono)}.app{flex-direction:column;min-height:100vh;display:flex}.app-bar{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--mdc-theme-primary);color:var(--mdc-theme-on-primary);box-shadow:var(--shadow-2);z-index:100;justify-content:space-between;align-items:center;display:flex}.app-bar__title{align-items:center;gap:var(--spacing-sm);display:flex}.app-bar__title h1{font-size:1.25rem;font-weight:500}.app-bar__actions{align-items:center;gap:var(--spacing-sm);display:flex}.app-bar__actions button{color:var(--mdc-theme-on-primary)}.app__content{padding:var(--spacing-lg);flex:1;overflow:auto}.app__grid{gap:var(--spacing-lg);grid-template-columns:320px 1fr 400px;max-width:1600px;margin:0 auto;display:grid}.app__column{gap:var(--spacing-lg);flex-direction:column;display:flex}.app__column--device{min-width:280px}.app__column--data{min-width:400px}.app__column--logs{min-width:360px}.app__card{flex-shrink:0}.mdc-card{background-color:var(--mdc-theme-surface);box-shadow:var(--shadow-1);border-radius:8px;transition:box-shadow .2s;overflow:hidden}.mdc-card:hover{box-shadow:var(--shadow-2)}.app__footer{padding:var(--spacing-md) var(--spacing-lg);background-color:var(--mdc-theme-surface);text-align:center;color:#0009;border-top:1px solid #0000001a}@media (width<=1400px){.app__grid{gap:var(--spacing-md);grid-template-columns:280px 1fr 320px}}@media (width<=1200px){.app__grid{grid-template-columns:1fr 1fr}.app__column--logs{flex-flow:wrap;grid-column:1/-1}.app__column--logs .mdc-card{flex:1;min-width:400px}}@media (width<=900px){.app__grid{grid-template-columns:1fr}.app__column{width:100%}.app__column--device,.app__column--data,.app__column--logs{min-width:auto}.app__column--logs{flex-direction:column}.app__column--logs .mdc-card{min-width:auto}}@media (width<=600px){.app__content{padding:var(--spacing-md)}.app-bar{padding:var(--spacing-sm) var(--spacing-md)}.app-bar__title h1{font-size:1.1rem}}.mdc-button{height:36px;font-family:var(--font-sans);letter-spacing:.025em;text-transform:uppercase;color:var(--mdc-theme-primary);cursor:pointer;background-color:#0000;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0 16px;font-size:.875rem;font-weight:500;transition:background-color .2s,box-shadow .2s;display:inline-flex}.mdc-button:hover{background-color:#1976d20a}.mdc-button:disabled{opacity:.38;cursor:not-allowed}.mdc-button--raised{background-color:var(--mdc-theme-primary);color:var(--mdc-theme-on-primary);box-shadow:var(--shadow-1)}.mdc-button--raised:hover{background-color:var(--mdc-theme-primary-dark)}.mdc-button--outlined{border:1px solid #0000001f}.mdc-button--dense{height:32px;padding:0 12px;font-size:.8125rem}.mdc-button__icon{margin-right:8px;font-size:18px}.mdc-text-field{background-color:#0000;border:1px solid #0000003b;border-radius:4px;align-items:center;width:100%;height:48px;padding:0 12px;transition:border-color .2s;display:inline-flex}.mdc-text-field:focus-within{border-color:var(--mdc-theme-primary)}.mdc-text-field--outlined{border-style:solid}.mdc-text-field--dense{height:36px;padding:0 8px}.mdc-text-field__input{background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:1rem}.mdc-radio{cursor:pointer;align-items:center;gap:4px;display:inline-flex}.mdc-radio input[type=radio]{width:18px;height:18px;margin:0}.material-icons{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-feature-settings:"liga";-webkit-font-smoothing:antialiased;direction:ltr;font-family:Material Icons;font-size:24px;font-style:normal;font-weight:400;line-height:1}.mdc-typography--headline5{letter-spacing:normal;font-size:1.5rem;font-weight:400;line-height:2rem}.mdc-typography--headline6{letter-spacing:.0125em;font-size:1.25rem;font-weight:500;line-height:2rem}.mdc-typography--subtitle2{letter-spacing:.00714em;font-size:.875rem;font-weight:500;line-height:1.375rem}.mdc-typography--body2{letter-spacing:.01786em;font-size:.875rem;font-weight:400;line-height:1.25rem}.mdc-typography--caption{letter-spacing:.03333em;font-size:.75rem;font-weight:400;line-height:1.25rem}
