html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  height: 100%;
  font-size: 100%;
}
*, *:before, *:after { -webkit-box-sizing: inherit; box-sizing: inherit; }

body {
  height: 100%;
  padding: 2rem;
  font: 100%/1.375em 'Roboto', sans-serif;
  background: #199447;
}

h1 {
  color: #ffffff;
  font-weight: bold;
  font-size: 180%;
  line-height: 1em;
  text-transform: uppercase;
  text-align: center;
}
h2 {
  color: #199447;
  font-weight: bold;
  font-size: 120%;
  line-height: 1em;
}
h1,
h2,
p { margin-bottom: 1.375rem; }

.button {
  display: inline-block;
  padding: 0.5em 1em;
  color: #333333;
  text-align: center;
  text-decoration: none;
  background: #BAD620;
  border-radius: 6px;
}
.button:hover { background: #199447; color: #ffffff; }

.map-list {
  position: relative;
}
.map-list li {
  position: relative;
  padding: 1.375em;
}
.map-list li:nth-child(even) { background: #eee; }
.map-list h2,
.map-list p { margin-bottom: 0; line-height: 1.375em; }
.map-list .button {
  position: absolute;
  top: 50%;
  right: 1.375em;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

  .map-list {
    height: 0;
    padding-top: 40%;
    background-image: url(../images/inaMap.svg);
    background-repeat: no-repeat;
    background-size: 105%;
    background-position: 0% 84%;
  }
  .map-list li {
    position: absolute;
    padding: 0;
    -webkit-transform: translateZ(0);
            transform: translateZ(0);
  }
  .map-list li:nth-child(even) { background: none; }
  .map-list li:after {
    position: absolute;
    bottom: 0;
    left: -1.5em;
    content: '';
    display: block;
    width: 1em;
    height: 1em;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
    background: #fff;
    border: 0.25em solid #c20;
    border-radius: 50%;
    border-bottom-right-radius: 0;
    cursor: pointer;
  }
  .map-list li:hover { z-index: 1;  }
  .map-list li.balikpapan { bottom: 59%; left: 51.5%; }
  .map-list li.makasar { bottom: 37%; left: 56.9%; }
  .map-list li.bandung { bottom: 26%; left: 30%; }
  .map-list li.jakarta { bottom: 31%; left: 29%; }
  .map-list li.jogja { bottom: 22.5%; left: 37%; }
  .map-list li.bali { bottom: 19.5%; left: 47.5%; }
  .map-list li.surabaya { bottom: 24.5%; left: 41%; }
  .map-list .details {
    text-align: center;
    padding: 1rem;
    margin-bottom: 1rem;
    -webkit-transform: scale(0);
            transform: scale(0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
    font-size: 75%;
    background: #eee;
    border-radius: 0.5em;
    -webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.15);
            box-shadow: 0 1px 3px rgba(0,0,0,0.15);
    opacity: 0;
    -webkit-transition: opacity 500ms, -webkit-transform 400ms cubic-bezier(0.6,-0.3,0.3,1.3);
    transition: opacity 500ms, -webkit-transform 400ms cubic-bezier(0.6,-0.3,0.3,1.3);
    transition: opacity 500ms, transform 400ms cubic-bezier(0.6,-0.3,0.3,1.3);
    transition: opacity 500ms, transform 400ms cubic-bezier(0.6,-0.3,0.3,1.3), -webkit-transform 400ms cubic-bezier(0.6,-0.3,0.3,1.3);
  }
  .map-list li:hover .details {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
  .map-list li.jogja .details,
  .map-list li.jakarta .details {
    position: absolute;
    bottom: 20px;
    right: 100%;
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
    white-space: nowrap;
  }
  .map-list li.bandung .details {
    position: absolute;
    bottom: 20px;
    -webkit-transform-origin: 100% 100%;
            transform-origin: 100% 100%;
    white-space: nowrap;
  }
  .map-list p { margin-bottom: 0.25rem; }
  .map-list .button {
    position: static;
    -webkit-transform: none;
            transform: none;
    width: 100%;
  }
}

@media only screen and (max-width:480px) {

.map-list li:nth-child(even) { background: none; }
.map-list li:after {
    position: absolute;
    bottom: 0;
    left: -1.5em;
    content: '';
    display: block;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    background: #fff;
    border: 0.5em solid #199447;
    border-radius: 50%;
    border-bottom-right-radius: 0;
    cursor: pointer;
  }
}