#map-wrap {
  position: fixed;
  inset: 0;
  overflow: hidden;
  z-index: 1;
  cursor: grab;
}

#map-wrap.is-panning {
  cursor: grabbing;
}

#map-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(800px 600px at 70% 80%, var(--ink-alpha-15), transparent 70%);
  pointer-events: none;
}

#map-pan {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(0px, 0px);
  transform-origin: 0 0;
  will-change: transform;
}

#map-layer {
  position: relative;
  display: inline-block;
  width: auto;
  height: auto;
  max-width: none;
  max-height: none;
  line-height: 0;
  user-select: none;
  pointer-events: auto;
}

#map-layer svg,
#map-layer img,
#map-layer canvas {
  display: block;
  max-width: none;
  max-height: none;
}

#map-layer .map-raster,
#map-layer .map-hit-layer {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

#map-layer .map-raster {
  z-index: 0;
  pointer-events: none;
}

#map-layer .map-hit-layer {
  z-index: 1;
}

#map-layer .map-hit-layer * {
  fill: transparent !important;
  stroke: transparent !important;
}

#map-layer .map-hit-layer [provinceid],
#map-layer .map-hit-layer [name] {
  pointer-events: all;
}

#map-layer .province-selected {
  stroke: var(--accent-left) !important;
  stroke-width: calc(var(--province-stroke-base, 2px) * 6 * var(--province-stroke-scale, 1)) !important;
  vector-effect: non-scaling-stroke;
  animation: province-pulse 1.6s ease-in-out infinite;
}

@keyframes province-pulse {
  0%,
  100% {
    stroke-width: calc(var(--province-stroke-base, 2px) * 6 * var(--province-stroke-scale, 1));
  }
  50% {
    stroke-width: calc(var(--province-stroke-base, 2px) * 7 * var(--province-stroke-scale, 1));
  }
}

