@font-face {
  font-family: "GrotesqueMT";
  src: url("../font/grotesquemt-bold.eot");
  src: url("../font/grotesquemt-bold.eot?#iefix") format("embedded-opentype"),
    url("../font/grotesquemt-bold.woff2") format("woff2"),
    url("../font/grotesquemt-bold.woff") format("woff"),
    url("../font/grotesquemt-bold.ttf") format("truetype");
  font-weight: bold;
  font-style: normal;
}

@font-face {
  font-family: "GrotesqueMT";
  src: url("../font/grotesquemt-italic.eot");
  src: url("../font/grotesquemt-italic.eot?#iefix") format("embedded-opentype"),
    url("../font/grotesquemt-italic.woff2") format("woff2"),
    url("../font/grotesquemt-italic.woff") format("woff"),
    url("../font/grotesquemt-italic.ttf") format("truetype");
  font-weight: normal;
  font-style: italic;
}

@font-face {
  font-family: "GrotesqueMT";
  src: url("../font/grotesquemt.eot");
  src: url("../font/grotesquemt.eot?#iefix") format("embedded-opentype"),
    url("../font/grotesquemt.woff2") format("woff2"), url("../font/grotesquemt.woff") format("woff"),
    url("../font/grotesquemt.ttf") format("truetype");
  font-weight: normal;
  font-style: normal;
}

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

  font-size: 16px;
  font-family: "GrotesqueMT", sans-serif;
  letter-spacing: 0.01em;
  line-height: 1.3em;
  min-height: 100vh;
}

a {
  color: black;
  text-decoration: none;
  border-bottom: 2px dotted black;
  padding-bottom: -1px;
}

a:hover {
  text-decoration: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;

  margin: 1em 1.5em;

  display: flex;
  flex-direction: column;

  align-items: start;
}

header > * {
  line-height: 0.9;

  font-size: 1.2em;
  font-weight: normal;
  margin: 0.2em 0.5em;
  padding: 0;
}

header h1 {
  letter-spacing: 0.04em;
}

.map {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.leaflet-container {
  background: #fff;
  outline: 0;
}

.marker-text {
  width: 300px;
  overflow-y: auto;
  word-wrap: break;
}

.leaflet-marker-icon img {
  transition: transform 0.2s linear;
}
.leaflet-marker-icon:hover img,
.leaflet-marker-icon.marker-active img {
  transform: scale(1.1);
}

@media only screen and (min-width: 768px) {
  header {
    flex-direction: row;
  }
}
