/* ─── Map Panel ──────────────────────────────────────────────────────────────── */
#map-panel {
  flex-shrink: 0;
  width: 420px;
  display: none;
  flex-direction: row;
  background: var(--bg2);
  border-left: 1px solid var(--border);
}
#map-panel.visible { display: flex; }

#map-resizer {
  flex-shrink: 0;
  width: 6px;
  cursor: ew-resize;
  touch-action: none;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  transition: background 0.15s;
}
#map-resizer:hover { background: var(--bg4); }

body.map-resizing {
  cursor: ew-resize;
  user-select: none;
}

#map-inner {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
}

#map-panel .panel-hdr { justify-content: space-between; }

#raw-panel .panel-hdr { justify-content: space-between; }

.map-hdr-controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

.map-mini-btn {
  padding: 2px 8px;
  border-radius: 2px;
  border: 1px solid var(--border2);
  background: transparent;
  color: var(--dim);
  font-family: var(--font);
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 0.5px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.map-mini-btn:hover       { color: var(--text); border-color: var(--dim); }
.map-mini-btn.active      { color: var(--cyan); border-color: var(--cyan); }

#map-container { flex: 1; min-height: 0; }

#map-layer-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  padding: 6px 8px;
  border-top: 1px solid var(--border);
  background: var(--bg2);
  flex-shrink: 0;
}

/* Leaflet overrides for dark theme */
.leaflet-control-zoom a {
  background: var(--bg3) !important;
  color: var(--text) !important;
  border-color: var(--border2) !important;
}
.leaflet-control-zoom a:hover { background: var(--bg4) !important; }
.leaflet-control-attribution {
  background: rgba(8,12,16,0.75) !important;
  color: var(--dim) !important;
  font-size: 9px !important;
}
.leaflet-control-attribution a { color: var(--dim) !important; }

/* Custom GPS marker */
.gps-marker-outer {
  width: 18px; height: 18px;
}
.gps-marker-inner {
  width: 9px; height: 9px;
  background: #3de87a;
  border-radius: 50%;
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 8px #3de87a;
  animation: marker-pulse 2s ease-in-out infinite;
}
@keyframes marker-pulse {
  0%, 100% { box-shadow: 0 0 6px rgba(61,232,122,0.7); }
  50%       { box-shadow: 0 0 14px rgba(61,232,122,1.0); }
}

/* ─── Reset & Base ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:        #080c10;
  --bg2:       #0d1117;
  --bg3:       #111820;
  --bg4:       #161e28;
  --border:    #21303d;
  --border2:   #2d3f50;
  --text:      #c8d6e0;
  --dim:       #5a7080;
  --dim2:      #3d5060;
  --cyan:      #2dd4e8;
  --cyan-dim:  #1a8090;
  --green:     #3de87a;
  --green-dim: #1a6040;
  --yellow:    #f0c040;
  --red:       #f04840;
  --magenta:   #c060f0;
  --white:     #e8f0f8;
  --gps:       #3de87a;
  --glonass:   #2dd4e8;
  --galileo:   #c060f0;
  --beidou:    #f0c040;
  --qzss:      #ff5ab7;
  --sbas:      #f09040;
  --font: 'Courier New', 'Menlo', 'Monaco', 'Consolas', monospace;
}

html, body {
  height: 100%;
  overflow: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13px;
  line-height: 1.4;
}

body {
  display: flex;
  flex-direction: column;
}

/* ─── Scrollbars ────────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--dim); }

/* ─── Title Bar ─────────────────────────────────────────────────────────────── */
#titlebar {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 16px;
  height: 44px;
  background: linear-gradient(180deg, #0d1a28 0%, var(--bg2) 100%);
  border-bottom: 1px solid var(--border);
  position: relative;
  z-index: 10;
}

#titlebar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  opacity: 0.6;
}

#logo {
  display: flex;
  align-items: center;
  gap: 10px;
}

#logo-icon {
  width: 28px;
  height: 28px;
  position: relative;
  flex-shrink: 0;
}

#logo-title {
  font-size: 15px;
  font-weight: bold;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cyan);
  text-shadow: 0 0 16px rgba(45, 212, 232, 0.5);
}

#logo-title em {
  color: var(--green);
  font-style: normal;
  text-shadow: 0 0 16px rgba(61, 232, 122, 0.5);
}

#logo-sub {
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 2px;
  margin-top: 1px;
}

.site-credit {
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 1px;
  margin-top: 2px;
}

.site-credit a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid transparent;
}

.site-credit a:hover {
  color: var(--text);
  border-bottom-color: var(--dim2);
}

.site-credit a:focus-visible {
  outline: 2px solid var(--cyan);
  outline-offset: 2px;
}

/* ─── Controls ──────────────────────────────────────────────────────────────── */
.controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ctrl-label {
  font-size: 10px;
  color: var(--dim);
  text-transform: uppercase;
  letter-spacing: 1px;
}

