@charset "UTF-8";
::-moz-selection {
  background-color: #EFE3BD;
  color: #000;
}
::selection {
  background-color: #EFE3BD;
  color: #000;
}

::-moz-selection {
  background-color: #EFE3BD;
  color: #000;
}

.hidden-sp {
  display: none;
}
@media screen and (min-width: 768px) {
  .hidden-sp {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media screen and (min-width: 768px) {
  .hidden-pc {
    display: none;
  }
}

.bg-overlay {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}

.logo {
  position: absolute;
  z-index: 50;
  top: 0.3%;
  left: 0;
}
@media screen and (min-width: 768px) {
  .logo {
    top: 0.4%;
    left: 0;
  }
}
.logo img {
  width: clamp(0px, 39.7435897436vw, 232.5px);
  height: clamp(0px, 14.6153846154vw, 85.5px);
}
@media screen and (min-width: 768px) {
  .logo img {
    width: clamp(0px, 15.6428571429vw, 329px);
    height: clamp(0px, 5.7142857143vw, 120px);
  }
}

.mv {
  position: relative;
  background-image: linear-gradient(36deg, rgb(0, 0, 0) 100%, rgb(71, 71, 71) 50%);
}
.mv::before {
  position: absolute;
  content: "";
  background-image: url(../img/mv-img.png);
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 50;
  width: clamp(0px, 66.1538461538vw, 387px);
  height: clamp(0px, 38.7179487179vw, 226.5px);
  bottom: clamp(0px, 180vh, 180px);
  left: 2%;
}
@media screen and (min-width: 768px) {
  .mv::before {
    width: clamp(0px, 31.7142857143vw, 666px);
    height: clamp(0px, 16.3571428571vw, 344px);
    bottom: 18%;
    left: 2%;
  }
}

.mv__inner {
  padding-bottom: clamp(0px, 19.7435897436vw, 77px);
}
@media screen and (min-width: 768px) {
  .mv__inner {
    padding-bottom: clamp(0px, 3.4285714286vw, 48px);
  }
}

.mv__swiper-body {
  width: 100%;
  height: auto;
}
.mv__swiper-body .swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
  width: 100%;
  height: auto;
}
.mv__swiper-body .swiper-slide {
  height: 64.1025641026vw;
}
@media screen and (min-width: 768px) {
  .mv__swiper-body .swiper-slide {
    height: 27.1428571429vw;
  }
}
.mv__swiper-body .swiper-slide img {
  width: 100%;
  height: 64.1025641026vw;
}
@media screen and (min-width: 768px) {
  .mv__swiper-body .swiper-slide img {
    width: 100%;
    height: 100%;
  }
}

.mv__text {
  color: #fff;
  font-size: clamp(0px, 7.1794871795vw, 28px);
  padding-left: clamp(0px, 4.1025641026vw, 35px);
  padding-top: clamp(0px, 19.7435897436vw, 77px);
  font-family: "Noto Serif JP", serif;
}
@media screen and (min-width: 768px) {
  .mv__text {
    padding-top: clamp(0px, 3.5714285714vw, 50px);
    padding-left: clamp(0px, 3.5714285714vw, 50px);
  }
}

.mv__link-box {
  position: fixed;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.3s, visibility 0.3s;
  transition: opacity 0.3s, visibility 0.3s;
  background-color: #6A5E40;
  border: 1px solid #D0B46C;
  bottom: 3%;
  right: 2%;
  z-index: 100;
  width: clamp(0px, 91.7948717949vw, 358px);
  height: clamp(0px, 23.8461538462vw, 93px);
}
@media screen and (min-width: 768px) {
  .mv__link-box {
    bottom: 2%;
    width: clamp(0px, 33.8571428571vw, 474px);
    height: clamp(0px, 8.8571428571vw, 124px);
  }
}
.mv__link-box.is-show {
  opacity: 1;
  visibility: visible;
}
.mv__link-box::before {
  content: "";
  position: absolute;
  background-image: url(../img/mv__link.png);
  background-repeat: no-repeat;
  background-size: contain;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 1%;
  width: clamp(0px, 11.5384615385vw, 45px);
  height: clamp(0px, 11.5384615385vw, 45px);
}
@media screen and (min-width: 768px) {
  .mv__link-box::before {
    width: clamp(0px, 4.2857142857vw, 60px);
    height: clamp(0px, 4.2857142857vw, 60px);
    top: 50%;
  }
}
.mv__link-box::before:hover {
  right: -2%;
}
.mv__link-box:hover {
  background-color: #403927;
}
.mv__link-box:hover::before {
  right: -2%;
}
.mv__link-box:hover .mv__link-img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.mv__link-img {
  position: absolute;
  top: 2%;
  left: 1%;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .mv__link-img {
    top: -6%;
    left: -5%;
  }
}
.mv__link-img img {
  width: clamp(0px, 38.4615384615vw, 150px);
  height: clamp(0px, 22.3076923077vw, 87px);
}
@media screen and (min-width: 768px) {
  .mv__link-img img {
    width: clamp(0px, 16.0714285714vw, 225px);
    height: clamp(0px, 9.3571428571vw, 131px);
  }
}

.mv__link-text {
  padding-top: clamp(0px, 4.1025641026vw, 16px);
  padding-left: clamp(0px, 41.0256410256vw, 160px);
  color: #fff;
}
@media screen and (min-width: 768px) {
  .mv__link-text {
    padding-top: clamp(0px, 1.5vw, 21px);
    padding-left: clamp(0px, 14.2857142857vw, 200px);
  }
}

.mv__link-text-1 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 3.8461538462vw, 15px);
  line-height: 1.7;
}
@media screen and (min-width: 768px) {
  .mv__link-text-1 {
    font-size: clamp(0px, 1.4285714286vw, 20px);
  }
}

