@charset "UTF-8";
/* CSS Document */


/**common**/
.wrap{
	padding-top:50px;
	background:linear-gradient(to bottom, rgba(51,91,124,1) 0%, rgba(72,149,174,1) 55%, rgba(72,149,174,1) 100%);}
html{
	height: 100%;
	background-color:#309eba;
	font-size:62.5%;
	}

body p{	
	font-size:1.5rem;
	line-height: 1.8;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
}

h1 {
	font-size:6rem;
	line-height: 1;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}

h2{
	font-size:4rem;
	line-height:1.75;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}


h3 {
	font-size:2.3rem;
	line-height: 1.75;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
}

h4 {
	font-size:5rem;
	line-height: 1;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}


h5 {
	font-size:2rem;
	line-height: 2.5;
	color:#309eba;
	font-family: 'Arima Madurai', cursive;
	text-align:center;
	font-weight: 300;
}



h7{
	font-size: 2.5rem;
	font-family: 'Arima Madurai', cursive;
	font-weight:200;
	color:#c6ac7b;
	line-height: 2.5;
}

h8 {
	font-size:2rem;
	line-height: 2.2;
	color:white;
	font-family: 'Arima Madurai', cursive;
	text-align:left;
	display:inline-block;
	font-weight: 300;
	margin-right:10%;
}

ul {list-style-type: none;}

