@charset "UTF-8";
:root {
  /* フォントファミリー */
  --ja-font-family: "M PLUS 1p";
  --en-font-family: "Jost";
  
  /* 数値（単位なし）で定義 */
  --base-font-size: 14; /* px */
  --base-width: 390; /* px */
  --max-width: 767; /* px */

  /* vwを使った流動フォントサイズ */
  --fluid-font-size: calc(var(--base-font-size) / var(--base-width) * 100vw);
  
  /* 最小・最大フォントサイズ */
  --min-font-size: 12px;
  --max-font-size: calc(var(--base-font-size) * var(--max-width) / var(--base-width) * 1px);
  
  /* pxからrem換算のフォントサイズ */
  --px-01: 0.071428571428571rem;
  --px-02: 0.14285714285714rem;
  --px-05: 0.35714285714286rem;
  --px-06: 0.42857142857143rem;
  --px-08: 0.57142857142857rem;
  --px-10: 0.71428571428571rem;
  --px-12: 0.85714285714286rem;
  --px-13: 0.92857142857143rem;
  --px-14: 1rem;
  --px-15: 1.0714285714286rem;
  --px-16: 1.1428571428571rem;
  --px-18: 1.2857142857143rem;
  --px-20: 1.4285714285714rem;
  --px-22: 1.5714285714286rem;
  --px-24: 1.7142857142857rem;
  --px-25: 1.7857142857143rem;
  --px-26: 1.8571428571429rem;
  --px-27: 1.9285714285714rem;
  --px-28: 2rem;
  --px-30: 2.1428571428571rem;
  --px-32: 2.2857142857143rem;
  --px-34: 2.4285714285714rem;
  --px-35: 2.5rem;
  --px-36: 2.5714285714286rem;
  --px-38: 2.7142857142857rem;
  --px-40: 2.8571428571429rem;
  --px-42: 3rem;
  --px-50: 3.5714285714286rem;
  --px-60: 4.2857142857143rem;
  --px-65: 4.6428571428571rem;
  --px-70: 5rem;
  --px-75: 5.3571428571429rem;
  --px-80: 5.7142857142857rem;
  --px-100: 7.1428571428571rem;
  --px-120: 8.5714285714286rem;
  --px-200: 14.285714285714rem;
  --px-240: 17.142857142857rem;

  /* 色 */
  --main-color: #3FAB9B;
  --accent-color: #F8FE4C;
  --other-color01: #D6DD0B;
  --other-color02: #CBD3D2;
  --other-color03: #F5F5F5;
  --emphasis-color: #FF2D5B;
  --line-color: #07B53B;
  --text-color: #4A5957;
  --bg-color01: #AADDD5;
  --bg-color02: #F5F8A4;
  --bg-color03: #F5F5F5;
  --bg-color04: #FFE3E3;
  --bg-marker: #269383;
  --bg-number-color: #E8F4F2;
  --transparent-main: rgb(63 171 155 / 90%);
  --cta-color: #ff4081;
}
html{
  font-size: clamp(var(--min-font-size), var(--fluid-font-size), var(--max-font-size));
  scroll-behavior: smooth;
  overflow-x: hidden;
}
body{
  font-family: var(--en-font-family), var(--ja-font-family), "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial",
  "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Meiryo", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  line-height: 1.86;
  letter-spacing: 0;
  color: var(--text-color);
  background-color: #fff;
  overflow-x: hidden;
}
@media screen and (min-width: 768px) {
  html{
    font-size: calc(var(--base-font-size) * 1px);
  }
  body{
    max-width: calc(var(--base-width) * 1px);
    margin: 0 auto;
  }
}
img, svg, video {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  image-rendering: -webkit-optimize-contrast;
}

/* header */
.header{
  position: relative;
  background-color: var(--bg-color01);
}
.header__inner{
  position: absolute;
  top: 0;
  left: 0;
}
.header_logo-area{
  width: 50%;
  background-color: #fff;
  padding: var(--px-14) var(--px-20);
  border-radius: 0 0 var(--px-40) 0;
}

/* ヘッダーのナビ部分 */
.header__nav {
  position: fixed;
  right: 0;
  top: 0;
  width: 95%;
  height: 100svh;
  transform: translateX(100%);
  background-color: var(--bg-color01);
  border-radius: var(--px-40) 0 0 var(--px-40);
  transition: ease .4s;
  padding: var(--px-50) var(--px-42);
  z-index: 999;
  overflow: overlay;
}
@media screen and (min-width: 768px) {
  .header__nav {
    position: fixed;
    min-width: 400px;
    width: 30%;
  }
}

