@charset "UTF-8";
/**************************************/
/* -------------------------
 * トップ共通
 * ------------------------- */
/* 商品情報 */
.product-info {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.product-info__brand-name-img {
  width: 22%;
}

.product-info__product-name-img {
  width: 100%;
  margin-block: 2.3rem 2rem;
}

.product-info__product-name-txt {
  font-size: var(--f12);
  color: #fff;
}

/* -------------------------
 * パララックス
 * ------------------------- */
.parallax-area {
  position: relative;
  aspect-ratio: 1680/920;
  width: 100%;
  overflow: hidden;
  z-index: 10;
}

.js-parallax {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  display: block;
}

/* 01 */
.section-bg01 {
  position: relative;
  z-index: 10;
}

.section-bg01__img {
  width: 100%;
  height: 100%;
}

/* 注釈 */
.note-txt {
  color: rgba(255, 255, 255, 0.5);
  font-size: var(--f10);
  text-align: right;
  margin-left: auto;
  line-height: 1.6;
  font-weight: 100;
}
@media (max-width: 834px) {
  .note-txt {
    text-align: left;
  }
}

/* 見出し */
@media (max-width: 834px) {
  .sec__ttl {
    font-size: 2.4rem !important;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
  }
}

@media (max-width: 834px) {
  .sec__sub-ttl {
    font-size: 1.8rem !important;
  }
}

/* -------------------------
 * MV
 * ------------------------- */
.mv {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.mv__bg {
  position: relative;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mv__ttl-wrap {
  position: absolute;
  z-index: 3;
  top: 18%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 834px) {
  .mv__ttl-wrap {
    top: 8%;
    left: 50%;
    transform: translate(-50%, 0);
  }
}

.mv__ttl {
  width: 19.5vw;
}
@media (max-width: 1024px) {
  .mv__ttl {
    width: 25vw;
  }
}
@media (max-width: 834px) {
  .mv__ttl {
    width: 230px;
  }
}
.mv__txt {
  color: #fff;
  font-size: var(--f21);
  text-align: center;
  letter-spacing: 0.06em;
  white-space: nowrap;
  margin-top: 2.7rem;
}

.mv__point {
  position: absolute;
  z-index: 3;
  top: 47%;
  left: 31%;
  transform: translate(-50%, -50%);
  width: 11%;
}
@media (max-width: 1024px) {
  .mv__point {
    left: 27%;
    width: 15%;
  }
}
@media (max-width: 834px) {
  .mv__point {
    top: 62%;
    left: unset;
    right: 3%;
    width: 22%;
  }
}
@media (max-width: 499px) {
  .mv__point {
    top: 57%;
    left: unset;
    right: -2%;
    width: 26%;
  }
}

.mv__mess {
  position: absolute;
  z-index: 3;
  top: 58%;
  right: 24%;
  transform: translate(-50%, -50%);
  writing-mode: vertical-rl;
  letter-spacing: 0.1em;
}
@media (max-width: 1024px) {
  .mv__mess {
    top: 50%;
    right: 24%;
  }
}
@media (max-width: 834px) {
  .mv__mess {
    top: 65%;
    right: unset;
    left: 25%;
    width: 15%;
  }
}

.kome {
  font-size: var(--f12);
}

.mv__mess-kome {
  top: unset;
  writing-mode: horizontal-tb;
  font-size: var(--f12);
  margin-top: 10px;
}

.mv__detail {
  position: absolute;
  z-index: 3;
  bottom: 40px;
  right: 30px;
  font-size: var(--f12);
  color: #222;
  opacity: 0.5;
}
@media (max-width: 499px) {
  .mv__detail {
    bottom: 20px;
    right: 20px;
  }
}

/* -------------------------
 * message
 * ------------------------- */
.message {
  position: relative;
  background: linear-gradient(to top, rgba(32, 43, 59, 0.5) 30%, rgba(32, 43, 59, 0) 100%);
  padding-block: 13rem 13rem;
}
@media (max-width: 499px) {
  .message {
    padding-block: 7rem 11rem;
  }
}

.message__lead {
  text-align: center;
  padding-right: 10%;
  transform: translate(0, 50%);
}
@media (max-width: 834px) {
  .message__lead {
    transform: translate(0, 30%);
  }
}

.message__mess {
  font-size: var(--f40);
  text-align: center;
}

.message__mess-kome {
  top: -0.9em;
}

.message__txt {
  color: #fff;
  font-size: var(--f16);
  text-align: center;
  letter-spacing: 0.06em;
  margin-top: 2.7rem;
}
@media (max-width: 834px) {
  .message__txt {
    text-align: start;
  }
}

.message__detail {
  position: absolute;
  z-index: 3;
  bottom: 40px;
  right: 30px;
  font-size: var(--f12);
  color: #fff;
  opacity: 0.5;
}
@media (max-width: 499px) {
  .message__detail {
    bottom: 20px;
    right: 20px;
  }
}

/* -------------------------
 * point
 * ------------------------- */
.point {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  background: url(../img/point_bg.webp) no-repeat center/cover;
}
@media (max-width: 1024px) {
  .point {
    grid-template-columns: repeat(1, 1fr);
    background: unset;
  }
}

.point__l {
  padding: 5vw 0 5vw 15.7%;
}
@media (max-width: 1024px) {
  .point__l {
    order: 2;
    padding: 5vw 0 5vw 0;
    background: url(../img/point_bg.webp) no-repeat center left/175%;
  }
}
@media (max-width: 600px) {
  .point__l {
    padding: 30px 0 45px 0;
    background: url(../img/point_bg.webp) no-repeat center left 16%/251%;
  }
}
@media (max-width: 399px) {
  .point__l {
    background: url(../img/point_bg.webp) no-repeat center left 17%/280%;
  }
}

@media (max-width: 1024px) {
  .point__r {
    order: 1;
    height: 100vw;
  }
}

@media (max-width: 1024px) {
  .point__r-img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

@media (max-width: 1556px) {
  .point__mess01 {
    font-size: 2.2rem;
  }
}

.point__img {
  width: 13.4%;
  margin: 20px auto 25px;
}
@media (max-width: 1024px) {
  .point__img {
    width: 10%;
    margin: 20px auto 25px;
  }
}
@media (max-width: 499px) {
  .point__img {
    width: 13.4%;
    margin: 20px auto 25px;
  }
}

.point__ttl {
  width: 31.1%;
  margin: 0 auto;
}
@media (max-width: 499px) {
  .point__ttl {
    width: 50%;
  }
}

.point__bottom {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.5647058824);
  border-radius: 10px;
  padding: 45px 20px 45px 25%;
  margin: 4vw 4vw auto auto;
}
@media (max-width: 1200px) {
  .point__bottom {
    padding: 30px 20px 30px 25%;
  }
}
@media (max-width: 1024px) {
  .point__bottom {
    padding: 20px 15px 20px 20%;
    margin: 50px 4vw auto 15vw;
  }
}
@media (max-width: 499px) {
  .point__bottom {
    padding: 20px 15px 20px 8%;
    margin: 45px 7vw auto 7vw;
  }
}

.point__circle {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-30%, -30%);
  width: 35%;
}
@media (max-width: 1024px) {
  .point__circle {
    transform: translate(-40%, -50%);
  }
}
@media (max-width: 499px) {
  .point__circle {
    left: unset;
    right: 0;
    transform: translate(17%, -69%);
  }
}

.point__txt {
  text-align: start;
}
@media (max-width: ) {
  .point__txt {
    font-size: 1.3rem;
  }
}

@media (max-width: ) {
  .point__txt02 {
    font-size: 1.6rem;
  }
}

/* -------------------------
 * tech
 * ------------------------- */
.tech_mecha {
  position: relative;
  overflow: hidden;
  padding-bottom: 13rem;
}
@media (max-width: 1024px) {
  .tech_mecha {
    padding-bottom: 10rem;
  }
}
@media (max-width: 499px) {
  .tech_mecha {
    padding-bottom: 5rem;
  }
}

.tech_mecha::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -2;
  background-color: #4c565f;
}

.tech_mecha_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: -1;
}