.mv__link-text-2 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 5.8974358974vw, 23px);
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .mv__link-text-2 {
    font-size: clamp(0px, 2.2857142857vw, 32px);
  }
}

.parallax-section {
  background-image: url(../img/mv2-3.png);
  background-attachment: fixed;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .parallax-section {
    padding: 27%;
  }
}

/*スクロールするコンテンツ*/
.parallax__content {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 100%;
  padding: 5%;
  background-image: linear-gradient(205deg, rgba(42, 29, 31, 0.94), rgb(0, 0, 0) 8%, rgba(40, 38, 38, 0.87) 23%, rgb(39, 35, 35) 33%, rgb(0, 0, 0) 40%, rgb(71, 60, 60) 75%);
  background-image: linear-gradient(205deg, rgba(42, 29, 31, 0.94), rgb(0, 0, 0) 8%, rgba(40, 38, 38, 0.87) 23%, rgb(39, 35, 35) 33%, rgb(0, 0, 0) 45%, rgb(39, 32, 32) 62%);
}

.parallax__content-inner {
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .parallax__content-inner {
    max-width: 1040px;
  }
}

.parallax__content-title-en {
  font-family: "Playfair Display", serif;
  font-size: clamp(0px, 11.2820512821vw, 44px);
  text-align: center;
  font-weight: 400;
  color: #fff;
  padding-top: clamp(0px, 24.8717948718vw, 97px);
  letter-spacing: 0.06em;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .parallax__content-title-en {
    font-size: clamp(0px, 5.7142857143vw, 80px);
    padding-top: clamp(0px, 13.3571428571vw, 187px);
  }
}

.parallax__content-title-ja {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 7.1794871795vw, 28px);
  padding-top: clamp(0px, 9.7435897436vw, 38px);
  text-align: center;
  font-weight: 400;
  color: #fff;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .parallax__content-title-ja {
    font-size: clamp(0px, 3.5714285714vw, 50px);
    padding-top: clamp(0px, 5.1428571429vw, 72px);
  }
}

.parallax__content-text {
  font-family: "Noto Serif JP", serif;
  color: #fff;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  padding-top: clamp(0px, 11.2820512821vw, 44px);
  padding-bottom: clamp(0px, 27.4358974359vw, 107px);
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .parallax__content-text {
    padding-top: clamp(0px, 5.7142857143vw, 80px);
    padding-bottom: clamp(0px, 15.3571428571vw, 215px);
    text-align: center;
    line-height: 2.5;
  }
}

.message {
  background-image: linear-gradient(165deg, rgb(255, 255, 255) 26%, rgb(232, 232, 232) 40%, rgb(255, 255, 255) 60% 90%);
}

.message__inner {
  padding-bottom: clamp(377px, 52.9vw + 222.1px, 580px);
  position: relative;
}
@media screen and (min-width: 768px) {
  .message__inner {
    padding-bottom: clamp(0px, 17.5714285714vw, 246px);
  }
}
.message__inner--type2 {
  padding-bottom: clamp(0px, 25.1282051282vw, 98px);
}

.message-top {
  margin: 0 auto;
  padding-top: clamp(0px, 20.2564102564vw, 79px);
  padding-bottom: clamp(0px, 26.4102564103vw, 103px);
  padding-left: clamp(0px, 4.1025641026vw, 16px);
  padding-right: clamp(0px, 4.1025641026vw, 16px);
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .message-top {
    width: clamp(0px, 74.2857142857vw, 1040px);
    padding-top: clamp(0px, 9.0714285714vw, 127px);
    max-width: 1040px;
  }
}

.message-top__title {
  font-family: "Noto Serif JP", serif;
  line-height: 1.5;
  font-size: clamp(0px, 6.1538461538vw, 26px);
}
@media screen and (min-width: 768px) {
  .message-top__title {
    font-size: clamp(0px, 3.5714285714vw, 50px);
    font-weight: 400;
  }
}

.typewriter {
  border-right: 2px solid rgb(71, 71, 71);
  white-space: nowrap;
  overflow: hidden;
  display: inline-block;
  -webkit-animation: blinkCursor 0.8s steps(1) infinite;
          animation: blinkCursor 0.8s steps(1) infinite;
}

@-webkit-keyframes blinkCursor {
  0% {
    border-color: transparent;
  }
  50% {
    border-color: rgb(71, 71, 71);
  }
  100% {
    border-color: transparent;
  }
}

