/*全共通CSS*/
@font-face {
  font-family: "Noto Sans JP";
  src: url(../fonts/NotoSansJP-Light.woff) format("woff");
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url(../fonts/NotoSansJP-Regular.woff) format("woff");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url(../fonts/NotoSansJP-Medium.woff) format("woff");
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url(../fonts/NotoSansJP-SemiBold.woff) format("woff");
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "Noto Serif JP";
  src: url(../fonts/NotoSerifJP-Regular.woff) format("woff");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Noto Serif JP";
  src: url(../fonts/NotoSerifJP-Medium.woff) format("woff");
  font-weight: 500;
  font-display: swap;
}
@font-face {
 font-family: "Noto Serif JP";
  src: url(../fonts/NotoSerifJP-SemiBold.woff) format("woff");
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "Zen Maru Gothic";
  src: url(../fonts/ZenMaruGothic-Regular.woff) format("woff");
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Zen Maru Gothic";
  src: url(../fonts/ZenMaruGothic-Medium.woff) format("woff");
  font-weight: 500;
  font-display: swap;
}

@font-face {
  font-family: "Zen Maru Gothic";
  src: url(../fonts/ZenMaruGothic-Bold.woff) format("woff");
  font-weight: 700;
  font-display: swap;
}
:root {
/*文字色カラー*/
--color-n: #222222;
/*白・黒カラー*/
--color-b: #000000;
--color-w: #ffffff;
/*グレー*/
--color-gl: #f5f5f5;
--color-ge: #eeeeee;
--color-gd: #dddddd;
--color-gc: #cccccc;
--color-g: #777777;
--color-gb: #444444;
--color-gh: #050102;
/*赤*/
--color-r: #dc143c;
--color-rd: #b5282e;
/*黄色*/
--color-y: #ffff00;
--color-yl:#f7f7cb;
--color-ys:#fffeee;
/*web入会*/
--color-wa:#a8951c;
--color-wl:#b55328; 
/*ピンクカラー*/
--color-ps:#fdf1f1;
--color-plb:#fbebeb;
--color-pf:#fceaf9;
--color-pl:#ffe6e6;
--color-pla: #fac5d4;
--color-pfd:#f4a6ba;
--color-pf8:#ff8d83;
--color-p: #e61673;
--color-pde:#DE1BAB;	
--color-p99:#993366;
/*オレンジ*/
--color-os:#fef5e9;
--color-ol:#fcdb9d;
--color-of:#FFA902;
--color-o:#f18d00;
--color-oe:#eb6100;
--color-od:#c16d08;
--color-ob:#b84c00;
/*緑色*/
--color-m:#229134;
--color-ma:#6ad01f;
--color-ml:#c2dab2;
--color-me:#d3e9d6;
--color-ms:#e8f4ea;	
/*青色*/
--color-as:#eef5fc;
--color-ad:#d1e5f3;		
--color-aa:#53a6e2;
--color-ab:#00bfff;
--color-a:#187fc4;	
/*土色*/
--color-cs:#ece3d3;
--color-ce:#e5dec7;	
--color-cl:#785512;
}

