.page-recruit .frame-gray {
  background-color: #f2f3f6;
}
.page-recruit .frame-gray .row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.page-recruit .frame-gray .row:not(:last-child) {
  padding-bottom: 45px;
  margin-bottom: 45px;
  border-bottom: 1px solid #bfc1c2;
}
@media screen and (max-width: 750px) {
  .page-recruit .frame-gray .row:not(:last-child) {
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
}
.page-recruit .frame-gray .row .info {
  width: calc(100% - 240px);
}
@media screen and (max-width: 750px) {
  .page-recruit .frame-gray .row .info {
    width: 100%;
  }
}
@media screen and (max-width: 750px) {
  .page-recruit .frame-gray .row .info .titleWrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .page-recruit .frame-gray .row .info .titleWrapper .ttl {
    width: 50%;
    padding-right: 15px;
  }
  .page-recruit .frame-gray .row .info .titleWrapper .ttl span {
    padding-bottom: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-bottom: 5px;
    height: 92px;
  }
  .page-recruit .frame-gray .row .info .titleWrapper .ttl .name {
    padding: 10px;
    width: calc(100% + 15px);
    background-color: #fff;
    font-size: 1.5rem;
    margin-left: -15px;
  }
  .page-recruit .frame-gray .row .info .titleWrapper img {
    width: 50%;
  }
}
.page-recruit .frame-gray .row .info .ttl {
  font-size: 2.2rem;
  padding-left: 20px;
  position: relative;
  margin-bottom: 35px;
}
@media screen and (max-width: 750px) {
  .page-recruit .frame-gray .row .info .ttl {
    font-size: 1.7rem;
    padding-left: 15px;
    margin-bottom: 20px;
  }
}
.page-recruit .frame-gray .row .info .ttl:before {
  content: "";
  position: absolute;
  width: 2px;
  height: 28px;
  background-color: #c4003a;
  left: 0;
  top: calc(50% - 14px);
}
@media screen and (max-width: 750px) {
  .page-recruit .frame-gray .row .info .ttl:before {
    width: 3px;
    height: auto;
    top: 3px;
    bottom: 84px;
  }
}
.page-recruit .frame-gray .row .info .ttl span {
  font-weight: bold;
}
.page-recruit .frame-gray .row .info p {
  line-height: 1.8;
}
.page-recruit .frame-gray .row .img {
  width: 180px;
  margin-left: 60px;
}
.page-recruit .frame-gray .row .img .name {
  text-align: center;
  padding: 10px 0;
  background-color: #fff;
}