/* ナビのリンク */
.nav-items__link {
  color: var(--bg-marker);
  width: 100%;
  display: block;
  text-align: left;
  font-size: var(--px-16);
  letter-spacing: 0.1em;
  margin-bottom: var(--px-10);
}
.nav-items__item:last-child .nav-items__link {
  margin-bottom: 0;
}
.nav-items__item--button{
  margin-top: var(--px-10);
}
@media screen and (min-width: 768px) {
  .nav-items__item--button .considerations-button,
  .nav-items__item--button .line-button{
    max-width: 300px;
  }
}

/* ハンバーガーメニュー */
.header__hamburger {
  width: var(--px-25);
}
.hamburger {
  background-color: transparent;
  border-color: transparent;
  position: fixed;
  top: var(--px-28);
  right: var(--px-26);
  z-index: 9999;
}
@media screen and (min-width: 768px) {
  .hamburger {
    position: fixed;
    top: var(--px-28);
    left: 50%;
    transform: translateX(calc(-50% + 155px));
  }
}
.hamburger::before{
  content: "";
  width: var(--px-60);
  height: var(--px-60);
  border-radius: 50%;
  background-color: var(--main-color);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 999;
}

/* ハンバーガーメニューの線 */
.hamburger span {
  width: 100%;
  height: 2px;
  background-color: #fff;
  position: relative;
  transition: ease .4s;
  display: block;
  z-index: 999;
}
.hamburger span:nth-child(1) {
  top: 0;
}
.hamburger span:nth-child(2) {
  margin-top: var(--px-08);
}

/* ハンバーガーメニュークリック後のスタイル */
.header__nav.active {
  transform: translateX(0);
}
.hamburger.active span:nth-child(1) {
  top: var(--px-05);
  transform: rotate(45deg);
}
.hamburger.active span:nth-child(2) {
  top: calc(var(--px-05) * -1);
  transform: rotate(-45deg);
}

/* メインビジュアル */
.mv{
  position: relative;
  background-color: var(--bg-color01);
  padding: var(--px-30) var(--px-22) var(--px-40);
}
.mv-icon-rotation-area {
  position: absolute;
  width: var(--px-200);
  height: var(--px-200);
  top: calc(var(--px-80) * -1);
  right: calc(var(--px-40) * -1);
  z-index: 1;
}
.mv-icon-rotation-img {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    animation: 17s linear infinite rotation;
}
.mv-main-copy-area{
  position: absolute;
  bottom: var(--px-30);
  left: var(--px-24);
  width: 63%;
  z-index: 2;
}
.mv-sub-copy-area{
  position: absolute;
  top: var(--px-10);
  right: var(--px-24);
  width: 17%;
  z-index: 3;
}
.carousel{
  background-color: var(--bg-color02);
}
.carousel__inner{
  padding: var(--px-25) 0;
}
.carousel__figure{
  width: 80%;
  margin: 0 auto var(--px-15);
  line-height: 1;
}