.tech {
  width: 100%;
  aspect-ratio: 1680/1350;
  padding-top: 10%;
}
@media (max-width: 1024px) {
  .tech {
    padding-top: 8%;
  }
}
@media (max-width: 834px) {
  .tech {
    padding-top: 9%;
    aspect-ratio: 1680/2330;
  }
}
@media (max-width: 639px) {
  .tech {
    aspect-ratio: 1680/2500;
  }
}
@media (max-width: 600px) {
  .tech {
    aspect-ratio: 1680/2600;
  }
}
@media (max-width: 499px) {
  .tech {
    padding-top: 6%;
    aspect-ratio: 1680/2800;
  }
}
@media (max-width: 450px) {
  .tech {
    aspect-ratio: 1680/3000;
  }
}
@media (max-width: 399px) {
  .tech {
    aspect-ratio: 1680/3150;
  }
}

.tech__txt {
  margin-top: 20px;
}
@media (max-width: 834px) {
  .tech__txt {
    margin-top: 70vw;
  }
}

.tech__list {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 6rem;
  margin-top: 120px;
  margin-left: 57%;
}
@media (max-width: 1399px) {
  .tech__list {
    gap: 4rem;
    margin-top: 8vw;
    margin-left: 57%;
  }
}
@media (max-width: 1024px) {
  .tech__list {
    gap: 3rem;
    margin-top: 5vw;
    margin-left: 57%;
  }
}
@media (max-width: 834px) {
  .tech__list {
    width: -moz-fit-content;
    width: fit-content;
    margin: 30px auto 0;
  }
}

