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


/**common**/


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:3rem;
	line-height: 3;
	color:white;
	font-family: 'Arima Madurai', cursive;
	font-weight:200;
}


h3 {
	font-size:3.5rem;
	line-height: 3.5;
	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;
}


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%;
	padding-right:20px;
}


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

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



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

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

nav>li:last-of-type(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;
}



.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;
	}
	
	.header-nav .logo {
		width: 100px;
	}

	.logo img{
    height: 55px;
	 /* width:auto; */
	 width: 100%;
	/* padding:5% 3% 0%;   */
}

	.main-nav{
		background-color:white;
		z-index: 100;
		height:60px;
		width: calc(100% - 100px);
	}
	
	/* ボタンの配置 */
	.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 {
     display: block;
        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;
}

}



 /*メニューのエフェクト*/
/* .nav-wrap{
display: none;
 -webkit-transform: translateX(0%);
 transform: translateX(0%);
 -webkit-transition:ease .5s;
 transition:ease .5s;
 z-index:1000;
}
.nav-wrap ul li{
 border-bottom: 1px solid #309eba;
} */
/*OPEN時の動き*/
/* .nav-wrap.open {
display:block;
 -webkit-transform:translateX(0);
 transform:translateX(0);
 -webkit-overflow-scrolling: touch;
	
} */

}


/**key visual**/
.header_visual{
	background: url('../images/trial_class.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: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: auto;
  z-index: -10;
  background: url('../images/trial_class.png') no-repeat center top;
  -webkit-background-size: 80%;
  -moz-background-size: 80%;
  -o-background-size: 80%;
   background-size: 80%;
  background-attachment: scroll; /* スクロールに追従 */
  z-index: -10;
 
}


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

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

/**content**/

.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%);

/**@media(max-width: 780px) {
		margin-top:5px;
	}**/

}


.contents {
    width: 80%;
    min-width: 80%;
    padding: 30px 10px;
    margin: 0 auto;
	z-index:2;
	
	@media(max-width: 780px) {
		width: 100%;
		padding: 0 0 30px 0;
	}
}

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

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

.mochimono{
	text-align: center;
	padding:80px 0px;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
			}

.mochimono_list{padding:30px;}


.mochimono li{
	display:inline-block;
	padding-left:100px;
	vertical-align: middle;
}

.mochimono li:first-of-type{
	margin-left:-100px;
}

/****contact form***/

