/* 調整用スタイル */

a {
  text-decoration: none;
}

ul,
li {
  list-style: none;
}


main {
  height: 800px;
}


.main {
  margin: auto;
}

.footer {
  background-color: #f6f6f6;
  height: 200px;
}

.footer div {
  margin: auto;
}

@font-face {
   font-family:meiryo;
   src: url('../font/meiryo/meiryo.ttc') format("truetype");
}

@font-face {
   font-family:meiryob;
   src: url('../font/meiryob/meiryob.ttc') format("truetype");
}


/* ヘッダー */


.header {
	background:rgba(0,0,0,0.5);
  width: 100%;
  height: 64px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
}

.header__inner {
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: inherit;
  position: relative;
}


/* ヘッダーのロゴ部分 */
.header__title {
  width: 240px;
}


.header__title img {
  display: block;
  width: 100%;
  height: 100%;
}

/* ヘッダーのナビ部分 */

.header__nav {
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  transform: translateX(100%);
	background:rgba(0,0,0,0.7);
  transition: ease .4s;
}


.nav-items {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 0;
}



/* ナビのリンク */
.nav-items__item a {
  color: black;
  width: 300px;
  display: block;
  text-align: center;
	font-family: "meiryob", serif;
  font-size: 1.2em;
	color: #FFFFFF;
	margin:0 auto;
  margin-bottom: 5%;
	padding-bottom:2%;
		border-bottom: 1px solid #FFF;
}

.nav-items__item:last-child a {
  margin-bottom: 0;
}



/* ハンバーガーメニュー */

.header__hamburger {
  width: 48px;
  height: 100%;

}

.hamburger {
  background-color: transparent;
  border-color: transparent;
  z-index: 9999;
}


/* ハンバーガーメニューの線 */
.hamburger span {
  width: 100%;
  height: 1px;
  background-color: #FFF;
  position: relative;
  transition: ease .4s;
  display: block;
}

.hamburger span:nth-child(1) {
  top: 0;
}

.hamburger span:nth-child(2) {
  margin: 8px 0;
}

.hamburger span:nth-child(3) {
  top: 0;
}


/* ハンバーガーメニュークリック後のスタイル */
.header__nav.active {
  transform: translateX(0);
}

.hamburger.active span:nth-child(1) {
  top: 5px;
  transform: rotate(45deg);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;

}

.hamburger.active span:nth-child(3) {
  top: -13px;
  transform: rotate(-45deg);
}