.tech__item {
  position: relative;
  width: 320px;
  height: 70px;
  line-height: 70px;
  text-align: center;
  background-color: rgba(120, 138, 185, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.5647058824);
  box-shadow: 0 0 10px 0px rgba(255, 255, 255, 0.5647058824), inset 0 0 10px 0 rgba(255, 255, 255, 0.5647058824);
}
@media (max-width: 1399px) {
  .tech__item {
    width: 260px;
    height: 50px;
    line-height: 47px;
  }
}
@media (max-width: 1024px) {
  .tech__item {
    width: 220px;
    height: 40px;
    line-height: 37px;
  }
}

.tech__item::after {
  content: "×";
  position: absolute;
  top: -100%;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 4rem;
  font-weight: 100;
  font-family: "Noto Sans JP", sans-serif;
  opacity: 0.5;
}
@media (max-width: 1399px) {
  .tech__item::after {
    font-size: 2.2rem;
    top: -95%;
  }
}
@media (max-width: 1024px) {
  .tech__item::after {
    font-size: 1.6rem;
    top: -90%;
  }
}

.tech__item:first-of-type::after {
  display: none;
}

.mecha {
  width: 90%;
  max-width: 1300px;
  padding: 8rem 5% 7rem;
  margin: 0 auto;
  background: url(../img/mecha_bg.webp) no-repeat center/cover;
}
@media (max-width: 834px) {
  .mecha {
    padding: 4.5rem 5% 4.5rem;
  }
}
@media (max-width: 499px) {
  .mecha {
    padding: 3.5rem 5% 2.5rem;
  }
}

.mecha__mess {
  line-height: 1.4;
  margin-top: 3rem;
  margin-bottom: 2.5rem;
  text-align: center;
}
@media (max-width: 834px) {
  .mecha__mess {
    margin-top: 2.5rem;
    margin-bottom: 2rem;
    text-align: start;
  }
}

.mecha__txt {
  text-align: center;
}
@media (max-width: 834px) {
  .mecha__txt {
    text-align: start;
  }
}

.mecha__img-sp02 {
  margin-top: 2.5rem;
}

.mecha__box-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px 3%;
  margin-top: 6rem;
}
@media (max-width: 600px) {
  .mecha__box-list {
    grid-template-columns: repeat(1, 1fr);
    gap: 20px 3%;
    margin-top: 5rem;
  }
}