@keyframes blinkCursor {
  0% {
    border-color: transparent;
  }
  50% {
    border-color: rgb(71, 71, 71);
  }
  100% {
    border-color: transparent;
  }
}
.message-top__text {
  padding-top: clamp(0px, 7.9487179487vw, 31px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 768px) {
  .message-top__text {
    padding-top: clamp(0px, 6.2142857143vw, 87px);
    width: clamp(0px, 74.2857142857vw, 1040px);
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: clamp(0px, 6.0714285714vw, 100px);
  }
}
.message-top__text .text-1 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  font-weight: 300;
  line-height: 2.3;
}
@media screen and (min-width: 768px) {
  .message-top__text .text-1 {
    width: 50%;
  }
}
.message-top__text .fadeIn_left {
  opacity: 0;
  -webkit-transform: translateX(-40px);
          transform: translateX(-40px);
  -webkit-transition: 3.5s;
  transition: 3.5s;
}
@media screen and (min-width: 768px) {
  .message-top__text .fadeIn_left {
    -webkit-transform: translate(-20%, 0);
            transform: translate(-20%, 0);
  }
}
.message-top__text .fadeIn_left.is-show {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  opacity: 1;
}
.message-top__text .fadeIn_right {
  opacity: 0;
  -webkit-transform: translateX(40px);
          transform: translateX(40px);
  -webkit-transition: 3.5s;
  transition: 3.5s;
}
@media screen and (min-width: 768px) {
  .message-top__text .fadeIn_right {
    -webkit-transform: translate(20%, 0);
            transform: translate(20%, 0);
  }
}
.message-top__text .fadeIn_right.is-show {
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  opacity: 1;
}
.message-top__text .text-2 {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  font-weight: 300;
  line-height: 2.3;
}
@media screen and (min-width: 768px) {
  .message-top__text .text-2 {
    width: 50%;
  }
}

.message-top__title-2 {
  text-align: center;
}

.message-image {
  width: 100%;
  height: auto;
  text-align: center;
}
.message-image img {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 768px) {
  .message-image img {
    width: clamp(0px, 96.4285714286vw, 1350px);
    height: clamp(0px, 44.1428571429vw, 618px);
  }
}

.present__card {
  width: clamp(0px, 91.7948717949vw, 459px);
  height: clamp(0px, 123.5897435897vw, 618px);
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 40px;
  background-image: url(../img/card-bg.png);
  z-index: 40;
}
@media screen and (min-width: 768px) {
  .present__card {
    width: clamp(0px, 74.2857142857vw, 1040px);
    height: clamp(0px, 33.0714285714vw, 463px);
    bottom: 5%;
  }
}

