.bs-faq .bs-faq-item {
  margin: 0 0 40px;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0;
  padding: 16px 32px 16px 60px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
  color: #000000;
  background-color: #f5f5f5;
  cursor: pointer;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl:before {
  content: 'Q';
  position: absolute;
  top: 16px;
  left: 20px;
  width: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl i {
  position: absolute;
  right: 8px;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 16px;
  height: 16px;
  -webkit-transition: ease 0.3s all;
  transition: ease 0.3s all;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl i:before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 16px;
  height: 2px;
  background-color: #000000;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl i:after {
  content: '';
  position: absolute;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 2px;
  height: 16px;
  background-color: #000000;
}

.bs-faq .bs-faq-item .bs-faq-q-ttl.active i {
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}

.bs-faq .bs-faq-item .bs-faq-a-txt {
  position: relative;
  display: none;
  margin: 0;
  padding: 0 32px 16px 60px;
  font-size: 16px;
  line-height: 1.5;
  background: #f5f5f5;
}

.bs-faq .bs-faq-item .bs-faq-a-txt:before {
  content: 'A';
  position: absolute;
  top: 0;
  left: 20px;
  width: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5;
}