.mecha__box {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 30px 7%;
  border-radius: 10px;
  background: url(../img/mecha_box_bg.webp) no-repeat center/cover;
}

.mecha__box-ttl,
.mecha__bottom-ttl {
  width: -moz-fit-content;
  width: fit-content;
  height: 38px;
  line-height: 38px;
  text-align: center;
  background-color: rgba(120, 138, 185, 0.8);
  border: 1px solid rgba(255, 255, 255, 0.5647058824);
  padding: 0 13px;
  margin: 0 auto;
  box-shadow: 0 0 6px 0px rgba(255, 255, 255, 0.5647058824), inset 0 0 6px 0 rgba(255, 255, 255, 0.5647058824);
}

.mecha__box-mess {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}
@media (max-width: 834px) {
  .mecha__box-mess {
    font-size: 2.3rem;
  }
}

.mecha__box-mess__kome {
  top: -1.5em;
  margin-left: 0.5em;
}
@media (max-width: 1024px) {
  .mecha__box-mess__kome {
    top: -0.5em;
  }
}

.mecha__box-cont {
  display: flex;
  align-items: center;
  gap: 6%;
}

.mecha__box-txt {
  width: calc(100% - 132px);
}
@media (max-width: 834px) {
  .mecha__box-txt {
    width: calc(100% - 100px);
  }
}

.mecha__box-img__area {
  width: 132px;
}
@media (max-width: 834px) {
  .mecha__box-img__area {
    width: 100px;
  }
}

.mecha__box-img__txt,
.mecha__bottom-img__txt {
  margin-top: 1rem;
  text-align: center;
  opacity: 0.5;
}

.mecha__box-list__detail {
  text-align: end;
  opacity: 0.5;
  margin-top: 20px;
}
@media (max-width: 834px) {
  .mecha__box-list__detail {
    margin-top: 10px;
  }
}

.mecha__bottom {
  position: relative;
  background-color: rgba(0, 0, 0, 0.3764705882);
  padding: 55px 8%;
  margin-top: 30px;
}
@media (max-width: 834px) {
  .mecha__bottom {
    padding: 50px 8% 40px;
    margin-top: 20px;
  }
}

.mecha__bottom::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 45px;
  height: 45px;
  background: url(../img/plus.svg) no-repeat center/contain;
}

.mecha__bottom-cont {
  display: flex;
  align-items: center;
  gap: 5%;
  margin-top: 20px;
}
@media (max-width: 600px) {
  .mecha__bottom-cont {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: 20px 5%;
    margin-top: 20px;
  }
}

.mecha__bottom-img__area {
  width: 240px;
}
@media (max-width: 834px) {
  .mecha__bottom-img__area {
    width: 180px;
  }
}

.mecha__bottom-main {
  width: calc(100% - 240px);
}
@media (max-width: 834px) {
  .mecha__bottom-main {
    width: calc(100% - 180px);
  }
}
@media (max-width: 600px) {
  .mecha__bottom-main {
    width: 100%;
  }
}

@media (max-width: 600px) {
  .mecha__bottom-mess {
    font-size: 1.9rem;
    text-align: center;
  }
}

.mecha__bottom-txt {
  margin-top: 15px;
}

/* -------------------------
 * aging
 * ------------------------- */
.aging {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  background: url(../img/aging_bg.webp) no-repeat center/cover;
}
@media (max-width: 1024px) {
  .aging {
    grid-template-columns: repeat(1, 1fr);
    background: unset;
  }
}

.aging__r {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-left: 16%;
}
@media (max-width: 1024px) {
  .aging__r {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }
}
@media (max-width: 499px) {
  .aging__r {
    padding-top: 45px;
    padding-bottom: 50px;
    padding-left: 5vw;
  }
}

@media (max-width: 1024px) {
  .aging__l {
    order: 1;
    height: 100vw;
  }
}