.card__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: clamp(0px, 5.1282051282vw, 25.6px);
}
@media screen and (min-width: 768px) {
  .card__inner {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

.card__content {
  text-align: center;
  padding-top: clamp(0px, 7.1794871795vw, 35.9px);
  padding-bottom: clamp(0px, 7.6923076923vw, 38.5px);
  padding-left: clamp(0px, 4.1025641026vw, 20.5px);
  padding-right: clamp(0px, 4.1025641026vw, 20.5px);
}
@media screen and (min-width: 768px) {
  .card__content {
    width: 50%;
    text-align: left;
    padding-right: clamp(0px, 0.3571428571vw, 5px);
    padding-top: clamp(0px, 4.9285714286vw, 69px);
    padding-left: clamp(0px, 5.3571428571vw, 75px);
    padding-bottom: clamp(0px, 7.3571428571vw, 103px);
  }
}

.card__title-en {
  color: #c6c6c6;
  font-family: "Playfair Display", serif;
  font-size: clamp(0px, 4.1025641026vw, 16px);
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .card__title-en {
    font-size: clamp(0px, 2.2857142857vw, 32px);
  }
}

.card__title-ja {
  font-family: "Noto Serif JP", serif;
  color: #292e33;
  font-size: clamp(0px, 6.1538461538vw, 24px);
  padding-top: clamp(0px, 2.0512820513vw, 10.3px);
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .card__title-ja {
    padding-top: clamp(0px, 1.6428571429vw, 23px);
    font-size: clamp(0px, 2.2857142857vw, 32px);
  }
}

.card__text {
  text-align: left;
  font-family: "Noto Serif JP", serif;
  color: #292e33;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  padding-top: clamp(0px, 46.1538461538vw, 230.8px);
  line-height: 2.2;
}
@media screen and (min-width: 768px) {
  .card__text {
    padding-top: clamp(0px, 1.6428571429vw, 23px);
    font-size: clamp(0px, 1vw, 14px);
  }
}

.card__image {
  width: clamp(0px, 71.0256410256vw, 328px);
  height: clamp(0px, 34.8717948718vw, 161px);
  position: absolute;
  bottom: clamp(0px, 51.2820512821vw, 280px);
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  margin: auto;
}
@media screen and (min-width: 768px) {
  .card__image {
    width: clamp(0px, 35.7142857143vw, 500px);
    height: clamp(0px, 20.7142857143vw, 290px);
    height: auto;
    bottom: 20%;
    left: 72%;
  }
}
.card__image img {
  width: clamp(0px, 71.0256410256vw, 320px);
  height: clamp(0px, 34.8717948718vw, 157px);
}
@media screen and (min-width: 768px) {
  .card__image img {
    width: clamp(0px, 35.7142857143vw, 500px);
    height: clamp(0px, 20.7142857143vw, 290px);
  }
}
.card__image:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.works__inner {
  padding-top: clamp(0px, 23.5897435897vw, 117.9px);
  padding-bottom: clamp(0px, 10.2564102564vw, 51.3px);
}
@media screen and (min-width: 768px) {
  .works__inner {
    padding-top: clamp(0px, 10.9285714286vw, 153px);
  }
}

.works__title {
  text-align: center;
  font-family: "Playfair Display", serif;
  font-size: clamp(0px, 11.2820512821vw, 44px);
  padding-bottom: clamp(0px, 10.2564102564vw, 40px);
  font-weight: 400;
  letter-spacing: 0.07em;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .works__title {
    font-size: clamp(0px, 5.7142857143vw, 80px);
  }
}

@media screen and (min-width: 768px) {
  .works__swiper-1 {
    width: clamp(0px, 94.0714285714vw, 1449px);
  }
}
@media screen and (min-width: 768px) and (min-width: 1920px) {
  .works__swiper-1 {
    margin: 0 auto;
  }
}

.works__swiper-body {
  position: relative;
}
@media screen and (min-width: 768px) {
  .works__swiper-body {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    width: clamp(0px, 94.0714285714vw, 1449px);
  }
}
@media screen and (min-width: 768px) {
  .works__swiper-body::before {
    content: "";
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    width: clamp(0px, 3.7857142857vw, 53px);
    height: clamp(0px, 2.8571428571vw, 40px);
    top: 2%;
    right: 11%;
  }
}
@media (min-width: 1100px) {
  .works__swiper-body::before {
    right: 14%;
  }
}
.works__swiper-body.icon-01::before {
  background-image: url(../img/01.png);
}
.works__swiper-body.icon-02::before {
  background-image: url(../img/02.png);
}
.works__swiper-body.icon-03::before {
  background-image: url(../img/03.png);
}
.works__swiper-body.icon-04::before {
  background-image: url(../img/04.png);
}
.works__swiper-body.icon-05::before {
  background-image: url(../img/05.png);
}

.works__swiper {
  width: 100vw;
}
@media screen and (min-width: 768px) {
  .works__swiper {
    width: clamp(0px, 74.2857142857vw, 1144px);
    height: clamp(0px, 50vw, 770px);
  }
}

.works__swiper-wrapper {
  padding-bottom: 5px;
}

.swiper-slide {
  overflow: hidden;
  height: 100%;
}
.swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  -o-object-position: center bottom;
     object-position: center bottom;
}

/* サムネイルのスタイル */
.thumbnail {
  width: 100vw;
  height: 33.5897435897vw;
  padding-bottom: 5px;
}
@media screen and (min-width: 768px) {
  .thumbnail {
    width: clamp(0px, 18.9285714286vw, 292px);
    height: clamp(0px, 28.7142857143vw, 442px);
  }
}

.thumbnail .swiper-slide {
  opacity: 0.5;
  overflow: hidden;
}
.thumbnail .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* サムネイルのアクティブスタイル */
.thumbnail .swiper-slide-thumb-active {
  opacity: 1;
}

.works__box {
  width: clamp(0px, 25.3846153846vw, 99px);
  height: clamp(0px, 9.2307692308vw, 36px);
  position: absolute;
  bottom: -0.5%;
  right: 0;
}
@media screen and (min-width: 768px) {
  .works__box {
    width: clamp(0px, 25.3846153846vw, 99px);
    height: clamp(0px, 9.2307692308vw, 36px);
  }
}

/* ページネーション */
.works__swiper-pagination {
  color: #fff;
  width: clamp(0px, 25.3846153846vw, 99px);
  height: clamp(0px, 9.2307692308vw, 36px);
  padding-top: clamp(0px, 1.2820512821vw, 5px);
  background-color: #000000;
}
.works__swiper-pagination .swiper-pagination-current {
  font-family: "Noto Serif JP", serif;
}
.works__swiper-pagination .swiper-pagination-total {
  font-family: "Noto Serif JP", serif;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev,
.swiper-button-next {
  padding-top: clamp(0px, 2.5641025641vw, 10px);
  width: clamp(0px, 1.0256410256vw, 4px);
  height: clamp(0px, 2.3076923077vw, 9px);
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: clamp(0px, 1.0256410256vw, 4px);
  height: clamp(0px, 2.3076923077vw, 9px);
  margin: auto 0;
}
@media screen and (min-width: 768px) {
  .swiper-button-prev::after,
  .swiper-button-next::after {
    width: clamp(8px, 0.5714285714vw, 8px);
    height: clamp(17px, 1.2142857143vw, 17px);
  }
}

/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
  position: absolute;
  background-image: url(../img/prev.png);
  width: 20px;
  top: 110%;
  left: 170%;
}
@media screen and (min-width: 768px) {
  .swiper-button-prev::after {
    top: 50%;
    left: 121%;
  }
}

/* 次への矢印カスタマイズ */
.swiper-button-next::after {
  position: absolute;
  background-image: url(../img/next.png);
  width: 10px;
  top: 110%;
  right: 100%;
}
@media screen and (min-width: 768px) {
  .swiper-button-next::after {
    width: 20px;
    top: 50%;
    right: -153%;
  }
}

/* 画像サイズ調整 */
.swiper-slide img {
  width: 100%;
  height: auto;
}

/* 現在のスライド番号 */
/* スライド総数 */
.works__content {
  padding-top: clamp(0px, 4.8717948718vw, 24.36px);
  padding-left: clamp(0px, 4.1025641026vw, 20.51px);
  padding-right: clamp(0px, 4.1025641026vw, 20.51px);
  padding-bottom: clamp(0px, 20.5128205128vw, 102.56px);
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .works__content {
    width: clamp(0px, 74.2857142857vw, 1040px);
    max-width: 1040px;
  }
}

.works__content-title {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 6.1538461538vw, 24px);
  color: #fff;
}
@media screen and (min-width: 768px) {
  .works__content-title {
    font-size: clamp(0px, 2vw, 28px);
  }
}