/* slickslider */
.slick-carousel .slick-slide {
  padding: 0 var(--px-10);
}
.slick-carousel-movie .slick-slide {
  padding: 0 var(--px-10);
  height: auto !important;
  display: flex;
  justify-content: center;
}
.slick-carousel-movie .slick-dots {
  bottom: calc(var(--px-40) * -1);
  display: flex !important;
  justify-content: center;
  gap: var(--px-10);
}
.slick-carousel-movie .slick-dots li {
  width: var(--px-25);
  height: var(--px-06);
  background-color: var(--other-color02);
  border: none;
  font-size: 0;
  cursor: pointer;
  transition: background-color 0.3s;
}
.slick-carousel-movie .slick-dots li.slick-active {
  background-color: var(--main-color);
}
.slick-carousel-movie .slick-dots li button:before{
  display: none;
}
.slick-carousel-movie .slick-arrow:before{
	content:""!important;
  width: 100%!important;
  height: 100%!important;
  position: absolute;
  top: 0;
  left: 0;
}
.slick-carousel-movie .slick-next{
  right: 0;
  width: var(--px-35);
  height: var(--px-70);
  z-index: 99;
}
.slick-carousel-movie .slick-next:before{
  content: "";
  background: url(../img/next.svg)!important;
  background-size: contain!important;
  background-repeat: no-repeat!important;
  opacity: 1!important;
}
.slick-carousel-movie .slick-prev{
  left: 0;
  width: var(--px-35);
  height: var(--px-70);
  z-index: 99;
}
.slick-carousel-movie .slick-prev:before{
  content: "";
  background: url(../img/prev.svg)!important;
  background-size: contain!important;
  background-repeat: no-repeat!important;
  opacity: 1!important;
}
.iframe-wrap{
  position: relative;
  width: 100%;
  padding-top: 177.77%; /* 16:9 → 56.25%、9:16 → 177.77% */
  overflow: hidden;
  margin: 0 auto; /* 中央寄せ */
  border-radius: var(--px-40);
}
.slick-carousel-movie iframe{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* 共通のスタイル */
.st-heading{
  color: var(--main-color);
  text-align: center;
  margin-bottom: var(--px-30);
}
.st-heading--mb-short{
  margin-bottom: var(--px-20);
}
.st-heading__main{
  display: block;
  font-size: var(--px-50);
  font-weight: 600;
  line-height: 0.8;
  letter-spacing: 0.1em;
  word-break: break-all;
}
.st-heading__sub{
  display: block;
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  font-weight: 500;
  line-height: 0.8;
  letter-spacing: 0.1em;
  margin-top: var(--px-10);
}
.st-heading__balloon{
  position: relative;
  display: inline-block;
  margin-bottom: var(--px-16);
  padding: var(--px-10) var(--px-20);
  border-radius: 9999px;
  background-color: var(--accent-color);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 1.21;
  color: var(--emphasis-color);
}
.st-heading__balloon::after {
  content: '';
  position: absolute;
  width: 0;
  height: 0;
  display: block;
  border-style: solid;
  border-color: transparent var(--accent-color) var(--accent-color) transparent;
  border-width: 10px;
  bottom: -8px;
  border-radius: 0 0 4px 0;
  transform: scaleX(0.6) translateX(-50%) rotate(45deg);
  left: 48%;
}

.marker {
  background: linear-gradient(transparent 70%, var(--accent-color) 70%);
  padding: 0 1px;
}
.text-marker {
  background-color: var(--bg-marker);
  color: var(--accent-color);
  font-weight: 500;
  padding: 0 2px;
  margin: 0 2px;
}

.list-disc{
  list-style: none;
}
.list-disc__item {
  display: flex;
  align-items: center;
}
.list-disc__item::before {
  content: "";
  width:  3px;
  height:  3px;
  display: inline-block;
  background-color: var(--main-color);
  border-radius:  50%;
  margin-right: var(--px-10);
}

.color-emphasis{
  color: var(--emphasis-color);
}

/* ボタン類 */
/* 注意事項 */
.considerations-button{
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  font-weight: 500;
  line-height: 0.81;
  color: var(--emphasis-color);
  background-color: var(--bg-color04);
  border: var(--px-02) solid var(--emphasis-color);
  padding: var(--px-22) var(--px-40) var(--px-22) var(--px-30);
  border-radius: 9999px;
  display: block;
  position: relative;
  width: 100%;
  text-align: center;
  box-shadow: var(--px-05) var(--px-05) var(--px-10) 0px rgba(0, 0, 0, 0.15);
}
.considerations-button::after{
  content: "";
  position: absolute;
  top: 50%;
  right: var(--px-20);
  transform: translateY(-50%);
  width: var(--px-20);
  height: var(--px-20);
  border-radius: 50%;
  background-color: #fff;
  border: var(--px-05) solid var(--emphasis-color);
}

/* LINE予約 */
.line-button{
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  font-weight: 500;
  line-height: 0.72;
  color: #fff;
  background-color: var(--line-color);
  border: var(--px-02) solid #fff;
  padding: var(--px-27) var(--px-50);
  border-radius: 9999px;
  display: block;
  position: relative;
  width: 100%;
  text-align: center;
  box-shadow: var(--px-05) var(--px-05) var(--px-10) 0px rgba(0, 0, 0, 0.15);
}
.line-button::after{
  content: "";
  position: absolute;
  top: 50%;
  right: var(--px-20);
  transform: translateY(-50%);
  width: var(--px-20);
  height: var(--px-20);
  border-radius: 50%;
  background-color: var(--line-color);
  border: var(--px-05) solid #fff;
}

/* TEL */
.tel-button{
  background-color: #fff;
  border: var(--px-02) solid var(--main-color);
  padding: var(--px-12);
  border-radius: 9999px;
  display: block;
  position: relative;
  width: 100%;
  text-align: center;
  box-shadow: var(--px-05) var(--px-05) var(--px-10) 0px rgba(0, 0, 0, 0.15);
}
.tel-button-number{
  display: block;
  font-size: var(--px-28);
  font-weight: 500;
  line-height: 0.71;
  letter-spacing: 0.05em;
  color: var(--main-color);
  margin-bottom: var(--px-08);
}
.tel-button-number::before{
  content: "";
  display: inline-block;
  background-image: url(../img/icon-tel.svg);
  background-size: cover;
  background-repeat: no-repeat;
  width: var(--px-20);
  height: var(--px-22);
  margin-right: var(--px-05);
  position: relative;
  top: var(--px-02);
}
.tel-button-open{
  display: block;
  font-family: var(--ja-font-family);
  line-height: 0.86;
}

/* 各セクションのスタイル */
/* あなただけのオリジナル3Dフィギュア体験を! */
.feature__inner{
  width: 100%;
  padding: var(--px-50) var(--px-24) var(--px-35);
}
.feature__logo-area{
  width: 44%;
  margin: 0 auto;
  margin-bottom: var(--px-40);
}
.feature__title{
  font-size: var(--px-22);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 1.36;
  letter-spacing: 0.05em;
  text-align: center;
  margin-bottom: var(--px-30);
}
.feature__text{
  letter-spacing: 0.03em;
  margin-bottom: var(--px-32);
}
.feature__icon-area{
  width: 96.5%;
  margin: var(--px-32) auto 0;
}

/* 3DMEの強み */
.strength__inner{
  width: 100%;
  padding: var(--px-35) var(--px-24) var(--px-70);
}
.strength__item{
  margin-bottom: var(--px-20);
}
.strength__item:last-child{
  margin-bottom: 0;
}
.strength__item-box{
  position: relative;
  border-radius: var(--px-40);
  z-index: 0;
  background: #fff; 
  padding: var(--px-34);
}
.strength__item-box::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 8px; /* border相当 */
  background: linear-gradient(135deg, #3fab9b80, #d6dd0b80);
  border-radius: var(--px-40);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  z-index: -1;
}
.strength__item-box--reason {
  background: var(--bg-color01); 
}
.strength__item-title-area{
  position: relative;
  margin-bottom: var(--px-20);
}
.strength__item-title-number{
  font-size: var(--px-100);
  font-weight: 700;
  line-height: 0.75;
  color: var(--bg-number-color);
  position: absolute;
  top: 0;
  right: calc(var(--px-18) * -1);
  z-index: -1;
}
.strength__item-title-icon{
  width: 50%;
  position: absolute;
  top: calc(var(--px-42) * -1);
  right: calc(var(--px-40) * -1);
  z-index: -1;
}
.strength__item-title{
  font-size: var(--px-25);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 1.28;
  letter-spacing: 0.05em;
  text-decoration: underline;
  color: var(--main-color);
}
.strength__item-title--reason{
  width: 90%;
  text-decoration: none;
  color: var(--bg-marker);
}
.strength__item-text{
  margin-bottom: var(--px-24);
}
.strength__item-img{
  border-radius: var(--px-40);
}

/* 料金 */
.price{
  background-color: var(--bg-color01);
  border-radius: var(--px-40) var(--px-40) 0 0;
}
.price__inner{
  width: 100%;
  padding: var(--px-70) var(--px-24);
}
.price__text{
  text-align: center;
  margin-bottom: var(--px-30);
}
.price__item{
  margin-bottom: var(--px-20);
}
.price__item:last-child{
  margin-bottom: 0;
}
.price__item-box{
  position: relative;
  border-radius: var(--px-40);
  background: #fff;
}
.price__item-title-area{
  background: var(--main-color);
  padding: var(--px-20);
  border-radius: var(--px-40) var(--px-40) 0 0;
  position: relative;
}
.price__item-title{
  font-family: var(--ja-font-family);
  font-size: var(--px-25);
  font-weight: 800;
  line-height: 0.9;
  color: #fff;
  text-align: center;
}
.price__item-title-unit{
  font-size: var(--px-22);
}
.price__item-batch{
  display: block;
  position: absolute;
  top: var(--px-40);
  right: var(--px-20);
}
.price__item-batch-inner{
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: var(--px-13);
  font-weight: 600;
  line-height: 1.38;
  text-align: center;
  width: var(--px-80);
  height: var(--px-80);
  border-radius: 50%;
  background-color: var(--bg-color01);
  color: var(--bg-marker);
}
.price__item-batch-inner--even{
  background-color: var(--other-color01);
}
.price__item-main-area{
  padding: var(--px-20);
}
.price__item-figure{
  margin-bottom: var(--px-20);
}
.price__item-price{
  font-size: var(--px-50);
  font-weight: 600;
  line-height: 0.8;
  letter-spacing: -0.01em;
  color: var(--main-color);
  text-align: center;
}
.price__item-price-unit{
  font-size: var(--px-25);
  letter-spacing: 0.05em;
}
.price__item-price-tax{
  font-size: var(--px-14);
  font-weight: 500;
  letter-spacing: 0.05em;
}
.price__item-description-area{
  background: var(--bg-color03);
  padding: 0 var(--px-40) var(--px-20);
  border-radius: 0 0 var(--px-40) var(--px-40);
}
.price__item-description-title{
  position: relative;
  top: calc(var(--px-12) * -1);
  display: block;
  width: 90%;
  margin: 0 auto;
  padding: var(--px-05);
  border-radius: 9999px;
  font-size: var(--px-16);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 0.94;
  background-color: var(--main-color);
  color: #fff;
  text-align: center;
  margin-bottom: var(--px-05);
}

/* オススメご利用シーン */
.scene__inner{
  width: 100%;
  padding: var(--px-70) var(--px-24);
}
.scene__item{
  margin-bottom: var(--px-50);
}
.scene__item:last-child{
  margin-bottom: 0;
}
.scene__item-img-area{
  position: relative;
  margin-bottom: calc(var(--px-20) + var(--px-15));
}
.scene__item-figure{
  text-align: center;
}
.scene__item-number-area{
  position: absolute;
  width: var(--px-120);
  height: var(--px-120);
  top: calc(var(--px-24) * -1);
  right: 0;
}
.scene__item-number{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 70%;
}
.scene__item-number-rotation{
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  animation:17s linear infinite rotation;
}
@keyframes rotation{
  0%{ transform:rotate(0);}
  100%{ transform:rotate(360deg); }
}
.scene__item-title{
  font-size: var(--px-22);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: 0.05em;
  position: absolute;
  left: 0;
  bottom: calc(var(--px-20) * -1);
}
.scene__item-title-inner{
  display: inline-block;
  background-color: var(--transparent-main);
  color: #fff;
  padding: var(--px-08) var(--px-15);
  margin-bottom: var(--px-05);
}

/* 法人利用にもオススメ */
.business-use{
  margin-top: var(--px-65);
  background-color: var(--bg-color02);
  border-radius: var(--px-40) var(--px-40) 0 0;
}
.business-use__inner{
  width: 100%;
  padding: 0 var(--px-24) var(--px-05);
  position: relative;
  top: calc(var(--px-65) * -1);
}
.business-use__heading{
  margin-bottom: var(--px-20);
}
.business-use__heading-sub{
  display: block;
  font-size: var(--px-20);
  font-weight: 500;
  letter-spacing: 0.1em;
  color: var(--main-color);
}
.business-use__heading-main{
  display: block;
  font-size: var(--px-60);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.08em;
  color: var(--other-color01);
  word-break: break-all;
}
.business-use__item{
  margin-bottom: var(--px-50);
}
.business-use__item:last-child {
    margin-bottom: 0;
}
.business-use__item-img-area{
  position: relative;
  margin-bottom: calc(var(--px-20) + var(--px-15));
}
.business-use__item-figure{
  text-align: center;
}
.business-use__item-title{
  font-size: var(--px-22);
  font-family: var(--ja-font-family);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: 0.05em;
  position: absolute;
  left: 0;
  bottom: calc(var(--px-20) * -1);
}
.business-use__item-title-inner{
  display: inline-block;
  background-color: var(--transparent-main);
  color: #fff;
  padding: var(--px-08) var(--px-15);
  margin-bottom: var(--px-05);
}

/* 体験の流れ */
.flow__inner{
  width: 100%;
  padding: var(--px-70) 0;
}
.flow__text{
  font-family: var(--ja-font-family);
  text-align: center;
  margin-bottom: var(--px-30);
}
.flow__item{
  display: grid;
  grid-template-columns: 43% 1fr;
  align-items: center;
  gap: var(--px-10);
  margin-bottom: var(--px-20);
}
.flow__item:last-child{
  margin-bottom: 0;
}
.flow__item-text-area{
  padding-right: var(--px-24);
}
.flow__item-title{
  font-family: var(--ja-font-family);
  font-size: var(--px-22);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: 0.05em;
  color: var(--main-color);
  margin-bottom: var(--px-18);
}
.flow__item-text{
  font-family: var(--ja-font-family);
  font-size: var(--px-12);
  line-height: 1.67;
}
.flow__button-area{
  padding: var(--px-40) var(--px-24) 0;
}

/* 3DME体験動画 */
.movie__inner{
  width: 100%;
  padding: 0 0 var(--px-70);
}
.movie__text{
  font-family: var(--ja-font-family);
  text-align: center;
  margin-bottom: var(--px-30);
}

/* 店舗紹介 */
.shop{
  background-color: var(--bg-color02);
  border-radius: var(--px-40) var(--px-40) 0 0;
}
.shop__inner{
  width: 100%;
  padding: var(--px-70) var(--px-24);
}
.shop__figure{
  margin-bottom: var(--px-32);
}
.shop__shop-name{
  font-family: var(--ja-font-family);
  font-size: var(--px-22);
  font-weight: 500;
  line-height: 0.9;
  letter-spacing: 0.05em;
  color: var(--main-color);
  margin-bottom: var(--px-20);
}
.shop__list-tag{
  margin-bottom: var(--px-25);
}
.shop__list-tag-item{
  display: inline-block;
  font-family: var(--ja-font-family);
  font-size: var(--px-13);
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: 0.03em;
  background-color: var(--main-color);
  color: #fff;
  padding: var(--px-05) var(--px-15);
  border-radius: 9999px;
  margin-right: var(--px-05);
  margin-bottom: var(--px-05);
}
.shop__shop-detail{
  font-family: var(--ja-font-family);
  font-size: var(--px-13);
  line-height: 1.77;
  margin-bottom: var(--px-30);
}
.shop__button-area{
  margin-bottom: var(--px-10);
}
.shop__text-link{
  display: block;
  position: relative;
  font-family: var(--ja-font-family);
  letter-spacing: 0.05em;
  color: var(--emphasis-color);
  margin: var(--px-20) auto 0;
  text-decoration: underline;
  padding-right: var(--px-10);
}
.shop__text-link::after{
  content: "";
  width: var(--px-06);
  height: var(--px-06);
  border: 0;
  border-top: solid 1px var(--emphasis-color);
  border-right: solid 1px var(--emphasis-color);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

/* よくあるご質問 */
.faq__inner{
  width: 100%;
  padding: var(--px-70) var(--px-24) var(--px-35);
}
.faq__accordion{
  margin-bottom: var(--px-10);
}
.faq__accordion:not([open]) {
  margin-bottom: 7px;
}
.faq__q {
  display: grid;
  grid-template-columns: var(--px-40) 1fr var(--px-30);
  align-items: center;
  position: relative;
  padding: var(--px-08) var(--px-16);
  border-radius: var(--px-10);
  border: 2px solid var(--other-color02);
  background-color: #fff;
  color: var(--text-color);
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  line-height: 1.36;
  letter-spacing: 0;
  font-weight: 500;
  cursor: pointer;
  min-height: var(--px-70);
}
.faq__q::-webkit-details-marker {
  display: none;
}
.faq__q::before {
  content: 'Q';
  font-size: var(--px-30);
  line-height: 1;
  font-weight: 600;
  color: var(--main-color);
}
.faq__q::after {
  content: '';
  width: var(--px-12);
  height: var(--px-12);
  border-bottom: 2px solid var(--main-color);
  border-right: 2px solid var(--main-color);
  transform: rotate(45deg);
  margin-left: var(--px-16);
  transition: transform .3s;
}
.faq__accordion[open] .faq__q::after {
  transform: rotate(225deg);
}
.faq__a {
  display: grid;
  grid-template-columns: var(--px-40) 1fr;
  align-items: flex-start;
  transform: translateY(-10px);
  opacity: 0;
  margin: 0;
  padding: var(--px-24) var(--px-16) var(--px-26) var(--px-18);
  border-radius: 0 0 var(--px-10) var(--px-10);
  background-color: var(--other-color03);
  color: var(--text-color);
  margin-top: calc(var(--px-10) * -1);
}
.faq__a::before {
  content: 'A';
  font-size: var(--px-30);
  line-height: 1;
  font-weight: 600;
  color: var(--other-color01);
}
.faq__accordion[open] .faq__a {
  transform: none;
  opacity: 1;
}

/* 運営会社 */
.company__inner{
  width: 100%;
  padding: var(--px-35) var(--px-24) var(--px-50);
}
.company__info-th{
  border-bottom: 1px solid var(--main-color);
  color: var(--main-color);
  font-size: var(--px-13);
  font-weight: 500;
  width: 32%;
  text-align: center;
  padding: var(--px-16);
  vertical-align: middle;
  position: relative;
}
.company__info-th::after{
  content: "";
  width: var(--px-05);
  height: 2px;
  background-color: #fff;
  position: absolute;
  bottom: -2px;
  right: 0;
  z-index: 1;
}
.company__info-td{
  border-bottom: 1px solid var(--other-color02);
  color: var(--text-color);
  font-size: var(--px-13);
  font-weight: 400;
  width: 68%;
  text-align: left;
  padding: var(--px-16);
}
.company__list{
  list-style: disc;
  margin-left: var(--px-20);
}
.company__list-item{
  line-height: 1.92;
}

/* footer */
.footer{
  background-color: var(--bg-color01);
  border-radius: var(--px-40) 0 0 0;
  position: relative;
}
.footer__inner{
  width: 100%;
  padding: var(--px-70) var(--px-40);
  display: grid;
  grid-template-columns: 34% 1fr;
  align-items: flex-start;
  gap: var(--px-40);
}
.footer__list{
  line-height: 2.14;
}
.footer__copy{
  background-color: var(--main-color);
  color: #fff;
  text-align: center;
  padding: var(--px-20) var(--px-20) var(--px-120);
}
.page_top_btn{
  position: absolute;
  top: calc(var(--px-20) * -1);
  right: var(--px-24);
  width: var(--px-70);
  height: var(--px-70);
  border-radius: 50%;
  background-color: var(--main-color);
  color: #fff;
}
.page_top_btn::after{
  content: "";
  width: var(--px-16);
  height: var(--px-16);
  border-top: 2px solid #fff;
  border-left: 2px solid #fff;
  position: absolute;
  top: calc(50% + var(--px-02));
  left: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
}

/* 追従CTA */
.following-button__inner{
  position: fixed;
  bottom: 0;
  left: 0;
  display: grid;
  grid-template-columns: 2fr 1fr;
  align-items: flex-end;
  width: 100%;
  z-index: 99;
}
@media screen and (min-width: 768px) {
  .following-button__inner{
    width: calc(var(--base-width) * 1px);
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}

/* モーダル */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
}
.modal-content{
  position: relative;
  border-radius: var(--px-40);
  z-index: 0;
  background: #fff; 
  padding: var(--px-50) var(--px-30) var(--px-30);
  margin: var(--px-24);
}
@media screen and (min-width: 768px) {
  .modal-content{
    max-width: calc(var(--base-width) * 1px);
    margin: 0 auto;
  }
}
.modal-content::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: 8px; /* border相当 */
  background: linear-gradient(135deg, #3fab9b80, #d6dd0b80);
  border-radius: var(--px-40);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  z-index: -1;
}
.modal-content__inner{
  max-height: 80svh;
  overflow-y: auto;
  margin: 0 calc(var(--px-10) * -1) 0 calc(var(--px-10) * -1);
  padding: var(--px-10);
}
.reserve-text{
  font-size: var(--px-13);
  text-align: center;
  margin-bottom: var(--px-14);
}
.modal-button{
  margin-bottom: var(--px-10);
}
.modal-button:last-child{
  margin-bottom: 0;
}
.modal-close{
  position: absolute;
  top: calc(var(--px-13) * -1);
  right: calc(var(--px-13) * -1);
}
.modal-close-button{
  width: var(--px-60);
  height: var(--px-60);
  border-radius: 50%;
  background-color: var(--main-color);
}
.modal-close-button::before,
.modal-close-button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: var(--px-24);
  height: var(--px-02);
  background-color: #fff;
  transform-origin: center;
}
.modal-close-button::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modal-close-button::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.modal-content__step2-button{
  margin-top: var(--px-30);
}
.modal-content__back-button{
  font-size: var(--px-15);
  font-weight: 600;
  line-height: 1.67;
  color: var(--bg-marker);
  background-color: var(--bg-color01);
  padding: var(--px-10);
  border-radius: 9999px;
  display: block;
  position: relative;
  box-shadow: var(--px-05) var(--px-05) var(--px-10) 0px rgba(0, 0, 0, 0.15);
  text-align: center;
  width: 80%;
  margin: 0 auto var(--px-10);
}
.modal-content__back-button::before{
  content: "";
  width: var(--px-10);
  height: var(--px-10);
  border: 0;
  border-bottom: solid 2px var(--bg-marker);
  border-left: solid 2px var(--bg-marker);
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  left: var(--px-15);
  bottom: 0;
  margin: auto;
}
.modal-content__close-button{
  font-size: var(--px-15);
  font-weight: 800;
  line-height: 1.67;
  color: var(--bg-marker);
  background-color: var(--bg-color01);
  padding: var(--px-10);
  border-radius: 9999px;
  display: block;
  position: relative;
  box-shadow: var(--px-05) var(--px-05) var(--px-10) 0px rgba(0, 0, 0, 0.15);
  text-align: center;
  width: 80%;
  margin: 0 auto var(--px-30);
}
.modal-content__close-button::before,
.modal-content__close-button::after {
  content: "";
  position: absolute;
  top: 50%;
  right: var(--px-15);
  width: var(--px-16);
  height: var(--px-02);
  background-color: var(--bg-marker);
  transform-origin: center;
}
.modal-content__close-button::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modal-content__close-button::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* ご利用上の注意事項 */
.guide-section__title{
  border-top: 2px solid var(--main-color);
  border-bottom: 2px solid var(--main-color);
  padding: var(--px-10);
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.05em;
  margin-bottom: var(--px-20);
}
.guide-description-icon{
  display: grid;
  grid-template-columns: 30% 1fr;
  align-items: flex-start;
  gap: var(--px-13);
  margin-bottom: var(--px-20);
}
.guide-text-area__title{
  font-family: var(--ja-font-family);
  font-size: var(--px-16);
  font-weight: 500;
  line-height: 0.93;
  letter-spacing: 0.05em;
  margin-bottom: var(--px-15);
}
.guide-list{
  list-style: none;
}
.guide-list__item{
  font-family: var(--ja-font-family);
  font-size: var(--px-13);
  line-height: 1.38;
  display: grid;
  grid-template-columns: var(--px-18) 1fr;
  gap: var(--px-05);
  align-items: flex-start;
  margin-bottom: var(--px-10);
}
.guide-description .guide-list__item{
  margin-bottom: var(--px-20);
}
.guide-list__item::before{
  content: "";
  display: inline-block;
  background-image: url(../img/icon-check-box.svg);
  background-size: cover;
  background-repeat: no-repeat;
  width: var(--px-18);
  height: var(--px-18);
}
.guide-description{
  margin-bottom: var(--px-30);
}
.guide-description__title{
  display: inline-block;
  font-size: var(--px-14);
  font-weight: 500;
  line-height: 1.43;
  letter-spacing: 0.05em;
  background: var(--main-color);
  color: #fff;
  padding: var(--px-05) var(--px-10);
  margin-bottom: var(--px-20);
}
.guide-description__title--attention{
  display: block;
  letter-spacing: 0;
  background: var(--emphasis-color);
  padding: var(--px-05);
}


/* セクションごとのアニメーション */
/* https://moshashugyo.com/media/animate-on-scroll */
/* アニメーションスタイル */
/* ---------------------------- */

/* アニメーション前 */
.u-fade-type-up{
    transform: translateY(50px);
    opacity: 0;
}

/* トリガー発火でis-activeを付与 */
.u-fade-type-up.is-active{
    transition: .6s;
    transform: translateY(0);
    opacity: 1;
}