@media (max-width: 1024px) {
  .aging__l-img {
    height: 100%;
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

@media (max-width: 834px) {
  .aging__lead {
    font-size: 1.5rem;
  }
}

.aging__mess {
  margin: 30px 0 40px;
}
@media (max-width: 834px) {
  .aging__mess {
    font-size: 2.2rem;
    margin: 20px 0 30px;
  }
}
@media (max-width: 499px) {
  .aging__mess {
    margin: 15px 0 25px;
  }
}

@media (max-width: 834px) {
  .aging__txt {
    font-size: 1.4rem;
  }
}

.aging__list {
  display: flex;
  align-items: center;
  gap: 20px 4%;
  margin-top: 50px;
}
@media (max-width: 499px) {
  .aging__list {
    margin-top: 30px;
  }
}

.aging__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 130px;
  aspect-ratio: 1/1;
  background: url(../img/aging_circle.webp) no-repeat center/contain;
}
@media (max-width: 1240px) {
  .aging__item {
    width: 120px;
  }
}
@media (max-width: 499px) {
  .aging__item {
    width: 100px;
  }
}

/* -------------------------
 * gel
 * ------------------------- */
.gel {
  padding: 8vw 0;
  background: url(../img/gel_bg.webp) no-repeat center/cover;
}
@media (max-width: 834px) {
  .gel {
    padding: 50px 0;
  }
}

.gel__head {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 1024px) {
  .gel__head {
    grid-template-columns: repeat(1, 1fr);
  }
}

.gel__head-l {
  position: relative;
  display: flex;
  align-items: center;
  padding-left: 110px;
}
@media (max-width: 1024px) {
  .gel__head-l {
    order: 2;
    padding-top: 50px;
  }
}
@media (max-width: 499px) {
  .gel__head-l {
    padding-top: 110px;
    padding-left: 0px;
  }
}

.gel__head-l-img {
  position: relative;
  z-index: 2;
  width: 27.8%;
}

.gel__head-l-ttl {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-15%, 0);
  width: 203px;
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
  background: url(../img/gel_circle.webp) no-repeat center/contain;
  mix-blend-mode: screen;
}
@media (max-width: 1024px) {
  .gel__head-l-ttl {
    top: 50px;
    transform: translate(-5%, 0);
    width: 160px;
  }
}
@media (max-width: 499px) {
  .gel__head-l-ttl {
    top: 30px;
    transform: translate(0%, 0);
    width: 130px;
  }
}

.gel__head-l-main {
  position: relative;
  z-index: 2;
  width: 320px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.gel__head-l-txt {
  text-align: center;
  border: 1px solid rgba(255, 255, 255, 0.5647058824);
  border-radius: 10px;
  padding: 10px 15px;
}
@media (max-width: 370px) {
  .gel__head-l-txt {
    font-size: 1.5rem;
  }
}

.gel__head-l-point {
  width: 80%;
}

@media (max-width: 1024px) {
  .gel__head-r {
    order: 1;
  }
}

.gel__head-r-lead {
  width: 25%;
  margin: 0 auto;
}

.gel__head-r-ttl {
  width: 50%;
  margin: 20px auto 0;
}

.gel__head-r-mess {
  text-align: center;
  margin: 35px auto 25px;
}
@media (max-width: 834px) {
  .gel__head-r-mess {
    font-size: 2.2rem;
  }
}

.gel__head-r-txt02 {
  margin-top: 1.5rem;
}

.gel__bottom {
  display: flex;
  align-items: center;
  background: url(../img/gel_bottom.webp) no-repeat center/cover;
  padding: 20px 6% 25px 7%;
  border-radius: 10px;
  margin-top: 50px;
}
@media (max-width: 834px) {
  .gel__bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 30px 5% 20px 5%;
    margin-top: 35px;
  }
}

.gel__bottom-main {
  width: 65%;
  padding-right: 7%;
}
@media (max-width: 834px) {
  .gel__bottom-main {
    width: 100%;
    padding-right: 0%;
  }
}

.gel__bottom-img {
  width: 35%;
}
@media (max-width: 834px) {
  .gel__bottom-img {
    width: 100%;
    max-width: 400px;
  }
}

.gel__bottom-txt {
  margin: 20px 0;
}