.works__content-text {
  font-family: "Noto Serif JP", serif;
  color: #fff;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  padding-top: clamp(0px, 6.1538461538vw, 24px);
  line-height: 2;
  font-weight: 300;
}
@media screen and (min-width: 768px) {
  .works__content-text {
    max-width: 800px;
  }
}

.cta {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.5))), url(../img/cta.png);
  background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url(../img/cta.png);
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 768px) {
  .cta {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(0, 0, 0, 0.5)), to(rgba(0, 0, 0, 0.5))), url(../img/cta-pc.png);
    background: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url(../img/cta-pc.png);
    background-repeat: no-repeat;
    background-size: cover;
  }
}

.cta__content {
  text-align: center;
  padding: 63px 32px;
}
@media screen and (min-width: 768px) {
  .cta__content {
    padding: 170px 0;
  }
}

.cta__title {
  font-family: "Playfair Display", serif;
  font-size: 44px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .cta__title {
    font-size: 80px;
  }
}

.cta__text {
  font-family: "Noto Serif JP", serif;
  font-size: 14px;
  line-height: 1.5;
  padding-top: 16px;
  font-weight: 300;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .cta__text {
    padding-top: 38px;
  }
}

.cta__button {
  margin-top: clamp(0px, 6.1538461538vw, 24px);
  padding-top: clamp(0px, 5.3846153846vw, 21px);
  padding-right: clamp(0px, 23.0769230769vw, 111px);
  padding-bottom: clamp(0px, 5.1282051282vw, 20px);
  padding-left: clamp(0px, 6.1538461538vw, 24px);
  background-color: #6A5E40;
  display: inline-block;
  position: relative;
}
@media screen and (min-width: 768px) {
  .cta__button {
    margin-top: clamp(0px, 3.2142857143vw, 45px);
    padding-top: clamp(0px, 2.1428571429vw, 30px);
    padding-right: clamp(0px, 12.7857142857vw, 179px);
    padding-bottom: clamp(0px, 2.1428571429vw, 30px);
    padding-left: clamp(0px, 2.2857142857vw, 32px);
  }
}
.cta__button a {
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 4.1025641026vw, 16px);
  color: #fff;
}
@media screen and (min-width: 768px) {
  .cta__button a {
    font-size: clamp(0px, 1.4285714286vw, 20px);
  }
}
.cta__button::before {
  content: "";
  position: absolute;
  background-image: url(../img/cta-link.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: 27px;
  height: 17px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 9%;
}
.cta__button:hover {
  background-color: #403927;
}
.cta__button:hover::before {
  right: 7%;
}

.message__swiper-body {
  /* ページネーション */
  /* 前へ次への矢印カスタマイズ */
  /* 前へ次への矢印カスタマイズ */
  /* 前への矢印カスタマイズ */
  /* 次への矢印カスタマイズ */
}
@media screen and (min-width: 768px) {
  .message__swiper-body {
    padding-left: 12.8571428571vw;
  }
}
@media screen and (min-width: 2500px) {
  .message__swiper-body {
    padding-left: 0;
    margin: 0 auto;
    width: 2476px;
  }
}
.message__swiper-body .message-box {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 91.7948717949vw;
  height: 4.6153846154vw;
  margin-top: 10px;
}
@media screen and (min-width: 768px) {
  .message__swiper-body .message-box {
    margin-top: clamp(0px, 0.7142857143vw, 10px);
    width: clamp(0px, 70.3571428571vw, 985px);
    height: clamp(0px, 2.2857142857vw, 32px);
  }
}
.message__swiper-body .swiper-pagination {
  height: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 12px;
  bottom: 0 !important;
  padding-bottom: 5px;
}
.message__swiper-body .swiper-pagination .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  margin-left: 0 !important;
  margin-right: 0 !important;
  background: transparent; /* ←中身透明 */
  border: 2px solid #8E8E8E; /* ←枠線を付ける */
  border-radius: 50%;
  opacity: 1;
}
.message__swiper-body .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #212121;
  border: 0;
}
@media screen and (min-width: 2500px) {
  .message__swiper-body .swiper-pagination {
    display: none;
  }
}
.message__swiper-body .swiper-button-prev,
.message__swiper-body .swiper-button-next {
  color: transparent !important; /* デフォルト矢印の色を透明に */
  font-size: 0 !important;
}
.message__swiper-body .swiper-button-prev::after,
.message__swiper-body .swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: 12.5641025641vw;
  height: 5.3846153846vw;
  margin: auto 0;
}
@media screen and (min-width: 768px) {
  .message__swiper-body .swiper-button-prev::after,
  .message__swiper-body .swiper-button-next::after {
    width: clamp(0px, 5.5714285714vw, 78px);
    height: clamp(0px, 2.2857142857vw, 32px);
  }
}
.message__swiper-body .swiper-button-prev::after {
  background-image: url(../img/message__swiper-prev.png);
  padding-left: 40px;
}
@media screen and (min-width: 768px) {
  .message__swiper-body .swiper-button-prev::after {
    top: 100%;
    padding-left: clamp(0px, 5.5714285714vw, 78px);
  }
}
.message__swiper-body .swiper-button-next::after {
  background-image: url(../img/message__swiper-next.png);
  padding-right: 40px;
}
@media screen and (min-width: 768px) {
  .message__swiper-body .swiper-button-next::after {
    top: 100%;
    padding-right: clamp(0px, 5.5714285714vw, 78px);
  }
}

