html {
  font-size: 100%;
}

/* 等倍可変をする場合に必要 */
@media screen and (max-width: 767.98px) {
  html {
    font-size: 3.8647342995vw;
  }
}

:where(.wrap) img {
  width: 100%;
}

.wrap {
  /* overflow: hidden; */
}

/* ここにPCを時の背景 */
.wrap:before {
  content: "";
  background-image: url(../img/pc_bg.webp);
  background-size: cover;
  width: 100%;
  height: 100vh;
  position: fixed;
  z-index: -1;
}

.wrap__inner {
  list-style: none;
  display: flex;
  justify-content: flex-start;
  width: 83%;
  margin-inline: auto;
  min-height: 500px;
}

.pc-area-logo {
  position: fixed;
  top: 2.7%;
  left: 2.5%;
}

.pc-area-logo img {
  width: 145px;
  height: 56px;
  /* background-color: Yellow; */
}

.pc-area-left {
  margin-right: 2%;
  width: 400px;
  position: relative;
}

.pc-area-left__inner {
  position: sticky;
  top: 100px;
  transform: translateY(-50%);
}
.pc-area-left img {
  /* 画像は親要素の幅を超えない */
  /* かつビューポートの高さも超えない */
  /* 幅・高さは自動計算（比率維持） */
  /* デフォルトの表示サイズ */
  width: 100%;
  max-width: 400px;
  /* height: 540px; */
  /* 親要素の幅に基づく最大幅（これを超えない） */
  /* max-width: 100%; */
  /* ビューポートの高さに基づく最大高（これを超えない） */
  max-height: 90vh;
  height: 750px;
  /* アスペクト比を維持したまま、指定領域に収まるように調整 */
  /* 画像が歪むのを防ぎます */
  object-fit: contain;
  /* ブロック要素として扱い、中央揃えなどをしやすくする場合（任意） */
  display: block;
}
.pc-area-left__btn {
  position: absolute;
  bottom: 2.3125rem;
  left: 50%;
  transform: translateX(-50%);
  width: 20.25rem;
  height: 3.625rem;
}
.pc-area-left__btn img {
  width: 100%;
  height: 100%;
}
.content {
  /* background: linear-gradient(to bottom, red, orange); */
  /* margin-top: 2.8125rem; */
  background-color: #fff;
}

.content__inner {
  width: 34.375rem;
  /* height: 125rem; */
  margin-inline: auto;
  overflow: hidden;
  /* border-radius: 24.42px; */
  box-shadow: 0px 0px 17.094px 0px rgba(0, 0, 0, 0.25);
}

.content__inner > * {
  position: relative;
}

.pc-area-right {
  margin-left: 5.5%;
}
.pc-area-right__inner {
  display: block;
  position: sticky;
  top: 81.2vh;
  transform: translateY(-50%);
}

.pc-area-right img {
  width: 18rem;
  height: 14.75rem;
  max-width: 100%;
  max-height: 90vh;
  object-fit: contain;
  display: block;
}

.fv__inner {
  position: relative;
}

.fv__btn {
  position: absolute;
  bottom: 12rem;
  left: 50%;
  transform: translateX(-50%);
  width: min(96.8vw, 532px);
}

.sec__cta {
  position: relative;
}
.sec__btn {
  position: absolute;
  /* bottom: 5.0625rem; */
  bottom: 6rem;
  left: 50%;
  transform: translateX(-50%);
  width: 30rem;
}
#sec6 .sec__btn {
  width: 34rem;
  bottom: 3.5rem;
}
#sec13 .sec__btn {
  bottom: 6.5rem;
}
#sec13 .sec__btn.sec__btn--2 {
  bottom: 5rem;
}

.video-deco {
  position: relative;
  z-index: 2;
}
.sec__movie {
  position: relative;
  width: 100%;
}

.sec__movie video {
  position: absolute;
  bottom: 102rem;
  left: 50%;
  width: 471px;
  transform: translateX(-50%);
  z-index: 1;
}
#sec7 .sec__movie video {
  position: absolute;
  bottom: 10rem;
  left: 50%;
  width: 471px;
  transform: translateX(-50%);
  z-index: 1;
  border-radius: 10px;
}
.sec__deco {
  position: absolute;
  top: 0;
  z-index: 2;
}
.sec__tag {
  position: relative;
  background-image: url(../img/img-08.webp);
  background-position: top;
  background-size: cover;
}
.sec__tag #gt {
  /* position: absolute; */
  /* top: 20px;
  width: 100%;
  left: 50%;
  transform: translateX(-50%); */
}

/* #sec16 {
  background-color: #f9f8f6;
  font-family: "Noto Serif JP", serif;
}

#sec16 .sec__inner {
  padding: 0 1.5625rem 1.5625rem 1.625rem;
}
#sec16 .sec__cont {
  margin-top: 1.875rem;
} */

#faq .sec__inner {
  padding: 29px 23px 42px;
}
.faq__heading {
  font-size: 26px;
  color: #5cafb2;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.13em;
}
.faq__list {
  margin-top: 30px;
}
.faq__item {
  margin-bottom: 0.4rem;
  border-radius: 10px;
  border: 2px solid #d0edec;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.89);
}

.faq__item:last-child {
  margin-bottom: 0;
}