.gel__bottom-detail {
  opacity: 0.5;
}

.gel__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 400px;
  max-width: 90%;
  height: 100px;
  border-radius: 50px;
  background-color: #918151;
  margin: 50px auto 0;
  transition: all 0.3s ease-in-out;
}
@media (max-width: 834px) {
  .gel__link {
    margin: 35px auto 0;
  }
}
.gel__link:hover {
  opacity: 0.8;
}

/* -------------------------
 * use
 * ------------------------- */
.use {
  padding: 13rem 0;
}
@media (max-width: 600px) {
  .use {
    padding: 8rem 0;
  }
}

.use-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 600px) {
  .use-inner {
    flex-direction: column;
    gap: 40px;
  }
}

.use-ttl {
  display: flex;
  flex-direction: column;
  width: 40%;
  gap: 1rem;
}
@media (max-width: 600px) {
  .use-ttl {
    width: 70%;
    max-width: 350px;
    align-items: center;
  }
}

.use-txt {
  width: 40%;
  white-space: nowrap;
  text-align: center;
}

/* -------------------------
 * product
 * ------------------------- */
.product {
  position: relative;
  z-index: 10;
}
.product .product-info {
  max-width: 44rem;
  margin-inline: auto;
}
.product .product-info__product-name-img {
  margin-block: 1.4rem 3.1rem;
}
@media (max-width: 499px) {
  .product .product-info__product-name-img {
    margin-bottom: 1.5rem;
  }
}

.product__flex {
  display: flex;
  background: #3f485a;
}
@media (max-width: 1240px) {
  .product__flex {
    flex-direction: column-reverse;
  }
}

.product__content-side {
  position: relative;
  background: #3f485a;
  padding: 15rem 5% 15rem;
  width: 50%;
  height: -moz-fit-content;
  height: fit-content;
}
@media (max-width: 1240px) {
  .product__content-side {
    width: 100%;
  }
}
@media (max-width: 834px) {
  .product__content-side {
    padding: 5rem 5%;
  }
}

.product__img-side {
  position: sticky;
  top: 0;
  left: 0;
  width: 50%;
  height: 100vh;
}
@media (max-width: 1240px) {
  .product__img-side {
    position: static;
    width: 100%;
    aspect-ratio: 5/4;
    height: auto;
    overflow: hidden;
  }
}
.product__img-side img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 1240px) {
  .product__img-side img {
    -o-object-position: center center;
       object-position: center center;
  }
}

.product__main-item {
  padding-bottom: 9rem;
  border-bottom: 1px solid #6f7582;
}
@media (max-width: 499px) {
  .product__main-item {
    padding-bottom: 5rem;
  }
}

.product__content-img {
  margin-block: 3rem;
}
@media (max-width: 834px) {
  .product__content-img {
    margin-block: 3rem 2rem;
  }
}

.product__detail {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-bottom: 2.9rem;
  border-bottom: 1px dotted #6f7582;
  margin-bottom: 3rem;
}
@media (max-width: 499px) {
  .product__detail {
    padding-bottom: 2rem;
    margin-bottom: 1.5rem;
  }
}

.product__description {
  mix-blend-mode: difference;
  font-size: 21px;
  line-height: 1.43;
  color: #fff;
  font-size: var(--f21);
}
@media (max-width: 499px) {
  .product__description {
    font-size: 1.5rem;
  }
}

.product__price-wrap {
  display: flex;
  align-items: flex-end;
  color: #fff;
}

.product__price {
  font-size: var(--f24);
  line-height: 1.2;
}

.product__price-unit {
  font-size: var(--f12);
}
@media (max-width: 499px) {
  .product__price-unit {
    line-height: 1.4;
  }
}

.product__txt {
  color: #fff;
}