select {
  background: var(--bg3);
  color: var(--text);
  border: 1px solid var(--border2);
  padding: 4px 8px;
  font-family: var(--font);
  font-size: 12px;
  border-radius: 3px;
  outline: none;
  cursor: pointer;
}
select:focus { border-color: var(--cyan); }

.btn {
  padding: 5px 14px;
  border-radius: 3px;
  border: 1px solid;
  font-family: var(--font);
  font-size: 11px;
  font-weight: bold;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  background: transparent;
  transition: background 0.15s, box-shadow 0.15s;
}

#btn-connect {
  color: var(--green);
  border-color: var(--green);
}
#btn-connect:hover { background: rgba(61,232,122,0.1); box-shadow: 0 0 8px rgba(61,232,122,0.2); }
#btn-connect.active {
  color: var(--red);
  border-color: var(--red);
}
#btn-connect.active:hover { background: rgba(240,72,64,0.1); }

#btn-demo {
  color: var(--yellow);
  border-color: var(--yellow);
}
#btn-demo:hover { background: rgba(240,192,64,0.1); }
#btn-demo.active { background: rgba(240,192,64,0.15); box-shadow: 0 0 8px rgba(240,192,64,0.2); }

#btn-map {
  color: var(--cyan);
  border-color: var(--cyan);
}
#btn-map:hover { background: rgba(45,212,232,0.1); }
#btn-map.active { background: rgba(45,212,232,0.15); box-shadow: 0 0 8px rgba(45,212,232,0.2); }

#btn-dop {
  color: var(--cyan);
  border-color: var(--cyan);
}
#btn-dop:hover { background: rgba(45,212,232,0.1); }
#btn-dop.active { background: rgba(45,212,232,0.15); box-shadow: 0 0 8px rgba(45,212,232,0.2); }

#dop-panel {
  flex-shrink: 0;
  height: 90px;
  display: none;
  flex-direction: column;
  background: var(--bg2);
  border-top: 1px solid var(--border);
}
#dop-panel.visible { display: flex; }
#dop-canvas-wrap { flex: 1; overflow: hidden; }
#dop-canvas { display: block; }

#btn-reset {
  color: var(--dim);
  border-color: var(--border2);
}
#btn-reset:hover { color: var(--text); border-color: var(--dim); }

/* Connection indicator */
.conn-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--dim);
}

.conn-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--dim2);
  transition: background 0.3s;
}
.conn-dot.connected { background: var(--green); box-shadow: 0 0 8px var(--green); animation: blink 1.8s ease-in-out infinite; }
.conn-dot.demo      { background: var(--yellow); box-shadow: 0 0 8px var(--yellow); animation: blink 1.8s ease-in-out infinite; }

@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

/* No-serial warning */
#no-serial-warn {
  display: none;
  font-size: 11px;
  color: var(--red);
  border: 1px solid var(--red);
  padding: 3px 10px;
  border-radius: 3px;
  background: rgba(240,72,64,0.08);
}

/* ─── Status Bar ────────────────────────────────────────────────────────────── */
#statusbar {
  flex-shrink: 0;
  display: flex;
  align-items: stretch;
  height: 32px;
  background: var(--bg3);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.stat-cell {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  border-right: 1px solid var(--border);
  white-space: nowrap;
}

.stat-cell:last-child { border-right: none; margin-left: auto; }

.stat-key {
  font-size: 10px;
  color: var(--dim);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.stat-val {
  font-size: 12px;
  font-weight: bold;
  color: var(--text);
}
.stat-val.good { color: var(--green); text-shadow: 0 0 8px rgba(61,232,122,0.3); }
.stat-val.warn { color: var(--yellow); }
.stat-val.bad  { color: var(--red); }

#stale-badge {
  font-size: 9px;
  font-weight: bold;
  letter-spacing: 1px;
  padding: 1px 6px;
  background: var(--red);
  color: #fff;
  border-radius: 2px;
  display: none;
}

/* ─── Data Bar ──────────────────────────────────────────────────────────────── */
#databar {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.data-group {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  padding: 0 8px;
  border-right: 1px solid var(--border);
  min-width: 0;
}
.data-group:last-child { border-right: none; }

.data-group.geo-group {
  flex: 0 0 100%;
  border-right: none;
  border-bottom: 1px solid var(--border);
}

.data-group.cpu-group {
  flex: 0 0 auto;
}

.data-item {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 10px;
  border-right: 1px solid var(--border);
  white-space: nowrap;
}
.data-item:last-child { border-right: none; }

.data-key {
  font-size: 10px;
  color: var(--dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.data-val {
  font-size: 12px;
  color: var(--text);
  min-width: 90px;
}
.data-val.pos { color: var(--green); }

#d-cpu,
#d-cpuclk {
  min-width: 76px;
}

#d-sbas {
  min-width: 160px;
}

/* ─── Main Layout ───────────────────────────────────────────────────────────── */
#workspace {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}

#panels {
  flex: 1;
  display: flex;
  overflow: hidden;
  min-height: 0;
}

