.wrap {
  padding: 0 3%;
}
#sec2 {
  background: url(../img/recruit/bg1.jpg);
  padding: 12vw 0 22vw;
  font-family: "Noto Serif JP";
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 30px;
  color: #000;
}
#sec2 * {
  box-sizing: border-box;
}
#sec2 img {
  width: 100%;
  height: auto;
}
#sec2 .set1 h2 {
  text-align: center;
  margin-bottom: 17vw;
}
#sec2 .set1 .content .item:not(:last-child) {
  margin-bottom: 9vw;
}
#sec2 .set1 .content .item .tit {
  text-align: center;
  margin-bottom: 8vw;
}
#sec2 .set1 .content .item .tit dt {
  margin-bottom: 6vw;
}
#sec2 .set1 .content .item .tit dt span {
  display: inline-block;
  padding: 0 12px 2px;
  font-size: 5vw;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #6c3821;
  border-bottom: 1px solid #6c3821;
}
#sec2 .set1 .content .item .tit dd {
  font-size: 6.4vw;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
#sec2 .set1 .content .item .photo {
  margin: 0 14%;
}
#sec2 .set2 {
  padding: 15vw 0 0;
}
#sec2 .set2 h2 {
  margin-bottom: 13vw;
  text-align: center;
}
#sec2 .set2 .content .item:not(:last-child) {
  margin-bottom: 12vw;
}
#sec2 .set2 .content .item .tit {
  display: flex;
  padding: 4vw 2% 4vw 5.5%;
  background: #f2ece6;
  border-radius: 17px;
  margin-bottom: 5vw;
}
#sec2 .set2 .content .item .tit dt {
  font-size: 5vw;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #471506;
  position: relative;
  padding-right: 13px;
  margin-right: 9vw;
}
#sec2 .set2 .content .item .tit dt::after {
  content: "";
  border-left: 1px solid #6c3821;
  position: absolute;
  top: 8px;
  right: 0;
  bottom: 7px;
}
#sec2 .set2 .content .item .tit dd {
  font-size: 6.2vw;
  letter-spacing: 0.1em;
}
#sec2 .set2 .content .item .txt {
  text-align: justify;
  font-size: 15px;
  padding: 0 2%;
}
#sec2 .set2 .content .item4 .tit dt {
  margin-right: 4vw;
}
#sec2 .set2 .content .item4 .tit dd {
  font-size: 5.5vw;
}
#sec8 {
  background: url(../img/recruit/bg2.jpg);
  padding: 18vw 0 22vw;
  font-weight: 500;
  line-height: 27px;
  font-family: "Noto Serif JP";
  letter-spacing: 0.05em;
}
#sec8 * {
  box-sizing: border-box;
}
#sec8 a {
  color: #000;
}
#sec8 p {
  line-height: 27px;
}
#sec8 img {
  width: 100%;
  height: auto;
}
#sec8 .content .item:not(:last-child) {
  padding-bottom: 13vw;
  margin-bottom: 16vw;
  position: relative;
}
#sec8 .content .item:not(:last-child)::before {
  content: "";
  border-top: 1px solid #6c6157;
  position: absolute;
  right: -3vw;
  bottom: 0;
  left: -3vw;
}
#sec8 .content .item .photo {
  margin: 0 2%;
}
#sec8 .content .item .gr-txt {
  text-align: center;
  margin: 10vw 0 0;
}
#sec8 .content .item .gr-txt h3 {
  font-size: 7.1vw;
  font-weight: 500;
  letter-spacing: 0.05em;
}
#sec8 .content .item .gr-txt .info {
  margin: 7vw 0 5vw;
}
#sec8 .content .item .gr-txt .info .tel dt {
  font-size: 15px;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}
#sec8 .content .item .gr-txt .info .tel dd img {
  width: 18px;
  height: auto;
  position: relative;
  margin-right: 8px;
  top: -6px;
  left: 4px;
}
#sec8 .content .item .gr-txt .info .tel dd span {
  font-size: 33px;
  letter-spacing: 0.05em;
  font-weight: 500;
}
#sec8 .content .item .gr-txt .info .btn-reserve {
  margin: 5vw 8% 0;
}
#sec8 .content .item .gr-txt .info .btn-reserve a {
  display: block;
  font-size: 4vw;
  letter-spacing: 0.2em;
  text-align: center;
  padding: 2.5vw 4%;
  color: #fff;
  background: #292626;
  border: 1px solid #292626;
}
#sec8 .content .item .gr-txt .info .btn-reserve a span {
  letter-spacing: 0.2em;
  margin-left: 4px;
}
#sec8 .content .item .gr-txt .txt .map-link {
  display: inline-block;
  margin-left: 19px;
  padding-left: 15px;
  position: relative;
}
#sec8 .content .item .gr-txt .txt .map-link::before {
  content: "";
  border-left: 1px solid #292626;
  position: absolute;
  top: 8px;
  left: 0;
  bottom: 7px;
}
#sec8 .content .item .gr-txt .txt .map-link a {
  display: inline-block;
  position: relative;
  padding-left: 18px;
}
#sec8 .content .item .gr-txt .txt .map-link a::before {
  content: "";
  background: url(../img/recruit/icon_map.png) no-repeat 0 0/100% auto;
  width: 9px;
  height: 11px;
  position: absolute;
  top: 8px;
  left: 0;
}
#sec8 .content .item .gr-txt .txt p:not(:last-child) {
  margin-bottom: 10px;
}
#sec8 .content .item .gr-txt .btn-link {
  margin: 10vw 0 0;
}
#sec8 .content .item .gr-txt .btn-link a {
  display: block;
  font-size: 4.8vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-align: center;
  color: #fff;
  border: 1px solid #292626;
  background: #292626;
  padding: 8vw 5%;
}
#sec8 .content .item2 .gr-txt h3 {
  font-size: 5.8vw;
  margin: 0 -2vw;
}
#sec8 .content .item3 .gr-txt h3 {
  font-size: 6.7vw;
}
