@charset "UTF-8";


/*================================================================
 スマホ（全てのサイズで読み込む）
================================================================*/

/*
ボタンデザイン
---------------------------------*/

/*--共通--*/

.button a {
  position: relative;
  margin: 0 auto;
  padding: 15px;
  width: 300px;
  text-align: center !important;
  font-size: 2rem;
  letter-spacing: .2rem;
  border-radius: 30px;
}

.button a::after {
  content: "";
  width: 12px;
  height: 12px;
  margin-top: -5px;
  border-top: solid 2px inherit;
  border-right: solid 2px inherit;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 30px;
}

.button a:hover {
  opacity: 1;
}

/*--採用情報のボタンの場合--*/

#recruit .button a {
  background: linear-gradient(145deg, #2f9bf6, #2883cf);
  box-shadow: 5px 5px 10px #1a578a,
    -5px -5px 10px #3eccffcb,
    inset 5px 5px 10px transparent,
    inset -5px -5px 10px transparent;
}

#recruit .button a::after {
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
}

/*--ホバー時--*/

#recruit .button a:hover {
  background: #2C91E6;
  box-shadow: 5px 5px 10px transparent,
    -5px -5px 10px transparent,
    inset 5px 5px 10px #1a578a,
    inset -5px -5px 10px #3ecbff;
}

/*--会社情報のボタンの場合--*/

#company .button {
  display: block;
  margin: 30px auto 50px;
}

#company .button a {
  font-weight: 500;
  background: linear-gradient(145deg, #ffffff, #d8dfe6d0);
  box-shadow: 5px 5px 10px #909599c4,
    -5px -5px 10px #ffffff,
    inset 5px 5px 10px transparent,
    inset -5px -5px 10px transparent;
}

#company .button a::after {
  border-top: solid 2px #1980D8;
  border-right: solid 2px #1980D8;
}

/*--ホバー時--*/

#company .button a:hover {
  background: #F0F8FF;
  box-shadow: 5px 5px 10px transparent,
    -5px -5px 10px transparent,
    inset 5px 5px 10px #909599c4,
    inset -5px -5px 10px #ffffff;
}

/*トップ画像*/
.top_image img {
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width:680px) {
  .top_image img {
    max-width: 950px;
  }
}

/*
事業案内
---------------------------------*/

#services ul li .img {
  margin: 0 auto;
  max-width: 180px;
}

#services ul li:nth-of-type(3) .img {
  max-width: 194px;
}

#services ul li p {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.5;
}

#services ul li span {
  display: inline-block;
}

/*
採用情報
---------------------------------*/

#recruit {
  position: relative;
}

#recruit h2 {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #333;
}

#recruit p {
  font-size: 1.8rem;
  line-height: 1.8;
}

#recruit .img {
  margin: 0 auto;
  max-width: 350px;
}

/*
会社情報
---------------------------------*/

#company .intro {
  font-size: 2.4rem;
  font-weight: 700;
}

#company .img {
  margin-bottom: 10px;
}


/*
グループ会社
---------------------------------*/

#group h3::before {
  content: "【";
}

#group h3::after {
  content: "】";
}

#group ul {
  display: inline-block;
}

#group ul li:first-child .img {
  margin-right: 8px;
  max-width: 88px;
}

#group ul li:nth-child(2) .img {
  margin-right: 15px;
  max-width: 50px;
}

#group ul li p {
  font-size: 1.8rem;
  font-weight: 700;
  white-space: nowrap;
}

#group ul li:first-child p {
  color: #2A481A;
}

#group ul li:nth-child(2) p {
  color: #EE6E2A;
}

#group ul li a,
#group ul li {
  justify-content: center;
}


/*================================================================
 タブレット（画面幅768px以上で読み込む）
================================================================*/
@media screen and (min-width:768px) {

  /*
  事業案内
  ---------------------------------*/

  #services ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-end;
  }

  #services ul li {
    width: 48%;
  }

  #services ul li .box:first-child {
    padding-top: 0;
  }

  /*
  事業への思い
  ---------------------------------*/

  #thought.inner {
    max-width: 600px;
  }

  /*
  採用情報
  ---------------------------------*/

  #recruit {
    padding-bottom: 85px;
    text-align: left;
  }

  #recruit .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #recruit .content {
    width: 60%;
    max-width: 480px;
  }

  #recruit p {
    white-space: nowrap;
  }

  #recruit .button {
    margin-bottom: 0;
  }

  #recruit .img {
    width: 35%;
    max-width: 400px;
  }

  /*
  会社情報
  ---------------------------------*/

  #company .inner {
    padding-top: 70px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  #company .img_box {
    width: 38%;
  }


  #company .content {
    padding-top: 0;
    width: 56%;
  }

  @media screen and (min-width:880px) {
    #company .img_box {
      width: 40%;
    }

    #company .content {
      width: 52%;
    }
  }

  #company p {
    font-size: 1.8rem;
  }

  #company .intro {
    font-size: 3rem;
  }

  #company .button {
    margin: 45px 0 0;
  }


  /*
  グループ会社
  ---------------------------------*/

  #group h3::before {
    content: "【";
  }

  #group h3::after {
    content: "】";
  }

  #group ul li:first-child .img {
    margin-right: 8px;
    max-width: 88px;
  }

  #group ul li:nth-child(2) .img {
    margin-right: 15px;
    max-width: 50px;
  }

  #group ul li p {
    font-size: 1.8rem;
    font-weight: 700;
    white-space: nowrap;
  }

  #group ul li:first-child p {
    color: #2A481A;
  }

  #group ul li:nth-child(2) p {
    color: #EE6E2A;
  }

}


/*================================================================
 PC（画面幅1080px以上で読み込む）
================================================================*/

@media screen and (min-width:1080px) {

  /*
  事業案内
  ---------------------------------*/

  #services .inner {
    max-width: 980px;
  }

  #services ul li {
    width: 23%;
  }

  /*
  採用情報
  ---------------------------------*/

  #recruit p {
    font-size: 2rem;
  }
}