/* ─── Sky Panel ─────────────────────────────────────────────────────────────── */
#sky-panel {
  flex-shrink: 0;
  aspect-ratio: 1 / 1;
  max-width: 50%;
  display: flex;
  flex-direction: column;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  overflow: hidden;
}

.panel-hdr {
  flex-shrink: 0;
  padding: 6px 12px;
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  background: var(--bg3);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
}

.panel-hdr-icon { color: var(--cyan-dim); }

#sky-canvas-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  min-height: 0;
}

#sky-canvas { display: block; }

#sky-legend {
  flex-shrink: 0;
  padding: 6px 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  border-top: 1px solid var(--border);
  background: var(--bg3);
  min-height: 30px;
}

.leg-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
}

.leg-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ─── Satellite Panel ───────────────────────────────────────────────────────── */
#sat-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: var(--bg2);
  overflow: hidden;
  min-width: 0;
}

#sat-scroll {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
}

#sat-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

#sat-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--bg3);
  color: var(--cyan);
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  white-space: nowrap;
}

#sat-table thead th.r { text-align: right; }

#sat-table tbody tr {
  border-bottom: 1px solid rgba(33,48,61,0.5);
  transition: background 0.1s;
}
#sat-table tbody tr:hover { background: rgba(45,212,232,0.04); }

#sat-table tbody td {
  padding: 4px 10px;
  white-space: nowrap;
}
#sat-table tbody td.r { text-align: right; }

.td-sys  { font-weight: bold; }
.td-snr  { font-weight: bold; font-variant-numeric: tabular-nums; text-align: right; }
.td-num  { font-variant-numeric: tabular-nums; text-align: right; color: var(--dim); }
.td-used { text-align: center; font-size: 11px; }

.sig-wrap { min-width: 80px; padding: 0 4px; }
.sig-bg {
  height: 8px;
  background: rgba(33,48,61,0.8);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.sig-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.4s ease;
  position: absolute;
  left: 0; top: 0;
}
.sig-hi { background: linear-gradient(90deg, #1a8a40, #3de87a); }
.sig-md { background: linear-gradient(90deg, #8a6010, #f0c040); }
.sig-lo { background: linear-gradient(90deg, #8a2010, #f04840); }

/* ─── Raw NMEA Panel ────────────────────────────────────────────────────────── */
#raw-panel {
  flex-shrink: 0;
  height: 120px;
  display: flex;
  flex-direction: column;
  background: var(--bg3);
  border-top: 1px solid var(--border);
}

#raw-resizer {
  flex-shrink: 0;
  height: 6px;
  cursor: ns-resize;
  touch-action: none;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
}

body.raw-resizing {
  cursor: ns-resize;
  user-select: none;
}

#raw-scroll {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px 14px;
  font-size: 11px;
  line-height: 1.6;
}

.nmea-line { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.n-dollar   { color: var(--cyan); }
.n-talker   { color: var(--cyan-dim); }
.n-type     { color: var(--green); font-weight: bold; }
.n-st       { color: var(--cyan); font-weight: normal; }
.n-st-type  { color: var(--cyan); font-weight: bold; }
.n-qz       { color: var(--qzss); font-weight: normal; }
.n-qz-type  { color: var(--qzss); font-weight: bold; }
.n-cpu      { font-weight: bold; }
.n-body     { color: var(--dim); }
.n-star     { color: var(--dim2); }
.n-cs       { color: var(--dim2); }
.n-info     { color: var(--yellow); font-style: italic; }

/* ─── Recorder Overlay ──────────────────────────────────────────────────────── */
#recorder-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
}
#recorder-overlay.visible { display: block; }

#recorder-overlay .rec-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
}

#recorder-overlay .rec-panel {
  position: absolute;
  inset: 18px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

#recorder-overlay .rec-hdr {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  height: 44px;
  padding: 0 12px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #0d1a28 0%, var(--bg3) 100%);
}

#recorder-overlay .rec-title {
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--red);
  font-weight: bold;
}

#recorder-overlay .rec-hdr .btn { font-family: var(--font); }

/* Tabs */
#recorder-overlay .rec-tabs {
  flex-shrink: 0;
  display: flex;
  gap: 6px;
  padding: 6px 16px;
  height: 44px;
  align-items: center;
  border-bottom: 1px solid var(--border);
  background: var(--bg2);
}

#recorder-overlay .rec-tab-btn {
  border: 1px solid var(--border);
  background: var(--bg3);
  color: var(--dim);
  padding: 0 12px;
  height: 32px;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--font);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
#recorder-overlay .rec-tab-btn.active { color: var(--text); border-color: var(--cyan); }
#recorder-overlay .rec-tab-btn:hover  { color: var(--text); border-color: var(--dim); }

/* Tab body */
#recorder-overlay .rec-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.rec-tab-pane { display: none; flex: 1; min-height: 0; overflow: auto; padding: 10px 12px; }
.rec-tab-pane.active { display: flex; flex-direction: column; gap: 8px; }

