/* CSS Document */
#contents .recruit {
  position: relative;
}
#contents .recruit .first {
  box-sizing: border-box;
  position: relative;
}
@media screen and (min-width: 931px) {
  #contents .recruit .first {
    margin-top: 150px;
    width: 100%;
    background-image: url("../img/comp_bg.png");
    background-repeat: no-repeat;
    background-size: contain;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first {
    margin: 100px auto 0;
    width: 95%;
    background: #fff;
  }
}
#contents .recruit .first h2 {
  font-size: clamp(16px, 1.5vw, 30px);
  color: #000;
  letter-spacing: 1px;
  padding: 0.5vw 1.5vw;
  box-sizing: border-box;
}
@media screen and (min-width: 931px) {
  #contents .recruit .first h2 {
    text-align: left;
    margin: 0 auto 0 10vw;
    width: 50%;
    border-bottom: 2px solid #8EC325;
    border-left: 8px solid #8EC325;
    border-right: 0px solid;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first h2 {
    border-bottom: 1px solid #8EC325;
    border-left: 4px solid #8EC325;
    border-right: 0px solid;
  }
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info {
    width: 50%;
    margin: 20px auto 0 10vw;
    min-height: 600px;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info {
    width: 100%;
    margin: 20px 0;
    min-height: 500px;
  }
}
#contents .recruit .first .recruit_info .flex_box {
  display: flex;
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .flex_box {
    text-align: left;
  }
}
#contents .recruit .first .recruit_info .flex_box .item_name {
  font-size: clamp(13px, 1vw, 18px);
  font-weight: 500;
  box-sizing: border-box;
  background: #8EC325;
  color: #fff;
  border-bottom: 1px solid #fff;
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .flex_box .item_name {
    width: 250px;
    padding: 20px 25px;
    letter-spacing: 2px;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info .flex_box .item_name {
    width: 100px;
    padding: 10px 15px;
  }
}
#contents .recruit .first .recruit_info .flex_box .item_l {
  font-size: clamp(13px, 1vw, 18px);
  font-weight: 500;
  box-sizing: border-box;
  border-bottom: 1px solid #d1d1d1;
  background: #fff;
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .flex_box .item_l {
    width: calc(100% - 250px);
    padding: 20px 25px;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info .flex_box .item_l {
    width: 250px;
    padding: 10px 15px;
  }
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .flex_box .item_l ul {
    box-sizing: border-box;
    padding-left: 20px;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info .flex_box .item_l ul {
    box-sizing: border-box;
    padding-left: 15px;
  }
}
#contents .recruit .first .recruit_info .recruit_title {
  font-size: clamp(13px, 1vw, 18px);
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .recruit_title {
    padding: 50px;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info .recruit_title {
    padding: 25px;
  }
  #contents .recruit .first .recruit_info .recruit_title br {
    display: none;
  }
}
#contents .recruit .first .recruit_info .entensyoku, #contents .recruit .first .recruit_info .engage {
  display: block;
  font-size: clamp(13px, 1vw, 18px);
  font-weight: 500;
  text-decoration: none;
  color: #000;
  transition: 0.4s;
  background-image: url("../img/arrow.png");
}
@media screen and (min-width: 931px) {
  #contents .recruit .first .recruit_info .entensyoku, #contents .recruit .first .recruit_info .engage {
    border-bottom: 1px solid #000;
    padding: 20px 20px 5px 20px;
    margin-left: 50px;
    width: 300px;
    background-size: 8%;
    background-position: 92% 70%;
    background-repeat: no-repeat;
  }
}
@media screen and (max-width: 930px) {
  #contents .recruit .first .recruit_info .entensyoku, #contents .recruit .first .recruit_info .engage {
    border-bottom: 1px solid #000;
    padding: 10px 10px 5px 10px;
    margin-left: 20px;
    max-width: 280px;
    width: 100%;
    background-size: 8%;
    background-position: 92% 70%;
    background-repeat: no-repeat;
  }
}
#contents .recruit .first .recruit_info .entensyoku:hover, #contents .recruit .first .recruit_info .engage:hover {
  color: #5fb93e;
  border-bottom: 1px solid #5fb93e;
}
#contents .recruit .first .recruit_info .entensyoku + a, #contents .recruit .first .recruit_info .engage + a {
  margin-top: 20px;
}

.Preparation {
  font-size: clamp(20px, 1.5vw, 40px);
  font-weight: 700;
  box-sizing: border-box;
  letter-spacing: 3px;
}
@media screen and (min-width: 931px) {
  .Preparation {
    padding: 50px;
    min-height: 600px;
  }
}
@media screen and (max-width: 930px) {
  .Preparation {
    min-height: 500px;
    padding: 25px;
  }
}