@charset "UTF-8";
/**
 * CSS Information
 * ===============================================================
 *
 * File name: _contents.scss
 * Summary:   ページ・コンテンツごとの固有スタイル
 *
 * -----------------------------------
 *
 * TOC:
 *     =1    home
 *
 * ===============================================================
*/
/** =1
 * ========================================
 * home
 * ========================================
 */

/**MV**/

.mvAreaWrapper,
.mvWrapper,
.mvSlick {
  height: 100%;
}
.mvCatchWrapper {
  bottom: 45px;
  left: 80px;
  z-index: 2;
}
.mvCatchCopy {
  margin-bottom: 15px;
  font-size: 5.2rem;
  letter-spacing: 0.05em;
}
.mvBodyCopy {
  font-size: 1.8rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.mvPatern {
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  background: url(../image/top/mvPatern.png) repeat 0 0;
  mix-blend-mode: multiply;
}
.mvSlideLi {
  height: 100%;
}
.mvSlideLi img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

@media screen and (max-width: 1025px) {
  .mvCatchWrapper {
    left: 40px;
  }
}

@media screen and (max-width: 767px) {
  .mvCatchWrapper {
    left: 20px;
    right: 20px;
    bottom: 70px;
  }
  .mvCatchCopy {
    margin-bottom: 5px;
    font-size: 3rem;
    letter-spacing: 0;
  }
  .mvBodyCopy {
    font-size: 1.6rem;
    line-height: 1.6;
    letter-spacing: 0;
  }
}

.mvSlick {
  -webkit-transition: all 300ms ease-in-out;
  transition: all 300ms ease-in-out;
}
.mvSlick.slick-dotted.slick-slider {
  margin-bottom: 0;
}
.mvSlick .slick-list,
.mvSlick .slick-track {
  height: 100%;
}
.mvSlick .slick-dots {
  z-index: 2;
  width: auto;
  bottom: 45px;
  right: 80px;
  font-size: 0;
}
.mvSlick .slick-dots li {
  margin: 0 0 0 5px;
  padding: 0;
  width: 40px;
  height: 4px;
  line-height: 1;
}
.mvSlick .slick-dots li button {
  padding: 0;
  width: 40px;
  height: 4px;
}
.mvSlick .slick-dots li button:before {
  content: "";
  display: inline-block;
  width: 40px;
  height: 4px;
  border: 1px solid #fff;
  opacity: 1;
  font-size: 0;
  line-height: 1;
}
.mvSlick .slick-dots li.slick-active button:before {
  opacity: 1;
  background: #fff;
}

@media screen and (max-width: 767px) {
  .mvSlick .slick-dots {
    bottom: 35px;
    right: 20px;
  }
}

/**Top Contents**/

.topH2 {
  margin: 24px 0 50px;
  font-size: 3.2rem;
}
.h2Jp {
  display: block;
}
.topH2::after {
  content: "";
  position: absolute;
  bottom: 39px;
  right: calc(50% - 20px);
  display: inline-block;
  width: 40px;
  height: 4px;
  background: #4e9262;
  background: -moz-linear-gradient(
    to right,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  background: -webkit-linear-gradient(
    to right,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  background: linear-gradient(
    to right,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4e9262', endColorstr='#295a36',GradientType=1 );
}
.topH2 span {
  margin-top: 25px;
}

@media screen and (max-width: 767px) {
  .topH2 {
    margin: 20px 0;
    font-size: 2.2rem;
  }
  .topH2 span {
    margin-top: 15px;
  }
  .topH2::after {
    bottom: 26px;
    right: calc(50% - 13px);
    width: 26px;
    height: 2px;
  }
}

.newsDl {
  flex-wrap: wrap;
  max-width: 680px;
  margin: 0 auto;
}
.newsDl .newsLink {
  width: 100%;
  padding: 15px;
}
.newsDl .newsDate {
  width: 110px;
}
.newsDl .newsTitle {
  width: calc(100% - 110px);
}

@media screen and (max-width: 767px) {
  .newsDl {
    font-size: 1.4rem;
  }
  .newsDl .newsLink {
    padding: 5px;
  }
  .newsDl .newsDate {
    width: 85px;
  }
  .newsDl .newsTitle {
    width: calc(100% - 85px);
  }
}

/** =2
 * ========================================
 * about
 * ========================================
 */
.aboutTxtPresidentName {
  margin-top: -60px;
}
#about .halfImgTxtBoxInnerBox {
  padding: 0 0 0 80px;
}

#about .halfImgImgBox img {
  max-width: 428px;
  height: 480px;
}
.companyProfileWrapper {
  width: 75%;
  margin: 0 auto;
}
.companyProfileDl {
  align-items: center;
  padding: 30px 0;
  border-bottom: 1px dotted #aaaaaa;
}
.companyProfileDt {
  width: 120px;
  margin-right: 50px;
  font-weight: 500;
}
.companyProfileDd {
  width: calc(100% - 170px);
}

@media screen and (max-width: 1025px) {
  #about .halfImgTxtBoxInnerBox {
    padding: 0 0 0 40px;
  }
  .companyProfileWrapper {
    width: 85%;
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .aboutTxtPresidentName {
    margin-top: -40px;
    font-size: 1.4rem;
  }
  #about .halfImgImgBox img {
    height: 300px;
  }
  #about .halfImgTxtBoxInnerBox {
    padding: 0 15px;
  }
  .companyProfileWrapper {
    width: 100%;
  }
  .companyProfileDl {
    flex-direction: column;
    align-items: flex-start;
    padding: 15px 0;
  }
  .companyProfileDt {
    width: 100%;
    margin-right: 0;
  }
  .companyProfileDd {
    width: 100%;
  }
}