/* Record tab */
.rec-status-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: var(--bg3);
  border: 1px solid var(--border);
  border-radius: 4px;
}

.rec-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--dim2);
  flex-shrink: 0;
}
.rec-status-dot.idle        { background: var(--dim2); }
.rec-status-dot.recording   { background: var(--red); box-shadow: 0 0 8px var(--red); animation: blink 1.2s ease-in-out infinite; }
.rec-status-dot.stopped     { background: var(--dim); }
.rec-status-dot.interrupted { background: var(--yellow); }

.rec-status-label {
  font-size: 11px;
  font-weight: bold;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.rec-status-label.idle        { color: var(--dim); }
.rec-status-label.recording   { color: var(--red); }
.rec-status-label.stopped     { color: var(--dim); }
.rec-status-label.interrupted { color: var(--yellow); }

.rec-session-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 10px;
  color: var(--dim);
  margin-left: auto;
  text-align: right;
}
.rec-session-info strong { color: var(--text); font-size: 11px; }

.rec-btn-row {
  display: flex;
  gap: 8px;
  align-items: center;
}

#btn-rec-start {
  flex: 1;
  padding: 8px 14px;
  font-size: 12px;
  color: var(--red);
  border-color: var(--red);
  background: rgba(240,72,64,0.12);
}
#btn-rec-start:hover { background: rgba(240,72,64,0.25); box-shadow: 0 0 10px rgba(240,72,64,0.25); }

#btn-rec-stop {
  flex: 1;
  padding: 8px 14px;
  font-size: 12px;
  color: var(--red);
  border-color: rgba(240,72,64,0.5);
  background: rgba(240,72,64,0.08);
}
#btn-rec-stop:hover { background: rgba(240,72,64,0.2); box-shadow: 0 0 10px rgba(240,72,64,0.2); }

#rec-btn-close {
  color: var(--dim);
  border-color: var(--border2);
}
#rec-btn-close:hover { color: var(--text); border-color: var(--dim); }

.rec-notice {
  padding: 10px 14px;
  border-radius: 6px;
  border: 1px solid var(--yellow);
  background: rgba(240,192,64,0.06);
  color: var(--yellow);
  font-size: 11px;
  line-height: 1.6;
}

.rec-stats-row {
  display: flex;
  gap: 16px;
  font-size: 10px;
  color: var(--dim);
  padding: 2px 0;
}
.rec-stats-row span { color: var(--text); }

/* Sessions tab */
.rec-session-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.rec-session-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--bg3);
  color: var(--cyan);
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 10px;
  border-bottom: 1px solid var(--border);
  text-align: left;
  white-space: nowrap;
}
.rec-session-table tbody tr {
  border-bottom: 1px solid rgba(33,48,61,0.5);
  cursor: pointer;
  transition: background 0.1s;
}
.rec-session-table tbody tr:hover  { background: rgba(45,212,232,0.04); }
.rec-session-table tbody tr.active { background: rgba(45,212,232,0.08); }
.rec-session-table tbody td {
  padding: 5px 10px;
  white-space: nowrap;
  vertical-align: middle;
}
.rec-status-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: bold;
  letter-spacing: 1px;
  padding: 1px 6px;
  border-radius: 2px;
}
.rec-status-badge.recording   { background: var(--red);    color: #fff; }
.rec-status-badge.stopped     { background: var(--bg3);    color: var(--dim);    border: 1px solid var(--border2); }
.rec-status-badge.interrupted { background: rgba(240,192,64,0.2); color: var(--yellow); border: 1px solid var(--yellow); }

.rec-action-btn {
  padding: 2px 8px;
  border-radius: 2px;
  border: 1px solid var(--border2);
  background: transparent;
  color: var(--dim);
  font-family: var(--font);
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 0.5px;
  cursor: pointer;
  margin-right: 4px;
  transition: color 0.15s, border-color 0.15s;
}
.rec-action-btn:hover { color: var(--text); border-color: var(--dim); }
.rec-action-btn.dl    { color: var(--cyan);   border-color: var(--cyan-dim); }
.rec-action-btn.dl:hover { border-color: var(--cyan); }
.rec-action-btn.map   { color: var(--green);  border-color: var(--green-dim); }
.rec-action-btn.map:hover { border-color: var(--green); }
.rec-action-btn.del   { color: var(--red);    border-color: rgba(240,72,64,0.4); }
.rec-action-btn.del:hover { border-color: var(--red); }

/* Session detail / map pane */
#rec-session-detail {
  flex-shrink: 0;
  border-top: 1px solid var(--border);
  background: var(--bg3);
  padding: 10px 16px;
  font-size: 11px;
  color: var(--dim);
}

#rec-session-map-wrap {
  flex-shrink: 0;
  height: 280px;
  border-top: 1px solid var(--border);
  position: relative;
  display: none;
  flex-direction: column;
}
#rec-session-map-wrap.visible { display: flex; }

#rec-map-resizer {
  flex-shrink: 0;
  height: 6px;
  cursor: ns-resize;
  touch-action: none;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
}
#rec-map-resizer:hover { background: var(--bg4); }

