* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

#map {
  width: 100%;
  height: 100%;
  background-color: var(--map-background);
}

.track.occupied {
  stroke: var(--track-occupied);
}
.track.reserved {
  stroke: var(--track-reserved);
}
.track {
  stroke: var(--track-free);
}

.train-name,
.station-name {
  font-family: var(--ui-font);
  font-weight: bold;
  font-size: 15px;
}
.station-name .track-number,
.train-name .car-number {
  display: inline-block;
  width: 1.4em;
  text-align: center;
  border-radius: 0.7em;
  background-color: #444;
  color: white;
}

.station-icon .fill {
  fill: var(--station-color);
}
.station-icon .outline {
  fill: var(--station-outline);
}

.portal-icon .fill {
  fill: var(--portal-color);
}
.portal-icon .outline {
  fill: var(--portal-outline);
}

.signal-icon.green .light {
  fill: var(--signal-green);
}
.signal-icon.yellow .light {
  fill: var(--signal-yellow);
}
.signal-icon.red .light {
  fill: var(--signal-red);
}
.signal-icon .frame {
  fill: var(--signal-outline);
}

.train {
  stroke: var(--train-color);
}
.train.lead-car {
  stroke: var(--lead-car-color);
}
.head-icon path {
  fill: var(--lead-car-color);
}

.coords-control {
  font-family: var(--ui-font);
  font-size: 16px;
  font-weight: 500;

  background-color: white;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.65);
  border-radius: 4px;
  padding: 2px 4px;
}

.coords-control .icon {
  display: inline-block;
  width: 16px;
  height: 16px;
  line-height: 24px;
  margin-right: 4px;
  transform: translate(2px, 2px);
}

.coords-control .center-x,
.coords-control .center-z,
.coords-control .cursor-x,
.coords-control .cursor-z {
  display: inline-block;
  padding: 0 5px;
}

.leaflet-control-ctm:not(.leaflet-control-expanded) .leaflet-control-body,
.leaflet-control-layers:not(.leaflet-control-layers-expanded) .leaflet-control-layers-list {
  display: none;
}
.leaflet-control-toggle,
.leaflet-control-layers-toggle {
  display: block;
  width: 36px;
  height: 36px;
  background-position: 50% 50%;
  background-size: 32px 32px;
}
.leaflet-control-ctm {
  margin-top: 8px;
  box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4);
  background: #fff;
  border-radius: 5px;
}
.leaflet-control-expanded,
.leaflet-control-layers-expanded {
  padding: 6px;
}

.leaflet-control-layers-separator {
  margin-top: 5px;
  margin-bottom: 5px;
}
.leaflet-control-layers-toggle {
  background-image: url(../icons/layers.svg);
}
.leaflet-control-ctm label,
.leaflet-control-layers label {
  font-family: var(--ui-font);
  font-size: 14px;
}
.leaflet-control-layers input[type="radio"],
.leaflet-control-layers input[type="checkbox"] {
  display: none;
}
.leaflet-control-layers input[type="radio"] + span,
.leaflet-control-layers input[type="checkbox"] + span {
  display: inline-block;
  width: 100%;
  border-radius: 2px;
  padding: 0 5px;
  margin-top: 2px;
}
.leaflet-control-layers-overlays label input + span {
  border-radius: 0;
}
.leaflet-control-layers-overlays label:first-child input + span {
  border-top-left-radius: 2px;
  border-top-right-radius: 2px;
}
.leaflet-control-layers-overlays label:last-child input + span {
  border-bottom-left-radius: 2px;
  border-bottom-right-radius: 2px;
}
.leaflet-control-layers input[type="radio"] + span:hover,
.leaflet-control-layers input[type="checkbox"] + span:hover {
  cursor: pointer;
  background-color: #ccc;
}
.leaflet-control-layers input[type="radio"]:checked + span,
.leaflet-control-layers input[type="checkbox"]:checked + span {
  background-color: #888;
  color: white;
  font-weight: bold;
}

.leaflet-control-train-list-toggle {
  background-image: url(../icons/trains.svg);
}
.leaflet-control-station-list-toggle {
  background-image: url(../icons/stations.svg);
}

.leaflet-control-scrollbar {
  overflow-y: scroll;
  overflow-x: hidden;
  padding-right: 5px;
}

.leaflet-right .leaflet-control {
  float: right;
}
.ctm-station-list .station,
.ctm-train-list .train {
  font-family: var(--ui-font);
  font-size: 14px;
  display: block;
  border-radius: 2px;
  padding: 0 5px;
  margin-top: 2px;
}
.ctm-station-list .station:hover,
.ctm-train-list .train:hover {
  cursor: pointer;
  background-color: #ccc;
}

.leaflet-top {
  top: 12px;
}
.leaflet-bottom {
  bottom: 12px;
}
.leaflet-left {
  left: 12px;
}
.leaflet-right {
  right: 12px;
}
