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


/**common**/

html{
	height: 100%;
	background:linear-gradient(220deg, rgb(51, 91, 124) ,rgb(72, 149, 175))fixed;
	font-size:62.5%;
	}


.wrap{
	height: 100%;
	background:linear-gradient(220deg, rgb(51, 91, 124) ,rgb(72, 149, 175))fixed;
	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: 200;
}

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

.text-paragraph{
	font-size:1.4rem;
	line-height: 1.8;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 200;
	/*text-align: center;*/
	margin: 2em 0 2em;
}

a{
	transition: all ease .3s;
}

a:hover{
	opacity: .8;
}

.link-white:link,
.link-white:active,
.link-white:visited{
	color: #fff;
}

.fz-textLink{
	font-size: 1.5rem;
}

.textC{
	text-align: center;
}

.display_b{
	display: block;
}

.display_ib{
	display: inline-block;
}

.mgAutoRL{
	margin-right: auto;
	margin-left: auto;
}

.ttl-mgT{
	margin-top: 1em;
}

.parag-mgT{
	margin-top: 1.5em;
}

.block-mgT{
	margin-top: 6em;
}

.page-pdT{
	padding-top: 2em;
}

.img-wrap{
	display: block;
	width: 100%;
	max-width: 520px;
	margin-top: 3%;
	margin-right: auto;
	margin-left: auto;
}

.img-wrap img{
	border-style: none;
    width: 100%;
    max-width: 100%;
    vertical-align: bottom;
}

.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;
    }
}

.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: 1 / 1;
}
@media screen and (max-width: 767px) {
	.class-fl__fig{
		width: 100%;
		margin-bottom: 30px;
	}
}

.class-fl__fig img{
	border-style: none;
    width: 100%;
    max-width: 100%;
    vertical-align: bottom;
}

.class-fl__fig.youTube{
/*	align-self: stretch;*/
    width: 48%;
aspect-ratio: 16 / 9;
}





@media screen and (max-width: 767px) {
	.class-fl__fig.youTube{
		width: 94%;
		margin-bottom: 30px;
		margin-right: auto;
		margin-left: auto;
	}
}


.prize{
	font-size: 1.5rem;
    line-height: 1.8;
    color: white;
    font-family: 'Noto Sans Japanese', sans-serif;
    font-weight: 200;
    text-align: center;
}

.class-fl__fig.youTube iframe{
	width: 100%;
	aspect-ratio: 16/9;
}

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

.objectFit_img img{
	border-style: none;
    width: 100%;
    max-width: 100%;
    vertical-align: bottom;
}

.class-fl__text{
	font-size: 16px;
    width: 58%;
    color: #fff;
	line-height: 1.8;
	font-weight: 200;
}

.class-fl_voice_text{
	font-size: 20px;
    width: 58%;
    color: #fff;
	line-height: 1.8;
	font-weight: 200;
}

@media screen and (max-width: 767px) {
	.class-fl__text{
		font-size: 15px;
		width: 94%;
		margin-right: auto;
		margin-left: auto;
	}

.class-fl_voice_text{
	font-size: 20px;
    width: 100%;
    color: #fff;
	line-height: 1.8;
	font-weight: 200;
}
}

.class-fl__text.youTube{
	font-size: 16px;
    width: 47%;
    color: #fff;
	line-height: 1.5;
	font-weight: 400;
}
@media screen and (max-width: 767px) {
	.class-fl__text.youTube{
		font-size: 15px;
		width: 94%;
		margin-right: auto;
		margin-left: auto;
	}
}

.modSection{
	margin: 8% 0% 5% 0%;
}

.textS{
	font-size: 0.8em;
}

.ttl_lh{
	line-height: 1.4;
}

.fl_2{
	display: flex;
	justify-content: space-evenly;
	width: 94%;
    margin-right: auto;
    margin-left: auto;
}

/*.fl_2__item{
	width: 100%;
}*/

.swiper-button-prev::after{
	color: #fff!important;
	font-size: 23px;
}

.swiper-button-next::after{
	color: #fff!important;
	font-size: 23px;
}

@media screen and (max-width: 767px) {
	.swiper-button-prev{
		left: 0%;
	}
	.swiper-button-next{
		right: 0%;
	}
}

.slider-textBlock{
	padding-right: 10%;
	padding-left: 10%;
}
@media screen and (max-width: 767px) {
	.slider-textBlock{
		padding-right: 8%;
		padding-left: 8%;
	}
}

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