/** =3
 * ========================================
 * service
 * ========================================
 */

#service .halfImgWrapperLRChange .halfImgTxtBoxInnerBox {
  padding: 0;
}
.sectionServisFlow .halfImgImgBox img {
  width: auto;
  height: 278px;
}
.sectionServisFlow .serviceFlowBlock01 .halfImgImgBox img {
  margin: 10px 0 0 -240px;
}
.sectionServisFlow .serviceFlowBlock02 .halfImgImgBox img {
  margin: -130px -120px 0 0;
}
.sectionServisFlow .serviceFlowBlock03 .halfImgImgBox img {
  margin: -140px 0 0 -100px;
}

@media screen and (max-width: 1025px) {
  .sectionServisFlow .serviceFlowBlock01 .halfImgImgBox img {
    margin: 50px 0 0 -160px;
  }
  .sectionServisFlow .serviceFlowBlock02 .halfImgImgBox img {
    margin: -120px 0px 0 0;
  }
  .sectionServisFlow .serviceFlowBlock03 .halfImgImgBox img {
    margin: -120px 0 0 -100px;
  }
}

@media screen and (max-width: 767px) {
  .serviceFlowBlock .halfImgImgBox {
    margin-top: 30px;
  }
  .serviceFlowBlock
    .halfImgImgBox
    .halfImgWrapperLRChange
    .halfImgImgBoxInnerBox {
    padding: 0 40px;
  }
  .sectionServisFlow .serviceFlowBlock01 .halfImgImgBox img,
  .sectionServisFlow .serviceFlowBlock02 .halfImgImgBox img,
  .sectionServisFlow .serviceFlowBlock03 .halfImgImgBox img {
    margin: 0;
  }
}

.serviceFlowDl {
  margin-left: 40px;
  padding-bottom: 60px;
  line-height: 2;
}
.serviceFlowDl::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  height: 1px;
  width: 316px;
  background: #55a349;
}
.serviceFlowBlock03 .serviceFlowDl:after {
  display: none;
}
.serviceFlowDl::after {
  content: "";
  position: absolute;
  bottom: -45px;
  left: 48%;
  transform: translate(-50%, 0);
  display: block;
  height: 79px;
  width: 43px;
  background: url(../image/service/serviceFlowArrow.svg) 0 0 no-repeat;
}
.serviceFlowDt {
  margin-bottom: 10px;
  font-size: 2rem;
}
.serviceFlowDdTxt {
  margin-top: 20px;
}

@media screen and (max-width: 767px) {
  .serviceFlowDl {
    margin: 0 0 40px 20px;
    padding-bottom: 50px;
    line-height: 1.7;
  }
  .serviceFlowDt {
    margin-bottom: 10px;
    font-size: 1.8rem;
  }
  .serviceFlowDd {
    font-size: 1.4rem;
  }
}

/** =4
 * ========================================
 * recrui
 * ========================================
 */
.sectionRecruitBlock01 .btnWrapper:nth-of-type(2) {
  margin-top: 15px;
}

.messageUl {
  justify-content: space-between;
}
.messageLi {
  flex-direction: column;
  align-items: center;
  width: 33%;
}
.messageImg {
  max-width: 240px;
}
.messageTxtBox {
  margin-top: 40px;
  padding: 0 50px;
}
.messageTxtTitle {
  font-weight: 500;
}
.messageTxtDt {
  display: inline-block;
  margin: 30px 0 10px -10px;
  padding: 6px 8px 8px;
  background: #264a21;
  color: #fff;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .messageUl {
    flex-direction: column;
    margin-top: 25px;
  }
  .messageLi {
    width: 100%;
    margin-bottom: 40px;
  }
  .messageImg {
    max-width: 180px;
  }
  .messageTxtBox {
    margin-top: 25px;
    padding: 0 20px;
  }
  .messageTxtDt {
    margin: 15px 0 5px -10px;
  }
}

.educationH4 {
  margin-bottom: 25px;
  font-size: 2rem;
}
.educationP {
  margin-bottom: 45px;
  font-size: 1.5rem;
  line-height: 2;
}

