@charset "utf-8";

/*====================
共通
====================*/
.post__fv{
  width: 100%;
  height: 100vh;
  background: url(../imgs/post/post_fv.jpg) no-repeat center center;
  background-size: cover;
}
.post__wrap{
  padding: 150px 0 0 90px;
  width: 100%;
  height: 100%;
  position: relative;
}

/* パンクズ */
.post__bred-list {
  display: flex;
  gap: 15px;
  padding-bottom: 10px;
  margin-bottom: 40px;
  overflow-x: auto;
  
  /* デフォルトではスクロールバー非表示 */
  scrollbar-width: none; /* Firefox */
}
.post__bred-list::-webkit-scrollbar {
  display: none; /* Chrome, Edge, Safari */
}

/* スクロール中だけ表示 */
.post__bred-list.scrolling::-webkit-scrollbar {
  display: block;
  height: 3px;
}
.post__bred-list.scrolling::-webkit-scrollbar-thumb {
  background-color: rgba(0,0,0,0.3);
  border-radius: 6px;
}
.post__bred-list.scrolling::-webkit-scrollbar-track {
  background: transparent;
}



.post__bred-listItem{
  min-width: fit-content;
  position: relative;
 
}
.post__bred-listItem::after{
  display: block;
  content: '>';
  font-size: 15px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  color: #000;

}

.post__bred-listItem:last-child::after{
  display: none;
}
.post__bred-listLink{
   padding-right: 20px;
  display: block;
  font-size: 15px;
  letter-spacing: 0.12em;
  white-space: nowrap;

}

.post__headWrap{
  left: 0;
}
.post__head{
  padding-left:71px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
  position: relative;
}
.post__head::before{
  content: '';
  display: block;
  width: 60px;
  height: 194px;
  background-color: #000;
  position: absolute;
  top: 0;
  left: 0;
  border-radius:3px;
}
.post__ttl{
  margin-bottom: 11px;
  padding: 30px 30px 29px 25px;
  display: inline-block;
  background-color: #000;
  color: #fff;
  font-size: 28px;
  letter-spacing: 0.2em;
  border-radius:3px;
}
.post__ttl--en{
  padding:2px 20px 1px 16px;
  display: inline-block;
  background-color: #000;
  color: #fff;
  font-size: 98px;
  font-family: bebas-neue, sans-serif;
  letter-spacing: 0.08em;
  line-height: 0.9;
  border-radius:3px;
}

.post__contant{
  padding-top: clamp(60px, 8vw, 110px);
  padding-bottom: clamp(60px, 8vw, 110px);
  border-bottom:1px solid #000;
}
.post__bottm{
  padding: 55px 20px 70px 20px;
  text-align: right;
}
.post__topLink{
  padding-right: 70px;
  font-size: 17px;
  letter-spacing: 0.02em;
  position: relative;
}
.post__topLink::after{
  content: '';
  display: inline-block;
  width: 47px;
  height: 47px;
  background:url(../imgs/post/post_bomAnc.svg) no-repeat center center;
  background-size: contain;
  margin-left: 10px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-o-transform: translateY(-50%);
}



@media screen and (max-width: 1600px) {
    .post__wrap {
        padding: 10% 0 0 45px;
    }
    .post__head{
      padding-left: 52px;
    }
    .post__head::before{
      width: 46px;
      height: 129px;
    }
    .post__ttl{
      margin-bottom: 7px;
      padding: 15px 16px;
      font-size: 20px;
    }
    .post__ttl--en{
      font-size: 72px;
    }
}
@media screen and (max-width: 1300px) {
    .post__wrap  {
        padding:15% 0 0 20px;
    }
}
@media screen and (max-width: 750px) {
    .post__wrap{
      padding-top: 120px;
    }
    .post__bred-list{
      margin-bottom: 10vh;
    }
    .post__bred-listLink{
      font-size: 12px;
    }

    .post__head{
      padding-left: 33px;
    }
    .post__head::before{
      width: 30px;
      height: 88px;
    }
    .post__ttl{
      margin-bottom: 3px;
      font-size: 16px;
      padding: 11px 13px 11px 10px;
    }
    .post__ttl--en{
      font-size: 50px;
      padding: 0 20px 0 11px;
    }

    .post__bottm{
      padding: 30px 20px 40px 20px;
    }
    .post__topLink{
      padding-right: 40px;
      font-size: 14px;
    }
    .post__topLink::after{
      width: 30px;
      height: 30px;
    }
    .no-post{
      font-size: 14px;
    }
}
@media screen and (max-width: 400px) {
    .post__wrap {
        padding-top: 80px;
    }
}