.arima{
	font-family: 'ArimaMadurai',cursive;
}



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

h2{
	font-size:3rem;
	line-height:1;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:200;
}


h3 {
	font-size:3rem;
	line-height: 2.5;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 400;
}

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;
}


ul {list-style-type: none;}

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

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

div{
	display: block;
}


/**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/kv.png');
	background-position: center center;
	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: 800px) {

.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/smpkv.png') no-repeat 69% center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
}


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

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

/**content**/

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



.contents {
    /*width: 80%;*/
    min-width: 80%;
    /*padding: 0 20px;*/
    margin: 0 auto;
}

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

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

.lead{
	width:680px;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
margin: 0 auto;}

.lead h6{
	text-align:center;
	margin:10% 0 10%;
}

.lead img{
	width:100%;
}

.point1{
	margin:10% 0% 5% 0%;
	text-align: center;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.point1 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:500px; 
	padding-bottom:1px;}

.point1 h3 p{
	margin:5%;
	text-align:center;
}

.point1 img{
	text-align:center;
	width:80%;
	margin: 5%;
}


.point2{
	margin:10% 0% 5% 0%;
	text-align: center;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.point2 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:500px; 
	padding-bottom:1px;}

.point2 h3 p{
	margin:5%;
	text-align:center;
}

.point2 img{
	text-align:center;
	width:80%;
	margin: 5%;
}


.point3{
	margin:10% 0% 5% 0%;
	text-align: center;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.point3 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:500px; 
	padding-bottom:1px;}

.point3 h3 p{
	margin:5%;
	text-align:center;
}

.point3 img{
	text-align:center;
	width:80%;
	margin: 5%;
}

.testimonial_all{
	text-align: center;
	padding:5% 0% 10%;
}
	
.testimonial{
	vertical-align: middle;
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 60px;
	width:400px;
    border-radius: 30px;/*角の丸み*/
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.testimonial i{
	display:inline-block;
	padding-right:10px;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
			  }
	

.testimonial h5{
	display:inline-block;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight:200;}


.testimonial button:hover {
	color:white;
	filter:none;
	background:#c6ac7b;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;}

.testimonial h5 i:hover{
	color:#c6ac7b;
	border-color:#c6ac7b;
}


/* ----------- SMPH ----------- */
/* Portrait and Landscape */

/* Portrait */
@media screen 
  and (max-width: 780px) 
 {
.contents{width:100%;
padding:0px;}

.lead{
	width:100%}

p{ padding:2%;
　　text-align:left;}

.modSection{
	margin:15% 0% 5% 0%};
}
	  
	  h3 {
	font-size:2.0rem;
	line-height: 2.5;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 00;
}
	  
	  
	  .lead h6{
	text-align:left;
	padding:10% 5%;
}
	  
	  
	  .point1{
	margin:25% 0% 5% 0%;
	text-align: left;
		  opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

	  
	
.point1 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:330px; 
	padding-bottom:1px;}
}

.point1 h3 p{
	margin:5%;
	text-align:center;
}

.point1 img{
	 text-align: center;
    width: 100%;
    margin: 5% 0%;
}


.point2{
	margin:10% 0% 5% 0%;
	text-align: left;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.point2 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:330px; 
	padding-bottom:1px;}

.point2 h3 p{
	margin:5%;
	text-align:center;
}

.point2 img{
    text-align: center;
    width: 100%;
    margin: 5% 0%;
}


.point3{
	margin:10% 0% 5% 0%;
	text-align: left;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.point3 h2{
	text-align: left;
	border-bottom:1px solid #fff; 
	width:330px; 
	padding-bottom:1px;}

.point3 h3 p{
	margin:5%;
	text-align:center;
}

.point3 img{
	 text-align: center;
    width: 100%;
    margin: 5% 0%;
}

	
.testimonial{
	vertical-align: middle;
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 60px;
	width:260px;
    border-radius: 30px;/*角の丸み*/
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.testimonial i{
	display:inline-block;
	padding-right:10px;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
			  }
	

.testimonial h5{
	display:inline-block;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight:200;}


.testimonial button:hover {
	color:white;
	filter:none;
	background:#c6ac7b;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;}

.testimonial h5 i:hover{
	color:#c6ac7b;
	border-color:#c6ac7b;
}
	  

	 

 
/**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-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;
}

/* ___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;