@charset "utf-8";

/* 
=================================================================================

▼▼▼　テンプレJS用のCSS。不要なものは削除　▼▼▼

=================================================================================
*/
html {
font-family: "zen-maru-gothic", sans-serif;
  font-weight: 400;
  font-style: bold;
}
h1, h2, h3, h4, h5 {
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  /* PC用 */
  html {
    font-size: 10px;
  }
  .inner {
    position: relative;
    max-width: 100%;
    display: block;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  /* SP用 */
  html {
    font-size: calc(10vw / 768 * 100); /* 最大値768px、文字サイズ10pxの場合 */
  }
  .inner {
    width: 100%;
    padding: 0 5rem;
    max-width: 100%;
    margin: auto;
  }
}

@font-face {
  font-family: "DINPro";
  src: url("../fonts/dinpro_medium.otf") format("opentype");
  font-weight: 500;
  font-style: normal;
}
/* 
=================================================================================

▼▼▼　文字　▼▼▼

=================================================================================
*/
.go {
  font-family: "Noto Sans JP", sans-serif;
}
.pop {
  font-family: "Poppins", sans-serif;
}
.din{
  font-family: "DINPro", sans-serif;
}
.b {
  font-weight: bold;
}
.m {
  font-weight: 500;
}

.f_blue{
  color: #0085c6;
}

/* 
=================================================================================

▼▼▼　ちらつき対策（CSS）　▼▼▼

=================================================================================
*/

.loading {
  position: fixed;
  background: #fff;
  z-index: 9999;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 1s all;
  opacity: 1;
  pointer-events: all;
}

/* 
=================================================================================

▼▼▼　ハンバーガーメニュー　▼▼▼

=================================================================================
*/

.header{
  position: absolute;
  top: 0;
  right: 0;
  z-index: 100;
}
.header_inner{
  width: 100%;
  display: flex;
  align-items: start;
  justify-content: end;
  gap: 2.5vw;
  padding: 3.5vw;
}
.head_logo{
  width: 17.5vw;
}

/* メインコンテンツ */
.mv_box{
  width: 100%;
}
.mv_pc02{
  width: 46.67vw;
  position: absolute;
  right: calc(50% - 46.67vw);
  bottom: 7.5vw;
}
.mv_inner{
  position: absolute;
  width: 15.83vw;
  top: 22%;
  right: calc(50% - 10.5rem);
}
.mv_inner::before{
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(../img/mv_inner.webp);
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 2;
}
.mv_inner_item{
  padding: 2vw 1.5vw 2vw 1.5vw;
  position: relative;
  z-index: 1;
}
.gmenu_arrow{
  font-size: 2rem;
  color: #fff;
  border: solid #fff 0.1rem;
  border-radius: 0.5rem;
}
.gloval_ul{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.5rem;
  height: 100%;
}
.item01 a{
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.mv{
  position: relative;
  z-index: 1;
}
.contents_bg{
  position: relative;
  z-index: 3;
}
section{
  position: relative;
  overflow: hidden;
}
.contents_bg::before{
  content: "";
  width: 100%;
  height: 100%;
  background-image: url(../img/contents_bg1.webp);
  background-size: cover;
  background-repeat: no-repeat;
  position: absolute;
  top: -9vw;
  left: 0;
}
.section_inner{
  max-width: 90rem;
  margin: auto;
}
.section_title_box{
  text-align: center;
  position: relative;
  z-index: 2;
  margin-top: 3rem;
}
.section_title{
  font-size: 4rem;
}
.section_title_text{
  font-size: 3rem;
  margin-top: 2rem;
}
.contents_logo{
  width: 26rem;
  margin: auto;
}
.feature_box{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5rem;
  padding-top: 9rem;
  padding-bottom: 8rem;
  position: relative;
  z-index: 3;
}
.feature_box_bg{
  position: relative;
  z-index: 1;
}
.feature_box_bg::after{
  content: "";
  display: block;
  width: 100rem;
  height: 38rem;
  background-image: url(../img/contents_bg3.webp);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  z-index: 1;
  top: 15rem;
  left: calc(50% - 50rem);
}
.feature_box li{
  width: calc(33.33% - 2.5rem);
  text-align: center;
}
.feature_box li img{
  width: 18rem;
  margin-bottom: 4rem;
}
.about{
  position: relative;
  padding-top: 16rem;
}
.about .section_title{
  max-width: 53rem;
  margin: auto;
}
.img04{
  width: 19rem;
  position: absolute;
  top: 0;
  right: calc(50% - 45rem);
}
.about_item1{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8rem;
}
.about_item1 li{
  width: 100%;
  text-align: center;
}
.about_item1 li:first-child .about_item1_contents::after{
  content: "";
  display: block;
  width: 4rem;
  height: 4rem;
  background-image: url(../img/arrow01.webp);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 30%;
  transform: translate(50%);
  right: -4rem;
}
.about_item1_contents{
  height: 10rem;
  font-size: 2.8rem;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.5rem;
  border-radius: 2rem;
  position: relative;
}
.bg_gray{
  background-color: #828282;
}
.bg_pink{
  background-color: #fd9dbb;
}
.about_item2{
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 3rem;
}
.reech_img25{
  width: 25rem;
  margin-left: auto;
}
.about_item2_contents{
  width: 50%;
  position: relative;
}
.reech_img24{
  padding-left: 2rem;
}
.adopt_list {
  max-width: 100rem;
  margin: 4rem auto 0;
  background-color: #fff;
  border-radius: 3rem;
  padding: 3rem 5rem;
  text-align: center;
}
.adopt_list h3{
  font-size: 3rem;
}
.adopt_list ul{
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.adopt_list ul li{
  width: 100%;
}

.img_list{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}
.img08{
  width: 57rem;
  margin: auto;
}
.strength_text{
  text-align: center;
  margin-top: 4rem;
}
.strength{
  margin-top: 3rem;
  padding-bottom: 14rem;
  z-index: 1;
}
.strength::after{
  content: "";
  display: block;
  width: 130rem;
  height: 138rem;
  top: 12rem;
  left: calc(50% - 56rem);
  background-image: url(../img/contents_bg4.webp);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  z-index: -1;
}
.img09{
  width: 68rem;
  margin: auto;
}
.ls01{
  letter-spacing: -0.01rem;
}
.coment1{
  position: relative;
}
.coment1::before{
  content: "";
  display: block;
  width: 15rem;
  height: 6.4rem;
  background-image: url(../img/reech_img10_1.webp);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  right: calc(50% - 29rem);
}

.achieve{
  margin-top: 8rem;
}
.coment2{
  position: relative;
}
.coment2::before{
  content: "";
  display: block;
  width: 15rem;
  height: 6.4rem;
  background-image: url(../img/reech_img10_2.webp);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: calc(50% - 29rem);
}

.coment3{
  position: relative;
}
.coment3::before{
  content: "";
  display: block;
  width: 15rem;
  height: 6.4rem;
  background-image: url(../img/reech_img10_3.webp);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  right: calc(50% - 29rem);
}

.company_list{
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1rem;
  gap: 1rem;
}
.photo_list{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}
.img_slide li{
  padding: 0 0.5rem;
}

.contact{
  margin-top: 8rem;
  padding-bottom: 5rem;
  background-color: #fff4f6;
}
.contact_subtitle{
  font-size: 4rem;
  color: #0099e2;
  text-align: center;
  margin-top: 4rem;
}
.contact_price{
  font-size: 10rem;
  color: #fd9dbb;
  text-align: center;
}
.contact_price2{
  font-size: 6rem;
}
.contact_text span{
  font-size: 6rem;
}
.contact_box{
  background-color: #fd9dbb;
  padding: 8rem 0 14rem;
  text-align: center;
}
.contact_box h3{
  font-size: 5rem;
  color: #ffffff;
}
.contact_btn{
  font-size: 2.5rem;
  width: 40rem;
  padding: 1rem 0;
  margin: 4rem auto 0;
  background-color: #ffffff;
  border-radius: 3rem;
}
.contact_text{
  font-size: 3rem;
  text-align: center;
}
.img12{
  width: 44rem;
  margin: 0 auto 4rem;
}
.img13{
  width: 25rem;
  position: absolute;
  top: 69%;
  left: calc(50% - 55rem);
}
.img14{
    width: 25rem;
    position: absolute;
    top: 69%;
    right: calc(50% - 55rem);
}
.lh15{
  line-height: 1.5;
}

@media screen and (max-width: 768px){
  .wrapper{
    overflow: hidden;
  }
  :root {
  --hamburger-size: 8rem; /* ハンバーガーアイコンサイズ */
  --hamburger-line: 0.5; /* ハンバーガーアイコンの横線の長さ */
  }
  .mv_sp02{
    width: 37rem;
    position: absolute;
    bottom: 13rem;
    right: 2rem;
  }
  .gloval-nav{
    width: 28rem;
    height: 44rem;
  }
  .head_logo{
    width: 21rem;
  }
  .section_inner{
    max-width: 65rem;
  }
  section{
    overflow: visible;
  }
  .feature_box{
    flex-direction: column;
    padding-top: 5rem;
  }
  .feature .section_title_box{
    position: relative;
    top: -3rem;
  }
  .feature_box_bg::after{
    width: 100%;
    height: 100%;
    background-image: url(../img/contents_bg3_sp.webp);
    top: 15rem;
    left: calc(50% - 31.7rem);
  }
  .contents_bg::before{
    height: 99.3%;
    top: -12rem;
  }
  .feature_box li{
    width: 100%;
  }
  .feature_box li img{
    width: 25rem;
    margin-bottom: 2rem;
  }
  .section_title{
    font-size: 6rem;
  }
  .section_title_text{
    font-size: 3.4rem;
  }

  .about{
    padding-top: 20rem;
  }
  .about .section_title{
    font-size: 5rem;
    max-width: 100%;
  }
  .img04{
    width: 25rem;
    position: absolute;
    top: 10rem;
    right: calc(50% - 33rem);
    z-index: 1;
  }
  .sp_lh15{
    line-height: 1.5 !important;
  }
  .sp_lh2{
    line-height: 2 !important;
  }
  .img_list{
    margin: auto;
    flex-direction: column;
  }
  .about_item1{
    max-width: 49rem;
    margin: auto;
    flex-direction: column;
  }
  .about_item1 li:first-child .about_item1_contents:nth-of-type(1)::after{
    top: 240%;
    right: 17rem;
    transform: rotate(90deg);
  }
  .about_item1 li:first-child .about_item1_contents:nth-of-type(2)::after{
    top: 125%;
    right: 27rem;
    transform: rotate(90deg);
  }
  .sp_f_pink{
    color: #fd90ba;
  }
  .about_item2{
    flex-direction: column;
  }
  .about_item2_contents{
    width: 100%;
  }
  .about_item2_contents:nth-of-type(1){
    order: 2;
  }
  .about_item2_contents:nth-of-type(2){
    order: 1;
  }
  .reech_img24{
    width: 48rem;
    margin: auto;
    padding-left: 0;
  }
  .reech_img25{
    width: 28rem;
    position: absolute;
    top: 0;
    right: -10rem;
  }
  .adopt_list ul{
    flex-wrap: wrap;
    margin-top: 3rem;
  }
  .adopt_list{
    max-width: 65rem;
  }
  .adopt_list ul li{
    width: calc(99.99% / 3);
  }

  .strength{
    margin-top: 10rem;
  }
  .strength_text{
    font-size: 4.4rem;
  }
  .strength::after{
    width: 104%;
    height: 104%;
    top: 12rem;
    left: 0px;
    background-image: url(../img/contents_bg4_sp.webp);
  }
  .img08{
    margin-bottom: 5rem;
  }
  .company_list{
    max-width: 48rem;
    margin: 3rem auto 0;
    flex-wrap: wrap;
    margin-top: 3rem;
  }
  .company_list li{
    width: calc(50% - 0.5rem);
  }
  .photo_list{
    margin-top: 2rem;
  }
  .contact_price{
    text-align: start;
  }
  .contact_text{
    text-align: start;
  }
  .img14{
    width: 20rem;
    top: 76%;
    right: calc(50% - 37rem);
  }
}