*::before,
*::after {
  box-sizing: border-box;
}

:root {
  --color-ccc: #ccc;
  --color-fff: #fff;
  --color-222: #222;
  --color-rbg0-0-0-02: rgba(0, 0, 0, 0.2);
  --color-506EEC: #506EEC;
}

html,
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
  -webkit-font-smoothing: antialiased;
}

.map-svg-segment path:hover {
  cursor: pointer;
  opacity: 0.5;
  /* transition: fill 0.6s, stroke 0.6s; */
}

.map-svg-segment .path-disable {
  fill: var(--color-ccc);
}

.map-svg-segment .path-disable:hover {
  cursor: not-allowed;
  opacity: 1;
}

.hover-badge {
  background-color: var(--color-222);
  color: var(--color-fff);
  padding: 6px 10px;
  border-radius: 4px;
  font-size: 12px;
  position: absolute;
  pointer-events: none;
  z-index: 1000;
  max-width: 100px;
  word-break: break-all;
  box-shadow: 0 2px 6px var(--color-rbg0-0-0-02);
  white-space: normal;
  word-break: break-all;
  text-align: center;
  opacity: 0;
  animation: badge 600ms forwards;
}

@keyframes badge {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}