:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#0e0f12;--bg-elev:#16181d;--bg-elev-2:#1c1f26;--border:#2a2e38;--border-strong:#3a3f4d;--fg:#e7e9ee;--fg-dim:#9aa0ad;--fg-faint:#5e6573;--accent:#5cc4ff;--accent-soft:#5cc4ff1f;--warn:#ffb454;--err:#ff6262;--ok:#6ddc8e;--mono:ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.45}code,.mono,.num{font-family:var(--mono)}button{font:inherit;background:var(--bg-elev-2);color:var(--fg);border:1px solid var(--border-strong);cursor:pointer;border-radius:6px;padding:8px 14px;transition:background .12s,border-color .12s}button:hover:not(:disabled){border-color:var(--accent);background:#242833}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent);color:#061018;border-color:var(--accent);font-weight:600}button.primary:hover:not(:disabled){background:#7ed1ff;border-color:#7ed1ff}input[type=text]{font:inherit;font-family:var(--mono);background:var(--bg);color:var(--fg);border:1px solid var(--border-strong);border-radius:6px;width:100%;padding:8px 10px}input[type=text]:focus{border-color:var(--accent);outline:none}a{color:var(--accent)}.app{flex-direction:column;min-height:100vh;display:flex}.center-stage{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;width:100%;max-width:560px;padding:28px}.card h1{margin:0 0 8px;font-size:20px;font-weight:600}.card h2{color:var(--fg);margin:0 0 6px;font-size:15px;font-weight:600}.card p{color:var(--fg-dim);margin:0 0 14px}.card .step{font-family:var(--mono);letter-spacing:.08em;color:var(--fg-faint);text-transform:uppercase;margin-bottom:8px;font-size:11px}.row{align-items:center;gap:8px;display:flex}.spacer{flex:1}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--fg-dim);font-size:12px}.field .help{color:var(--fg-faint);font-size:12px}.field .err{color:var(--err);font-size:12px}.callout{background:var(--accent-soft);color:var(--fg);border:1px solid #5cc4ff40;border-radius:8px;margin-bottom:14px;padding:10px 12px;font-size:13px}.callout.warn{background:#ffb45414;border-color:#ffb4544d}.callout.err{background:#ff626214;border-color:#ff62624d}.appheader{background:var(--bg-elev);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px 14px;padding:12px 20px;display:flex}.appheader .brand{font-family:var(--mono);letter-spacing:.04em;color:var(--fg);white-space:nowrap;font-weight:700}.appheader .brand .tag{color:var(--accent)}.appheader .meta{font-family:var(--mono);color:var(--fg-faint);white-space:nowrap;font-size:12px}.appheader .select{flex:180px;min-width:0}@media (width<=700px){button{min-height:36px;padding:8px 12px}button.primary{min-height:40px}input[type=text]{min-height:40px;padding:10px 12px;font-size:16px}input[type=checkbox]{width:18px;height:18px}select.select{min-height:36px;padding:8px 10px;font-size:14px}.center-stage{padding:16px}.card{padding:20px}main{padding:14px!important}.appheader{gap:6px 10px;padding:10px 12px}.appheader .meta{font-size:11px}.appheader .spacer{flex-basis:0}.appheader button{white-space:nowrap;min-height:32px;padding:6px 10px;font-size:13px}.conn-row{flex-wrap:wrap}.conn-row .spacer{flex-basis:0}.conn-meta{justify-content:flex-end;width:100%;margin-top:4px}.logging-controls{gap:10px;padding:12px}.readout-toolbar{flex-wrap:wrap;gap:8px}.readout-toolbar input{width:100%;max-width:none}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px}.pid-card{padding:6px 8px}.pid-value{font-size:16px}.session-row{grid-template-columns:1.6fr .7fr .5fr 1.2fr;gap:6px;padding:6px 8px;font-size:11px}.session-row>:nth-child(4),.session-row>:nth-child(5),.session-row>:nth-child(7){display:none}.modal-backdrop{padding:16px 10px!important}.modal-card{border-radius:10px;padding:16px!important}.vehicle-row{flex-wrap:wrap;gap:8px}.vehicle-row>:first-child{flex:100%}.profile-row{flex-wrap:wrap;gap:6px}.grid-2{grid-template-columns:1fr}.vin-row{flex-direction:column;align-items:stretch}.vin-row>*{width:100%}.row{flex-wrap:wrap}}.placeholder{background:var(--bg-elev);border:1px dashed var(--border-strong);color:var(--fg-dim);text-align:center;border-radius:10px;padding:24px;font-size:13px}.kbd{font-family:var(--mono);background:var(--bg-elev-2);border:1px solid var(--border-strong);color:var(--fg);border-bottom-width:2px;border-radius:4px;padding:1px 6px;font-size:12px}.linklike{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.section-title{color:var(--fg-dim);text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px;font-size:13px;font-weight:600}.dim{color:var(--fg-faint)}.conn-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.conn-row{align-items:center;gap:12px;display:flex}.conn-status{align-items:center;gap:10px;display:flex}.dot{background:var(--fg-faint);border-radius:50%;width:10px;height:10px;box-shadow:0 0 0 3px #ffffff0a}.dot.off{background:var(--fg-faint)}.dot.ok{background:var(--ok);box-shadow:0 0 0 3px #6ddc8e2e}.dot.err{background:var(--err);box-shadow:0 0 0 3px #ff62622e}.dot.warn{background:var(--warn);animation:1.2s ease-in-out infinite pulse;box-shadow:0 0 0 3px #ffb45438}.dot.busy{background:var(--accent);animation:1.2s ease-in-out infinite pulse;box-shadow:0 0 0 3px #5cc4ff38}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.conn-state{color:var(--fg);font-size:13px;font-weight:600}.conn-detail{color:var(--fg-dim);font-size:12px}.conn-meta{align-items:center;gap:6px;display:flex}.badge{font-family:var(--mono);letter-spacing:.08em;border:1px solid var(--border-strong);color:var(--fg-dim);background:var(--bg-elev-2);border-radius:4px;padding:2px 7px;font-size:10px}.badge.ok{color:var(--ok);background:#6ddc8e14;border-color:#6ddc8e73}.conn-log{border-top:1px solid var(--border);margin-top:14px;padding-top:10px}.conn-log summary{cursor:pointer;color:var(--fg-dim);-webkit-user-select:none;user-select:none;font-size:12px}.conn-log summary::marker{color:var(--fg-faint)}.conn-log-body{background:var(--bg);border:1px solid var(--border);border-radius:6px;max-height:220px;margin-top:10px;padding:8px 10px;font-size:12px;line-height:1.5;overflow:auto}.logline{gap:8px;display:flex}.logline-dir{color:var(--fg-faint);flex-shrink:0;width:36px}.logline-text{white-space:pre-wrap;word-break:break-all}.logline.dir-tx .logline-dir{color:var(--accent)}.logline.dir-rx .logline-dir{color:var(--ok)}.logline.dir-info .logline-dir{color:var(--fg-dim)}.logline.dir-err .logline-dir,.logline.dir-err .logline-text{color:var(--err)}select.select{font:inherit;font-family:var(--mono);background:var(--bg);color:var(--fg);border:1px solid var(--border-strong);border-radius:6px;padding:6px 8px}select.select:focus{border-color:var(--accent);outline:none}.vehicle-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:12px 16px}.vehicle-name{color:var(--fg);margin-bottom:2px;font-size:14px;font-weight:600}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#08090cb3;justify-content:center;align-items:flex-start;padding:40px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:14px;width:100%;max-width:720px;padding:22px;display:flex}.vehicle-list{flex-direction:column;gap:8px;display:flex}.vehicle-row{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.vehicle-row.active{border-color:var(--accent);background:#5cc4ff0d}.vehicle-meta{color:var(--fg-faint);font-size:11px}.vin-row{align-items:flex-end;gap:8px;margin-bottom:14px;display:flex}.grid-2{grid-template-columns:1fr 1fr;gap:0 14px;display:grid}.warn-inline{color:var(--warn)!important}.vehicle-form{flex-direction:column;display:flex}.vehicle-form .field,.vehicle-form .callout{margin-bottom:12px}.logging-controls{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:14px;padding:12px 16px;display:flex}.logging-state,.logging-stats{font-size:13px}.rate-picker{color:var(--fg-dim);font-size:12px}.readout{flex-direction:column;gap:14px;display:flex}.readout-toolbar{align-items:center;gap:12px;display:flex}.readout-toolbar input{max-width:320px}.readout-section{flex-direction:column;gap:8px;display:flex}.cat-header{text-align:left;color:var(--fg);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:4px 0;font-size:13px;font-weight:600;display:inline-flex}.cat-header:hover{color:var(--accent)}.cat-caret{width:12px;color:var(--fg-faint);display:inline-block}.cat-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;display:grid}.pid-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;min-width:0;padding:8px 10px}.pid-name{color:var(--fg-dim);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:11px;overflow:hidden}.pid-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.pid-value{color:var(--fg);font-size:18px;font-weight:600}.pid-unit{color:var(--fg-faint);margin-left:4px;font-size:11px;font-weight:400}.session-table{flex-direction:column;gap:4px;font-size:12px;display:flex}.session-row{border-radius:6px;grid-template-columns:1.6fr .8fr .6fr .5fr .6fr 1.2fr 2fr;gap:8px;padding:6px 10px;display:grid}.session-row:nth-child(odd):not(.session-head){background:var(--bg-elev)}.session-head{color:var(--fg-faint);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding-bottom:6px;font-size:11px}.progress{background:var(--bg);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar{background:var(--accent);height:100%;transition:width .15s linear}.sweep-grid{border:1px solid var(--border);border-radius:6px;flex-direction:column;max-height:360px;margin-top:10px;display:flex;overflow:hidden auto}.sweep-row{grid-template-columns:1.4fr .5fr .5fr 1fr .6fr 3fr;gap:8px;padding:4px 10px;font-size:11px;display:grid}.sweep-row.sweep-head{color:var(--fg-faint);text-transform:uppercase;background:var(--bg-elev-2);font-size:10px;position:sticky;top:0}.sweep-row.status-ok{color:var(--ok)}.sweep-row.status-no_data{color:var(--fg-faint)}.sweep-row.status-error{color:var(--err)}.sweep-row.status-no_response{color:var(--fg-faint);opacity:.6}.sweep-row.status-rejected{color:var(--warn)}.sweep-modes{flex-direction:column;gap:6px;display:flex}.settings-section{border-top:1px solid var(--border);padding-top:14px}.settings-section h3{color:var(--fg);margin:0 0 8px;font-size:13px;font-weight:600}.profile-list{flex-direction:column;gap:4px;margin-top:10px;display:flex}.profile-row{background:var(--bg);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;padding:6px 10px;display:flex}
