.cat{
  margin: 4px;
  background-color: #104068;
  border-radius: 4px;
  border: 1px solid #fff;
  overflow: hidden;
  float: left;
  padding: 0px 20px;
}

.cat label {
  float: left; line-height: 3.0em;
  width: 8.0em; height: 3.0em;
  cursor:pointer;
}

.cat label span {
  text-align: center;
  padding: 3px 0;
  display: block;
}

.cat label input {
  position: absolute;
  display: none;
  color: #fff !important;
}

.cat label input + span{color: #fff;}
.cat input:checked + span {
    color: #ffffff;
    text-shadow: 0 0  6px rgba(0, 0, 0, 0.8);
}

.pay{
  margin: 4px;
  border-radius: 4px;
  border: 1px solid #fff;
  overflow: hidden;
  float: left;
}

.pay label {
  float: left; line-height: 4.0em;
  width: 15.0em; height: 4.0em;
  cursor:pointer;
}

.pay label span {
  text-align: center;
  padding: 4px 0;
  display: block;
}

.pay label input {
  position: absolute;
  display: none;
  color: #fff !important;
}

.pay label input + span{color: #fff;}
.pay input:checked + span {
    color: #ffffff;
    text-shadow: 0 0  6px rgba(0, 0, 0, 0.8);
}
.pay-active input:checked +span{border: 2px solid #004767;}