body.rec-map-resizing {
  cursor: ns-resize;
  user-select: none;
}

#rec-session-map { flex: 1; min-height: 0; }

/* レイヤー切り替えボタン群 (地図右上に重ねて表示) */
#rec-map-layer-btns {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 1000;
  display: flex;
  gap: 4px;
}
.rec-layer-btn {
  padding: 3px 9px;
  border-radius: 3px;
  border: 1px solid var(--border2);
  background: rgba(13,17,23,0.82);
  color: var(--dim);
  font-family: var(--font);
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 0.5px;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.rec-layer-btn:hover  { color: var(--text); border-color: var(--dim); }
.rec-layer-btn.active { color: var(--cyan); border-color: var(--cyan); background: rgba(45,212,232,0.10); }

/* Leaflet popup — dark theme for rec map */
#rec-session-map .leaflet-popup-content-wrapper {
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--text);
  box-shadow: 0 4px 16px rgba(0,0,0,0.6);
  padding: 0;
}
#rec-session-map .leaflet-popup-content {
  margin: 0;
  font-family: var(--font);
  font-size: 11px;
  line-height: 1.7;
}
#rec-session-map .leaflet-popup-tip {
  background: var(--border2);
}
#rec-session-map .leaflet-popup-close-button {
  color: var(--dim) !important;
  font-size: 16px !important;
  top: 4px !important;
  right: 6px !important;
}
#rec-session-map .leaflet-popup-close-button:hover { color: var(--text) !important; }

.rec-popup {
  padding: 8px 12px;
  min-width: 180px;
}
.rec-popup-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.rec-popup-key {
  color: var(--dim);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.rec-popup-val {
  color: var(--cyan);
  font-weight: bold;
  text-align: right;
}

.rec-map-empty {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--dim);
  font-size: 12px;
  background: var(--bg3);
  pointer-events: none;
}

/* REC indicator in statusbar */
#rec-indicator {
  display: none;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: bold;
  letter-spacing: 1px;
  color: var(--red);
  padding: 2px 8px;
  border: 1px solid var(--red);
  border-radius: 3px;
  background: rgba(240,72,64,0.08);
}
#rec-indicator.visible { display: flex; }
#rec-indicator .rec-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--red);
  animation: blink 1.2s ease-in-out infinite;
}

#btn-rec-toggle {
  color: var(--red);
  border-color: var(--red);
}
#btn-rec-toggle:hover { background: rgba(240,72,64,0.1); }
#btn-rec-toggle.recording {
  color: var(--red);
  border-color: var(--red);
  background: rgba(240,72,64,0.18);
  box-shadow: 0 0 8px rgba(240,72,64,0.25);
  animation: blink-btn 1.2s ease-in-out infinite;
}
@keyframes blink-btn {
  0%, 100% { box-shadow: 0 0 6px rgba(240,72,64,0.2); }
  50%       { box-shadow: 0 0 14px rgba(240,72,64,0.45); }
}

#btn-rec {
  color: var(--dim);
  border-color: var(--border2);
}
#btn-rec:hover { color: var(--text); border-color: var(--dim); }

/* Rec sessions list scroll area */
#rec-sessions-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
}

/* ─── Teseo Overlay (Integrated) ───────────────────────────────────────────── */
#teseo-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
}
#teseo-overlay.visible { display: block; }

#teseo-overlay .teseo-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

#teseo-overlay .teseo-panel {
  position: absolute;
  inset: 18px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

#teseo-overlay .teseo-hdr {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  height: 44px;
  padding: 0 12px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #0d1a28 0%, var(--bg3) 100%);
}

#teseo-overlay .teseo-title {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

#teseo-overlay .teseo-title .name {
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  font-weight: bold;
}

#teseo-overlay .teseo-title .sub {
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 1px;
}

#teseo-overlay .teseo-controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Settings dropdown */
.settings-dropdown-wrap {
  position: relative;
}

#btn-settings {
  color: var(--dim);
  border-color: var(--border2);
  font-size: 20px;
  line-height: 1;
  padding: 1px 10px;
}
#btn-settings:hover { color: var(--text); border-color: var(--dim); }

.settings-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--bg3);
  border: 1px solid var(--border2);
  border-radius: 4px;
  min-width: 190px;
  z-index: 9000;
  box-shadow: 0 6px 20px rgba(0,0,0,0.5);
  padding: 4px 0;
}

.settings-menu.open {
  display: block;
}

.settings-menu-label {
  padding: 6px 14px 4px;
  font-size: 9px;
  font-weight: bold;
  letter-spacing: 1px;
  color: var(--dim);
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}

.settings-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 8px 14px;
  border: none;
  background: transparent;
  color: var(--text);
  font-family: var(--font);
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.5px;
  cursor: pointer;
  text-align: left;
  transition: background 0.12s;
}

.settings-menu-item:hover {
  background: var(--bg4);
}

