
html {
  font-size: 2.5vw;
}

@media screen and (min-width: 750px) {
  html{
    font-size:calc( 750 / 400 * 10px);
  }
}

/* pcの電話番号発信対応 */

/* ホバー */
a {
  text-decoration: none;
  color: inherit;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}



/* Remove default padding */
ul,
ol {
  padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Set core root defaults */
html {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* Remove list styles on ul, ol elements with a class attribute */
ul,
ol {
  list-style: none;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}


/* Natural flow and rhythm in articles by default */
article > * + * {
  margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}


/* Remove all animations and transitions for people that prefer not to see them */
/* フォームリセット */
input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}


body {
  font-family: 'Lato', 'Noto Sans JP', '游ゴシック Medium', '游ゴシック体', 'Yu Gothic Medium', YuGothic, 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	margin: auto;
  max-width: 750px;
}

span{
	display: inline-block;
}

img{
  max-width: 100%;
  vertical-align: bottom;
  line-height: 1.0em;
}

/* 汎用 */
.sans-serif{
	font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}

/* ヘッダー */
#header_2208 {
  max-width: 750px;
  width: 100%;
  z-index: 99;
  position: sticky;
  top: 0;
  left: 0;
  background-color: #000;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}


.header_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.header_logo {
  width: 20%;
  height: auto;
  padding-top: 10px;
}

.header_logo_2208 {
  width: 30%;
  height: auto;
  padding-top: 5px;
}

.header_logo img {
  width: 100%;
  height: 100%;
}

.header_logo_2208 img {
  width: 35%;
  height: 100%;
}

.header_body {
  font-size: 0;
  width: 45%;
  padding-top: 7px;
}

.header_body_2208 {
  font-size: 0;
  width: 45%;
  padding-top: 0px;
}

.header_body img,
.header_body_2208 img {
  width: 100%;
  height: 100%;
}

#map {
  height: 0;
  overflow: hidden;
  padding-bottom: 55%;
  position: relative;
  width: 100%;
}

#map iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  }

#address {
  position: relative;
  padding: 9px 20px 45px;
  text-align: center;
}

#address img {
  width: 40%;
  margin-bottom: 30px;
}

#address_address {
  text-align: center;
  margin: 10px auto;
  line-height: 1;
}

#address_tel {
  text-align: center;
  margin-top: 7px;
  margin-bottom: 10px;
  line-height: 1.4;
}

#address_tel span {
  font-size: 22px;
}

/* フッター */
#footer {
  background-color: #000;
  margin-top: 4px;
  padding: 10px 0px;
/*  padding-bottom: 5%; */
  text-align: center;
  color: white;
}

#footer_company {
  margin-top: 16px;
  letter-spacing: 1px;
  font-weight: 200;
}

#floating_line_button {
  z-index: 1;
  max-width: 750px;
  width: 100%;
  position: fixed;
  bottom: 43vw;
  right: calc(-890 / 1160*100vw);
/*  transform: translateX(-50%); */
}

#floating_reserve_button {
  z-index: 1;
  max-width: 750px;
  width: 100%;
  position: fixed;
  bottom: 20vw;
  right: calc(-890 / 1160*100vw);
/*  transform: translateX(-50%); */
}

.footer_link {
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
  padding: 10px;
  font-size: 1rem;
}

.footer_link a {
  position: relative;
  display: inline-block;
  padding: 0 1.5em;
}

.footer_link a + a::before {
  content: "|";
  color: #fff;
  display: block;
  position: absolute;
  left: 0;
  top: 0;
}

@media screen and (min-width: 750px) {
  .footer_link {
    font-size: 1rem;
  }
  #floating_reserve_button,
  #floating_line_button {
    bottom: 105px;
    right: calc( (100vw - 1160px) / 2 + -375px );
  }
  #floating_line_button {
    bottom: 275px;
  }

  #floating_reserve_button img,
  #floating_line_button img {
    width: 150px;
  }
}


#floating_reserve_button img,
#floating_line_button img {
  width: 22%;
  height: 100%;
}

#floating_reserve_button button,
#floating_line_button button {
  outline: none;
}

#floating_reserve_button button:focus,
#floating_line_button button:focus,
button:hover {
  outline: none;
}

/* 入会・体験予約はコチラから */
.yoyaku {
  padding-top: 20px;
  padding-bottom: 30px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #000;
  color: #53E926;
  text-align: center;
  font-size: 12px;
}

.yoyaku_ttl {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 3px;
  padding: 5px;
}

.yoyaku_btn {
  display: block;
  width: 100%;
  height: auto;
  margin-right: auto;
  margin-left: auto;
}

.yoyaku_btn img {
  width: 80%;
  height: 100%;
  padding: 10px;
}