.message__swiper-box {
  text-align: center;
}
.message__swiper-box .img-1 img {
  width: 61.5384615385vw;
  height: 16.1538461538vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .message__swiper-box .img-1 img {
    width: clamp(0px, 22.1428571429vw, 310px);
    height: auto;
  }
}
.message__swiper-box .img-2 img {
  width: 91.5384615385vw;
  height: 95.3846153846vw;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .message__swiper-box .img-2 img {
    width: clamp(0px, 32.8571428571vw, 460px);
    height: auto;
  }
}

.message-button {
  padding-top: 11.0256410256vw;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .message-button {
    padding-top: clamp(0px, 6.4285714286vw, 90px);
  }
}

.contact__inner {
  padding-top: clamp(0px, 14.6153846154vw, 57px);
}
@media screen and (min-width: 768px) {
  .contact__inner {
    padding-top: clamp(0px, 9.4285714286vw, 132px);
  }
}

.contact__box {
  padding-bottom: 25.641025641vw;
}
@media screen and (min-width: 768px) {
  .contact__box {
    padding-bottom: 175px;
  }
}

.contact__title {
  text-align: center;
}

.contact__title-en {
  font-family: "Playfair Display", serif;
  font-size: clamp(0px, 11.2820512821vw, 44px);
  color: #fff;
  line-height: 1;
  letter-spacing: 0.08em;
}
@media screen and (min-width: 768px) {
  .contact__title-en {
    font-size: clamp(0px, 5.7142857143vw, 80px);
  }
}

.contact__title-ja {
  padding-top: clamp(0px, 1.7948717949vw, 7px);
  font-family: "Noto Serif JP", serif;
  font-size: clamp(0px, 3.5897435897vw, 14px);
  color: #fff;
  letter-spacing: 0.08em;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .contact__title-ja {
    font-size: clamp(0px, 1.4285714286vw, 20px);
    padding-top: clamp(0px, 1.7857142857vw, 25px);
  }
}

.contactform {
  padding-top: clamp(0px, 6.1428571429vw, 86px);
  width: 100%;
  max-width: 500px;
  padding-left: 16px;
  padding-right: 16px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .contactform {
    padding-bottom: 0;
    padding-top: clamp(0px, 6.1428571429vw, 86px);
    width: clamp(621px, 61.4285714286vw, 860px);
    max-width: 860px;
  }
}
.contactform p {
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  line-height: 1.5;
}
.contactform p span {
  font-size: 10px;
  line-height: 1;
  padding-top: 3px;
  padding-bottom: 3px;
}
.contactform .cf7__note {
  font-family: "Noto Serif JP", serif;
  font-size: 12px;
  padding-left: 10px;
}

/* ============================
   全体
============================ */
fieldset.hidden-fields-container {
  border: none;
  padding: 0;
  margin: 0;
}

.cf7 {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  color: #fff;
  font-family: inherit;
}

/* ============================
   行（ラベル + 入力欄）
============================ */
.cf7__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 6px;
  margin-bottom: 24px;
}

/* PCレイアウト（横並び） */
@media screen and (min-width: 768px) {
  .cf7__row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
/* ============================
   ラベル部分（dt）
============================ */
.cf7__row dt {
  padding-left: 10px;
  font-size: 16px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6px;
}
@media screen and (min-width: 768px) {
  .cf7__row dt {
    padding-left: 0;
    width: clamp(170px, 16.9285714286vw, 237px);
  }
}

/* 必須ラベル */
.cf7__required {
  background-color: #90001C;
  color: #fff;
  font-size: 12px;
  padding: 1px 6px;
  border-radius: 3px;
}

/* ============================
   入力欄（dd）
============================ */
.cf7__row dd input,
.cf7__row dd textarea,
.cf7__row dd select {
  width: 97%;
  height: clamp(0px, 17.9487179487vw, 70px);
  padding: clamp(0px, 5.641025641vw, 22px) clamp(0px, 4.1025641026vw, 16px) clamp(0px, 6.4102564103vw, 25px) clamp(0px, 4.1025641026vw, 16px);
  color: #000;
  background-color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 16px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  .cf7__row dd input,
  .cf7__row dd textarea,
  .cf7__row dd select {
    width: 100%;
    padding: clamp(0px, 1.5714285714vw, 22px) clamp(0px, 2.5vw, 35px) clamp(0px, 1.7857142857vw, 25px) clamp(0px, 2.5vw, 35px);
  }
}

/* メッセージ欄 */
.cf7__row textarea {
  height: 160px;
}

.cf7-dd {
  width: 100%;
}

.cf7-dd-2 {
  width: 46%;
}
@media screen and (min-width: 768px) {
  .cf7-dd-2 {
    width: 30%;
  }
}

/* ============================
   年・月 横並び
============================ */
.cf7__row--horizontal {
  width: 100%;
  gap: 12px;
}
.cf7__row--horizontal p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}

.cf7__row--horizontal input {
  text-align: center;
}