/*====================
blog アーカイブ
====================*/
.blog__list{
  /* margin-bottom: 136px; */
  display: flex;
  justify-content: start;
  align-items: start;
  flex-wrap: wrap;
  gap: 5vw 3.6%;
}
.blog__item{
  width: calc((100% - 7.2%)/3);
  border-bottom: 1px solid #cccccc;
}
.blog__itemLink{
  display: block;
  width: 100%;
}
.blog__itemImgWrap{
  position: relative;
}
.blog__itemImg{
  width: 100%;
  /* height: 278px; */
  padding-top: 59.5%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  object-fit: cover;
  position: relative;
}
.blog__itemImg::after{
  content: "";
  display: block;
  background:url(../imgs/common/blog_anc.svg) no-repeat center center;
  background-size: contain;
  width: 57px;
  height: 57px;
  position: absolute;
  bottom: 17px;
  right: 32px;
}
.blog__textWrap{
  padding: 22px 10px 0 10px;
  height: 170px;
}
.blog__itemDate{
  font-size: 17px;
  letter-spacing: 0.02em;
}
.blog__itemTtl{
  padding-top: 15px;
  font-size:18px ;
  letter-spacing: 0.02em;
  line-height: 1.73;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

@media screen and (max-width: 1600px) {
  .blog__itemTtl{
    font-size: 16px;
  }
  .blog__itemImg::after{
    width: 30px;
    height: 30px;
    right: 15px;
    bottom: 15px;
  }
  .moreLink{
    padding-right: 75px;
    font-size: 16px;
  }
  .moreLink::after{
    width: 52px;
    height: 52px;
  }
}
@media screen and (max-width: 980px) {
  .blog{
    padding-top: 80px;
  }
  .blog__head{
    margin-bottom: 50px;
  }
  .blog__date{
    font-size: 15px;
  }
  .blog__ttl{
    padding-top: 5px;
    font-size: 16px;
  }
  .moreLink{
    padding-right: 50px;
    font-size: 15px;
  }
  .moreLink::after{
    width: 37px;
    height: 37px;
  }
}
@media screen and (max-width: 750px) {
  .blog__wrap{
    margin-bottom: 60px;
  }
  .blog__list{
    display: block;
    max-width: 350px;
    margin: 0 auto;
  }
  .blog__item{
    width: 100%;
    margin-bottom: 30px;
  }
  .blog__item:last-child{
    margin-bottom: 0;
  }
  .blog__textWrap{
    height: auto;
    padding: 12px 10px 30px 10px;
  }
  .blog__itemDate{
    font-size: 12px;
  }
  .blog__itemTtl{
    padding-top: 8px;
    font-size: 14px;
  }
}


/*====================
news アーカイブ
====================*/
.news__wrap{
  padding-top:120px ;
  padding-bottom: 112px;
  background-color: #e6e6e6;
  border-radius: 26px;
}
.news__list{
    border-top:1px solid #cccccc;
}
.news__item{
  padding: 0 30px;
  border-bottom: 1px solid #cccccc;
  position: relative;
}
.news__item:nth-of-type(odd){
  background-color: #d6d6d6;
}
.news__item::after{
  content: "";
  display: block;
  background:url(../imgs/index/news_anc.svg) no-repeat center center;
  background-size: contain;
  width: 14px;
  height: 10px;
  position: absolute;
  top:50%;
  transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	-moz-transform: translateY(-50%);
	-o-transform: translateY(-50%);
  right: 12px;
}
.news__itemLink{
  padding:  56px 0;
  display: flex;
  justify-content: start;
  align-items: center;
}
.news__itemImg{
  width: 142px;
  padding-top: 80px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  object-fit: cover;
  position: relative;
  border-radius: 3px;
}
.news__itemWrap{
  width: calc(100% - 142px);
  padding: 0 0 0 45px;
}
.news__itemTtl{
  margin-bottom: 10px;
  font-size: 20px ;
  letter-spacing: 0.02em;
  line-height: 1.56;
}
.news__itemDate{
  font-size: 18px;
  letter-spacing: 0.02em;
  color: #666666;
}



@media screen and (max-width: 1600px) {
  .news__item{
    padding: 30px;
  }
  .news__itemTtl{
    font-size: 16px;
  }
  .news__itemDate{
    font-size: 14px;
  }
}
@media screen and (max-width: 1280px) {

  .news__itemLink{
    align-items: start;
  }
  .news__itemWrap{
    padding-left: 20px;
  }
}

@media screen and (max-width: 750px) {
.news__wrap{
  padding-top:60px ;
  padding-bottom: 60px;
}
  .news__itemTtl{
    font-size: 14px;
  }
}
@media screen and (max-width: 480px) {
  .news__itemLink{
    display: block;
  }
  .news__itemImg{
    margin-bottom: 10px;
  }
  .news__itemWrap{
    padding-left: 0;
    width: 100%;
  }
  .news__item {
    padding: 30px 10px;
  }
  .news__item::after{
    top: auto;
    bottom: 15px;
  }
  .news__itemImg{
    width: 100%;
    padding-top: 62%;
  }
}






/*====================
single 共通
====================*/
.news__sngleHead{
  padding-bottom: 40px;
  border-bottom: 2px solid #000;
}
.news__sngleTtl{
  margin-bottom: 60px;
  font-size: 52px;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.73;
}
.news__sngleDate{
  font-size: 24px;
  letter-spacing: 0.02em;
  color: #666666;
}



@media screen and (max-width: 1600px) {
  .news__sngleTtl{
    margin-bottom: 30px;
    font-size: 37px;
  }
  .news__sngleDate{
    font-size: 18px;
  }
}
@media screen and (max-width: 750px) {
  .news__sngleHead{
    margin-bottom: 20px;
  }
   .news__sngleTtl{
    margin-bottom: 10px;
    font-size: 25px;
  }
  .news__sngleDate{
    font-size: 14px;
  }
}
@media screen and (max-width: 400px) {
  .news__sngleHead{
    padding-bottom: 30px;
  }
   .news__sngleTtl{
    font-size: 18px;
    line-height: 1.6;
  }
  .news__sngleDate{
    font-size: 12px;
  }
}