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


/**common**/


html{
	height: 100%;
	background-color:#309eba;
	font-size:62.5%;
	}

body p{	
	font-size:1.8rem;
	line-height: 2.2;
	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%;
}


  .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-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;
      }
    
	
	.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/contact_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/contact_kv.png') no-repeat center 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{
	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%);}



.contents {
    width: 80%;
    min-width: 80%;
    padding: 100px 10px;
    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;
}



/****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:100%;
}
.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;
	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%;
	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
{
	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 0;
}



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

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:10em;
}

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

	
.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:#c6ac7b;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
	box-shadow:none;}

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

.tel h3{
	padding:30px;
}

.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;
	opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}
 



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

/* Portrait */
@media screen 
  and (max-width: 780px) 
 {
	  
#form_container
{	margin:0;
	text-align:left;
	width:100%;
}
	  
	  
form ul
{
	font-size:100%;
	list-style-type:none;
	margin:0;
	padding:0%;
	width:100%;
}
	  
	  .appnitro li{
		  width:100%;
	  }  
	  
	  
	  
}
	  
	  
/**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;
}

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