

body {
  font-family: "Yu Mincho", "YuMincho", "游明朝", serif;
  line-height: 1.6;
}

.setcontent {
    width: 1280px;
    margin: 0 auto;
    padding: 130px 0px;
}

.about h3,
.cometrue h3,
.flow h3,
.location h3 {
    font-size: 55px;
    text-align: center;
    letter-spacing: 10px;
}
h3 {
  margin-bottom: 50px;
  line-height: 1;
}



.fv {
  position: relative; /* 基準点 */
}



  .fv-wrap{
  position: relative;
  width: 100%;
}

.fv-bg{
  width: 100%;
  height: auto;
  display: block;
}

.fv-cta{
  display: block;
  width: 100%;
}

.fv-cta-link{
  position: absolute;
  /* 置きたい位置に合わせて調整 */
  left: 50%;
  bottom: 13%;
  transform: translateX(-115%);

  width: 31%;
  height: auto;

  display: block;
  z-index: 2;          /* 背面に回らないように */
}



.fv-text {
  position: absolute;
  z-index: 2; /* 黒より前に出す */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* 中央寄せ */
  color: #fff;
  text-align: center;
}

.fv-text h1 {
  font-size: 2.5rem;
  line-height: 1.3;
}

.fv-text p {
  margin-top: 16px;
  font-size: 1rem;
}

.fv::before {
  content: "";
  position: absolute;
  inset: 0; /* top right bottom left = 0 */

  z-index: 1;
}




/* about */

.flex {
    display: flex;
}

.about img {
    width: 30%;
}

.about .about-gallery {
    gap: 20px;
}

.about .flex {
  justify-content: center;
  gap: 100px;
}

.about p {
  line-height: 3;
}

.inner {
  overflow: hidden;
}



.cta img {
    width: 35%;
}
.cta {
    text-align: center;
    margin: 100px 0px;
}



/* 叶えること */
.cometrue h3 {
  color: #fff;
}
.cometrue .square {
    width: 360px;

    text-align: center;
    background-color: rgba(217, 217, 217, 0.8);
    font-size: 24px;
}
.cometrue .square p {
  border: 1px solid #1E1715;
  margin: 10px;
  padding: 30px;
}

.feature {
    display: flex;
    gap: 100px 100px;
    flex-wrap: wrap;
    justify-content: center;
}

.cometrue {
  position: relative;
  background-image: url("../img/cometrue.jpg");
  
  background-size: cover;       /* 全体にフィット */
  background-position: center;  /* 中央寄せ */
  background-repeat: no-repeat;
}
.cometrue::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5); /* ← 数値を上げるほど暗くなる */
  pointer-events: none;
}
.cometrue .setcontent {
  position: relative;
  z-index: 1;
}



/* flow */
.flow {
    background-color: #1E1715;
}
.flow p,
.flow li,
.flow h3 {
    color: #fff;
}
.flow .number {
    font-size: 24px;
    width: 30%;
}
.flow .process {
    font-size: 20px;
    width: 70%;
}
.flow .flex {
    margin-bottom: 20px;
    height: 60px;
}

.flow .center {
  width: 800px;
  margin: 0 auto;
}

.formin {
    width: 500px;
    font-size: 35px;
    margin: 50px auto;
    padding: 30px;
    background-color: brown;
    text-align: center;
}

.flow li {
  margin-bottom: 10px;
  text-indent: -1em;
}
.flow li::before {
  content: "・";
}
.flow a {
  text-decoration: none;
}




.footerback {
  background-color: black;
}
.footerlogo img {
    padding-top: 48px;
    width: 98px;
}
.whitebar {
    width: 250px;
    height: 1.5px;
    background: #fff;
    margin: 13px 0;
    color: #fff;
}
.footertext {
    font-size: 13px;
    line-height: 1;
    padding-bottom: 15px;
    color: #fff;
}



.fixed-img {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 350px;      /* 好きなサイズ */
  z-index: 1000;    /* 他要素より前に */
  box-shadow: 0 6px 20px rgba(0, 0, 0, 1);

  /* 非表示状態 */
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}

/* 表示用クラス */
.fixed-img.is-show {
  opacity: 1;
  pointer-events: auto;
}



@media screen and (max-width: 1279px) {
    .setcontent {
        width: 100%;
        margin: auto;
    }
}

@media (min-width: 728px) {
    .sp {
        display: none;
    }
}

@media (max-width: 728px) {
    .pc {
      display: none;
    }
    .fv-cta-link {
    bottom: 22%;
    transform: translateX(-50%);
    width: 80%;
    }
    .fixed-img {
      position: fixed;
      right: 10px;
      bottom: 10px;
      width: 180px; 
    }


    .setcontent {
      width: 95%;
      padding: 60px 0px;
    }

    .flex {
      display: block;
    }
    .about h3,
    .cometrue h3,
    .flow h3,
    .location h3 {
      font-size: 22px;
  }

  .about p {
    line-height: 2;
  }
  .about .inner .slider img,
  .about .flex img {
    width: 100%;
  }
  .about .inner,
  .gallerytitle {
    width: 95%;
    margin: 0 auto;
  }
  .about .inner li {
    margin: 10px;
  }
  .gallerytitle {
    text-align: center;
    font-size: 22px;
  }


  .cta {
    margin: 50px 0px;
  }
  .cta img {
    width: 95%;
  }


  /* 叶えること */
  .feature {
    display: flex;
    gap: 15px 15px;
  }
  .cometrue .square {
    width: 170px;
    font-size: 15px;
  }
  .cometrue .square p {
    padding: 20px 5px;
  }


  /* flow */
  .flow .flex {
    height: 100%;
  }
  .flow .number {
      font-size: 19px;
      width: 100%;
  }
  .flow .process {
      font-size: 15px;
      width: 100%;
  }

  .flow .center {
    width: 95%;
    margin: 0 auto;
  }
  .formin {
    width: 80%;
    font-size: 25px;
  }
  .flow li {
    font-size: 12px;    
  }
}


.listTab li.active a {
    border-bottom: 2px solid black;
}
.listTab li a {
  padding: 10px 0px;
}