.settings-menu-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Base button styling inside overlay (covers tabs and any future buttons) */
#teseo-overlay button {
  font-family: var(--font);
  color: var(--text);
}

#teseo-overlay button:focus-visible {
  outline: 2px solid rgba(45,212,232,0.55);
  outline-offset: 2px;
}

#teseo-overlay .teseo-controls .btn {
  color: var(--text);
  border-color: var(--border2);
}

#teseo-overlay .teseo-controls .btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}


#teseo-overlay #teseo-btn-read {
  color: var(--cyan);
  border-color: var(--cyan);
}
#teseo-overlay #teseo-btn-read:hover { background: rgba(45,212,232,0.10); }

#teseo-overlay #teseo-btn-write {
  color: var(--green);
  border-color: var(--green);
}
#teseo-overlay #teseo-btn-write:hover { background: rgba(61,232,122,0.10); }

#teseo-overlay #teseo-btn-save {
  color: var(--yellow);
  border-color: var(--yellow);
}
#teseo-overlay #teseo-btn-save:hover { background: rgba(240,192,64,0.10); }

#teseo-overlay #teseo-btn-reset {
  color: var(--red);
  border-color: var(--red);
}
#teseo-overlay #teseo-btn-reset:hover { background: rgba(240,72,64,0.10); }

#teseo-overlay #teseo-btn-close {
  color: var(--dim);
  border-color: var(--border2);
}
#teseo-overlay #teseo-btn-close:hover { color: var(--text); border-color: var(--dim); }

/* Tab buttons: make hover/active states clearer */
#teseo-overlay .teseo-tab-btn:hover {
  color: var(--text);
  border-color: var(--dim);
}

#teseo-overlay .teseo-tab-btn.active {
  background: rgba(45,212,232,0.10);
}

#teseo-overlay .teseo-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* ─── Teseo UI (scoped) ───────────────────────────────────────────────────── */
#teseo-overlay {
  --t-bg: var(--bg);
  --t-bg2: var(--bg2);
  --t-bg3: var(--bg3);
  --t-panel: var(--bg2);
  --t-border: var(--border);
  --t-text: var(--text);
  --t-muted: var(--dim);
  --t-accent: var(--green);
  --t-accent2: var(--cyan);
  --t-warn: var(--yellow);
  --t-bad: var(--red);
  --t-good: var(--green);
  --t-font: var(--font);
}

#teseo-overlay * { box-sizing: border-box; }

#teseo-overlay .app {
  display: grid;
  grid-template-rows: auto 44px 1fr auto;
  height: 100%;
  font-family: var(--t-font);
  color: var(--t-text);
  background: var(--t-bg2);
}

#teseo-overlay .statusbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--t-border);
  background: var(--t-bg3);
}

#teseo-overlay .status-card {
  padding: 10px 12px;
  background: var(--t-panel);
  border: 1px solid var(--t-border);
  border-radius: 8px;
}

#teseo-overlay .status-key { color: var(--t-muted); font-size: 11px; letter-spacing: 1px; }
#teseo-overlay .status-val { font-size: 13px; font-weight: 700; }
#teseo-overlay .status-val.good { color: var(--t-good); }
#teseo-overlay .status-val.bad { color: var(--t-bad); }
#teseo-overlay .status-val.warn { color: var(--t-warn); }

#teseo-overlay .constellation-warning {
  margin-top: 8px;
  padding: 7px 10px;
  border-radius: 4px;
  border: 1px solid var(--t-bad);
  background: rgba(255,80,80,0.08);
  color: var(--t-bad);
  font-size: 11px;
  line-height: 1.6;
  white-space: pre-line;
}

#teseo-overlay .tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 16px;
  height: 44px;
  align-items: center;
  border-bottom: 1px solid var(--t-border);
  background: var(--t-bg2);
}

#teseo-overlay .teseo-tab-btn {
  border: 1px solid var(--t-border);
  background: var(--t-bg3);
  color: var(--t-muted);
  padding: 0 12px;
  height: 32px;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--t-font);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
#teseo-overlay .teseo-tab-btn.active { color: var(--t-text); border-color: var(--t-accent2); }

#teseo-overlay .main {
  padding: 14px 16px 18px 16px;
  display: grid;
  gap: 16px;
  min-height: 0;
  overflow: auto;
}

#teseo-overlay .panel {
  background: var(--t-panel);
  border: 1px solid var(--t-border);
  border-radius: 12px;
  padding: 14px;
}

/* Log panel: let textarea grow to match the panel height */
#teseo-overlay .panel.log-panel {
  display: flex;
  flex-direction: column;
  min-height: 240px;
}

#teseo-overlay .panel h2 {
  margin: 0 0 12px 0;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--t-accent2);
  text-transform: uppercase;
}

#teseo-overlay .grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

#teseo-overlay .item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--t-border);
  border-radius: 8px;
  background: var(--t-bg3);
}

#teseo-overlay .item .label { font-size: 12px; }
#teseo-overlay .item small { color: var(--t-muted); }