div.facility{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/fgmevo_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.fgmevo{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/fgmevo_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.santana{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/santana_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.privacy{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/privacy_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.lesson{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/lesson_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.method{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/method_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

div.contact{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/contact_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

/* ========== キャンペーンバナー部分 ========== */

p.cp_bnr{
	width:100%;
	margin:0 0 0 0;
}

p.cp_bnr img{
	width:100%;
}


div.news{
		width:100%;
	margin:0 auto;
	background-image: url("../img/keyv/news_sm.jpg");
	background-repeat: no-repeat;
	background-position: top center;
	padding-bottom: 5%;
}

/* 見出し部分 */

h2.keyv_mida{
	width:96%;
	font-size:2em;
	font-family: "meiryob", serif;
	color:#FFF;
	text-align:center;
	margin:0 auto;
	padding-top:60%;
}

h2.cont_mida{
	width:96%;
	font-size:1.6em;
	font-family: "meiryob", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-bottom: 18px;
}


h2.cont_midaw{
	width:96%;
	font-size:1.6em;
	font-family: "meiryob", serif;
	color:#FFF;
	text-align:center;
	margin:0 auto;
	margin-bottom: 18px;
}

p.keyv_mida_txt{
	width:96%;
	font-size:1em;
	font-family: "meiryo", serif;
	color:#FFF;
	text-align:center;
	margin:0 auto;
	margin-top:3%;
	padding-bottom:30%;
}



h2.cont_mida_uline{
	width:96%;
	font-size:1.6em;
	font-family: "meiryob", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-bottom: 5%;
	padding-top:10%;
	padding-bottom:8%;
	border-bottom: 1px solid #000000;
}

h2.moriz_uline{
	width:96%;
	font-size:1.2em;
	font-family: "meiryob", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-bottom: 3%;
	padding-top:7%;
	padding-bottom:5%;
	border-bottom: 1px solid #000000;
}

h3.pra_mida_uline{
	width:96%;
	font-size:1.4em;
	font-family: "meiryob", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-bottom: 5%;
	padding-top:10%;
	padding-bottom:8%;
	border-bottom: 1px solid #000000;
}

h2.les_mida01{
	width:96%;
	font-size:1.6em;
	font-family: "meiryob", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-top:3%;
	
}

h3.les_komida01{
	width:96%;
	font-size:0.8em;
		font-family: "meiryob", serif;
		line-height: 160%;
		font-weight: normal;
		margin-bottom:20px;
}


h3.les_komida01{
	width:96%;
	font-size:1em;
		font-family: "meiryob", serif;
		line-height: 160%;
		font-weight: normal;
	text-align:center;
}

h3.cont_copyw{
	width:96%;
	font-size:1em;
		font-family: "meiryob", serif;
		color:#FFF;
		line-height: 160%;
		font-weight: normal;
		margin-bottom:5%;
		text-align:center;
}

h3.scont_mida{
	width:96%;
	font-size:1em;
	font-family: "meiryo", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	padding-bottom:5%;
}

h3.scont_midaw{
	width:90%;
	font-size:1em;
	font-family: "meiryo", serif;
	color:#FFF;
	text-align:center;
	margin:0 auto;
}

h3.scont_midal{
	width:90%;
	font-size:1em;
	font-family: "meiryo", serif;
	color:#000;
	text-align:center;
	margin:0 auto;
	margin-bottom: 3%;
	padding-bottom:2%;
	border-bottom: 1px solid #000000;
}


section.mid_body{
	width:100%;
	margin:0 auto;
	margin-top:5%;
	padding-bottom:1%;
	background-color: #FFFFFF;
}

/* ========== facility部分 ========== */

div.jisya{
	width:100%;
	margin:0 auto;
	margin-bottom:8%;
}


div.jisya:after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}


div.jisya p.leftspace{
	width:470px;
	height:auto;
}

div.jisya p.leftspace_box{
	width:100%;
	height:auto;
	margin:0 auto;
}

div.jisya p.leftspace_box img{
	width:100%;
}

div.jisya p.leftspace_boxs{
	width:94%;
	height:auto;
	margin:0 auto;
}

div.jisya p.leftspace_boxs img{
	width:100%;
}


div.jisya div.rightspace{
	width:96%;
	height:auto;
	margin:0 auto 0 auto;
}

h3.komida01{
		width:94%;
		font-size:1.2em;
		font-family: "meiryo", serif;
		line-height: 160%;
		font-weight: normal;
	margin:0 auto;
}

p.shisetsu_txt{
		width:94%;
		font-size:1em;
		font-family: "meiryo", serif;
		line-height: 160%;
		font-weight: normal;
	margin:0 auto;
		margin-top:5%;
}

p.yonezawa_txt{
		width:94%;
		font-size:1em;
		font-family: "meiryo", serif;
		line-height: 160%;
		font-weight: normal;
	margin:0 auto;
		margin-top:5%;
	text-align:center;
}

a.syou_box{
	display: block;
	width:240px;
	height:27px;
	border: 1px solid;
	border-color: #666666;
	text-decoration: none;
	color:#000;
	font-size:16px;
	font-family: "meiryo", serif;
	text-align: center;
	padding-top:10px;
	margin-top: auto;
	margin-bottom:15px;
	margin-right: auto;
    margin-left: auto;
}

a.syou_box:hover {
  opacity: 0.7;
}

div.mini_sisebox{
	width:46%;
	margin:0 2% 0 2%;
	float:left;
}

p.mini_sisephoto{
	width:100%;
}

p.mini_sisephoto img{
	width:100%;
}

p.mini_sisetxt{
	width:100%;
	color:#000;
	font-size:1em;
	font-family: "meiryo", serif;
	text-align:center;
	padding:3% 0 3% 0;
}

/* ========== Mg move 部分 ========== */

p.midtxt{
	width:94%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 auto;
	text-align:center;
}

div.mgmove_base{
	width:94%;
	margin:0 auto;
	margin-bottom:30px;
}


div.mgmove_base:after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

p.mgmove_box{
	width:46%;
	margin:5% 2% 0 2%;
	float:left;
}

p.mgmove_box img{
	width:100%;
}


/* リセットCSS */
* {
  list-style: none;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.qa-container {
  margin: 50px auto 0;
  max-width: 80%;
  width: 80%;
}

.qa-list:not(:first-child) {
  margin-top: 10px;
}

.question-title {
  background: #FFF;
  cursor: pointer;
  font-size: 1em;
  padding: 20px 40px;
  position: relative;
	border-bottom: 1px solid #000000;
}

.question-title:before {
  position: absolute;
  display: block;
  content: 'Q';
  top: 18px;
  left: 12px;
  color: #000;
  font-size: 1em;
}

.question-title:after {
  position: absolute;
  display: block;
  content: '';
  top: 35%;
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: rotate(135deg);
  transition: all .3s ease-in-out;
}

.question-title.open:after {
  transform: rotate(-45deg);
  top: 45%;
}

.answer-text {
  display: none;
  padding: 20px 40px;
  position: relative;
	background-color: #d5ead7;
}

.answer-text:before {
  position: absolute;
  display: block;
  content: 'A';
  top: 18px;
  left: 12px;
  color: #000;
  font-size: 1em;
}

/* ========== Lesson部分 ========== */


div.lesson_cib{
	width:94%;
	margin-top:5%;
	margin:0 auto;
}

div.lesson_cib:after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

p.les_photo{
	width:100%;
	margin-bottom:3%;
}

p.les_photo img{
	width:100%;
}

p.les_photo_s{
	width:48%;
	float:left;
}

p.les_photo_s img{
	width:100%;
}

h3.les_smidashi{
		width:100%;
		font-size:1em;
		font-family: "meiryob", serif;
		line-height: 160%;
		font-weight: normal;
		margin-bottom:3%;
}

p.les_stext{
		width:100%;
		font-size:1em;
		font-family: "meiryo", serif;
		line-height: 160%;
		font-weight: normal;
		margin-bottom:5%;
}


/* ========== お問い合わせ部分 ========== */
section.body_base div.gyoumubox{
width:90%;
margin:0 auto;
padding-bottom:50px;
}

section.body_base div.gyoumubox:after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

div.gyoumubox div.conta{
width:90%;
margin:10% auto 5% auto;
padding-bottom:50px;
}

div.gyoumubox div.conta h2.contah{
width:100%;
font-size:1.6em;
font-family: "meiryo", serif;
color:#000;
text-align: center;
}

div.gyoumubox div.conta p.contap{
width:100%;
font-size:1em;
font-family: "meiryo", serif;
color:#000;
margin-top:3%;
text-align: left;
}

table.mailf{
	width:100%;
	border-collapse: collapse;
	margin:0 auto;
}

table.mailf th.conth, td.contd {
border: solid 10px #FFFFFF;
}

table.mailf td.contd {
	width:97%;
	padding:3px 3% 7px 0;
}

table.mailf th.conth{
font-size:1em;
font-family: "meiryo", serif;
color:#000;
text-align:left;
padding:0 0 0 0;
}

input[type='text'] {
	font: 15px/24px sans-serif;
	box-sizing: border-box;
	width: 100%;
	padding: 0.3em;
	transition: 0.3s;
	letter-spacing: 1px;
	color: #000000;
	border: none;
	border-bottom: 1px solid #1b2538;
	background: transparent;
}

input[type='email'] {
	font: 15px/24px sans-serif;
	box-sizing: border-box;
	width: 100%;
	padding: 0.3em;
	transition: 0.3s;
	letter-spacing: 1px;
	color: #000000;
	border: none;
	border-bottom: 1px solid #1b2538;
	background: transparent;
}


textarea{
	font: 15px/24px sans-serif;
	box-sizing: border-box;
	width: 100%;
	height: 15em;
	padding: 0.3em;
	transition: 0.3s;
	letter-spacing: 1px;
	color: #000000;
	border: none;
	border-bottom: 1px solid #1b2538;
	background: transparent;
}

::placeholder {
  font-size: 1.1em;
}

.sub_button {
  display       : inline-block;
  border-radius : 5%;          /* 角丸       */
  font-size     : 13pt;        /* 文字サイズ */
  text-align    : center;      /* 文字位置   */
  cursor        : pointer;     /* カーソル   */
  padding       : 12px 0 12px 0;   /* 余白       */
  background    : #000000;     /* 背景色     */
  color         : #ffffff;     /* 文字色     */
  line-height   : 1em;         /* 1行の高さ  */
  transition    : .3s;         /* なめらか変化 */
  border        : 2px solid #000000;    /* 枠の指定 */
	width:250px;
	height:50px;
	margin:10px 0 0 2%;
}
.sub_button:hover {
  color         : #000000;     /* 背景色     */
  background    : #ffffff;     /* 文字色     */
}

div.subwaku{
	text-align:center;
	
}

.bkp_button {
  display       : inline-block;
  border-radius : 5%;          /* 角丸       */
   font-size     : 13pt;         /* 文字サイズ */
  text-align    : center;      /* 文字位置   */
  cursor        : pointer;     /* カーソル   */
  padding       : 12px 0 12px 0;   /* 余白       */
  background    : #000000;     /* 背景色     */
  color         : #ffffff;     /* 文字色     */
  line-height   : 1em;         /* 1行の高さ  */
  transition    : .3s;         /* なめらか変化 */
  border        : 2px solid #000000;    /* 枠の指定 */
	width:100px;
	height:50px;
	margin:10px 0 0 0;
}
.bkp_button:hover {
  color         : #000000;     /* 背景色     */
  background    : #ffffff;     /* 文字色     */
}

div.kakunin_box{
width:100%;
margin:20px auto 0 auto;
padding-bottom:50px;
}

/* ========== フッターバナー ========== */

div.footbnr{
	width:98%;
	margin:0 auto;
	margin-bottom:3%;
}


div.footbnr:after{
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

p.f_btn01{
	width:46%;
	margin:0 2% 0 2%;
	float:left;
}

p.f_btn01 img{
	width:100%;
}

/* ========== フッター ========== */
div#footer{
	width:100%;
	margin:0 0 0 0;
	background-image: url("../img/keyv/footer.jpg");
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: top center;
}

h1.footer_logo{
	width:80%;
	margin:0 auto;
	padding-top:100px;
}

h1.footer_logo img{
	width:100%;
}

address.site_add{
	width:100%;
	text-align: center;
	font-family: "meiryo", serif;
	font-size:1em;
	font-style:normal;
	color:#FFF;
	margin:0 auto;
	margin-top:5%;
}

address.site_add a{
	font-family: "meiryo", serif;
	font-size:1em;
	font-style:normal;
	color:#FFF;
	text-decoration: none;
}

p.footer_tel{
	width:100%;
	text-align: center;
	font-family: "meiryob", serif;
	font-size:1.3em;
	font-style:normal;
	color:#FFF;
	margin:0 auto;
	margin-top:10px;
}

p.footer_tel a{
	font-family: "meiryob", serif;
	font-size:1.3em;
	text-decoration: none;
	color:#FFF;
}

a.footer_button{
	display: block;
	width:300px;
	margin:0 auto;
	margin-top:50px;
	padding: 20px 7px 17px 7px;
	background: #000;
	box-shadow: 0px 0px 0px 5px #000;
	border: solid 1px #fff;
	text-align: center;
	text-decoration: none;
	font-family: "meiryo", serif;
	font-size:22px;
	font-style:normal;
	color:#FFF;
}

a.footer_button:hover {
  opacity: 0.7;
}

p.footer_nav{
	width:94%;
	text-align: center;
	margin:0 auto;
	margin-top:46px;
	line-height: 220%;
}

p.footer_nav a{
	font-family: "meiryob", serif;
	font-size:1em;
	font-style:normal;
	color:#FFF;	
	text-decoration: none;
}

p.footer_nav a:hover {
  opacity: 0.7;
}


p.copy{
	width:90%;
	text-align: center;
	font-family: "meiryo", serif;
	font-size:0.8em;
	font-style:normal;
	color:#FFF;
	margin:0 auto;
	margin-top:30px;
	line-height: 220%;
}

/* ========== プライバシーポリシー 部分 ========== */

p.puratxt{
	width:94%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 auto;
}

p.puratxtin{
	width:92%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 auto;
	margin-top:3%;
		padding-left: 1em;
  text-indent: -1em;
}

div.puratxtinl{
	width:92%;
	height:auto;
	margin:0 auto;
	margin-top:3%;
	margin-bottom:5%;
}

p.puratxtinl01{
	width:95%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 0 0 5%;
	margin-top:3%;
	padding-left: 1em;
  text-indent: -1em;
}

p.puratxtinl02{
	width:90%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 0 0 10%;
	margin-top:3%;
	padding-left: 1em;
  text-indent: -1em;
}

/* ========== 利用規約 部分 ========== */

div.kiyaku_box{
	width:94%;
	margin:0 auto;
}

table.kiyakutab{
	width:100%;
	border-collapse: collapse;
}

th.kiyakuth{
	border: solid 1px black;
	font-size:1em;
	font-family: "meiryob", serif;
	padding:5px 10px;
	text-align:left;
}

td.kiyakutd{
	border: solid 1px black;
	font-size:1em;
	font-family: "meiryo", serif;
		padding:5px 10px;
	text-align:left;
}

/* ========== サイトマップ 部分 ========== */

p.maptxt{
	width:84%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 auto;
	margin-bottom:10px;
}

p.maptxt a{
	font-size:1em;
	font-family: "meiryo", serif;
	color:#000;
}

p.maptxtin{
	width:82%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 auto;
		margin-bottom:10px;
		padding-left: 1em;
  text-indent: -1em;
}

p.maptxtin a{
	font-size:1em;
	font-family: "meiryo", serif;
	color:#000;
}

div.maptxtinl{
	width:82%;
	height:auto;
	margin:0 auto;
	margin-top:3%;
	margin-bottom:5%;
}

p.maptxtinl01{
	width:85%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 0 0 5%;
	margin-top:3%;
	padding-left: 1em;
  text-indent: -1em;
}

p.maptxtinl01 a{
	font-size:1em;
	font-family: "meiryo", serif;
	color:#000;
}

p.maptxtinl02{
	width:80%;
	height:auto;
	font-size:1em;
	font-family: "meiryo", serif;
	line-height: 160%;
	margin:0 0 0 10%;
	margin-top:3%;
	padding-left: 1em;
  text-indent: -1em;
}

/* ========== サイズ強制 ========== */

.mt3{
	margin-top:3% !important;
}

.mt5{
	margin-top:5% !important;
}

.mt10{
	margin-top:10% !important;
}

.mt15{
	margin-top:15% !important;
}

.mt20{
	margin-top:20% !important;
}

.mr2{
	margin-right:2% !important;
}

.mr4{
	margin-right:4% !important;
}

.ml2{
	margin-left:2% !important;
}

.ml4{
	margin-left:4% !important;
}

.ml20{
	margin-left:20% !important;
}

.mb5{
	margin-bottom:5% !important;
}


.mb20{
	margin-bottom:20% !important;
}

.pt7{
	padding-top:7% !important;
}

.pt10{
	padding-top:10% !important;
}

.pb10{
	padding-bottom:10% !important;
}

.pb20{
	padding-bottom:20% !important;
}

.pb40{
	padding-bottom:40% !important;
}