.faq__question-wrapper {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  padding: 17px 22px 20px 18px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

.faq__answer-wrapper {
  display: none;
  padding: 0 25px 24px 23px;
}

.faq__item.active .faq__answer-wrapper {
  display: flex;
  gap: 12px;
}

.faq__title {
  font-size: 28px;
  color: #5cafb2;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.05em;
  flex-shrink: 0;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}
.faq__title--a {
  font-size: 18px;
}

.faq__question {
  padding-top: 10px;
  font-size: 15px;
  color: #2d231a;
  line-height: 1.69;
  letter-spacing: 0.05em;
  font-weight: bold;
  flex: 1;
  margin: 0;
}

.faq__answer {
  font-size: 0.875rem;
  color: #303131;
  line-height: 1.7;
  letter-spacing: 0.05em;
  margin: 0;
  flex: 1;
}

.faq__toggle-icon {
  position: relative;
  flex-shrink: 0;
  width: 13px;
  height: 13px;
  cursor: pointer;
  margin-top: 15px;
}

.faq__toggle-icon::before,
.faq__toggle-icon::after {
  content: "";
  position: absolute;
  background-color: #5cafb2;
  transition: all 0.3s ease;
}

.faq__toggle-icon::before {
  top: 50%;
  left: 50%;
  width: 13px;
  height: 1px;
  transform: translate(-50%, -50%);
}

.faq__toggle-icon::after {
  top: 50%;
  left: 50%;
  width: 1px;
  height: 13px;
  transform: translate(-50%, -50%);
}

.faq__item.active .faq__toggle-icon::after {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(90deg);
}

#sec15 .sec__img {
  position: relative;
}
.sec__links {
  position: absolute;
  display: flex;
  padding: 0 25px;
  gap: 12.5px;
  bottom: 14%;
}

/* 商品情報セクション */
.product-info {
  background: #93c1bb;
  padding: 21px 16px 33px;
}

.product-info__heading {
  font-size: 28px;
  color: #fff;
  text-align: center;
  line-height: 1.4;
  letter-spacing: 0.13em;
  font-weight: 900;
}

.product-info__list {
  margin-top: 18px;
  background-color: #fff;
  border-radius: 20px;
  padding: 33px 32px 29px;
}
.product-info__item {
  margin-bottom: 10px;
}

.product-info__item:last-child {
  margin-bottom: 0;
}

.product-info__header {
  background: #5cafb2;
  border-radius: 3px;
  color: #fff;
  padding: 3px;
  text-align: center;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.14em;
}

.product-info__content {
  margin-top: 8px;
  background: #fff;
  font-size: 14px;
  line-height: 1.6;
}

.product-info__content p {
  text-align: center;
  color: #2d231a;
  font-size: 14px;
  font-weight: 400;
  line-height: 169%; /* 23.66px */
  letter-spacing: 0.05em;
}

.product-info__content p.product-name {
  font-size: 16px;
  letter-spacing: 0.05em;
}

.product-info__content p.product-name-sub {
  font-size: 8px;
  letter-spacing: 0.05em;
}

.ingredient-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.product-info__content p.ingredient-item {
  text-align: left;
  width: fit-content;
  margin: 8px auto 0;
}
.product-info__content p.text-left {
  text-align: left;
}

.precautions-list {
  margin: 0;
  padding-left: 0;
  list-style: none;
}

.precautions-list li {
  line-height: 1.69;
  color: #2d231a;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.05em;
}

.cta-fixed {
  display: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.5s;
  position: fixed;
  right: 3.5rem;
  bottom: 0;
  width: 100vw;
  max-width: 200px;
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

.fix {
  display: none;
}

@media screen and (max-width: 1060px) {
  .wrap__inner {
    justify-content: flex-end;
  }
  .cta-fixed.active {
    opacity: 1;
    pointer-events: auto;
    display: flex;
  }
  .cta-fixed img {
    height: auto;
    display: block;
  }

  .cta-fixed {
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
    max-width: 400px;
  }
}

@media screen and (max-width: 1508px) {
  .pc-area-left img {
    height: auto;
  }
  .pc-area-left__btn {
    position: absolute;
    bottom: 7%;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    height: auto;
  }
}

@media screen and (max-height: 600px) and (min-width: 1508px) {
  .pc-area-left__btn {
    width: 54vh;
    bottom: 6%;
  }
}

@media screen and (max-width: 1059.98px) {
  .pc-area-left,
  .pc-area-right {
    display: none;
  }
}

@media screen and (max-width: 767.98px) {
  .wrap {
    overflow: hidden;
  }
  .wrap::before {
    display: none;
  }

  .wrap__inner {
    width: 100%;
    display: block;
  }

  .pc-area-logo {
    display: none;
  }

  .pc-area-left {
  }

  .pc-area-left__inner {
  }

  .content {
    margin-top: 0;
  }

  .content__inner {
    width: 100%;
    border-radius: 0;
    background: #fff;
    overflow: initial;
    box-shadow: none;
  }

  .fv__btn {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 96vw;
    bottom: 9rem;
  }
  .sec__btn {
    bottom: 4.4rem;
    width: 22.5rem;
  }
  #sec6 .sec__btn {
    width: 25rem;
    bottom: 2.6rem;
  }
  #sec13 .sec__btn {
    bottom: 4.7rem;
  }
  #sec13 .sec__btn.sec__btn--2 {
    bottom: 4rem;
  }
  .pc-area-right {
  }

  .pc-area-right__inner {
  }
  .sec__movie video,
  #sec7 .sec__movie video {
    width: 22.4375rem;
    bottom: 77rem;
  }
  #sec7 .sec__movie video {
    bottom: 7rem;
  }
}

@media screen and (max-width: 1059px) {
  .fix {
    display: block;
    position: fixed;
    bottom: 0%;
    width: 99%;
    max-width: 552px;
    z-index: 9999;
    display: none;
  }

  .fix.active {
    display: block;
  }
}
@media screen and (max-width: 767.98px) {
  .fix {
    width: 99%;
    max-width: 100%;
  }
}