@media screen and (max-width: 767px) {
  .sectionRecruiBlock03 .halfImgImgBox {
    margin-top: 30px;
  }
  .sectionRecruiBlock03 .halfImgWrapperLRChange .halfImgTxtBoxInnerBox {
    padding: 0 20px;
  }
  .educationH4 {
    margin-bottom: 15px;
    font-size: 1.8rem;
  }
  .educationP {
    margin-bottom: 30px;
    font-size: 1.4rem;
    line-height: 1.7;
  }
}

.bigBtnWrapper {
  margin-top: 60px;
}
.bigBtnWrapper a.greenBtn {
  width: 485px;
  border-bottom: 66px solid #264a21;
  border-right: 50px solid transparent;
  font-size: 2.6rem;
}
.bigBtnWrapper a.greenBtn::before {
  right: -52px;
  border-bottom: 66px solid #55a349;
  border-right: 50px solid transparent;
}
.bigBtnWrapper a.greenBtn:hover::before {
  transform: scale(1, 1);
}
.bigBtnWrapper .btnBg.greenBtnBg {
  width: 80px;
  right: -12px;
  border-bottom: 66px solid #55a349;
  border-right: 50px solid transparent;
}

@media screen and (max-width: 767px) {
  .bigBtnWrapper {
    margin-top: 30px;
  }
  .bigBtnWrapper a.greenBtn {
    width: 320px;
    padding: 0 40px;
    border-bottom: 50px solid #264a21;
    border-right: 38px solid transparent;
    font-size: 1.8rem;
    line-height: 2.6;
  }
  .bigBtnWrapper a.greenBtn::before {
    right: -52px;
    border-bottom: 50px solid #55a349;
    border-right: 38px solid transparent;
  }
  .bigBtnWrapper .btnBg.greenBtnBg {
    right: -10px;
    border-bottom: 50px solid #55a349;
    border-right: 38px solid transparent;
  }
}

/** =5
 * ========================================
 * contact
 * ========================================
 */
.contactFormCaption {
  margin: 0 0 15px;
  font-size: 1.4rem;
}
#contact .companyProfileDl:first-of-type {
  border-top: 1px dotted #aaaaaa;
}
#contact .companyProfileDt {
  width: 150px;
  margin-right: 50px;
  font-size: 1.5rem;
  color: #55a349;
}
#contact .companyProfileDd {
  width: calc(100% - 200px);
}

.select {
  display: inline-block;
  position: relative;
  vertical-align: middle;
}
select {
  appearance: none;
  width: 450px;
  padding: 10px;
  padding-right: 1em;
  border: none;
  outline: 0;
  background: #eee;
  text-overflow: ellipsis;
  cursor: pointer;
}
.select::before {
  content: "";
  position: absolute;
  top: 17px;
  right: 16px;
  width: 0;
  height: 0;
  border-width: 11px 7px 0 7px;
  border-style: solid;
  border-color: #666666 transparent transparent transparent;
  pointer-events: none;
}
select::-ms-expand {
  display: none;
}
option[selected][disabled] {
  display: none;
}

@media screen and (max-width: 767px) {
  select {
    width: 350px;
  }
}

.contactThanksTxt {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {
  .contactFormCaption {
    max-width: 100%;
    margin: 25px auto 15px;
    font-size: 12px;
    font-size: 1.2rem;
  }
  #contact .companyProfileDt {
    width: 100%;
    margin-right: 0;
  }
  #contact .companyProfileDd {
    width: 100%;
  }
}

/** =6
 * ========================================
 * PRIVACY POLICY
 * ========================================
 */
.privacyDlWrapper {
  margin-top: 40px;
}
.privacyDt {
  position: relative;
  margin-bottom: 10px;
  font-weight: 500;
  text-align: left;
}
.privacyDt::before {
  content: "";
  display: inline-block;
  width: 50px;
  height: 3px;
  margin-right: 15px;
  vertical-align: 4px;
  background: #145096;
  background: -moz-linear-gradient(
    left,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  background: -webkit-linear-gradient(
    left,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  background: linear-gradient(
    to right,
    #264a21 0%,
    #264a21 50%,
    #55a349 50%,
    #55a349 100%
  );
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#4e9262', endColorstr='#295a36',GradientType=1 );
}
.privacyDd {
  margin-bottom: 40px;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .privacyMainP {
    font-size: 1.5rem;
  }
  .privacyDl {
    max-width: 100%;
  }
  .privacyDt {
    margin-bottom: 0;
    font-size: 14px;
    font-size: 1.4rem;
  }
  .privacyDt::before {
    width: 30px;
    height: 3px;
    margin-right: 5px;
  }
  .privacyDd {
    margin-bottom: 30px;
    font-size: 1.4rem;
  }
}

/** =7
 * ========================================
 * NEWS DETAIL
 * ========================================
 */
#news .privacyDt {
  margin-bottom: 40px;
  font-size: 1.7rem;
}

@media screen and (max-width: 767px) {
  #news .privacyDt {
    margin-bottom: 30px;
    font-size: 1.5rem;
  }
}
