div:before, div:after {
  content: "";
  display: table;
}

#shop-card {
  max-width: 480px;
  margin: 0 auto;
}

.card__header-title {
  margin: 0.75em;
  font-size: 1.25em;
  text-align: center;
}

.card__header-shop-name {
  margin: 0.75em;
  font-size: 1em;
  text-align: center;
}

.card__info {
  padding: 1em;
}
.card__info .card-text span {
  display: inline-block;
  font-size: 0.8em;
  line-height: 1.1em;
  color: rgb(43, 42, 42);
}

.card__ranks .card {
  width: 100vw;
  max-width: 100%;
  margin: 0;
  border: none;
  border-radius: 0;
}
.card__ranks .card img {
  border-radius: 0;
}
.card__ranks .card .stamps {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.card__ranks .card .stamps .stamp {
  width: calc(20% - 3px);
}
.card__ranks .card .stamps .stamp img {
  width: 100%;
  margin-bottom: 3px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 50%;
}
.card__ranks .card .stamps .stamp p {
  text-align: center;
  font-size: 0.7em;
}
.card__ranks .card .stamps .stamp p.shop-name {
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.card__ranks .card i {
  color: gray;
}
.card__ranks .card i.color-gold {
  color: gold;
}
.card__ranks .card i + i {
  margin-left: 0.25em;
}

#qr-scan {
  width: 3em;
  height: 3em;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: white !important;
  background-color: #d14a34;
  border-radius: 1.5em;
  text-decoration: none;
  position: relative;
  top: -1.25em;
  margin-top: -3em;
  float: right;
  z-index: 99;
}
#qr-scan svg {
  margin-top: 0.3em;
}
#qr-scan span {
  font-size: 0.6em;
  line-height: 1.5em;
}