/*　基本
---------------------------------*/
body {
  font-weight: 400;
  background-color: var(--color-gl);
}
a:hover {
  text-decoration: none;
}
img {
  vertical-align: top;
  max-width: 100%;
  height: auto;
  width: auto;
  image-rendering: -webkit-optimize-contrast;
}
.cvimg img {
  width: 100%;
}
a img {
  -webkit-transition: 0.5s ease-out;
  -moz-transition: 0.5s ease-out;
  transition: 0.5s ease-out;
}
a:hover img {
  opacity: .85;
  filter: alpha(opacity=85);
  -ms-filter: "alpha(opacity=85)";
  -khtml-opacity: .85;
  -moz-opacity: .85;
  transform: translateY(-5px);
  -webkit-transform: translateY(-5px);
  -moz-transform: translateY(-5px);
}
.btm05 {
  margin-bottom: 0.28rem;
}
.btm10 {
  margin-bottom: 0.56rem;
}
.btm20 {
  margin-bottom: 1.11rem !important;
}
.btm30 {
  margin-bottom: 1.67rem;
}
.btm40 {
  margin-bottom: 2.22rem;
}
.btm50 {
  margin-bottom: 2.78rem;
}
.btm60 {
  margin-bottom: 3.33rem;
}
.btm70 {
  margin-bottom: 3.89rem;
}
.btm80 {
  margin-bottom: 4.44rem;
}
.btm90 {
  margin-bottom: 5rem;
}
.al_right {
  text-align: right;
}
.al_left {
  text-align: left;
}
.al_center {
  text-align: center;
}
.small{font-size:0.8em; }
.nowrap {
  white-space: nowrap;
}
.justify {
  text-align: justify;
  text-justify: inter-ideograph;
}
em {
  font-style: normal;
}
.marker-yellow {
  background: -webkit-linear-gradient(transparent 60%, var(--color-y) 0%);
  background: -o-linear-gradient(transparent 60%, var(--color-y) 0%);
  background: linear-gradient(transparent 60%, var(--color-y) 0%);
}
@media only screen and (min-width: 680.1px) {
  html, body {
    font-size: 18px;
  }
  .sp {
    display: none;
  }
}
@media only screen and (max-width: 680px) {
  html, body {
	 font-size: clamp(13px, 2.8vw, 18px)
  }
  .pc {
    display: none;
  }
}
/* ヘッダー
-------------------------------------------------------*/
heder h1 {
	line-height: 1;
  padding: 1rem;
  text-align: center;
	margin: 0;
}
/* ブロッグ
------------------------------------------------------------*/
main#container {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  background-color: var(--color-w);
}
/*web予約
-------------------------------------------*/
.cmpBox {
  background: var(--color-w);
  border: solid 0.8rem var(--color-rd);
}
.cmpBox h2{background: var(--color-rd);}
.cmpBox > div {
  display: block;
  padding: 1.5rem 1.2rem;
}
.cmpBox01 {
  text-align: center;
}
.cmpBox01 p {
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.9rem;
}
.cmpBox01 p span {
  color: var(--color-r);
}
.cmpBox02 a {
  display: flex;
  justify-content: center;
  align-items: center;
	text-decoration: none;
  width: 100%;
  padding: 2rem 1.25rem;
  border-radius: 0.8rem;
  background: linear-gradient(110deg, var(--color-rd) 0%, var(--color-wl) 100%);
  text-align: center;
  
	color: var(--color-w);
  font-size: 1.3rem;
  line-height: normal;
  transition: opacity 0.2s ease 0s;
}
.cmpBox02 a:hover {
	color: var(--color-w);
  background: linear-gradient(110deg, var(--color-wl) 0%, var(--color-r) 100%);
}
.cmpBox02 a span {
  display: block;
  font-size: 0.88rem;
}
.cmpBox02 a strong {
  font-size: 1.3rem;
  display: inline-block;
}
.cpyInpt {
  position: absolute;
  opacity: 0;
  left: -999px;
  top: -999px;
}
.cpyBtn {
  display: inline-block;
  font-size: 180%;
  font-weight: 600;
  line-height: normal;
  color: var(--color-w);
  background: var(--color-wa);
  padding: 0.4rem 1.25rem;
  border-radius: 4px;
  transition: 0.2s;
}
.cpyBtn:hover {
  background: var(--color-b);
}
/*H2 タイトル
---------------------------------*/
.section__title {
  text-align: center;
}
.section__title h2 {
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
  border-bottom: var(--color-n) solid 3px;
  padding: 0 0 0.56rem;
  font-size: 2.7rem;
  white-space: nowrap;
	line-height: 1.1;
}
.section__title h2 span {
  display: block;
  font-size: 2rem;
	padding-bottom: 0.6rem;
}
.img_title {
  text-align: center;
}
/*注意書き
---------------------------------*/
.toptext{padding: 1rem 1rem 0.7rem;}
.toptext ol {
	margin-left: 1.2rem;
}
.toptext ol>li {
	list-style-type: none;
	line-height: 1.4;
	padding-bottom:0.3rem;
	font-size: 0.94rem;
}
.toptext ol>li::before {
	content: "※";
	display:inline-block;
	margin-left:-1.2rem;
	width: 1.2rem;
}
/*リンクボタン（黒orピンク）
---------------------------------*/
a.btn {
  position: relative;
  display: inline-block;
  padding: 0.8em 4em;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  vertical-align: middle;
  text-decoration: none;
  border-radius: 100vh;
  -webkit-border-radius: 100vh;
  -moz-border-radius: 100vh;
}
a.btn--pink {
  color: var(--color-w);
  background-color: var(--color-p);
  border-bottom: 5px solid var(--color-pd);
}
a.btn--pink:hover {
  margin-top: 3px;
  border-bottom: 2px solid var(--color-pd);
}
a.btn--orange {
  color: var(--color-w);
  background-color: var(--color-oe);
  border-bottom: 5px solid var(--color-pd);
}

