body {
  font-family: sans-serif;
}

h2 {
  text-align: center;
}

.color-legend {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 1em;
}

.table-wrap {
  overflow-x: auto;
  margin-left: auto;
  margin-right: auto;
}

.table-dostavka {
  border-collapse: collapse;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
}

.td-dostavka {
  border: 1px solid grey;
  padding: 3px 3px;
  min-width: 80px;
  text-align: center;
  vertical-align: top;
  transition: box-shadow 0.2s;
}

.route-btn {
  font-size: 12px;
  border: none;
  border-radius: 5px;
  padding: 3px 8px;
  margin: 0 4px 8px 0;
  font-weight: bold;
  cursor: pointer;
  transition: box-shadow 0.2s;
}

.route-btn.active,
.route-btn:hover {
  box-shadow: 0 0 0 2px #333;
}

.highlight {
  outline: 2.5px solid #000 !important;
  box-shadow: 0 0 10px #777;
  z-index: 2;
  position: relative;
}

.cell-top {
  font-size: 12px;
  color: #333;
  font-weight: 600;
  padding-bottom: 6px;
  margin-bottom: 5px;
}

.cell-bottom {
  font-size: 12px;
  padding-top: 0;
  font-weight: bold;
}

.gray {
  color: #bbb;
}