@media screen and (min-width: 750px) {
  .yoyaku {
    padding-top: 30px;
    padding-bottom: 50px;
    font-size: 18px;
  }
  .yoyaku_ttl {
    font-size: 30px;
  }
}

/* ファーストビュー */
.fv {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.fv_main {
  width: 100%;
  height: auto;
  position: relative;
}


.fv_main img {
  width: 100%;
  height: 100%;
}

/* 入会キャンペーン */
.cp {
  font-size: 18px;
  margin: 0;
  padding: 0;
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #fff;
  text-align: center;
}

@media screen and (min-width: 750px) {
  .cp {
    padding: 0;
  }
}

.cp img {
  max-width: 100%;
}


.cp_txt {
  font-weight: bold;
  padding: 20px 0;
}
.cp_txt span {
  display: inline; /*複数行対応*/
	background-image: linear-gradient(rgba(0,0,0,0) 85%, rgb(83,233,38) 85%);
}

.cp_txt2 {
  font-size: 25px;
  font-weight: bold;
}

.cp_txt3 {
  font-size: 12px;
  font-weight: bold;
}

.cp_naiyou {
  font-size: 15.5px;
  color: #000;
  background-color: #53E926;
  letter-spacing: 0.03em;
  text-align: center;
  font-weight: bold;
  padding: 30px 0;
  margin:20px 50px;
}

.cp_catch1 {
  font-size: 25px;
  color: #fff;
  width: 65%;
  padding: 5px;
  background-color: #000;
  margin: 20px auto 10px auto;
  font-weight: bold;
  border-radius: 100px;
}

.cp_catch2{
  font-size: 20px;
  border-bottom: 3px solid #000;
  margin: 10px auto;
  font-weight: bold;
  display: inline-block;
}

.cp_naiyou .txt {
  font-size: 18px;
}

.cp_naiyou .attention {
  font-size: 10px;
}

@media screen and (min-width: 750px) {
  .cp {
    font-size: 25px;
  }

  .cp_naiyou {
      font-size: 25px;
      margin:30px 90px;
  }

  .cp_catch1 {
    font-size: 30px;
    width: 50%;
  }

  .cp_catch2 {
    font-size: 30px;
  }

  .cp_naiyou .txt {
    font-size: 28px;
  }

  .cp_naiyou .attention {
    font-size: 15px;
  }

  .cp_txt2 {
    font-size: 30px;
  }

  .cp_txt3 {
    font-size: 15px;
  }

}

/* concept */
.concept {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #54E926;
  padding-bottom: 50px;
}

.concept h2 {
  padding: 30px 0;
}

.concept img {
  width: 100%;
  height: 100%;
}

.concept_syosai {
  font-size: 15px;
  text-align: center;
  letter-spacing: 0.1em;
  color: #000;
  line-height: 2;
}

.concept_syosai img {
  width: 80%;
  height: 100%;
  margin-top: 30px;
}

.concept_syosai .catch {
  font-size: 25px;
  letter-spacing: 0.2em;
  text-align: center;
  font-weight: bold;
}

/* 施設情報 */
.facility {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #000;
  color: #53E926;
  padding-bottom: 50px;
}

.facility h2 {
  padding-top: 30px;
  padding-bottom: 10px;
}

.facility img {
  width: 100%;
  height: 100%;
  margin-bottom: 20px;
}

.facility_syosai {
  font-size: 22px;
  text-align: center;
  padding: 20px 0;
}

.facility_syosai img {
  width: 80%;
  height: 100%;
}

.facility_syosai .catch {
  font-size: 28px;
  letter-spacing: 0.1em;
  text-align: center;
  font-weight: bold;
  padding-bottom: 20px;
}

/* PRICE */
.price {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.price h2 {
  padding: 30px 0;
}

.price img {
  width: 100%;
  height: 100%;
}

.price_catch {
  font-size: 26px;
  text-align: center;
  letter-spacing: 0.1em;
  color: #53E926;
  width: 60%;
  padding: 10px;
  background-color: #000;
  margin: 10px auto 25px auto;
  font-weight: bold;
}

.price_syosai {
  font-size: 25px;
  text-align: center;
  font-weight: bold;
  padding: 20px 0;
}

.price_syosai .ryoukin{
  margin: 20px auto;
}

.price_syosai img {
  width: 65%;
  height: 100%;
}

.price_syosai .monthly {
  font-size: 30px;
  text-align: center;
  color: #000;
  width: 60%;
  padding: 5px;
  background-color: #fff;
  border: 3px solid #000;
  margin: 0 auto;
  font-weight: bold;
  border-radius: 100px;
}

.price_syosai .catch {
  font-size: 38px;
  letter-spacing: 0.03em;
  text-align: center;
  font-weight: bold;
  letter-spacing: 3px;
}

.price_syosai .txt {
  display: inline; /*複数行対応*/
  letter-spacing: 0.1em;
	background-image: linear-gradient(rgba(0,0,0,0) 85%, rgb(83,233,38) 85%);
}

.price_syosai .muryou{
  width: 80%;
  margin: 20px auto;
}

.price_syosai .cp {
  background-color: #54E926;
  padding: 10px 0;
  margin-bottom: 20px;
}

.price_syosai .all {
  font-size: 35px;
  text-align: center;
  letter-spacing: 0.1em;
  color: #53E926;
  width: 60%;
  padding: 5px;
  background-color: #000;
  margin: 20px auto;
  font-weight: bold;
  border-radius: 100px;
}

.h-water {
  background-color: #000;
  text-align: center;
}

.h-water img {
  width: 80%;
}

@media screen and (min-width: 750px) {
  .price_catch, .price_syosai {
    font-size: 35px;
    }
}

/* コロナ感染対策 */
.corona {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background-color: #53E926;
  color: #000;
}

.corona h2 {
  padding: 30px 0;
}

.corona img {
  width: 100%;
  height: 100%;
}

.corona_syosai {
  font-size: 25px;
  text-align: center;
  font-weight: bold;
  padding-bottom: 20px;
}

.corona_syosai .kasen {
display: inline; /*複数行対応*/
background-image: linear-gradient(rgba(0,0,0,0) 70%, rgb(156,244,124) 70%);
margin-bottom: 50px;
}

.corona_syosai img {
  width: 80%;
  height: 100%;
}

.corona_syosai .onegai {
  font-size: 21px;
  text-align: center;
  letter-spacing: 0.1em;
  color: #fff;
  width: 60%;
  padding: 5px;
  background-color: #000;
  margin: 20px auto;
  font-weight: bold;
  border-radius: 100px;
}

.corona_syosai .txt1 {
  font-size: 10px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  margin: 30px;
}

.corona_syosai .txt2 {
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  margin: 30px;
}

@media screen and (min-width: 750px) {
  .corona_syosai, .corona_syosai .onegai {
    font-size: 35px;
    }
  .corona_syosai .txt1 {
    font-size: 15px;
    }
  .corona_syosai .txt2 {
    font-size: 18px;
  }
}

/* スタッフ紹介 */
.staff {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.staff h2 {
  padding: 30px 0;
}

.staff img {
  width: 100%;
  height: 100%;
}

.staff_syosai {
  width: 90%;
  height: 480px;
  margin: auto;
  padding: 10px 0;
  position: relative;
  overflow: hidden;
  background-color:#fff;
}

.staff_syosai_2208 {
  height: 550px;
}

.staff_syosai:nth-child(2) {
  height: 275px;
  margin-top: 30px;
}

.staff_syosai:nth-child(2) span{
  display: initial;
}

.staff_syosai::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  border-top: 240px solid #c3deff;
  border-left: 180px solid transparent;
}

.staff_syosai::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  border-bottom: 240px solid #c3deff;
  border-right: 180px solid transparent;
}

.staff_syosai:nth-child(2)::before {
  border-top: 240px solid #ffd2ca;
}

.staff_syosai:nth-child(2)::after {
  border-bottom: 240px solid #ffd2ca;
}

.staff_img {
  width: 36%;
  position: absolute;
  top: 3%;
  right: 3%;
}

.staff_naiyou {
z-index: 1;
}

.staff_naiyou dl {
  margin: 5%;
  font-size: 13px;
  font-weight: bold;
  position: absolute;
  z-index: inherit;
}

.staff_naiyou dd {
  padding-bottom: 1em;
}

@media screen and (min-width: 750px) {
  .staff_syosai {
    height: 700px;
  }

  .staff_syosai_2208 {
    height: 800px;
  }

  .staff_naiyou dl {
    margin: 5%;
    font-size: 20px;
  }

  .staff_syosai:nth-child(2) {
    height: 400px;
    margin-top: 50px;
  }

  .staff_syosai:nth-child(2) span{
    display: inline-block;
  }
}

@media screen and (min-width: 550px) {
  .staff_syosai:nth-child(2) span{
    display: inline-block;
  }
}

/* 店舗情報 */
.shop {
  margin-right: auto;
  margin-left: auto;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.shop h2 {
  padding: 30px 0;
}

.shop img {
  width: 100%;
  height: 100%;
}

.shop_catch {
  font-size: 20px;
  text-align: center;
  color: #53E926;
  width: 50%;
  padding: 5px;
  background-color: #000;
  margin: 30px auto 20px auto;
  font-weight: bold;
  border-radius: 100px;
}

.shop_syosai {
  text-align: center;
  padding: 10px 0 30px 0;
}

.shop_syosai img {
  width: 70%;
  height: 100%;
}

@media screen and (min-width: 750px) {
  .shop_catch {
    font-size: 30px;
    }
}
