/* ヘッダーはここから */
.hero{
  padding: 64px;
}
.btn-menu{
  width: 112px;
  position: absolute;
  top: 3%;
  right: 2.5%;
  cursor: pointer;
}
.btn-menu img{
  width: 112px;
}
.hero-inner1 h1{
  font-size: 192px;
  font-weight: 600;
}
.hero-inner2{
  display: flex;
  justify-content: space-between;
}
.hero-inner2-text{
  width: 70%;
  font-size: 64px;
  line-height: 1.2;
  font-weight: 400;
}
.hero-inner2-text h2{
  font-size: 64px;
  line-height: 1.2;
  font-weight: 600;
}
.hero-inner2-table{
  width: 30%;
  height: 100%;
  font-size: 24px;
  line-height: 1.2;
  font-weight: bold;
  margin-left: 64px;
}
td, th{
  border-bottom: 2px solid black;
  padding: 20px 0;
}
th{
  text-align: left;
}
td{
  text-align: right;
}
table {
  border-collapse: collapse;
}
.key-visual img{
  width: 100%;
  height: auto;
}
/* ヘッダーはここまで */


/* 紹介ページはここから */
.service{
  width: 100%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  padding: 64px 64px 0 64px;
}
.service-inner1{
  width: 30%;
  position: relative;
  padding-right: 64px;
  display: flex;
  justify-content: space-between;
}
.service-inner1 h2{
  font-size: 32px;
  font-weight: 600;
}
.service-inner1::before{
  content:"";/*疑似要素の中身を指定*/
  position:absolute;/*絶対位置指定*/
  left:100%;/*横位置の指定*/
  top:0%;/*縦位置の指定*/
  background:#000000;/*線の色指定*/
  width:2px;/*線の幅指定*/
  height:100%;/*線の高さ指定*/
}
.service-inner1 img{
  width: 50px;
}
.service-inner2{
  width: 70%;
  padding-left: 64px;
}
  .service-part{
    position: relative;
    padding: 64px 0;
  }
  .service-part::before {
    content:"";/*疑似要素の中身を指定*/
    position:absolute;/*絶対位置指定*/
    left:0;/*横位置の指定*/
    top:100%;/*縦位置の指定*/
    background:#000000;/*線の色指定*/
    height:2px;/*線の高さ指定*/
    width:100%;/*線の幅指定*/
    }
  .service-part:first-child{
    padding: 0 0 64px 0;
  }
  .service-part:last-child{
    padding: 64px 0 0 0;
  }
  .service-part:last-child::before{
    content: none;
  }
  .service-title1{
    font-size: 24px;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 16px;
  }
  .service-title2{
    font-size: 48px;
    font-weight: 600;
    line-height: 1.2;
    margin-bottom: 16px;
  }
  .service-text{
    font-size: 24px;
    line-height: 1.6;
    opacity: .7;
  }
/* 紹介ページはここまで */


/* ギャラリーはここから */
.gallery-part{
  display: block;
}
.arrow{
  display: none;
}
.gallery img{
  width: 100%;
  height: auto;
  display: block;
}
.gallery-title{
  font-size: 32px;
  font-weight: 600;
  line-height: 1.2;
  padding: 64px 64px 48px 64px;
}
/* ギャラリーはここまで */


/* レスポンシブ(768〜1280px)はここから */
@media screen and (max-width: 1280px) {
  .hero-inner1 h1{
    font-size: 140px;
  }
  .hero-inner2-text h2{
    font-size: 45px;
  }
  .service-inner1 img{
    width: 40px;
  }
  .service-inner1 h2{
    writing-mode: vertical-rl; /* 縦書き、右から左へ書く */
    text-orientation: upright; /* 文字の向きを縦に保つ */
  }
}
/* レスポンシブ(768〜1024px)はここまで */


/* レスポンシブル(sp)はここから */
@media screen and (max-width: 768px) {
/* ヘッダー(sp)はここから */
.hero{
  padding: 55px 0 0 0;
}
.hero-inner{
  padding: 30px 24px;
}
.btn-menu{
  width: 92px;
}
.btn-menu img{
  width: 92px;
}
.hero-inner1 h1{
  font-size: 80px;
  line-height: 1.1;
  padding-bottom: 10px;
}
.hero-inner2{
  display: block;
}
.hero-inner2-text{
  width: 100%;
  padding-bottom: 30px;
}
.hero-inner2-text h2{
  font-size: 23.59px;
}
.hero-inner2-table{
  width: 100%;
  font-size: 17.28px;
  padding: 25px 20px 25px 20px;
  margin-left: 0;
}
td, th{
  border-bottom: 1.44px solid black;
  padding: 14px 0;
}
/* ヘッダー(sp)はここまで */


/* 紹介ページ(sp)はここから */
.service{
  display: block;
  padding: 57.28px 19px 0 20px;
}
.service-inner1{
  width: 100%;
  padding-right: 0;
  padding-bottom: 71px;
}
.service-inner1::before{
  content:none;/*疑似要素の中身を指定*/
}
.service-inner1 h2{
  font-size: 22px;
  writing-mode: horizontal-tb; /* 横書きに戻す */
  text-orientation: mixed; /* 文字の向きをデフォルトにする */

}
.service-inner1 img{
  width: 30.34px;
}
.service-inner2{
  width: 100%;
  padding-left: 0;
}
  .service-part{
    padding: 29px 0 27px 0;
  }
  .service-part::before {
    height:1px;/*線の高さ指定*/
    }
  .service-part:first-child{
    padding: 29px 0 27px 0;
  }
  .service-part:last-child{
    padding: 29px 0 27px 0;
  }
  .service-part:last-child::before{
    content: "";
  }
  .service-title1{
    margin-bottom: 11px;
  }
  .service-title2{
    font-size: 32px;
    margin-bottom: 11px;
  }
  .service-text{
    font-size: 20px;
  }
/* 紹介ページ(sp)はここまで */


/* ギャラリー(sp)はここから */
.gallery{
  padding-top: 57.57px;
}
.gallery-part{
  display: flex;
  justify-content: space-between;
  padding: 0 20px 19px 20px;
}
.arrow{
  display: block;
  width: 30.34px;
}
.gallery img{
  width: 100%;
  height: auto;
}
.gallery-title{
  font-size: 22px;
  padding: 0;
}
/* ギャラリー(sp)はここまで */
}
/* レスポンシブル(sp)はここまで */