.product__sub-item {
  margin-top: 8rem;
  display: grid;
  grid-template-columns: 270fr 290fr;
  gap: 0rem 5%;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 834px) {
  .product__sub-item {
    margin-top: 6rem;
    display: flex;
    flex-direction: column;
  }
}
.product__sub-item .product-info {
  align-items: flex-start;
}
@media (max-width: 1240px) {
  .product__sub-item .product-info {
    max-width: 360px;
    align-items: center;
  }
}
@media (max-width: 834px) {
  .product__sub-item .product-info {
    order: 1;
    width: 100%;
  }
}
.product__sub-item .product-info__brand-name-img {
  width: 44%;
}
.product__sub-item .product-info__product-name-img {
  margin-block: 0.9rem 1.5rem;
  width: 93%;
}
.product__sub-item .product__detail {
  flex-direction: column;
  align-items: flex-start;
  padding-bottom: 2rem;
  margin-bottom: 2rem;
}
@media (max-width: 834px) {
  .product__sub-item .product__detail {
    order: 3;
    width: 100%;
    flex-direction: row;
    align-items: flex-end;
  }
}
.product__sub-item .product__description {
  margin-block: 2rem;
  line-height: 1.75;
}
@media (max-width: 834px) {
  .product__sub-item .product__description {
    margin-block: 0rem;
  }
}
.product__sub-item .product__description sup {
  font-size: 0.5em;
  position: relative;
  top: -0.8em;
}
.product__sub-item .product__txt {
  font-size: var(--f14);
  margin-bottom: 3rem;
}
@media (max-width: 834px) {
  .product__sub-item .product__txt {
    order: 4;
  }
}
.product__sub-item .product__txt sup {
  font-size: 0.5em;
  position: relative;
  top: -0.8em;
}
@media (max-width: 834px) {
  .product__sub-item .product__sub-img {
    order: 2;
    margin-block: 3rem 2rem;
  }
}
@media (max-width: 834px) {
  .product__sub-item .product__note-txt {
    order: 5;
  }
}

@media (max-width: 834px) {
  .product__sub-content {
    display: contents;
  }
}

/* -------------------------
 * Q&A よくある質問
 * ------------------------- */
.faq {
  position: relative;
  z-index: 10;
  background-color: #202b3b;
  padding-block: 12rem 10.7rem;
}

.faq__ttl-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  margin-bottom: 6rem;
}
@media (max-width: 834px) {
  .faq__ttl-wrap {
    margin-bottom: 4rem;
  }
}

.faq__sub-ttl {
  font-size: var(--f50);
  line-height: 1.3;
}

.faq__ttl {
  font-size: var(--f14);
}

/* -------------------------
 *  Q&A アコーディオン
 * ------------------------- */
.accordion {
  color: #202b3b;
}

.accordion__item {
  display: grid;
  grid-template-rows: min-content 0fr;
  transition: grid-template-rows 300ms ease;
  cursor: pointer;
  overflow: hidden;
  border-radius: 4px;
}
.accordion__item.accordion-open {
  grid-template-rows: min-content 1fr;
}
.accordion__item.accordion-open .open-close-btn::before {
  content: "";
  transition: all 0.3s 0s ease;
  transform: translate(50%, -50%) rotate(-90deg);
}
.accordion__item.accordion-open .accordion__detail {
  border-top: 1px solid #c0c0c0;
}

.accordion__item .accordion__detail {
  overflow: hidden;
}

.accordion__item + .accordion__item {
  margin-top: 3rem;
}

.accordion__summary {
  display: grid;
  grid-template-columns: 1fr auto;
  -moz-column-gap: 1em;
       column-gap: 1em;
  align-items: center;
  font-size: 1.8rem;
  padding: 2rem 3rem;
  background: #e5eaf4;
}
@media (max-width: 834px) {
  .accordion__summary {
    font-size: 1.6rem;
    padding: 2rem;
  }
}
.accordion__summary .accordion__txt {
  font-weight: 600;
  margin-top: 0.1em;
}

.accordion__symbol {
  font-size: 2.4rem;
  line-height: 1.5;
}
@media (max-width: 834px) {
  .accordion__symbol {
    font-size: 1.8rem;
    line-height: 1.7;
  }
}

.accordion__cont-flex {
  display: flex;
  gap: 1em;
}