input, textarea, select {
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.contact_form
{   font-size:1.8rem;
	line-height: 2;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 200;
	margin:8px 0 16px;
	text-align:center;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

#form_container
{	margin:0 auto;
	text-align:left;
	width:80%;
}
.send{
	text-align: center;
}

#top
{
	display:block;
	height:10px;
	margin:10px auto 0;
	width:650px;
}


#bottom
{
	display:block;
	height:10px;
	margin:0 auto;
	width:650px;
}

form.appnitro
{
	/* margin:20px 20px 0; */
	/* margin: 20px 0; */
	padding:0 0 20px;
}


/**** Form Section ****/
.appnitro
{	font-size:1.8rem;
	line-height: 2;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
}

.appnitro li
{
	width:100%;
}

form ul
{
	font-size:100%;
	list-style-type:none;
	margin:0;
	padding:0% 22%;
}

form li
{
	display:block;
	margin:0;
	padding:20px 5px 2px 9px;
	position:relative;
}

form li:after
{
	clear:both;
	content:".";
	display:block;
	height:0;
	visibility:hidden;
}



* html form li
{
	height:1%;
}



* html form li div
{
	display:inline-block;
}

form li div
{
	color:#444;
	margin:0 4px 0 0;
	padding:0 0 8px;
}

form li span
{
	color:#444;
	float:left;
	margin:0 4px 0 0;
	padding:0 0 8px;
}


form li div label
{
	clear:both;
	color:#444;
	display:block;
	font-size:9px;
	line-height:9px;
	margin:0;
	padding-top:3px;
}

form li span label
{
	clear:both;
	color:#444;
	display:block;
	font-size:9px;
	line-height:9px;
	margin:0;
	padding-top:3px;
}


.form_description{
	clear:both;
	display:inline-block;
	margin:0 0 1em;
}

.li_4{padding:20px;}
.age_checkbox{
	display:block;
	font-size: 1.5rem;
	font-weight:300;
}
.age_checkbox input{
	appearance:radio;
	-webkit-appearance:radio;
	height:15px; width:15px; outline-color:white;background-color:white;}

p .description{font-size:1.6rem; font-weight:300;}

.form_description[class]
{
	display:block;
}


form hr
{
	display:none;
}


form ul li.first
{
	border-top:none !important;
	margin-top:0 !important;
	padding-top:0 !important;
}





/**** Inputs and Labels ****/
label.description,
div.description
{
	border:none;
	color:white;
	display:block;
	font-size:95%;
	font-weight:200;
	line-height:1.5;
	padding:0 0 1px;
}

span.symbol
{
	font-size:115%;
	line-height:130%;
}

input.text
{	font-size:100%;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	/* font-weight: 100; */
	background:#fff;
	/* color:#444444; */
	margin:0;
	padding:2px;
}



textarea.textarea
{	font-size:100%;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
	background:#fff;
	color:#444444;
	margin:0;
	width:100%;
}

input.small
{
	width:25%;
}

select.small
{
	width:25%;
}

input.medium
{
	width:100%;
}

select.medium
{
	width:100%;
}

input.large
{
	width:99%;
}

select.large
{
	width:100%;
}

textarea.small
{
	height:5.5em;
}

textarea.medium
{
	height:3em;
}

textarea.large
{
	height:20em;
}


/**** Guidelines and Error Highlight ****/


form .guidelines
{
	background:#f5f5f5;
	border:1px solid #e6e6e6;
	color:#444;
	font-size:80%;
	left:100%;
	line-height:130%;
	margin:0 0 0 8px;
	padding:8px 10px 9px;
	position:absolute;
	top:0;
	visibility:hidden;
	width:42%;
	z-index:1000;
}

form .guidelines small
{
	font-size:105%;
}

form li.highlighted .guidelines
{
	visibility:visible;
}

form li:hover .guidelines
{
	visibility:visible;
}

.no_guidelines .guidelines
{
	display:none !important;
}

.no_guidelines form li
{
	width:97%;
}

.no_guidelines li.section
{
	padding-left:9px;
}


/*****send button*****/
.send input{
	vertical-align: middle;
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 40px;
	width:200px;
    border-radius: 20px;/*角の丸み*/
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight:200;
	outline: none !important;
}

.send input:hover {
	outline: none !important;
}

.send input:focus {
	outline: none !important;
	box-shadow: none;
}

.send input:focus-visible {
	outline: 2px solid #309eba !important;
	outline-offset: 2px;
	box-shadow: 0 0 0 3px rgba(48, 158, 186, 0.3);
}

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


.send:hover {
	color:white;
	filter:none;
	background:transparent;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;
}

.send input:hover {
	background:#fff;
	color:#309eba;
	cursor: pointer;
}

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

.tel{
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
  padding-bottom: 30px;
}

.tel h3{
	padding:30px 30px 15px;
}

.phone{
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 50px;
	width:300px;
    border-radius: 25px;/*角の丸み*/
	
	
}

.phone i{
	display:inline-block;
	padding-right:15px;
	color:#309eba;
	font-size:2rem;
			  }
	

.phone p{
	display:inline-block;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Arima madurai', sans-serif;
	font-weight:300;}


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



	 
.tel{
	text-align: center;
}
 


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

/* Portrait */
@media screen 
  and (max-width: 780px) 
 {
	  
	  h3{
	font-size:2.5rem;
	line-height: 1.8;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 200;
		  
	  }
	  
	  .mochimono img{
		  height:50px;
	  }
	  
	  .mochimono{
	text-align: center;
	padding:20px 0px;
			}

.mochimono_list{padding:10px;}


.mochimono li{
	display:inline-block;
	padding-left:20px;
	vertical-align: middle;
}

.mochimono li:first-of-type{
	margin-left:-5%;
}

/****contact form***/
	  

input, textarea, select {
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

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

#form_container
{	margin:0 auto;
	text-align:left;
	width:90%;
}
.send{
	text-align: center;
}

#top
{
	display:block;
	height:10px;
	margin:10px auto 0;
	width:650px;
}


#bottom
{
	display:block;
	height:10px;
	margin:0 auto;
	width:650px;
}

form.appnitro
{
	/* margin:20px 20px 0; */
	/* margin: 20px 0; */
	padding:0 0 20px;
}


/**** Form Section ****/
.appnitro
{	font-size:1.8rem;
	line-height: 2;
	color:white;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
}

.appnitro li
{
	/* width:90%; */
	width: 100%;
}

form ul
{
	font-size:100%;
	list-style-type:none;
	margin:0;
	padding:0%;
	width:100%;
}

form li
{
	display:block;
	margin:0;
	padding:4px 5px 2px 9px;
	position:relative;
}

form li:after
{
	clear:both;
	content:".";
	display:block;
	height:0;
	visibility:hidden;
}



* html form li
{
	height:1%;
}



* html form li div
{
	display:inline-block;
}

form li div
{
	color:#444;
	margin:0 4px 0 0;
	padding:0 0 8px;
}

form li span
{
	color:#444;
	float:left;
	margin:0 4px 0 0;
	padding:0 0 8px;
}


form li div label
{
	clear:both;
	color:#444;
	display:block;
	font-size:9px;
	line-height:9px;
	margin:0;
	padding-top:3px;
}

form li span label
{
	clear:both;
	color:#444;
	display:block;
	font-size:9px;
	line-height:9px;
	margin:0;
	padding-top:3px;
}


.form_description{
	clear:both;
	display:inline-block;
	margin:0 0 1em;
}

.form_description[class]
{
	display:block;
}


form hr
{
	display:none;
}


form ul li.first
{
	border-top:none !important;
	margin-top:0 !important;
	padding-top:0 !important;
}

/**** Inputs and Labels ****/
label.description,
div.description
{
	border:none;
	color:white;
	display:block;
	font-size:95%;
	font-weight:200;
	line-height:1.5;
	padding:0 0 1px;
}

span.symbol
{
	font-size:115%;
	line-height:130%;
}

input.text
{	font-size:100%;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
	background:#fff;
	color:#444444;
	margin:0;
	padding:2px;
}



textarea.textarea
{	font-size:100%;
	font-family: 'Noto Sans Japanese',   sans-serif;
  	font-weight: 100;
	background:#fff;
	color:#444444;
	margin:0;
	width:100%;
}

input.small
{
	width:25%;
}

select.small
{
	width:25%;
}

input.medium
{
	width:100%;
}

select.medium
{
	width:100%;
}

input.large
{
	width:99%;
}

select.large
{
	width:100%;
}

textarea.small
{
	height:5.5em;
}

/* textarea.medium
{
	height:3em;
} */

textarea.large
{
	height:20em;
}


/**** Guidelines and Error Highlight ****/


form .guidelines
{
	background:#f5f5f5;
	border:1px solid #e6e6e6;
	color:#444;
	font-size:80%;
	left:100%;
	line-height:130%;
	margin:0 0 0 8px;
	padding:8px 10px 9px;
	position:absolute;
	top:0;
	visibility:hidden;
	width:42%;
	z-index:1000;
}

form .guidelines small
{
	font-size:105%;
}

form li.highlighted .guidelines
{
	visibility:visible;
}

form li:hover .guidelines
{
	visibility:visible;
}

.no_guidelines .guidelines
{
	display:none !important;
}

.no_guidelines form li
{
	width:97%;
}

.no_guidelines li.section
{
	padding-left:9px;
}


/*****send button*****/
.send input{
	vertical-align: middle;
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 40px;
	width:200px;
    border-radius: 20px;/*角の丸み*/
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight:200;
	outline: none !important;
}

.send input:hover {
	outline: none !important;
}

.send input:focus {
	outline: none !important;
	box-shadow: none;
}

.send input:focus-visible {
	outline: 2px solid #309eba !important;
	outline-offset: 2px;
	box-shadow: 0 0 0 3px rgba(48, 158, 186, 0.3);
}

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


.send:hover {
	color:white;
	filter:none;
	background:transparent;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;
}

.send input:hover {
	background:#fff;
	color:#309eba;
	cursor: pointer;
}

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

.tel h3{
	/* padding:30px; */
	padding:30px 30px 15px;
}

.phone{
	position: relative;
    display: inline-block;
    padding: 0.25em 0.5em;
    text-decoration: none;
    background: #fff;/*背景色*/
    border: none;
	height: 50px;
	width:300px;
    border-radius: 25px;/*角の丸み*/
}

.phone i{
	display:inline-block;
	padding-right:15px;
	color:#309eba;
	font-size:2rem;
			  }
	

.phone p{
	display:inline-block;
	font-size:2rem;
	line-height: 1.3;
	color:#309eba;
	font-family: 'Arima madurai', sans-serif;
	font-weight:300;}


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



	 
.tel{
	text-align: center;
}
 
	  
}

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

	vertical-align: middle;
}


.footer_contact{
	
	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: '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: '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;
}

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

/* ----------------------
___additions 2025-11
------------------------- */
* {
	box-sizing: border-box;
  }

:root{
	--font-arima-weight: 400;
	--font-noto-weight: 400;
}

.font-arima-madurai{
	font-family: 'Arima Madurai', cursive;
	font-weight: var(--font-arima-weight, 400);
}

.font-noto-sans-japanese{
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: var(--font-noto-weight, 400);
}

.header_visual-trialLesson{

background: url('../images/trial_class.png');
	background-position: right top;
	background-size:cover;
	background-repeat: no-repeat;
	width: 100%;
	/* height: calc(100vh - 80px); */
	height: 100vh;



@media (max-width: 767px) {
	background: url('../images/trial_class.png');
	background-position: right 170px;
	background-size:cover;
	background-repeat: no-repeat;
	width: 100%;
	/* height: calc(100vh - 80px); */
	height: 100vh;
  	/* height: 55vh; */
	text-align: center;
	/* padding-top:20%; */
	/* padding-top: 80px; */

		/* @media (max-width: 770px) { */
			/* height: calc(100svh - 60px); */
			/* padding-top: 60px; */
			/* height: 100svh; */
		/* } */
	}
}

.header_visual-trialLesson-container{
	padding-top: 10rem;
	color: #fff;
	background-color: #356080;
	/* height: 65vh; */
	padding-bottom: 80px;
	text-align: center;

	@media (max-width: 767px) {
		padding-bottom: 40px;
	}
}

@media (max-width: 767px) {
	.header_visual-trialLesson-inner{
		width: 90%;
		/* min-width: 80%; */
		/* padding-inline: 10px; */
		margin: 0 auto;
	}
}

.header_visual-trialLesson-title--en{
	font-size: 45px
}

.header_visual-trialLesson-title--en.font-arima-madurai{
	--font-arima-weight: 600;
}

.header_visual-trialLesson-title--jp{
	display: inline-block;
	font-size: 20px;
	margin-bottom: 30px;

	@media (max-width: 767px) {
		font-size: 16px;
	}
}

.header_visual-trialLesson-title--jp.font-noto-sans-japanese{
	--font-noto-weight: 300;
}

.header_visual-trialLesson-text{
	font-size: 16px;
	line-height: 1.8;

	@media (max-width: 767px) {
		font-size: 14px;
	}
}

.header_visual-trialLesson-text:not(:first-of-type){
	margin-top: 16px;
}

.header_visual-trialLesson-text.font-noto-sans-japanese{
	--font-noto-weight: 200;
}

@media (max-width: 767px) {
	.header_visual-trialLesson-text{
		text-align: left;
		padding-inline: 20px;
	}

	.header_visual-trialLesson-text br{
		display: none;
	}
}

.header_visual-trialLesson-what-to-bring-flex{
	display: flex;
	justify-content: center;
	align-items: center;
}

.header_visual-trialLesson-what-to-bring-wrap{
	margin-top: 60px;
	border: 3px solid #fff;
	padding: 10px;
	width: 90%;
	max-width: 637px;
	margin-inline: auto;

	@media (max-width: 767px) {
		margin-top: 30px;
	}
}

.header_visual-trialLesson-what-to-bring-title{
	font-size: 25px;
	margin-bottom: 1em;

	&.font-noto-sans-japanese{
		--font-noto-weight: 300;
	}

	@media (max-width: 767px) {
		font-size: 20px;
	}
}

.header_visual-trialLesson-what-to-bring-list{
	text-align: left;

	&.font-noto-sans-japanese{
		--font-noto-weight: 200;
	}
}

.header_visual-trialLesson-what-to-bring-list__item{
	font-size: 16px;
	line-height: 1.4;
	margin-bottom: .5em;

	@media (max-width: 767px) {
		font-size: 14px;
	}
}

.trialLesson__title{
	line-height: initial;
	margin-bottom: 20px;
}

/* form style */
.class_selection_note {
	font-size: 1.3rem;
	line-height: 1.5;
	color: white;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	margin: 0.5em 0 1.5em;
	padding:0;}

	.class_selection_note li {
	padding:0;}

	.class_selection_container {
	padding: 0;
}

	@media (max-width: 767px) {
		font-size: 1.2rem;
		margin-bottom: 1em;
	}
}

.class_selection_container {
	list-style: none;
	padding: 0;
	margin: 0;
}

.class_category {
	padding: 0;
}

.class_category:last-child {
	margin-bottom: 0;
}

.class_category_header {
	margin-bottom: 0.5em;
	cursor: pointer;
	background: none;
	border: none;
	padding: 0;
	width: 100%;
	text-align: left;
	outline: none;
}

.class_category_header-inner {
	display: flex;
	align-items: center;
	padding: 0;
}

.class_category_icon {
	display: inline-block;
	width: 3rem;
	height: 3rem;
	position: relative;
	/* margin-right: 0.5em; */
	transition: transform 0.3s ease;
}

.class_category_icon::before {
	content: '';
	position: absolute;
	/* top: 50%; */
	top: 40%;
	left: 50%;
	width: .7em;
	height: .7em;
	border-top: 2px solid white;
	border-right: 2px solid white;
	transform: translate(-50%, -50%) rotate(135deg);
	transform-origin: center;
}

.class_category.closed .class_category_icon {
	transform: rotate(-90deg);
}

.class_category_title {
	font-size: 18px;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 400;
	color: white;
	line-height: 1.5;
	cursor: pointer;
	padding: 0;

	/* @media (max-width: 767px) {
		font-size: 2rem;
	} */
}

.class_category.closed .class_category_content {
	display: none;
}

.class_category_description {
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.5;
	margin-bottom: 0.2em;
	margin-left: 3.5rem;

	@media (max-width: 767px) {
		font-size: 1.3rem;
		/* margin-left: 1.5em; */
	}
}

.class_options {
	margin-left: 3.5rem;
	padding-bottom: 0;

	/* @media (max-width: 767px) {
		margin-left: 1.5em;
	} */
}

.class_option {
	display: flex;
	align-items: center;
	margin-bottom: 0.5em;
	cursor: pointer;
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.5;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.class_option:last-child {
	margin-bottom: 0;
}

.class_option input[type="checkbox"] {
	display: none;
}

.class_option_bullet {
	display: inline-block;
	margin-right: 0.5em;
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	background: white;
	position: relative;
	flex-shrink: 0;
	transition: background-color 0.2s ease;
	padding: 0;
	margin: 0 .8em 8px 0;
}

.class_option input[type="checkbox"]:checked + .class_option_bullet::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 1rem;
	height: 1rem;
	background-color: #54A0B4;
	border-radius: 50%;
}

.class_option_text {
	display: inline-block;
	color: white;
}

.class_option_day {
	margin-right: 1em;
	color: white;
	padding: 0;
}

/* 年齢確認セクション */
.age_verification_section {
	padding: 0 !important;
	margin: 20px 0;
}

.age_verification_container {
	/* padding: 30px 0; */
	padding: 4px 5px 2px 9px
	/* border-radius: 8px; */

	/* @media (max-width: 767px) {
		padding: 20px;
	} */
}

.age_verification_title {
	font-size: 1.8rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 400;
	color: white;
	margin-bottom: 15px;
	line-height: 1.5;

	@media (max-width: 767px) {
		font-size: 1.8rem;
	}
}

.age_verification_intro {
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.8;
	margin-bottom: 20px;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.age_verification_options {
	margin-bottom: 25px;
}

.age_radio_option {
	display: flex;
	align-items: center;
	margin-bottom: 15px;
	cursor: pointer;
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.5;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.age_radio_option:last-child {
	margin-bottom: 0;
}

.age_radio_option input[type="radio"] {
	display: none;
}

.age_radio_circle {
	display: inline-block;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	/* border: 2px solid white; */
	background-color: white;
	position: relative;
	margin-right: 10px;
	flex-shrink: 0;
	transition: all 0.2s ease;
}

.age_radio_option input[type="radio"]:checked + .age_radio_circle {
	background-color: white;
}

.age_radio_option input[type="radio"]:checked + .age_radio_circle::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 10px;
	height: 10px;
	background-color: #309eba;
	border-radius: 50%;
}

.age_radio_text {
	display: inline-block;
	color: white;
	padding: 0;
}

.guardian_info_fields {
	margin-top: 25px;
	margin-bottom: 20px;
	display: none;
}

.guardian_info_fields .description {
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	/* margin-bottom: 8px; */
	margin-top: 15px;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.guardian_info_fields .description:first-child {
	margin-top: 0;
}

.guardian_input {
	background: white !important;
	color: #444444;
	padding: 8px 10px;
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 100;
	width: 100%;
	border: none;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.guardian_input:focus {
	outline: none;
	border-bottom: 2px solid #54A0B4;
}

.guardian_consent_option {
	display: flex;
	align-items: center;
	margin-top: 20px;
	margin-bottom: 15px;
	cursor: pointer;
	font-size: 1.5rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.5;

	@media (max-width: 767px) {
		font-size: 1.3rem;
	}
}

.guardian_consent_option input[type="checkbox"] {
	display: none;
}

.guardian_consent_circle {
	display: inline-block;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	/* border: 2px solid white; */
	background-color: white;
	position: relative;
	margin-right: 10px;
	flex-shrink: 0;
	transition: all 0.2s ease;
}

.guardian_consent_option input[type="checkbox"]:checked + .guardian_consent_circle {
	background-color: white;
}

.guardian_consent_option input[type="checkbox"]:checked + .guardian_consent_circle::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 10px;
	height: 10px;
	background-color: #309eba;
	border-radius: 50%;
}

.guardian_consent_text {
	display: inline-block;
	color: white;
	padding: 0;
}

.age_verification_note {
	font-size: 1.2rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 1.6;
	margin-top: 20px;

	@media (max-width: 767px) {
		font-size: 1.1rem;
	}
}

/* 送信完了メッセージ */
#form_success_message {
	margin-top: 40px;
	padding: 40px;
	background-color: rgba(255, 255, 255, 0.1);
	border-radius: 8px;
	text-align: center;
	animation: fadeIn 0.5s ease-in;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.success_message_container h3 {
	font-size: 3rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 400;
	color: white;
	margin-bottom: 20px;
	line-height: 1.5;

	@media (max-width: 767px) {
		font-size: 2.5rem;
	}
}

.success_message_container p {
	font-size: 1.6rem;
	font-family: 'Noto Sans Japanese', sans-serif;
	font-weight: 200;
	color: white;
	line-height: 2;

	@media (max-width: 767px) {
		font-size: 1.4rem;
	}
}
