@charset "UTF-8";
/* ===================================================================
RECRUIT
=====================================================================*/
html:focus-within {
  scroll-behavior: auto;
}

/* -------------------------------------------------------------- */
#mainContents {
  padding-bottom: 0;
}

/* -------------------------------------------------------------- */
/* 背景 */
/* -------------------------------------------------------------- */
.bg_blue02 {
  background-color: #ECF2F7;
}

/* -------------------------------------------------------------- */
/* 改行 */
/* -------------------------------------------------------------- */
.line_break {
  display: inline-block;
}

/* 募集
===================================================================== */
#Introduction.section_basic.recruit {
  padding: 45px 0;
}
@media screen and (max-width: 768px) {
  #Introduction.section_basic.recruit {
    padding: 4% 0;
  }
}

.staff_box {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  background: #fff;
  border-radius: 1em;
  padding: 5% 7%;
  margin-bottom: 100px;
}
@media screen and (max-width: 768px) {
  .staff_box {
    padding: 10% 7%;
    margin-bottom: 10vw;
    border-radius: initial;
  }
}
.staff_box h4 {
  position: relative;
  color: #78C153;
  font-size: 24px;
  font-weight: 300;
  font-family: "NotoSerif", serif !important;
  text-align: center;
  padding-bottom: 0.5em;
  margin-bottom: 1em;
}
@media screen and (min-width: 769px) and (max-width: 1919px) {
  .staff_box h4 {
    font-size: min(3vw, 24px);
  }
}
@media screen and (max-width: 768px) {
  .staff_box h4 {
    font-size: min(3.385vw, 26px);
  }
}
.staff_box h4:before {
  position: absolute;
  content: "";
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 2rem;
  height: 1px;
  background: #78C153;
}

.one_period p {
  font-family: "NotoSerif", serif !important;
  font-size: 22px;
}
@media screen and (min-width: 769px) {
  .one_period p {
    font-size: clamp(19px, 1.0422vw, 22px);
  }
}
@media screen and (max-width: 1024px) {
  .one_period p {
    font-size: clamp(17px, 1.757vw, 19px);
  }
}
@media screen and (max-width: 768px) {
  .one_period p {
    font-size: clamp(17px, 2.343vw, 19px);
  }
}
@media screen and (max-width: 480px) {
  .one_period p {
    font-size: clamp(16px, 3.54vw, 17px);
  }
}
@media screen and (max-width: 768px) {
  .one_period p {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .one_period p {
    font-size: min(3.75vw, 18px);
  }
}

/* -------------------------------------------------------------- */
dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: 100px;
  font-size: clamp(16px, 0.937vw, 18px);
}
dl:last-of-type {
  margin-bottom: 0;
}

/* -------------------------------------------------------------- */
dt, dd {
  height: auto;
  font-size: 18px;
}
@media screen and (min-width: 769px) {
  dt, dd {
    font-size: clamp(16px, 0.937vw, 18px);
  }
}
@media screen and (max-width: 1024px) {
  dt, dd {
    font-size: clamp(15px, 1.562vw, 16px);
  }
}
@media screen and (max-width: 768px) {
  dt, dd {
    font-size: clamp(15px, 2.083vw, 16px);
  }
}
@media screen and (max-width: 480px) {
  dt, dd {
    font-size: clamp(13px, 2.916vw, 15px);
  }
}

/* -------------------------------------------------------------- */
#sec01 dt {
  position: relative;
  width: 28%;
  padding: 1em;
  color: #78C153;
  /*  &:before {
      display: none;
    }*/
}
#sec01 dt:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #EBEBEB;
}
@media screen and (max-width: 768px) {
  #sec01 dt {
    width: 100%;
    padding: 1em 0 0;
    font-size: min(2.864vw, 18px);
    /* font-size: min(3.75vw, 23px); */
  }
  #sec01 dt:before {
    display: none;
  }
}

/* -------------------------------------------------------------- */
dd {
  position: relative;
  width: 72%;
  padding: 1em 0;
  text-align: justify;
}
dd:before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: #EBEBEB;
}
@media screen and (max-width: 768px) {
  dd {
    width: 100%;
    padding: 0 0 1em;
    font-size: min(2.343vw, 18px);
    /* font-size: min(3.75vw, 23px); */
  }
}
dd.last_border {
  padding: initial;
}
dd.last_border:before {
  display: none;
}

/* お問い合わせ
===================================================================== */
.link_box {
  margin: 0 auto;
  width: 90%;
  max-width: 1200px;
}

/* -------------------------------------------------------------- */
.recruit_link {
  position: relative;
  display: block;
  width: 60%;
  max-width: 600px;
  margin: 0 auto;
  padding: 3% 6% 3% 5%;
  text-align: center;
  font-size: 25px;
  line-height: 1.5;
  color: #fff;
  background: #78C153;
  font-family: "Cochin", "NotoSerif", serif !important;
  opacity: 1;
}
@media screen and (max-width: 768px) {
  .recruit_link {
    width: 80%;
    padding: 1.5em 2.5em 1.5em 1em;
    font-size: min(3.125vw, 24px);
  }
}
.recruit_link:hover {
  opacity: 0.5;
}
.recruit_link:before {
  position: absolute;
  content: "";
  top: 50%;
  right: 0;
  width: 1.2em;
  height: 1em;
  transform: translate(-100%, -50%) rotate(-90deg);
  background: url(../images/company/allow_under.png) no-repeat center/contain;
}/*# sourceMappingURL=recruit.css.map */