.svg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: move;
}
  
.proxy {
  fill: none;
  stroke: none;
}

svg #areas > g {
  pointer-events: fill;
}

svg #areas g path, svg #areas g polygon, svg #areas g polyline, svg #areas g rect {
  fill: transparent;
  transition: fill 0.2s ease-in;
  position: relative;
}
svg #areas g:hover path, svg #areas .area-selected, svg #areas g.area-highlight path,
svg #areas g:hover polygon, svg #areas g.area-highlight polygon,
svg #areas g:hover polyline, svg #areas g.area-highlight polyline,
svg #areas g:hover rect, svg #areas g.area-highlight rect {
  cursor: pointer;
  fill: rgba(17, 0, 255, 0.158);
  transition: fill 0.15s ease-in;
}

svg #areas g .number {
  opacity: 0;
  /* transform: translateY(5px);
  transform-origin: center; */
  transition: opacity 0.2s ease-in, transform 0.2s ease-in;
}

svg #areas g:hover .number, svg #areas g.area-highlight .number {
  cursor: pointer;
  opacity: 1;
  /* transform: translateY(0); */
  transition: opacity 0.15s ease-out, transform 0.15s ease-out;
}

svg #areas g text {
  font-family: Arial, sans-serif;
  font-style: normal;
  font-weight: bold;
}

svg #areas.area-disabled g, svg #areas g.area-highlight {
  pointer-events: none;
}