.wpcf7-form-control-wrap {
  width: 33%;
  padding-left: 10px;
  padding-right: 10px;
}
@media screen and (min-width: 768px) {
  .wpcf7-form-control-wrap {
    width: 25%;
  }
}

/* ============================
   送信ボタン
============================ */
.cf7__button {
  height: 67px;
  width: clamp(200px, 91.7948717949vw, 358px);
  display: block;
  margin: 0 auto;
  margin-top: clamp(0px, 12.8205128205vw, 50px);
}
@media screen and (min-width: 768px) {
  .cf7__button {
    margin-top: clamp(80px, 5.7142857143vw, 80px);
    width: clamp(380px, 27.1428571429vw, 450px);
  }
}
.cf7__button input[type=submit] {
  width: clamp(200px, 91.7948717949vw, 358px);
  background-color: #6a5e40;
  color: #fff;
  padding: clamp(0px, 5.1282051282vw, 20px);
  text-align: center;
  font-size: 18px;
  border: none;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .cf7__button input[type=submit] {
    padding: clamp(0px, 2.1428571429vw, 30px);
    width: clamp(380px, 27.1428571429vw, 450px);
  }
}

.cf7__button input[type=submit]:hover {
  background-color: #514934;
}

/* input */
input::-webkit-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
input::-moz-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
input:-ms-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
input::-ms-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
input::placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}

/* textarea */
textarea::-webkit-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
textarea::-moz-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
textarea:-ms-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
textarea::-ms-input-placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}
textarea::placeholder {
  color: #C3C3C3;
  opacity: 1;
  font-size: 16px;
  font-weight: 300;
}

.screen-reader-response {
  display: none;
}

.wpcf7-response-output {
  color: #D0B46C;
  text-align: center;
}

.wpcf7-not-valid-tip {
  color: #D0B46C;
}

