#map {
    height: 80vh;
}
#key {
    position: absolute;
    bottom: 0;
    left: 0;
    background: #FFF;
    padding: 0 20px 10px 20px;
    box-sizing: border-box
}
#key h1 {
    margin: 0;
    font-family: 'Open Sans', sans-serif;
    font-weight: 800;
    color: #d93852;
    font-size: 54px;
}
#key p {
    font-size: 20px
}
#key p:first-of-type {
    margin-top: 0
}
.keydot {
    display: inline-block;
    background: #555;
    height: 18px;
    width: 18px;
    border-radius: 50%;
    margin-right: 5px;
    color: #FFF;
    line-height: 18px;
    font-size: 12px;
    text-align: center;
}
.yellow {
    background: #fff102
}
.purple {
    background: #a589b8
}
.blue {
    background: #2c3992
}
.darkpurple {
    background: #583b86
}
.green {
    background: #5fb750
}
.aqua {
    background: #57b7dc
}
.pink {
    background: #d93953
}
.catpurple {
    background: #9e1f62
}
.turqouise {
    background: #3d95a1
}
.infobox {
    max-width: 300px
}
.infobox h1, .infobox p {
    margin: 0
}
.infobox h1 {
    font-size: 20px
}
.infobox  a {
    color: #000;
}