:root {
  --track-navy: #1c3466;
  --track-cyan: #1d95c9;
  --track-orange: #f08416;
  --track-bg: #f4f6f8;
  --track-text: #0f172a;
}
body { font-family: "Inter", "Segoe UI", system-ui, sans-serif; color: var(--track-text); background: var(--track-bg); }
.track-navbar { background: var(--track-navy) !important; }
.hero-track { background: linear-gradient(135deg, var(--track-navy), var(--track-cyan)); }
.btn-success { background: var(--track-navy); border-color: var(--track-navy); }
.btn-success:hover, .btn-success:focus { background: #162c57; border-color: #162c57; }
.btn-outline-success { color: var(--track-orange); border-color: var(--track-orange); }
.btn-outline-success:hover { background: var(--track-orange); border-color: var(--track-orange); color: #fff; }
.nav-tabs .nav-link.active { color: var(--track-navy); border-bottom-color: var(--track-orange); font-weight: 600; }
.text-success { color: var(--track-navy) !important; }
.track-map { height: 520px; border-radius: .75rem; }
.card { border-radius: 1rem; }
.leaflet-control-attribution { display: none !important; }
.table-sm td, .table-sm th { vertical-align: middle; }
.card-body.p-0 { position: relative; }
.map-toolbar-toggle-btn {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 920;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: .5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.map-info-toggle-btn {
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 921;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: .5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.map-sim-toggle-btn {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 921;
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: .5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.map-editor-toolbar {
  position: absolute;
  top: 54px;
  left: 12px;
  z-index: 900;
  display: flex;
  gap: .35rem;
  align-items: center;
  flex-wrap: wrap;
  padding: .35rem;
  border-radius: .5rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid #dbe2ea;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
}
.map-editor-toolbar.is-collapsed {
  display: none;
}
.map-editor-toolbar .btn i { pointer-events: none; }
.map-toolbar-divider {
  width: 1px;
  height: 24px;
  background: #dbe2ea;
  margin: 0 .1rem;
}
.map-editor-toggle {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: 0 .2rem 0 .35rem;
  margin-bottom: 0;
  margin-right: .1rem;
  border-right: 1px solid #e2e8f0;
}
.map-editor-edit-tools {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
.map-editor-toggle .form-check-input {
  margin: 0;
  cursor: pointer;
}
.map-editor-toggle .form-check-label {
  font-size: .78rem;
  color: #475569;
  user-select: none;
  cursor: pointer;
}
.map-road-toggle {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: 0 .25rem;
  border-right: 1px solid #e2e8f0;
  margin-right: .1rem;
}
.map-road-toggle .form-check-input {
  margin: 0;
  cursor: pointer;
}
.map-road-toggle .form-check-label {
  font-size: .78rem;
  color: #334155;
  user-select: none;
  cursor: pointer;
}
.map-editor-toolbar .form-select {
  width: 78px;
  min-height: calc(1.5em + .5rem + 2px);
  padding-top: .15rem;
  padding-bottom: .15rem;
}
.map-info-panel {
  position: absolute;
  left: 12px;
  right: auto;
  bottom: 54px;
  z-index: 890;
  width: fit-content;
  max-width: min(860px, calc(100% - 24px));
  max-height: calc(100% - 24px);
  display: flex;
  flex-direction: column;
  gap: .22rem;
  padding: .45rem .6rem;
  border-radius: .6rem;
  background: rgba(15, 23, 42, 0.52);
  border: 1px solid rgba(148, 163, 184, 0.4);
  color: #e2e8f0;
  backdrop-filter: blur(4px);
  overflow: auto;
}
.map-info-panel.is-collapsed {
  display: none;
}
.map-sim-panel {
  position: absolute;
  right: 12px;
  bottom: 54px;
  z-index: 890;
  width: min(420px, calc(100% - 24px));
  display: flex;
  flex-direction: column;
  gap: .45rem;
  padding: .55rem .65rem;
  border-radius: .6rem;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(148, 163, 184, 0.4);
  color: #e2e8f0;
  backdrop-filter: blur(4px);
}
.map-sim-panel.is-collapsed {
  display: none;
}
.map-sim-row {
  display: flex;
  gap: .45rem;
}
.map-sim-item {
  min-width: 0;
  flex: 1 1 0;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .76rem;
  line-height: 1.25;
  color: #e2e8f0;
}
.map-sim-item i {
  color: #7dd3fc;
}
.map-sim-item strong {
  color: #f8fafc;
  font-weight: 700;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.map-sim-item span {
  min-width: 0;
}
.map-sim-item-grow {
  flex: 1 1 100%;
}
.map-sim-row-share {
  justify-content: flex-end;
}
.map-sim-row-share .form-check-label {
  color: #e2e8f0;
  font-size: .76rem;
}
.map-info-row {
  display: flex;
  align-items: center;
  gap: .38rem;
  font-size: .77rem;
  line-height: 1.2;
  flex-wrap: wrap;
}
.map-info-row i {
  color: #7dd3fc;
}
.map-info-row strong {
  color: #f8fafc;
  font-weight: 700;
}
.map-info-editor-text {
  color: #e2e8f0;
}
.map-info-editor-text.is-error {
  color: #fecaca;
}
.map-info-sep {
  opacity: .55;
}
@media (max-width: 767.98px) {
  .map-info-panel {
    width: calc(100% - 24px);
    max-width: calc(100% - 24px);
  }
  .map-sim-panel {
    width: calc(100% - 24px);
  }
  .map-info-row {
    font-size: .73rem;
  }
  .map-sim-row {
    flex-direction: column;
    gap: .35rem;
  }
  .map-sim-item {
    font-size: .73rem;
  }
  .map-sim-row-share {
    justify-content: flex-start;
  }
}
.toolbar-section + .toolbar-section { margin-top: 1rem; padding-top: 1rem; border-top: 1px solid #e9ecef; }
.toolbar-title { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: #6c757d; margin-bottom: .5rem; font-weight: 700; }
.manual-tool-btn.active { color: #fff; background: var(--track-navy); border-color: var(--track-navy); }
.manual-point-pin { background: transparent; border: 0; }
.manual-point-pin span {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: #0d6efd;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 1px 4px rgba(13, 110, 253, 0.45);
}
.manual-point-pin.is-selected span {
  background: #198754;
  box-shadow: 0 0 0 3px rgba(25, 135, 84, 0.25);
}
