* {
  box-sizing: border-box;
}

@font-face {
  font-family: "mintsodalime";
  src: url("/_public/fonts/mintsodalime.ttf") format("truetype");
  font-display: swap;
}

:root {
  --background: none;
  --map-bg: dodgerblue;
  --legend-bg: white;
  --state-default: url(#concrete);
  --state-ordered: url(#grass);
  --newjersey: url(#newjersey);
  --separator: rgb(120, 195, 198);
  --borders: green;
  --font-header: mintsodalime, monospace;
  --font-body: sans-serif;
  --link: blue;
  --bg-water: url(/glitch/bugs-map/water.gif);
  --bg-grass: url(/glitch/bugs-map/grass.jpg);
  --bg-concrete: url(/glitch/bugs-map/concrete.jpg);
}

body {
  background-color: var(--background);
  font-family: var(--font-body);
  padding: 1em;
  font-size: 18px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-header);
}

a {
  color: var(--link);
  text-decoration: none;
}

footer {
  padding: 0.5em 0;
  font-size: 0.8em;
  font-style: italic;
}

/** map **/
#map {
  background-color: var(--map-bg);
  background-image: var(--bg-water);
  background-size: cover;
  position: relative;
  max-width: 800px;
}

.state {
  fill: var(--state-default);
}
.borders {
  stroke: var(--borders);
  stroke-width: 2;
}
.separator {
  stroke: var(--separator);
  stroke-width: 2;
}

/** color states with orders **/
.ny,
.ga,
.ca,
.or,
.ma,
.va,
.tx,
.pa,
.mo {
  fill: var(--state-ordered);
}

.nj {
  fill: var(--newjersey);
}

/** legend **/
#legend {
  border: 1px solid var(--borders);
  font-size: 0.8em;
  display: inline-block;
  padding: 0.5em;
  line-height: 1.6em;
  position: absolute;
  right: 10px;
  bottom: 10px;
  background-color: var(--legend-bg);
}

#legend ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

#legend .color {
  width: 16px;
  height: 16px;
  display: inline-block;
  vertical-align: middle;
  border: 1px solid var(--borders);
}

.color.default {
  background: var(--bg-concrete);
}
.color.ordered {
  background: var(--bg-grass);
}