a.btn--black {
  color: var(--color-w);
  background-color: var(--color-n);
  border-bottom: 5px solid var(--color-b);
}
a.btn--black:hover {
  margin-top: 3px;
  border-bottom: 2px solid var(--color-b);
}
a.btn--shadow {
  -webkit-box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
  box-shadow: 0 3px 5px rgba(0, 0, 0, .3);
}
/*入会申込み方法
---------------------------------*/
.mySwiper_step {
  background-color: var(--color-w);
}
.swiper.mySwiper_step {
  width: 100%;
  height: 100%;
}
.mySwiper_step .swiper-slide {
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-align: center;
  background: var(--color-w);
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
.mySwiper_step .title {
  font-size: 2.22rem;
  font-weight: 600;
}
.mySwiper_step .subtitle {
  font-size: 2.11rem;
  font-weight: 600;
  padding-bottom: 1em;
}
.mySwiper_step .img img {
  width: 12.5rem;
}
.mySwiper_step .text p {
  text-align: center;
  font-size: 1.11rem;
  padding-top: 1.5rem;
}
.swiper-button-next, .swiper-button-prev {
  --swiper-navigation-color: var(--color-n);
}

/*インスタグラム
---------------------------------*/
#insta h2 img {
  max-width: 40vw;
}
#insta .swiper-slide {
  display: block;
  position: relative;
}
#insta .swiper-slide:before {
  content: "";
  display: block;
  padding-top: 100%;
}
#insta .swiper-slide img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  object-fit: cover;
}
/*体験申込みフォーム
---------------------------------*/
.trial {
  padding: 4rem 1.5rem;
}
#formWrap {
	padding: 2rem 0.9rem 2.3rem 1.2rem !important;
	background-color: var(--color-w)
}
#formWrap table {
 width: 100%;
}
#formWrap table th, #formWrap table td {
  padding: 0.4rem 0.7rem;
  text-align: left;
}
input[type=text], input[type=email], input[type=tel], input[type=datetime-local], input[type=date], textarea, select {
  border: var(--color-gb) solid 2px;
  font-size: 1.1rem;
  margin: 2px 0;
  background: var(--color-w);
  width: calc(100% - 4px);
  padding: 0.5rem 1%;
}
::placeholder {
  color: var(--color-gb);
}
input[type=text].w50,input[type=date].w50,input[type=tel].w50{width: 12rem !important;}
textarea {
  outline: none;
  resize: vertical;
}
#formWrap table td label {
  display: inline-block;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
input[type=text]:hover, input[type=email]:hover, input[type=tel]:hover, input[type=date]:hover, input[type=datetime-local]:hover, textarea:hover {
  background: var(--color-gl);
}
#formWrap table th .require {
  float: right;
  padding: 3px 10px;
  font-size: 0.81rem;
  background: var(--color-r);
  color: var(--color-w);
}
#formWrap table th .norequire {
  float: right;
  padding: 3px 10px;
  font-size: 0.81rem;
  background: var(--color-gb);
  color: var(--color-w);
}
.error {
  color: var(--color-r);
  font-size: 0.94em;
  font-weight: 600;
}
.btn [type=submit] {
  display: inline-block;
  padding: 0.5rem 2rem;
  width: 70%;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  vertical-align: middle;
  font-size: 1.5rem;
  border-left: none;
  border-top: none;
  border-right: none;
  border-radius: 100vh;
  -webkit-border-radius: 100vh;
  -moz-border-radius: 100vh;
  font-weight: 500;
  letter-spacing: 0.1em;
}
.btn.btn--pink [type=submit] {
  color: var(--color-w);
  background-color: var(--color-p);
  border-bottom: 5px solid var(--color-pd);
}
.btn.btn--pink [type=submit]:hover {
  margin-top: 3px;
  border-bottom: 2px solid var(--color-pd);
}
.btn.btn--black [type=submit] {
  color: var(--color-w);
  background-color: var(--color-n);
  border-bottom: 5px solid var(--color-b);
}
.btn.btn--black [type=submit]:hover {
  margin-top: 3px;
  border-bottom: 2px solid var(--color-b);
}
.btn.btn_back [type=submit] {
  color: var(--color-w);
  background: var(--color-g);
  border-bottom: 5px solid var(--color-n);
}
.btn.btn_back [type=submit]:hover {
  margin-top: 3px;
  border-bottom: 2px solid var(--color-n);
}
#output {
  font-size: 1.8rrem;
}
#form {
  padding-top: 3.8rem;
  padding-bottom: 4rem;
}
#formWrap table td label {
  display: inline-block;
  padding-top: 0;
  padding-bottom: 0.4rem;
  padding-right: 0.4rem
}
#formWrap table th, #formWrap table td {
  font-size: 1.11rem;
}
#formWrap table th {
  width: 99%;
  display: block;
  padding: 0.4rem 0.5% 0;
}
#formWrap table td {
  width: 99%;
  display: block;
  padding: 0.4rem 0.5%;
}
@media only screen and (min-width: 680.1px) {
  #formWrap {
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }
}