.fade-in-up {
  opacity: 0;
  -webkit-transform: translateY(24px);
          transform: translateY(24px);
  -webkit-transition: opacity 3s, -webkit-transform 3s;
  transition: opacity 3s, -webkit-transform 3s;
  transition: opacity 3s, transform 3s;
  transition: opacity 3s, transform 3s, -webkit-transform 3s;
}
.fade-in-up.is-in-view {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.contact-text {
  font-family: "Noto Serif JP", serif;
  font-size: 12px;
  text-align: center;
  color: #fff;
  padding-top: 24px;
}
@media screen and (min-width: 768px) {
  .contact-text {
    padding-top: clamp(0px, 2.8571428571vw, 50px);
    font-size: 14px;
  }
}

.footer {
  background: #3E3A39;
}
@media screen and (min-width: 768px) {
  .footer {
    width: 100%;
    background: #3E3A39;
    color: #FFF;
  }
}

.footer__inner {
  padding: 0 5%;
  max-width: 500px;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .footer__inner {
    padding: 0;
    width: clamp(0px, 71.4285714286vw, 1000px);
    height: clamp(0px, 26vw, 364px);
    max-width: 1000px;
    margin: 0 auto;
    position: relative;
  }
}

.footer__img {
  text-align: center;
  padding-top: 10%;
}
@media screen and (min-width: 768px) {
  .footer__img {
    float: left;
    padding: clamp(0px, 4.2857142857vw, 60px) clamp(0px, 6.4285714286vw, 90px) 0 0;
  }
}
.footer__img img {
  width: 140px;
  height: auto;
}
@media screen and (min-width: 768px) {
  .footer__img img {
    width: clamp(0px, 15.7142857143vw, 220px);
  }
}

.footer__address {
  color: #fff;
  padding: 60px 90px 0 0;
}
@media screen and (min-width: 768px) {
  .footer__address {
    float: left;
    padding: clamp(0px, 4.2857142857vw, 60px) clamp(0px, 6.4285714286vw, 90px) 0 0;
  }
}
.footer__address .name {
  font-size: 14px;
  border-bottom: #FFF solid 1px;
  padding-bottom: 10px;
  line-height: 1.8em;
}
@media screen and (min-width: 768px) {
  .footer__address .name {
    font-size: clamp(0px, 1.1428571429vw, 16px);
    padding-bottom: clamp(0px, 0.7142857143vw, 10px);
    line-height: 180%;
  }
}
.footer__address .tel {
  margin: 10px 0 0;
  line-height: 1.8em;
}
@media screen and (min-width: 768px) {
  .footer__address .tel {
    margin: clamp(0px, 0.7142857143vw, 10px) 0 0;
    line-height: 1.5;
  }
}
.footer__address .tel a {
  color: #FFF;
  text-decoration: none;
  font-weight: bold;
  font-size: 16px;
}
@media screen and (min-width: 768px) {
  .footer__address .tel a {
    color: #FFF;
    text-decoration: none;
    font-weight: bold;
    font-size: clamp(0px, 1.7142857143vw, 24px);
  }
}

.footer__content {
  margin-top: 10%;
}
@media screen and (min-width: 768px) {
  .footer__content {
    width: clamp(0px, 44.2857142857vw, 620px);
    position: absolute;
    top: 31%;
    left: 0;
  }
}

.footer-title {
  color: #fff;
  font-size: 14px;
  margin: 0 0 5px;
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  .footer-title {
    font-size: clamp(0px, 1vw, 14px);
    margin: 0 0 clamp(0px, 0.3571428571vw, 5px);
  }
}

.footer__text {
  color: #fff;
  font-size: 12px;
  line-height: 1.8em;
  font-weight: 300;
}
@media screen and (min-width: 768px) {
  .footer__text {
    font-size: clamp(0px, 0.8571428571vw, 12px);
    line-height: 180%;
  }
}

.footLink {
  padding: 10% 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  .footLink {
    width: 31%;
    position: absolute;
    top: 0;
    right: 0;
    float: right;
    padding: clamp(0px, 4.2857142857vw, 60px) 0;
    gap: clamp(0px, 5vw, 70px);
  }
}
.footLink ul {
  width: 50%;
  margin-right: 8%;
}
@media screen and (min-width: 768px) {
  .footLink ul {
    margin-right: 0;
    vertical-align: top;
  }
}
.footLink li {
  margin: 0 0 5%;
  font-size: 12px;
}
@media screen and (min-width: 768px) {
  .footLink li {
    margin: 0 0 clamp(0px, 1.4285714286vw, 20px);
    font-size: clamp(0px, 1vw, 14px);
  }
}
.footLink li a {
  color: #fff;
  font-weight: 300;
}
@media screen and (min-width: 768px) {
  .footLink li a {
    text-decoration: none;
  }
}

.footer__copy {
  color: #FFF;
  background: #242424;
  text-align: center;
  font-size: 12px;
  padding: 5% 0;
  font-weight: 300;
}
@media screen and (min-width: 768px) {
  .footer__copy {
    background: #242424;
    text-align: center;
    font-size: 12px;
    padding: 24px 0;
  }
}

.thanks__logo {
  text-align: center;
  background-color: #000000;
  height: clamp(0px, 16vw, 80px);
  padding-top: clamp(0px, 1.0714285714vw, 15px);
  padding-bottom: clamp(0px, 1.0714285714vw, 15px);
}
@media screen and (min-width: 768px) {
  .thanks__logo {
    height: clamp(0px, 6.1428571429vw, 86px);
    padding-top: clamp(0px, 1.0714285714vw, 15px);
    padding-bottom: clamp(0px, 1.0714285714vw, 15px);
  }
}
.thanks__logo img {
  width: clamp(0px, 28vw, 140px);
  height: clamp(0px, 10vw, 50px);
}
@media screen and (min-width: 768px) {
  .thanks__logo img {
    width: clamp(0px, 11vw, 154px);
    height: clamp(0px, 4vw, 56px);
  }
}

.thanks__inner {
  padding-bottom: clamp(0px, 3.5714285714vw, 50px);
}

.thanks__title-en {
  text-align: center;
  font-weight: 400;
  padding-top: clamp(0px, 10vw, 50px);
  font-size: clamp(0px, 3vw, 15px);
}
@media screen and (min-width: 768px) {
  .thanks__title-en {
    padding-top: clamp(0px, 4.2857142857vw, 60px);
    font-size: clamp(0px, 1.2857142857vw, 18px);
  }
}

.thanks__ja {
  text-align: center;
  font-weight: 500;
  padding-top: clamp(0px, 4vw, 30px);
  font-size: clamp(0px, 4vw, 20px);
}
@media screen and (min-width: 768px) {
  .thanks__ja {
    padding-top: clamp(0px, 2.1428571429vw, 30px);
    font-size: clamp(0px, 2.2857142857vw, 32px);
  }
}

.thanks__text {
  margin: 0 auto;
  line-height: 2;
  font-weight: 400;
  padding-top: clamp(0px, 10vw, 50px);
  padding-bottom: clamp(0px, 8vw, 40px);
  font-size: clamp(0px, 2vw, 10px);
  width: clamp(0px, 60vw, 400px);
}
@media screen and (min-width: 768px) {
  .thanks__text {
    padding-top: clamp(0px, 4.3571428571vw, 61px);
    padding-bottom: clamp(0px, 3.5714285714vw, 50px);
    width: clamp(0px, 35.7142857143vw, 500px);
    font-size: clamp(0px, 0.8571428571vw, 12px);
  }
}

.thanks__button {
  width: clamp(0px, 20vw, 100px);
}
@media screen and (min-width: 768px) {
  .thanks__button {
    width: clamp(0px, 8.5714285714vw, 120px);
  }
}

.thanks__button-text {
  font-size: clamp(0px, 2.4vw, 12px);
  width: clamp(0px, 20vw, 100px);
  line-height: 2;
  border-bottom: 1px solid #000000;
  margin: 0 auto;
  position: relative;
}
@media screen and (min-width: 768px) {
  .thanks__button-text {
    font-size: clamp(0px, 1vw, 14px);
    width: clamp(0px, 8.5714285714vw, 120px);
  }
}
.thanks__button-text::before {
  content: "";
  position: absolute;
  background-image: url(../img/thanks.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: clamp(0px, 1.2vw, 6px);
  height: clamp(0px, 1.2vw, 6px);
  top: 40%;
  right: -5%;
}
@media screen and (min-width: 768px) {
  .thanks__button-text::before {
    width: clamp(0px, 0.6428571429vw, 9px);
    height: clamp(0px, 0.6428571429vw, 9px);
    top: 40%;
    right: -5%;
  }
}

/*-------------------- 追記 --------------------*/
body {
  position: relative;
}

#webgl-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: -1;
}

/*-------------------- 追記ここまで --------------------*/