#teseo-overlay .label-title {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: baseline;
}
#teseo-overlay .label-title .name { font-weight: 700; }
#teseo-overlay .label-title .desc { color: var(--t-muted); }

#teseo-overlay .list { grid-template-columns: 1fr; }

#teseo-overlay .detail { margin-top: 6px; }
#teseo-overlay .detail summary {
  cursor: pointer;
  list-style: none;
  font-size: 11px;
  color: var(--t-accent2);
}
#teseo-overlay .detail summary::-webkit-details-marker { display: none; }
#teseo-overlay .detail-body {
  margin-top: 6px;
  color: var(--t-muted);
  font-size: 11px;
  line-height: 1.5;
}

#teseo-overlay .toggle-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

#teseo-overlay .toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 8px;
  border: 1px solid var(--t-border);
  border-radius: 999px;
  background: var(--t-bg2);
  font-size: 11px;
  line-height: 1;
}

#teseo-overlay .toggle-btn input {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: var(--t-accent);
}

#teseo-overlay .pending { box-shadow: 0 0 0 1px rgba(240, 192, 64, 0.55) inset; }

#teseo-overlay .row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

#teseo-overlay .log {
  width: 100%;
  min-height: 120px;
  flex: 1;
  overflow: auto;
  background: var(--t-bg);
  border: 1px solid var(--t-border);
  color: var(--t-muted);
  padding: 8px;
  border-radius: 8px;
  font-size: 11px;
}

#teseo-overlay .log-view {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  line-height: 1.5;
  white-space: pre;
}

#teseo-overlay .log-view:empty::before {
  content: attr(data-placeholder);
  color: var(--t-muted);
}

#teseo-overlay .log-line { white-space: pre; }
#teseo-overlay .log-line.cmd { color: var(--t-accent2); }
#teseo-overlay .log-line.resp { color: var(--t-text); }
#teseo-overlay .log-line.warn { color: var(--t-warn); }
#teseo-overlay .log-line.err { color: var(--t-bad); }

#teseo-overlay footer {
  padding: 10px 16px 14px 16px;
  color: var(--t-muted);
  font-size: 11px;
  border-top: 1px solid var(--t-border);
  background: var(--t-bg3);
}

#teseo-overlay .hidden { display: none; }

/* ─── u-blox M10 Overlay ────────────────────────────────────────────────────── */
#ublox-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: none;
}
#ublox-overlay.visible { display: block; }

#ublox-overlay .m10-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

#ublox-overlay .m10-panel {
  position: absolute;
  inset: 18px;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

#ublox-overlay .m10-hdr {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #0d1a28 0%, var(--bg3) 100%);
}

#ublox-overlay .m10-title {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

#ublox-overlay .m10-title .name {
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cyan);
  font-weight: bold;
}

#ublox-overlay .m10-title .sub {
  font-size: 10px;
  color: var(--dim);
  letter-spacing: 1px;
}

#ublox-overlay .m10-controls {
  display: flex;
  align-items: center;
  gap: 8px;
}

#ublox-overlay button {
  font-family: var(--font);
  color: var(--text);
}

#ublox-overlay button:focus-visible {
  outline: 2px solid rgba(45,212,232,0.55);
  outline-offset: 2px;
}

#ublox-overlay .m10-controls .btn {
  color: var(--text);
  border-color: var(--border2);
}

#ublox-overlay .m10-controls .btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  pointer-events: none;  /* ホバーをラッパー span に委譲するため */
}

/* 無効ボタンのラッパー: title ツールチップを表示するために span でくるむ */
#ublox-overlay .m10-btn-wrap {
  display: inline-block;
}
#ublox-overlay .m10-btn-wrap.is-disabled {
  cursor: not-allowed;
}

#ublox-overlay #m10-btn-read {
  color: var(--cyan);
  border-color: var(--cyan);
}
#ublox-overlay #m10-btn-read:hover { background: rgba(45,212,232,0.10); }

#ublox-overlay #m10-btn-write {
  color: var(--green);
  border-color: var(--green);
}
#ublox-overlay #m10-btn-write:hover { background: rgba(61,232,122,0.10); }

#ublox-overlay #m10-btn-save-flash,
#ublox-overlay #m10-btn-save-bbr {
  color: var(--yellow);
  border-color: var(--yellow);
}
#ublox-overlay #m10-btn-save-flash:hover,
#ublox-overlay #m10-btn-save-bbr:hover { background: rgba(240,192,64,0.10); }

#ublox-overlay #m10-btn-reset {
  color: var(--red);
  border-color: var(--red);
}
#ublox-overlay #m10-btn-reset:hover { background: rgba(240,72,64,0.10); }

#ublox-overlay #m10-btn-close {
  color: var(--dim);
  border-color: var(--border2);
}
#ublox-overlay #m10-btn-close:hover { color: var(--text); border-color: var(--dim); }

#ublox-overlay .m10-tab-btn:hover {
  color: var(--text);
  border-color: var(--dim);
}