/*フッター 店舗情報
---------------------------------*/
.shop {
  padding: 4rem 1.5rem;
}
.facilityFoot__info {
  margin-bottom: 1.5rem;
}
.facilityFoot__map {
  height: 0;
  overflow: hidden;
  padding-bottom: 69%;
  position: relative;
  margin-left: auto;
  margin-right: auto;
}
.facilityFoot__map iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}
.facilityFoot__logo {
	text-align: center;
	margin-bottom:1.5rem;
}
.facilityFoot__name {
  font-size: 1.1rem;
  font-weight: 600;
	margin-bottom: 0.6rem;
}

.facilityFoot__address {
  font-size: 0.94rem;
  margin-bottom: 0.6rem;
}
.facilityFoot__table {
  font-size: 0.94rem;
}
.facilityFoot__table tr th {
  text-align: left;
  font-weight: 600;
  padding: 0.1rem 1.8rem 0.1rem 0;
	white-space: nowrap;
	vertical-align: top;
}
.facilityFoot__table tr td span {
  display: inline-block;
}
.facilityFoot__annotation {
  font-size: 0.94rem;
}
#footer {
  clear: both;
  padding: 4rem 0 10rem 0;
  text-align: center;
  font-size: 0.88rem;
}
/*トップへ戻るボタン
-------------------------------------------*/
#to_top {
  position: fixed;
  bottom: 5rem;
  right: 1rem !important;
  z-index: 200;
}
#to_top a {
	width: 2rem;
 color: var(--color-w);
  font-size: 0.75rem;
  text-decoration: none;
  text-align: center;
	display: inherit;
  padding: 0.7rem 0;
	line-height: 2rem;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  letter-spacing: 2px;
  -webkit-transition: 0.5s ease-out;
  -moz-transition: 0.5s ease-out;
  transition: 0.5s ease-out;
}
#to_top a:hover {
  transform: translateY(-5px);
  -webkit-transform: translateY(-5px);
  -moz-transform: translateY(-5px);
}
/* フッターフロートボタン
-------------------------------------------*/
.Bnr {
  position: fixed;
  bottom: 0;
  left: 0;
  margin: 0 auto;
  width: 100%;
  display: none;
  text-align: center;
  z-index: 9;
}
.Bnr .Bnr__img {
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 9;
  text-align: center;
}
.Bnr .Bnr__img ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}
.Bnr .Bnr__img ul li {
  width: 48%;
  padding-right: 1%;
  padding-left: 1%;
	list-style: none
}
.Bnr .Bnr__img ul li a {
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;	
  text-decoration: none;
  color: var(--color-n);
  line-height: 1.3;
  display: block;
  padding: 0.6rem 0.2rem 0.8rem;
  -webkit-transition: 0.5s ease-out;
  -moz-transition: 0.5s ease-out;
  transition: 0.5s ease-out;
}
.Bnr .Bnr__img ul li a:hover {
  transform: translateY(-5px);
  -webkit-transform: translateY(-5px);
  -moz-transform: translateY(-5px);
}
.Bnr .Bnr__img ul li a .top {
  font-size: 1.25rem;
  font-weight: bold;
}
.Bnr .Bnr__img ul li a .btm {
  font-size: 0.94rem;
  display: block;
  height: 0.94rem;
}
.Bnr .Bnr__img ul li a .btm.small {
  font-size: 0.69rem;
	
}
.Bnr .Bnr__img ul li.mail a .top::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 1.94rem;
  height: 1.44rem;
  background: url(../img/ic_mail.svg) no-repeat;
  background-size: contain;
  background-position: top -0.2rem left 0;
  margin-right: 0;
}
.Bnr .Bnr__img ul li.tel a .top::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 1.19rem;
  height: 1.56rem;
  background: url(../img/ic_tel.svg) no-repeat;
  background-size: contain;
  background-position: top 0 left 0;
  margin-right: 0.2rem;
}

@media only screen and (min-width:800px) {
  .Bnr .Bnr__img {
    padding: 0.7rem 1% 0.7rem;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.65);
  }
}
@media only screen and (max-width: 799px) {
  .Bnr .Bnr__img {
    padding: 0;
    width: 100%;
  }
  .Bnr .Bnr__img ul li {
    width: 50%;
    padding-right: 0;
    padding-left: 0;
  }
	Bnr .Bnr__img ul li a {
  padding: 0.6rem 0.1rem;
	}
}