a {
	text-decoration: none;
	color:#309eba;}

a:hover{
	color:#c6ac7b;
	opacity:0.5;
}

div{
	display: block;
}

h3, h1, h2{
	text-align: center;
}

/**navigation**/

.header-nav{
	display: flex;
    flex-direction: row;
	justify-content: flex-start;
    align-items: center;
    position: relative;
    height: 80px;
	background: #fff;
	width:100%;
}



.main-nav{
	display: flex;
    flex-direction: row;
    align-items: center;
	justify-content: flex-end;
    position: relative;
    height: 80px;
	background: #fff;
	width:100%;
}


  .logo img {
    height: 75px;
	 width:auto;
	 }


.nav li {
	display:flex;
	flex-direction: column; /* 縦に並べる */
  align-items: center; /* 中央揃え */
	padding-left:25px;
	color:#309eba;
	font-size:1.8rem;
	line-height: 1.5;
	font-family: 'Arima Madurai', cursive;
	font-weight:300;}

.nav li:nth-child(1) {
  padding-left: 22px; /* 任意の値に調整 */
}

.nav li:nth-child(2) {
  padding-left: 22px; /* 任意の値に調整 */
}

	.nav .jp-sub {
  font-size: 1.2rem;
  color: #309eba;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 0.1em;
  line-height: 1.2;
}


.nav{
	width:auto;
	display: flex;
    flex-direction: row;
    align-items: center;}

.trial_lesson .jp{
	display:block;
	text-align: center;
	font-size:1.3rem;
	line-height: 1.3;
	font-weight:200;
	
}

.trial_lesson {
	justify-content: flex-end;
	margin-left:35px;
	vertical-align: middle;
	position: relative;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: solid 5px;
	height: 60px;
	width:260px;
    border-radius: 30px;/*角の丸み*/
	font-size:1.8rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Arima Madurai', cursive;
	font-weight:300;}

.trial_lesson:hover {
	border-color:#c6ac7b;
	filter:none;
	background:#fff;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;}

.button_text:hover{
	color:#c6ac7b;
	border-color:#c6ac7b;
}

  
.nav-button {
  display: none;
}





@media screen and (max-width: 935px) {
	
	
	
	.header-nav{
		justify-content: space-between;
		position:fixed;
		background-color:white;
		z-index: 100;	
		height:60px;
	}
	
	.logo img{
    height: 55px;
	 width:auto;
	padding:5% 3% 0%;  }
	
	.main-nav{
		background-color:white;
		z-index: 100;
		height:60px;}
	
	/* ボタンの配置 */
	.nav-button780{
		text-align: right;
		align-content: center;
	}
	
	/* ハンバーガーボタン */
	.nav-button {
  display: block;
  cursor: pointer;
  border: none;          /* ← デフォルトボーダーを消す */
  background: transparent; /* ← 背景を透明に */
  outline: none;         /* ← フォーカス枠を消す */
  box-shadow: none;      /* ← Safari対策（押した時の光る枠） */
}

/* ブラウザーの仕様打ち消し */
.nav-button:focus,
.nav-button:active {
  outline: none;
  box-shadow: none;
}
	
.nav{
	padding-top:8em;
	height: 5em;
	flex-direction: column;}
	
	 .nav li {
        padding-top: 1.3em;
        padding-right: 1em;
        padding-left: 1em;
        text-align: center;
        background-color: none;
      }
	
      a {
        color: #309eba;
        font-size: 1.8rem;
      }
    
   .nav .jp-sub {
  display: block;
  font-size: 1.2rem;
  color: #309eba;
  font-family: "Noto Sans JP", sans-serif;
  margin-top: 0.1em;
  line-height: 1.2;
  writing-mode: horizontal-tb; /* 横書きに戻す */
}
	
	.trial_lesson {
	margin:0;
	vertical-align: middle;
	position: fixed;
	top: 93%;
	left: 50%;
	transform: translate(-50%, -50%);
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: solid 5px;
	height: 55px;
	width:260px;
    border-radius: 30px;/*角の丸み*/
	font-size:1.8rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Arima Madurai', cursive;
	font-weight:300;}

	
  /*メニューボタンのエフェクト*/
	
  .nav-button {
    position: relative; 
    width: 28px;
    height: 20px;
  }
	
  .nav-button span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #309eba;
    border-radius: 1px;
  }
	
	
	/* ハンバーガー（罰）アイコン */
  .nav-button780{
   position: fixed;
  right: 20px;
  z-index: 2000; 
  will-change: transform;
  transform: translateZ(0); /* ←これが一番重要 */
  }
 
	/* 罰線にも保険で上書きしておく */
.nav-button span {
  position: absolute;
  width: 100%;
  height: 2px;
  background: #309eba;
  border-radius: 1px;
  z-index: 2100; /* ← 念のため追加 */
  transition: all 0.4s ease;
}

  .nav-button span:nth-of-type(1) {
    top: 0px;
  }
  .nav-button span:nth-of-type(2) {
    top: 9px;
  }
  .nav-button span:nth-of-type(3) {
    bottom: 0px;
  }
	
	
  .nav-button780.open .nav-button span:nth-of-type(1) {
    -webkit-transform: translateY(9px) rotate(-45deg);
    transform: translateY(9px) rotate(-45deg);
  }
  .nav-button780.open .nav-button span:nth-of-type(2) {
    opacity: 0;
  }
  .nav-button780.open .nav-button span:nth-of-type(3) {
    -webkit-transform: translateY(-9px) rotate(45deg);
    transform: translateY(-9px) rotate(45deg);
  }


 /*メニューのエフェクト*/

.nav-wrap{
position: fixed;
  top: 0; 
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(255,255,255,0.7); /* ←透過白 */
  backdrop-filter: blur(10px); /* ぼかし効果 */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease;
  z-index: 900; /* 背景用レイヤー */
  transform: translateZ(0); /* ←レイヤー固定 */
 }

/*OPEN時の動き*/
.nav-wrap.open {
  opacity: 1;
  visibility: visible;
}

}

	 
/**key visual**/
.header_visual{
	background: url('../images/class_kv.png');
	background-position: center right;
	background-size:cover;
	background-repeat: no-repeat;
	width: 100%;
  	height: 55vh;
	text-align: center;
	padding-top:20%;
	background-attachment: fixed;
	z-index:1;
	}

@media screen and (max-width: 1024px) and (orientation:portrait) {

.header_visual{background:none;
				padding-top:75%;
				}

.header_visual:before {
  content: "";
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  background: url('../images/class_kv.png') no-repeat right -187px center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
text-align:center;
}

.textwrap{    width: 90%;
    margin-left: 5%;}

.class-photo img{width:100vw;}

}

@media screen and (max-width: 800px) and (orientation:landscape) {

.header_visual{background:none;
				padding-top:30%;
				}

.header_visual:before {
  content: "";
  display: block;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -10;
  background: url('../images/class_kv.png') no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}


}
	
	
	

/**content**/

.wrap{background-color:#309eba;}



.contents {
    width: 80%;
    min-width: 80%;
    padding: 0px ;
    margin: 0 auto;
	text-align: center;
}

.contents::before{
 	display: block;
    height: 0;
    content: "\0020";
    visibility: hidden;
}

.contents::after{
    clear:both;
	display: block;
    height: 0;
    content: "\0020";
    visibility: hidden;
}

.level{display:none;}

.text1{
	margin: 2.8% 5%;
	text-align: left;   
	width: 90%;
}	
.class_photo{
	padding:40px 0px;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.class_photo img{
	width:100%;
}
	
.class_title{
	margin:5% 0% 2% 0%;
}

.text2{
	text-align: center;
	margin-bottom: -2.8%;
}


.enjoy_schedule{
	display:flex;
	}


.class_detail{
    margin-top: 10%;
    padding: 8% 0% 5% 10%;
    background-color: rgba(240,104,179,0.8);}

.class_detail_e{
	width:66%;
	margin:10% 0% 10% 12%;
	padding:10%;
	background-color:#DA936E;}

.class_detail_k{
	width: 67%;
    margin: 10% 0% 10% 12%;
    padding: 8% 8% 12% 10%;
	background-color: rgba(243,145,95,0.85);}

.class_detail ul{
	display:table;
}

.class_detail_k ul{
	display:table;
}

.class_detail li{
	display:table-cell;
}

.class_detail_k li{
	display:table-cell;
}

.class_detail1 p{margin-left:60px;}
.class_detail2 p{margin-left: 78px;}
.class_detailenjoy2 p{margin-left: 93px;}
.class_detail3 .p1{margin-left: 18px;font-weight: bold;}
.class_detail3 .p2{margin-left: -18px;}
.class_detail3 .p3{margin-left: 18px;}
.class_detail3 .p4{margin-left: -18px;}


.class_detailenjoy3 .p1{
    font-weight: bold;
    width: 161px;}
.class_detailenjoy3 .p2{margin-left: -25px;}
.class_detailenjoy3 .p3{margin-left: 5px;}
.class_detailenjoy3 .p4{margin-left: -35px;}

.class_detail5{display:flex;}
.class_detail5 .p1{margin-left: 21px;font-weight: bold;line-height: 2.8;}
.class_detail5 .p2{margin-left: -52px;}
.class_detail5 .p3{margin-left: -18px;}
.class_detail5 .p4{margin-left: -56px;}

.class_detail6{display:flex;}
.class_detail6 h8{margin-left: -25%; margin-right:0%;}
.class_detail6 p{margin-left: 78px;line-height: 2.8;}


.class_detail4{
	margin-left: 64px;
    text-align: left;
}
.class_detail4 .p1{
	font-weight: bold;
}

.class_detailenjoy4{
	margin-left: 64px;
    text-align: left;
	padding-top: 7px;
}

.class_detailenjoy4 .p1{
	font-weight: bold;
}
.clearfix::after{
  content: "";
  display: block;
  clear: both;
}


.kupuna_class{
	clear:both;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.enjoy_class{
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.enjoy_photo{
	float: right;
    margin: -2% -2% 1%;

}

.entry_photo{
	float: left;
    margin: -5% 5% 5%;

}




.kupuna_photo{
	float:left;
	margin: -5% 11% 5%;
}


/***fee_table**/

.fee{
	margin:10% 27% 10%;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}


table.greyGridTable {
  border: 2px solid #FFFFFF;
  width: 100%;
  text-align: center;
  border-collapse: collapse;
margin-top:5%;
}
	
	
table.greyGridTable td, table.greyGridTable th {
  border: 1px solid #FFFFFF;
  padding: 3px 4px;
}
table.greyGridTable tbody td {
  	font-size: 1.8rem;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 200;
}
table.greyGridTable td:nth-child(even) {
  	background-color: rgba(255, 255, 255, 0.2)
}


/* ----------- SMPH ----------- */


@media screen 
	and (max-width: 1024px) and (orientation:portrait)
 {
	 
	 .contents{
		 width:100%;
              padding:30px 0px;
	 }
	 
	
	  img{
		  width:100%;
		  height:auto;
		  text-align: center;
	  }
	  
	  
	  .class_photo{
		  text-align: center;
	  }	

	 .class{margin-bottom: 20%;}	 
	 .enjoy_schedule{display: flex;}
	 
.class_detail{
	
	width:70%;
	margin:0%;
	padding:10% 10% 10% 20%;
	background-color:rgba(240,104,179,0.8);}
	 
	 .class_detail ul{display:block;}

.class_detail_k{
	width:58%;
	margin:0%;
	padding:10% 10% 10% 32%;
	background-color:rgba(243,145,95,0.85);}
	 
	.class_detail_e {
    width: 54%;
    margin: 0%;
    padding: 5% 23%;
    background-color: #DA936E;
}
	 
	.class_detailenjoy4 {
    padding: 0% 12% 0% 14%;
    margin: 0%;
    width: 47%;
}
	  
	  .text1{
		  text-align: left;
		 margin: 3% 5% 3% 5%;
	  }
	 
	 .text2{
		  text-align: left;
		  margin: 3% 20%;
          width: 60%;
	  }
	  
	 
	  .fee{
		  margin: 0;
        padding: 0% 10% 13% 10%;
	  }
	  
.entry_photo{
	float:none;
	padding:0;
	margin:0;
}
.enjoy_photo{
	float:none;
	padding:0;
	margin:0;
}


.kupuna_photo{
	float:none;
	padding:0;
	margin:0;
}
	 
	 }


@media screen 
	and (max-width: 770px) and (orientation:portrait)
 {
	 
	 
	 
	 
.fee {
    margin: 0;
	padding: 0% 10% 13% 10%;}
	 
	 
	 
	 
	 .class_detail {
    width: 90%;
    margin: 0%;
    /* padding: 10% 10% 10% 20%; */
		 background-color: rgba(240,104,179,0.8);}
	 


.class_detail_k{
	margin-left:0;
	width:60%;
	margin-top:5%;
	padding:10% 10% 10% 30%;
	background-color:rgba(243,145,95,0.85);}
	 

.enjoy_photo{
	float:none;
	padding:0;
	margin:0%;
}


.kupuna_photo{
	float:none;
	padding:0;
	margin:0;
}

.text1{
		  text-align: left;
		 margin-bottom: 5%;
    width: 90%;
    margin-left: 5%;
	  }
	 
	 .text2{
		  text-align: left;
		  margin-bottom: 5%;
    width: 90%;
    margin-left: 5%;
	  }

	 
	.enjoy_schedule{display:flex;}
	.class_detail_e{
	margin:0%;
	padding:5%;
	background-color:#DA936E;}
	 
	 .class_detailenjoy4{
		 width:254px;
		 padding-left:100px;
		 margin:0%;
	 } 
	 
	 .class_detail_e {
    width: 34%;
    margin: 0%;
    padding: 5% 33%;
    background-color: #DA936E;
}
	 
	 /*.class_detail_e {
    width: 50%;
    margin: 0%;
    padding: 5% 25%;
	 background-color: #DA936E;}*/


.class_detail {
    width: 82%;
    margin: 0%;
    padding: 7% 8% 7% 10%;
    background-color: rgba(240,104,179,0.8);}
	
	.class_detail_k {
    width: 55%;
    margin: 0%;
    padding: 10% 10% 6% 35%;
	background-color: rgba(243,145,95,0.85);}
	
	
	 
	 }
	
@media screen 
	and (max-width: 440px) and (orientation:portrait)
 {
	 .class_detail_k {
    width: 63%;
    margin: 0%;
    padding: 10% 10% 10% 27%;
    background-color: rgba(243,145,95,0.85);
}
	 
.class_detail6 {
    display: flex;
	padding-left: 6px;}
	
.enjoy_schedule{display:block;}

.class_detail_e {
    width: 70%;
    margin: 0%;
    padding: 5% 15%;
	background-color: #DA936E;}
	 
.class_detail_k {
   width: 69%;
    margin: 0%;
    padding: 10% 11% 10% 20%;
	background-color: rgba(243,145,95,0.85);}
	 
.class_detailenjoy4{
		 width:161px;
		 padding-left:132px;
		 margin:0%;
	 }  
	 
.fee{margin: 0;
		 padding: 0% 0% 13% 0%;}

}
	 


/****calendar

.class_schedule{
	margin:17% 0%;
}

.calendar{
	display: block;
	margin:5% 27%;
}

.month_name,.year_name {
	font-family: 'Arima Madurai', cursive;
	font-size:2.5rem;
	line-height: 1.75;
	color:white;
  	display: block;
  	font-weight: 400;
}

.week_name time {
 	width: 60px;
	margin: 2px 0;
	font-size:2rem;
	text-align: center;
	display: inline-block;
	border: 1px solid transparent;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight: 300;
}

.week_name:first-of-type {
  text-align: right;
}

.month {
  float: left;
}

.week {
  display: block;
}

.week time {
 	width: 60px;
	height:30px;
	font-size: 2rem;
	margin: 2px 0;
	text-align: center;
	vertical-align: middle;
	display: inline-block;
	border: 1px solid white;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight: 300;
}

.week:first-of-type {
  text-align: right;
}

***/

 
/**footer**/


.footer{
	clear:left;
	background-color: #fff;
	width:100%;
}

.footer p{
	color:#444444;
	font-size: 1.5rem;
	line-height: 1.5;
	font-family: 'Noto Sans Japanese';
	font-weight:100;
}

.footer_sub{
	display:flex;
	justify-content: space-evenly;
	-webkit-justify-content:space-evenly;
	vertical-align: middle;
	padding-bottom:5%;
}

.footer_connect{
	display:inline-block;
	padding:8% 0% 0%;
	vertical-align: middle;
}


.footer_contact{
	padding:8% 0% 0%;
	vertical-align: middle;
	text-align: center;
}


.contact_list, h5{
	text-align: center;
}

.sns_icon, h5{
	text-align: center;
}

.footer p{
	color:#444444;
	font-size: 1.5rem;
	line-height: 1.5;
	font-family: 'Arima Madurai', cursive,'Noto Sans Japanese';
	font-weight:100;
}

.cell_num p{
	text-align: center;
/*	width:110px;*/
	white-space: nowrap;
}

.mail_add p{
	text-align: center;
/*	width:100px;*/
	white-space: nowrap;
}
.contact_list ul {
	display: block;
}

.icon,.phone_mail{
	text-align: center;
	vertical-align: middle;
}

.footer_contact, .footer_connect i{
	color:#309eba;
	font-size:2.6rem;
}

.icon li{
	padding:42% 0%
}

.phone_mail li{
	padding:5%;
}

.footer_connect li{
	display:inline-block;
	padding-top:20px;
	padding-left:20px;
	padding-right:20px;
}

.to_top_icon i{
	color:#309eba;
	font-size:3rem;
	line-height:1.75;
	font-weight: 600;
	margin:1%;
	background-color:transparent;
}

.to_top_icon{
	display: -webkit-flex;
    display: flex;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    -webkit-align-items: flex-end;
    align-items: flex-end;
	padding-right:10px;
	padding-bottom:5px;
}

.copyright{
	display:block;
	font-size: 1.2rem;
	line-height: 1.5;
	font-family: 'Arima Madurai', cursive;
	font-weight:100;
	color:#444444;
	text-align: center;
}
	  



@media screen and (max-width: 900px) {
	
	.footer_sub{
	display:block;
}

.footer_connect{
	display:block;
	padding:5%;
}


.footer_contact{
	display:block;
	text-align: center;
}


.contact_list, h5{
	text-align: center;
}

.sns_icon, h5{
	text-align: center;
}

.footer p{
	color:#444444;
	font-size: 1.5rem;
	line-height: 1.5;
	font-family: 'Arima Madurai', cursive,'Noto Sans Japanese';
	font-weight:100;
	margin:0;
}

.contact_list ul {
	display: inline-block;
}

.icon,.phone_mail{
	text-align: left;
	vertical-align: middle;
}
	
	.phone_mail{
		width:140px;
	}

.footer_contact, .footer_connect i{
	color:#309eba;
	font-size:2.6rem;
}

.footer_contact li{
	padding:5% 13%;}

	.icon li{
		padding:35%;
	}


.footer_connect li{
	display:inline-block;
	padding-top:20px;
	padding-left:20px;
	padding-right:20px;
	}

}
	
	
#myBtn {
    bottom: 2%; /* Place the button at the bottom of the page */
    margin-left:93%; /* Place the button 30px from the right */
    z-index: 99; /* Make sure it does not overlap */
    border: none; /* Remove borders */
    outline: none; /* Remove outline */
    cursor: pointer; /* Add a mouse pointer on hover */
    padding: 0px; /* Some padding */
    font-size: 2.5rem; /* Increase font size */
	color:#309eba;
	background-color:transparent;
}

#myBtn:hover {
    background-color: none; /* Add a dark-grey background on hover */
	opacity: 0.5;
}	
	
.copyright p{
	display:block;
	font-size: 1.2rem;
	line-height: 1.5;
	font-family: 'Arima Madurai', cursive;
	font-weight:100;
	color:#444444;
	text-align: center;
}

/* ---------------
___added 2022_11
------------------ */
/* ___padding */
.pd_side_3{
	padding-right: 3%;
	padding-left: 3%;
}

.pdB_5em{
	padding-bottom: 5em;
}

/*.pdT_3em{
	padding-top: 3em;
}*/

.pdT_5em{
	padding-top: 5em;
}

.pdT_2em{
	padding-top: 2em;
}

/* ___text style */
.word-nowrap{
	display: inline-block;
}

.textC{
	text-align: center;
}

.textL{
	text-align: left;
}

.textR{
	text-align: right;
}

a{
	transition: all .6s ease;
}

.text_uLine{
	text-decoration: underline;
	font-size: inherit!important;
}

.text_uLine:link,
.text_uLine:visited{
	color: #fff;
}

/* ___width */
.wLimited{
	max-width: 1680px;
  	margin-right: auto;
  	margin-left: auto;
  	overflow: hidden;
  	box-sizing: border-box;
}

.content-w70p{
	width: 70%;
	margin-right: auto;
	margin-left: auto;
	min-width: 750px;
	max-width: 1030px;
}
@media screen and (max-width: 768px) {
	.content-w70p{
		width: 100%;
		min-width: initial;
		max-width: initial;
	}
	_:-ms-lang(x)::-ms-backdrop,.content-w70p{
		min-width: auto;
		max-width: auto;
	}
}

.content-w86p{
	width: 86%;
	min-width: 750px;
	margin-right: auto;
	margin-left: auto;
}
@media screen and (max-width: 767px) {
	.content-w86p{
		width: 100%;
		min-width: initial;
	}
	_:-ms-lang(x)::-ms-backdrop,.content-w86p{
		min-width: auto;
	}
}

.display_b_sp{
	display: none;
}
@media screen and (max-width: 500px) {
	.display_b_sp{
		display: block;
	}
}

/* ___modBlock */
.modBlock-pageTop {
	padding-top: 70px;
	padding-bottom: 100px;
  }
  @media screen and (max-width: 500px) {
	.modBlock-pageTop {
	  padding-top: 60px;
	  padding-bottom: 0px;
	}

	section#KEIKI.wLimited {
	  padding-bottom: 60px;
	}
  }

  .modBlock-noB {
	padding-top: 70px;
  }
  @media screen and (max-width: 500px) {
	.modBlock-pageTop {
	  padding-top: 60px;
	  padding-bottom: 0px;
	}
  }

/* ___title */
h2.modTitle-two{
	text-align: center;
	font-size:6rem;
	display: inline-block;
	padding-top: .7em;
	position: relative;
	margin-bottom: 1em;
/*	line-height: 1;*/
	line-height: 1.3;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}
@media screen and (max-width: 767px) {
h2.modTitle-two{
	text-align: center;
	font-size:4rem;
	display: inline-block;
	/*padding-top: 1.7em;*/
	position: relative;
	margin-bottom: .3em;
/*	line-height: 1;*/
	line-height: 1.3;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}
.modTitle-two{
		font-size: 34px;
	}
}

@media screen and (max-width: 477px) {
h2.modTitle-two{
	text-align: center;
	font-size:3.8rem;
	display: inline-block;
	padding-top: 1.7em;
	position: relative;
	margin-bottom: .3em;
/*	line-height: 1;*/
	line-height: 1.3;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:400;
}
}

	


h2 span.modTitle-two-jp{
	font-size:1.7rem;
	line-height: 2;
	color:#fff;
	font-family: 'Noto Sans Japanese', sans-serif;
  	font-weight: 200;

}
/*@media screen and (max-width: 767px) {
	.modTitle-two-jp{
		font-size: 23px;
	}
}*/

h2.modTitle-two.columns,
h2.modTitle-two.workshop,
h2.modTitle-two.price{
	line-height: 1.2;
	display: block;
/*	width: 100%; */
	padding-top: .6em;
}

h2.modTitle-two.gracious,
h2.modTitle-two.wahine,
h2.modTitle-two.kupuna,
h2.modTitle-two.keiki{
	line-height: 1.2;
	display: block;
	margin-right: auto;
	margin-left: auto;
}
@media screen and (max-width: 790px) {
h2.modTitle-two.gracious,
{width: 400px;
	}
}

@media screen and (max-width: 767px) {
h2.modTitle-two.wahine,
h2.modTitle-two.kupuna,
h2.modTitle-two.keiki{
		width: auto;
	}
}
@media screen and (max-width: 600px) {
h2.modTitle-two.gracious,{
	width: 300px;
	}
}

@media screen and (max-width: 477px) {
h2.modTitle-two.gracious,
h2.modTitle-two.wahine,
h2.modTitle-two.kupuna,
h2.modTitle-two.keiki{
		width: 160px;
	}
}



h2.modTitle-two::before {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
/*	padding-left: 18px;
	margin-left: -9px;*/
	line-height: 1;
  }

h2.modTitle-two.columns::before{
	content: 'Columns';
}

h2.modTitle-two.workshop::before{
	content: 'Workshop';
}

h2.modTitle-two.gracious::before{
	content: 'Gracious Class';
	line-height: 1.1;
}

h2.modTitle-two.price::before{
	content: 'Fee';
}

h2.modTitle-two.wahine::before{
	content: 'Wahine Class';
	line-height: 1.1;
}

h2.modTitle-two.kupuna::before{
	content: 'Kupuna Class';
	line-height: 1.1;
}

h2.modTitle-two.keiki::before{
	content: 'Keiki Class';
	line-height: 1.1;
}

h3.modTitle-three{
	font-size:inherit;
	color:#fff;
	font-family: 'Noto Sans Japanese', sans-serif;
  	font-weight: 600;
	margin-bottom: 1.7em;
	margin-top:1em;
	text-align: left;
}
@media screen and (max-width: 767px) {
	h3.modTitle-three{
/*		text-align: center;*/
		font-size: 17px;
	}
}

/* ___intLink */
.intLink-list__wrap{
	margin-bottom: 100px;
/*	width: 80%;
	margin-right: auto;
	margin-left: auto;*/
}
@media screen and (max-width: 500px) {
	.intLink-list__wrap{
		margin-bottom: 60px;
/*		width: 100%;*/
	}
}

.intLink-list{
	display: flex;
	justify-content: space-evenly;
	align-items: flex-end;
}
/*@media screen and (max-width: 500px) {
	.intLink-list{
		
	}
}*/

.intLink-list__item{
	width: 100%;
/*	font-size: 12px!important;*/
	text-align: center;
}

a.intLink-list__item--a{
/*	width: 100%;*/
/*	height: 100%;*/
	transition: all .6s ease;
	font-size: 14px!important;
	display: inline-block;
	position: relative;
}
@media screen and (max-width: 500px) {
	a.intLink-list__item--a{
		font-size: 12px!important;
	}
}

.intLink-list__item--a::after{
	content: '';
	position: absolute;
	bottom: -1em;
	left: 50%;
	transform: translateX(-50%) rotate(45deg);
	width: 0.6em;
	height: 0.6em;
	border-right: 2px solid #fff;
	border-bottom: 2px solid #fff;
}

.intLink-list__item--a:link,
.intLink-list__item--a:visited{
	color: #fff;
}

@media screen and (max-width: 500px) {
	.intLink-list__item--a:link,
	.intLink-list__item--a:visited,
	.intLink-list__item--a:hover{
		opacity: 1;
	}
}

/* img */
img {
	border-style: none; /* 1 */
	width: 100%;
	max-width: 100%;
	vertical-align: bottom;
  }

.objectFit_img {
	height: 100%;
	object-fit: cover;
}

/* ___flex */
.class-fl{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-right: 3%;
	padding-left: 3%;
}
@media screen and (max-width: 767px) {
	.class-fl{
		flex-direction: column;
		padding-right: 0;
		padding-left: 0;
	}
}

.class-fl__fig{
	align-self: stretch;
	width: 37%;
	aspect-ratio: 16 / 9;
}
@media screen and (max-width: 767px) {
	.class-fl__fig{
		width: 100%;
		margin-bottom: 30px;
	}
}

.class-fl__text{
	font-size: 16px;
	width: 58%;
	color: #fff;
}
@media screen and (max-width: 767px) {
	.class-fl__text{
		font-size: 14px;
		width: 94%;
		margin-right: auto;
		margin-left: auto;
	}
}

.class-fl__text a:link,
.class-fl__text a:visited{
	color: #fff;
	font-size: inherit;
}

.class-fl__text p{
	font-weight: 400!important;
}

.class-fl__text--listItem{
	margin-bottom: 1em;
	line-height: 1.4;
}

.detail-fl{
	margin-top: 50px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-right: 3%;
	padding-left: 3%;
}
@media screen and (max-width: 767px) {
	.detail-fl{
		margin-top: 40px;
		flex-direction: column;
		padding-right: 0;
		padding-left: 0;
	}
}

.detail-fl__text a:link,
.detail-fl__text a:visited{
	color: #fff;
	font-size: inherit;
}

.detail-fl p{
	font-weight: 400!important;
}

.detail-fl__fig{
/*	align-self: stretch;*/
/*	width: 37%;*/
	width: 45%;
	aspect-ratio: 16 / 9;
}
@media screen and (max-width: 767px) {
	.detail-fl__fig{
		display: none;
/*		width: 100%;
		margin-bottom: 30px;*/
	}
}

.detail-fl__text{
	font-size: 16px;
/*	width: 58%;*/
	width: 45%;
	color: #fff;
}
@media screen and (max-width: 767px) {
	.detail-fl__text{
		font-size: 14px;
		width: 94%;
		margin-right: auto;
		margin-left: auto;
	}
}

.detail-fl__text>h3.modTitle-three{
	margin-bottom: 1em;
}

.priceList{
	display: inline-block;
}

.priceList__item{
	font-size: 20px;
	color: #fff;
	margin-bottom: 0.8em;
}
@media screen and (max-width: 767px) {
	.priceList__item{
		font-size: 16px;
		color: #fff;
	}
}

.priceList__item--dl{
	display: flex;
}

.textIndent_dot{
	position: relative;
	padding-left: 1em;
}
/*@media screen and (max-width: 500px) {
	.textIndent_dot{
		padding-left: 0;
	}
}*/

.textIndent_dot::before{
	position: absolute;
	left: 0;
	content:'・';
	width: 1em;
	height: 1em;
}

.classDetail__p{
	margin-top: 1.5em;
	font-size: 16px;
}
@media screen and (max-width: 767px) {
	.classDetail__p{
		font-size: 14px;
	}
}

.detail-fl__text>.classDetail__p{
	margin-top: 1em;
}

/* ___footer */
.footer_connect_icon{
	width: 2.6rem;
	display: inline-block;
  }

  .footer_connect_icon img{
	width: 100%;
  }

.footer_connect li{
	vertical-align: middle;
} 

.footer_access{
	margin:20px 0px 60px;
	text-align: center;
}

.footer_logo img{
	display: flex;
	padding-top:50px;
	margin:auto;
	height:90px;
	width:auto;