.accordion__detail {
  background: #fff;
  padding-left: 3.4em;
}
@media (max-width: 834px) {
  .accordion__detail {
    padding-left: 0rem;
  }
}

.accordion__detail-inner {
  padding: 2rem;
}

.open-close-btn {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  transition: 0.5s;
  display: grid;
  position: relative;
}
.open-close-btn::before, .open-close-btn::after {
  content: "";
  position: absolute;
  background: #c8c9d1;
  transition: all 0.2s ease;
}
.open-close-btn::after {
  width: 15px;
  height: 2px;
  position: absolute;
  top: 50%;
  right: 50%;
  transform: translate(50%, -50%);
}
.open-close-btn::before {
  width: 2px;
  height: 15px;
  position: absolute;
  top: 50%;
  right: 50%;
  transform: translate(50%, -50%);
}

/* アコーディオンエリア全体 */
.faq__accordion-area {
  position: relative;
}
.faq__accordion-area .accordion {
  max-height: 38rem;
  overflow: hidden;
  transition: max-height 1000ms ease;
  position: relative;
}
.faq__accordion-area .accordion::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 8rem;
  background: linear-gradient(to bottom, transparent, #202b3b);
  pointer-events: none;
  opacity: 1;
  transition: opacity 1000ms ease;
}
.faq__accordion-area.area-open .accordion {
  max-height: unset;
}
.faq__accordion-area.area-open .accordion::after {
  opacity: 0;
}

.faq__accordion-btn {
  font-size: var(--f18);
  color: #fff;
  min-width: 15rem;
  height: 4.5rem;
  margin: 2rem auto 0;
  background: transparent;
  border-radius: 100vmax;
  border: 1px solid #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: background-color 0.3s, color 0.3s;
}
.faq__accordion-btn:hover {
  cursor: pointer;
  background-color: #fff;
  color: #202b3b;
}
.faq__accordion-btn .close-txt {
  display: none;
}
.faq__accordion-btn .open-txt {
  display: block;
}
.faq__accordion-btn.area-open .close-txt {
  display: block;
}
.faq__accordion-btn.area-open .open-txt {
  display: none;
}

/* -------------------------
 * CTA
 * ------------------------- */
.cta {
  position: relative;
  z-index: 10;
  background: url(../img/cta_bg.webp) no-repeat center center/cover;
  padding-block: 13.7rem 14.8rem;
}

.cta__ttl {
  font-size: var(--f36);
  margin-bottom: 9.8rem;
  color: #fff;
  text-align: center;
  letter-spacing: 0.08em;
}
@media (max-width: 834px) {
  .cta__ttl {
    margin-bottom: 4rem;
  }
}

.cta__btns {
  color: #fff;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 3.4%;
  justify-content: space-between;
  align-items: center;
}

.cta__btn {
  border-radius: 10px;
  border: solid 1px rgba(255, 255, 255, 0.4);
  padding: 6.9rem 5%;
  display: inline-block;
  display: grid;
  place-content: center;
  overflow: clip;
}
@media (max-width: 834px) {
  .cta__btn {
    padding-block: 3rem;
  }
}
.cta__btn:hover {
  background: rgba(32, 43, 59, 0.4);
}
.cta__btn:nth-child(2) {
  position: relative;
  pointer-events: none;
}
.cta__btn:nth-child(2)::after {
  content: "COMING SOON";
  position: absolute;
  inset: 0;
  background: rgba(29, 58, 80, 0.7);
  color: #fff;
  font-size: var(--f28);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-family: "Tenor Sans", sans-serif;
  text-align: center;
  line-height: 1.3;
}
@media (max-width: 499px) {
  .cta__btn:nth-child(2)::after {
    font-size: 1.4rem;
  }
}
.cta__btn:nth-child(2):hover {
  background: none;
}

.cta__btn-txt--ja {
  text-align: center;
  font-size: var(--f24);
}
@media (max-width: 834px) {
  .cta__btn-txt--ja {
    font-size: 1.6rem;
  }
}

.cta__btn-txt--en {
  text-align: center;
  font-size: var(--f10);
}/*# sourceMappingURL=top.css.map */