svg`<svg viewBox="-100 -100 200 200" style="max-width: 20em">
${repeat(tick(70, 5, "hsl(30, 20%, 70%)"), numMinorTicks * 4 * numMajorTicks)}
${repeat(tick(70, 8, "hsl(30, 20%, 50%)"), numMajorTicks * 4)}
${repeat(`<path d="M 0,-79 l 3,10 l -6,0 z" fill="white" stroke="hsl(30, 20%, 50%)" stroke-width="1"/>`, 4, 45)}
<circle r="70" fill="none" stroke="hsl(30, 20%, 30%)" stroke-width="3" />
<circle r="60" fill="none" stroke="hsl(30, 20%, 60%)" stroke-width="1" />
<circle r="50" fill="none" stroke="hsl(30, 20%, 30%)" stroke-width="2" />
${repeat(`<circle cy="-40" r="1.5" fill="hsl(30, 20%, 50%)"/>`, numDots)}
${repeat(directionMarker(88, 15), 4)}
${repeat(directionMarker(65, 8), 4, 45)}
${repeat(angleMarker(84, 7), 24)}
${repeat(wedge(cardinalLength, cardinalLength * cardinalWedge), 4)}
${repeat(wedge(cardinalLength*0.75, cardinalLength * cardinalWedge * 1.7, 0.3), 4, 45)}
${patternDefs}
</svg>
`