:root {
  --bg: #061420;
  --surface: rgba(8, 25, 38, .91);
  --surface-strong: #0a2030;
  --line: rgba(110, 151, 171, .25);
  --line-bright: rgba(74, 224, 197, .38);
  --text: #ecf5f8;
  --muted: #95adba;
  --brand: #38d8bd;
  --brand-dark: #062821;
  --blue: #33a9f4;
  --amber: #edb54b;
  --target: #ef4050;
  --route: #46dbbe;
  --bridge: #f6b85d;
  --sun: #ffc95e;
  --moon: #a7d9ff;
}
* { box-sizing: border-box; }
html, body {
  height: 100%;
  margin: 0;
  overflow: hidden;
  color: var(--text);
  font-family: Inter, "Segoe UI", Arial, sans-serif;
  background: var(--bg);
}
#map {
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 50% 20%, #143142, #061420 48%);
}
.maplibregl-canvas { filter: saturate(.9) brightness(.86) contrast(1.06); transition: filter 1.2s ease; }
body[data-light="twilight"] .maplibregl-canvas { filter: saturate(.78) brightness(.69) contrast(1.1); }
body[data-light="night"] .maplibregl-canvas { filter: saturate(.68) brightness(.51) contrast(1.13); }
.navigation-model-overlay { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 1; pointer-events: none; }
.map-loader {
  position: fixed;
  z-index: 12;
  inset: 0;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 12px;
  background:
    radial-gradient(circle at 50% 42%, rgba(48, 121, 137, .27), transparent 26%),
    rgba(5, 15, 25, .94);
  transition: opacity .46s ease, visibility .46s ease;
}
.map-loader.ready { opacity: 0; visibility: hidden; pointer-events: none; }
.map-loader strong { font-size: 20px; letter-spacing: .11em; text-transform: uppercase; }
.map-loader span { color: var(--muted); font-size: 12px; }
.loader-world {
  position: relative;
  width: 94px;
  height: 64px;
  transform: perspective(150px) rotateX(56deg) rotateZ(-18deg);
}
.loader-world i {
  position: absolute;
  height: 2px;
  width: 100%;
  left: 0;
  background: rgba(56, 216, 189, .36);
}
.loader-world i:nth-child(1) { top: 4px; }
.loader-world i:nth-child(2) { top: 31px; }
.loader-world i:nth-child(3) { top: 58px; }
.loader-world b {
  position: absolute;
  width: 22px;
  height: 13px;
  left: 36px;
  top: 28px;
  border-radius: 5px 5px 3px 3px;
  background: var(--brand);
  box-shadow: 0 0 15px rgba(56, 216, 189, .7);
  animation: load-drive 1.25s ease-in-out infinite alternate;
}
@keyframes load-drive {
  from { transform: translateY(16px); }
  to { transform: translateY(-23px); }
}
body::before {
  content: "";
  position: fixed;
  z-index: 1;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(circle at 78% 16%, rgba(151, 201, 255, .13), transparent 18%),
    linear-gradient(180deg, rgba(3, 11, 25, .42), transparent 44%);
  transition: opacity 1.2s ease;
}
body[data-light="twilight"]::before { opacity: .4; }
body[data-light="night"]::before { opacity: 1; }
.maplibregl-ctrl-top-right { top: 80px; right: 12px; }
.maplibregl-ctrl-group {
  overflow: hidden;
  border: 1px solid var(--line) !important;
  background: var(--surface-strong) !important;
  box-shadow: 0 8px 18px rgba(0, 0, 0, .28) !important;
}
.maplibregl-ctrl-group button { background-color: var(--surface-strong); }
.maplibregl-ctrl button .maplibregl-ctrl-icon { filter: invert(1); opacity: .88; }
.maplibregl-popup-content {
  color: var(--text);
  background: var(--surface-strong);
  border: 1px solid var(--line-bright);
  border-radius: 11px;
  padding: 11px 13px;
}
.maplibregl-popup-tip { border-top-color: var(--surface-strong) !important; }
.topbar {
  position: fixed;
  z-index: 2;
  top: 16px;
  left: 18px;
  right: 18px;
  min-height: 60px;
  padding: 9px 13px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(6, 19, 30, .78);
  backdrop-filter: blur(18px);
}
.brand { display: flex; align-items: center; gap: 10px; min-width: 210px; }
.brand img { width: 43px; height: 43px; }
.brand p {
  margin: 0 0 2px;
  font-size: 10px;
  letter-spacing: .28em;
  color: var(--brand);
  font-weight: 700;
}
.brand h1 {
  margin: 0;
  font-size: 20px;
  line-height: 1;
  letter-spacing: .08em;
}
.brand h1 span {
  margin-left: 6px;
  border-left: 1px solid var(--line-bright);
  padding-left: 9px;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: .15em;
}
.status-bar {
  height: 42px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
  font-size: 13px;
}
.status-bar strong { color: var(--text); }
.sky-status {
  padding: 5px 8px;
  border: 1px solid rgba(255, 201, 94, .34);
  border-radius: 999px;
  color: var(--sun);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .11em;
}
body[data-light="night"] .sky-status {
  border-color: rgba(167, 217, 255, .34);
  color: var(--moon);
}
.pulse {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 0 0 5px rgba(56, 216, 189, .12), 0 0 15px var(--brand);
}
.top-actions { display: flex; align-items: center; gap: 9px; }
.icon-action span { margin-right: 7px; font-size: 17px; }
.icon-action em { font-style: normal; }
.guidance-banner {
  position: fixed;
  z-index: 3;
  top: 95px;
  left: 50%;
  width: 324px;
  min-height: 60px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 10px;
  border: 1px solid var(--line-bright);
  border-radius: 16px;
  background: rgba(6, 19, 30, .89);
  box-shadow: 0 13px 27px rgba(0, 0, 0, .25);
  backdrop-filter: blur(16px);
}
.guidance-banner[hidden] { display: none; }
.direction-arrow {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 12px;
  color: var(--brand-dark);
  background: var(--brand);
  font-size: 25px;
  font-weight: 800;
  transition: transform .24s ease;
}
.guidance-banner div { min-width: 0; flex: 1; }
.guidance-banner small { margin: 0 0 2px; font-size: 9px; letter-spacing: .16em; }
.guidance-banner strong { display: block; font-size: 14px; line-height: 1.15; }
.guidance-banner div span { color: var(--muted); font-size: 11px; }
.heading-chip {
  padding: 8px 7px;
  border-radius: 999px;
  color: var(--text);
  background: rgba(35, 68, 84, .68);
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
}
.camera-tools {
  position: fixed;
  z-index: 3;
  top: 96px;
  right: 352px;
  display: flex;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(6, 19, 30, .84);
  box-shadow: 0 13px 27px rgba(0, 0, 0, .2);
  backdrop-filter: blur(16px);
}
.camera-tools button {
  width: 55px;
  min-height: 49px;
  display: grid;
  place-items: center;
  gap: 2px;
  padding: 5px;
  background: transparent;
}
.camera-tools button span { font-size: 20px; line-height: 1; }
.camera-tools small { margin: 0; font-size: 9px; }
.camera-tools button.active {
  border-color: var(--line-bright);
  color: var(--brand);
  background: rgba(56, 216, 189, .1);
}
.quiet-link {
  color: var(--muted);
  text-decoration: none;
  padding: 10px 13px;
  font-size: 13px;
}
button {
  min-height: 39px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: var(--text);
  background: rgba(17, 43, 58, .88);
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
button:hover { border-color: var(--line-bright); background: rgba(23, 55, 69, .95); }
button.primary {
  color: var(--brand-dark);
  background: var(--brand);
  border-color: var(--brand);
}
button.primary:hover { background: #54e4cc; }
.overlay-grid {
  position: fixed;
  z-index: 2;
  top: 93px;
  left: 18px;
  right: 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  pointer-events: none;
}
.panel {
  pointer-events: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface);
  box-shadow: 0 22px 50px rgba(0, 0, 0, .33);
  backdrop-filter: blur(19px);
}
.navigation-panel {
  width: 335px;
  padding: 20px;
  max-height: calc(100vh - 151px);
  overflow-y: auto;
}
.eyebrow {
  margin: 0 0 7px;
  color: var(--brand);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .17em;
  text-transform: uppercase;
}
h2 { margin: 0 0 8px; font-size: 21px; letter-spacing: -.02em; }
.supporting {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
  margin: 0 0 18px;
}
label {
  display: grid;
  gap: 6px;
  margin-bottom: 11px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}
input {
  width: 100%;
  height: 41px;
  padding: 0 11px;
  border: 1px solid var(--line);
  border-radius: 9px;
  color: var(--text);
  background: #081b2a;
  font: inherit;
  font-size: 13px;
}
input:focus { outline: 2px solid rgba(56, 216, 189, .35); border-color: var(--brand); }
.map-pick {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin: -2px 0 13px;
}
.text-action {
  min-height: 29px;
  padding: 0;
  border: 0;
  color: var(--brand);
  background: transparent;
  font-size: 12px;
}
.text-action.active { color: var(--amber); }
.route-buttons { display: flex; gap: 8px; }
.route-buttons button:first-child { flex: 1; }
.message {
  min-height: 18px;
  margin: 12px 0 15px;
  color: var(--muted);
  font-size: 12px;
}
.message.error { color: #ff8e86; }
.message.success { color: var(--brand); }
.journey-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 7px;
  margin-bottom: 19px;
}
.journey-summary div, .readings div {
  padding: 9px;
  border: 1px solid rgba(110, 151, 171, .14);
  border-radius: 9px;
  background: rgba(16, 39, 53, .74);
}
small { display: block; color: var(--muted); font-size: 10px; margin-bottom: 6px; }
.journey-summary strong { display: block; font-size: 14px; white-space: nowrap; }
.mode-controls {
  border-top: 1px solid var(--line);
  padding-top: 15px;
}
.camera-controls { margin-top: 14px; }
.mode-controls h3 { margin: 0 0 12px; font-size: 13px; }
.toggle {
  display: flex;
  grid-template-columns: 16px auto;
  align-items: center;
  gap: 9px;
  margin: 9px 0;
  color: var(--text);
}
.toggle input {
  width: 15px;
  height: 15px;
  accent-color: var(--brand);
}
.tilt-row {
  display: grid;
  grid-template-columns: 34px 1fr;
  align-items: center;
  gap: 9px;
  margin-top: 15px;
}
.tilt-row label { margin: 0; }
.tilt-row input { height: auto; accent-color: var(--brand); padding: 0; }
.telemetry-panel {
  width: 316px;
  padding: 18px;
  max-height: calc(100vh - 151px);
  overflow-y: auto;
}
.telemetry-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.pill {
  padding: 5px 9px;
  border: 1px solid rgba(56, 216, 189, .4);
  border-radius: 999px;
  color: var(--brand);
  background: rgba(56, 216, 189, .09);
  font-size: 10px;
  font-weight: 750;
  letter-spacing: .1em;
}
.pill.device { color: var(--blue); border-color: rgba(51, 169, 244, .42); background: rgba(51, 169, 244, .1); }
.speed-readout {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 17px 0 13px;
}
.speed-readout strong { font-size: 62px; line-height: .9; letter-spacing: -.07em; }
.speed-readout span { color: var(--muted); font-size: 13px; }
.readings { display: grid; grid-template-columns: 1fr 1fr; gap: 7px; }
.readings strong {
  display: block;
  overflow: hidden;
  color: var(--text);
  font-size: 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sky-readings {
  margin-top: 16px;
  padding: 13px;
  border: 1px solid rgba(110, 151, 171, .14);
  border-radius: 11px;
  background: rgba(16, 39, 53, .54);
}
.sky-readings h3 { margin: 0 0 10px; color: var(--muted); font-size: 12px; }
.sky-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 9px; }
.sky-grid strong {
  display: block;
  color: var(--text);
  font-size: 11px;
  line-height: 1.35;
}
.signal { margin-top: 17px; }
.signal-copy {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 11px;
  margin-bottom: 9px;
}
.signal-copy b { color: var(--text); font-weight: 600; }
progress {
  width: 100%;
  height: 6px;
  border: 0;
  border-radius: 99px;
  overflow: hidden;
}
progress::-webkit-progress-bar { background: #112d3f; }
progress::-webkit-progress-value { background: linear-gradient(90deg, var(--blue), var(--brand)); }
.device-button { width: 100%; margin: 20px 0 11px; color: var(--brand); border-color: rgba(56, 216, 189, .31); }
.device-button:disabled { opacity: .48; cursor: not-allowed; }
.record-consent {
  display: flex;
  align-items: start;
  gap: 9px;
  margin: 18px 0 0;
  padding: 11px;
  border: 1px solid rgba(110, 151, 171, .18);
  border-radius: 10px;
  color: var(--muted);
  font-size: 11px;
  line-height: 1.45;
}
.record-consent input { width: 15px; height: 15px; flex: 0 0 auto; margin-top: 2px; accent-color: var(--brand); }
.sync-status { margin: 0 0 8px; color: var(--brand); font-size: 11px; }
.privacy { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.46; }
.scene-note {
  position: fixed;
  z-index: 2;
  left: 372px;
  bottom: 48px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: rgba(6, 19, 30, .8);
  color: var(--muted);
  font-size: 11px;
  backdrop-filter: blur(16px);
}
.scene-key { width: 10px; height: 10px; border-radius: 3px; display: inline-block; margin-right: -7px; }
.scene-key.building { background: #5a8b9a; }
.scene-key.bridge { background: var(--bridge); }
.scene-key.route { background: var(--route); }
.scene-key.tracked { background: var(--brand); box-shadow: 0 0 7px rgba(56, 216, 189, .65); }
.scene-key.ahead { background: #8eacb8; }
.scene-key.sun { background: var(--sun); box-shadow: 0 0 7px var(--sun); }
.scene-key.moon { background: var(--moon); box-shadow: 0 0 7px var(--moon); }
.scene-disclaimer { border-left: 1px solid var(--line); padding-left: 12px; }
.attribution-note {
  position: fixed;
  z-index: 2;
  left: 18px;
  right: 18px;
  bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 11px;
  color: #9fb5bf;
  font-size: 11px;
}
.attribution-note a { color: #c6d8de; text-decoration: none; }
.model-credit { color: var(--brand) !important; }
.location-board {
  position: relative;
  min-width: 130px;
  max-width: 186px;
  padding: 7px 9px 8px;
  border: 1px solid rgba(56, 216, 189, .48);
  border-radius: 8px;
  color: var(--text);
  background: rgba(5, 20, 30, .94);
  box-shadow: 0 11px 24px rgba(0, 0, 0, .34);
  text-align: left;
  pointer-events: none;
}
.location-board::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -17px;
  width: 2px;
  height: 17px;
  background: var(--brand);
}
.location-board.target { border-color: rgba(239, 64, 80, .68); }
.location-board.target::after { background: var(--target); }
.location-board small {
  margin: 0 0 3px;
  color: var(--brand);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .16em;
}
.location-board.target small { color: var(--target); }
.location-board strong {
  display: block;
  overflow: hidden;
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.location-board span {
  display: block;
  overflow: hidden;
  color: var(--muted);
  font-size: 9px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.placement-panel {
  position: fixed;
  z-index: 7;
  left: 50%;
  bottom: 66px;
  width: min(430px, calc(100vw - 20px));
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px;
  border: 1px solid var(--line-bright);
  border-radius: 14px;
  background: rgba(6, 19, 30, .94);
  box-shadow: 0 18px 37px rgba(0, 0, 0, .34);
  backdrop-filter: blur(18px);
}
.placement-panel[hidden] { display: none; }
.placement-panel div { flex: 1; min-width: 0; }
.placement-panel small { color: var(--brand); margin-bottom: 3px; letter-spacing: .14em; }
.placement-panel.target small { color: var(--target); }
.placement-panel strong, .placement-panel span {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.placement-panel strong { font-size: 12px; }
.placement-panel span { color: var(--muted); font-size: 10px; }
.placement-panel button { min-height: 37px; padding: 0 11px; }
.mobile-sheet-head, .mobile-trip-panel, .map-prompt, .panel-close { display: none; }
@media (max-width: 980px) {
  html, body { overflow: auto; }
  #map { position: fixed; }
  .topbar { left: 10px; right: 10px; top: 10px; gap: 8px; }
  .status-bar, .quiet-link { display: none; }
  .overlay-grid {
    top: auto;
    left: 10px;
    right: 10px;
    bottom: 39px;
    align-items: end;
    gap: 8px;
  }
  .navigation-panel { width: min(54vw, 330px); max-height: 57vh; overflow-y: auto; padding: 14px; }
  .telemetry-panel { width: min(45vw, 316px); max-height: 57vh; padding: 13px; }
  .speed-readout strong { font-size: 46px; }
  .readings { grid-template-columns: 1fr; }
  .scene-note { display: none; }
}
@media (max-width: 640px), (max-height: 500px) and (max-width: 980px) {
  html, body { overflow: hidden; }
  .brand h1 { font-size: 16px; }
  .brand h1 span { font-size: 10px; margin-left: 5px; padding-left: 7px; }
  .brand p { display: none; }
  .brand { min-width: auto; }
  .topbar { min-height: 57px; padding: 7px 9px; }
  .brand img { width: 36px; height: 36px; }
  .top-actions { gap: 5px; }
  .top-actions button { min-height: 34px; padding: 0 8px; font-size: 11px; }
  .top-actions #overviewButton { display: none; }
  .top-actions .icon-action em { display: none; }
  .top-actions .icon-action span { margin: 0; }
  .maplibregl-ctrl-top-right { display: none; }
  .guidance-banner {
    top: 74px;
    right: 10px;
    left: 10px;
    width: auto;
    min-height: 54px;
    transform: none;
    padding: 6px 8px;
    gap: 9px;
  }
  .direction-arrow { width: 39px; height: 39px; border-radius: 10px; font-size: 23px; }
  .guidance-banner strong { font-size: 13px; }
  .heading-chip { font-size: 9px; }
  .camera-tools {
    top: 74px;
    right: 10px;
    display: grid;
    gap: 5px;
    padding: 4px;
  }
  body[data-guidance="true"] .camera-tools { top: 136px; }
  .camera-tools button { width: 46px; min-height: 45px; padding: 4px; }
  .camera-tools button span { font-size: 18px; }
  .location-board {
    min-width: 105px;
    max-width: 148px;
    padding: 5px 7px 6px;
    transform: scale(.9);
    transform-origin: bottom center;
  }
  .location-board strong { font-size: 10px; }
  .overlay-grid {
    position: static;
    display: block;
  }
  .navigation-panel, .telemetry-panel {
    position: fixed;
    z-index: 6;
    display: none;
    top: auto;
    left: 10px;
    right: 10px;
    bottom: 219px;
    width: auto;
    max-height: calc(100svh - 293px);
    overflow-y: auto;
    padding: 14px;
  }
  .navigation-panel.mobile-open, .telemetry-panel.mobile-open { display: block; }
  .telemetry-panel {
    max-height: calc(100svh - 293px);
  }
  .mobile-sheet-head {
    position: sticky;
    z-index: 1;
    top: -14px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: -14px -14px 13px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--line);
    background: var(--surface-strong);
    color: var(--text);
    font-size: 13px;
  }
  .panel-close {
    display: inline-flex;
    align-items: center;
    min-height: 31px;
    margin-left: auto;
    padding: 0 11px;
    font-size: 11px;
  }
  .telemetry-head { align-items: center; gap: 9px; }
  .telemetry-head .panel-close { margin-left: 0; }
  .speed-readout { margin: 13px 0 11px; }
  .speed-readout strong { font-size: 52px; }
  .readings { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .readings div { padding: 8px; }
  .signal { margin-top: 13px; }
  .sky-readings { display: block; margin-top: 13px; }
  .device-button { min-height: 37px; margin: 14px 0 8px; font-size: 12px; }
  .navigation-panel .supporting { display: none; }
  .navigation-panel h2 { font-size: 18px; }
  .mobile-trip-panel {
    position: fixed;
    z-index: 5;
    right: 10px;
    bottom: 25px;
    left: 10px;
    display: block;
    padding: 9px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: rgba(6, 26, 43, .93);
    box-shadow: 0 15px 32px rgba(0, 0, 0, .34);
    backdrop-filter: blur(17px);
  }
  .mobile-trip-panel header {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-bottom: 8px;
  }
  .mobile-trip-panel header div { flex: 1; min-width: 0; }
  .mobile-trip-panel header div strong { display: block; color: var(--text); font-size: 12px; }
  .mobile-trip-panel header div span { display: block; color: var(--brand); font-size: 10px; }
  .mobile-trip-panel header button {
    width: 39px;
    min-height: 34px;
    padding: 0;
    color: var(--brand);
    font-size: 17px;
  }
  .mobile-trip-panel header button.active { background: rgba(56, 216, 189, .13); }
  .mobile-readings { display: grid; grid-template-columns: repeat(4, 1fr); gap: 5px; }
  .mobile-readings div {
    min-width: 0;
    min-height: 44px;
    padding: 6px;
    border: 1px solid rgba(56, 216, 189, .2);
    border-radius: 8px;
    background: rgba(11, 39, 60, .72);
  }
  .mobile-readings small { margin: 0 0 3px; font-size: 8px; text-transform: uppercase; }
  .mobile-readings strong {
    display: block;
    overflow: hidden;
    color: var(--text);
    font-size: 10px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .mobile-readings div:first-child strong { color: var(--brand); }
  body[data-braking="true"] .mobile-readings div:first-child { border-color: rgba(255, 45, 62, .8); box-shadow: inset 0 0 16px rgba(255, 28, 47, .2); }
  body[data-braking="true"] #mobileSpeedValue { color: #ff5160; }
  .map-prompt {
    position: fixed;
    z-index: 5;
    top: 78px;
    left: 50%;
    display: block;
    transform: translateX(-50%);
    margin: 0;
    padding: 9px 13px;
    border: 1px solid var(--line-bright);
    border-radius: 999px;
    background: rgba(6, 19, 30, .92);
    color: var(--brand);
    font-size: 12px;
    white-space: nowrap;
  }
  .map-prompt[hidden] { display: none; }
  .placement-panel { bottom: 204px; padding: 7px; }
  .attribution-note { left: 5px; right: 5px; bottom: 4px; gap: 6px; justify-content: center; font-size: 9px; }
  .attribution-note .map-issue, .attribution-note .contact-link { display: none; }
}