#ublox-overlay .m10-tab-btn.active {
  background: rgba(45,212,232,0.10);
}

#ublox-overlay .m10-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

/* ─── M10 UI (scoped) ────────────────────────────────────────────────────── */
#ublox-overlay {
  --t-bg: var(--bg);
  --t-bg2: var(--bg2);
  --t-bg3: var(--bg3);
  --t-text: var(--text);
  --t-muted: var(--dim);
  --t-border: var(--border);
  --t-accent: var(--cyan);
  --t-accent2: var(--cyan);
  --t-good: var(--green);
  --t-warn: var(--yellow);
  --t-bad: var(--red);
  --t-panel: var(--bg3);
  --t-font: var(--font);
}

#ublox-overlay * { box-sizing: border-box; }

#ublox-overlay .app {
  display: grid;
  grid-template-rows: auto 44px 1fr auto;
  height: 100%;
  overflow: hidden;
  background: var(--t-bg2);
}

#ublox-overlay .statusbar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  padding: 10px 16px;
  background: var(--t-bg3);
}

#ublox-overlay .status-card {
  padding: 10px 12px;
  background: var(--t-panel);
  border: 1px solid var(--t-border);
  border-radius: 8px;
}

#ublox-overlay .status-key { color: var(--t-muted); font-size: 11px; letter-spacing: 1px; }
#ublox-overlay .status-val { font-size: 13px; font-weight: 700; }
#ublox-overlay .status-val.good { color: var(--t-good); }
#ublox-overlay .status-val.bad  { color: var(--t-bad); }
#ublox-overlay .status-val.warn { color: var(--t-warn); }

#ublox-overlay .tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 16px;
  height: 44px;
  align-items: center;
  border-bottom: 1px solid var(--t-border);
  background: var(--t-bg2);
}

#ublox-overlay .m10-tab-btn {
  border: 1px solid var(--t-border);
  background: var(--t-bg3);
  color: var(--t-muted);
  padding: 0 12px;
  height: 32px;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--t-font);
  font-size: 12px;
  letter-spacing: 1px;
  text-transform: uppercase;
}
#ublox-overlay .m10-tab-btn.active { color: var(--t-text); border-color: var(--t-accent2); }

#ublox-overlay .main {
  padding: 14px 16px 18px 16px;
  display: grid;
  gap: 16px;
  align-content: start;
  overflow: auto;
}

#ublox-overlay .panel {
  background: var(--t-panel);
  border: 1px solid var(--t-border);
  border-radius: 12px;
  padding: 14px 16px;
}

#ublox-overlay .panel.log-panel {
  display: flex;
  flex-direction: column;
  min-height: 240px;
}

#ublox-overlay .panel h2 {
  margin: 0 0 12px 0;
  font-size: 13px;
  letter-spacing: 2px;
  color: var(--t-text);
  text-transform: uppercase;
}

#ublox-overlay .grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

#ublox-overlay .item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border: 1px solid var(--t-border);
  border-radius: 8px;
  background: var(--t-bg3);
}

#ublox-overlay .item .label { font-size: 12px; }
#ublox-overlay .item small  { color: var(--t-muted); }

#ublox-overlay .label-title {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: baseline;
}
#ublox-overlay .label-title .name { font-weight: 700; }
#ublox-overlay .label-title .desc { color: var(--t-muted); }

#ublox-overlay .list { grid-template-columns: 1fr; }

#ublox-overlay .toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 8px;
  border: 1px solid var(--t-border);
  border-radius: 999px;
  background: var(--t-bg2);
  font-size: 11px;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
}

#ublox-overlay .toggle-btn input {
  width: 14px;
  height: 14px;
  margin: 0;
  accent-color: var(--t-accent);
}

#ublox-overlay .pending { box-shadow: 0 0 0 1px rgba(240, 192, 64, 0.55) inset; }

#ublox-overlay .row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

#ublox-overlay .log {
  width: 100%;
  min-height: 120px;
  flex: 1;
  overflow: auto;
  background: var(--t-bg);
  border: 1px solid var(--t-border);
  color: var(--t-muted);
  padding: 8px;
  border-radius: 8px;
  font-size: 11px;
}

#ublox-overlay .log-view {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  line-height: 1.5;
  white-space: pre;
}

#ublox-overlay .log-view:empty::before {
  content: attr(data-placeholder);
  color: var(--t-muted);
}

#ublox-overlay .log-line { white-space: pre; }
#ublox-overlay .log-line.cmd  { color: var(--t-accent2); }
#ublox-overlay .log-line.resp { color: var(--t-text); }
#ublox-overlay .log-line.warn { color: var(--t-warn); }
#ublox-overlay .log-line.err  { color: var(--t-bad); }

#ublox-overlay footer {
  padding: 10px 16px 14px 16px;
  color: var(--t-muted);
  font-size: 11px;
  border-top: 1px solid var(--t-border);
  background: var(--t-bg3);
}

#ublox-overlay .hidden { display: none; }
