@charset "utf-8";

/*slidein　下から*/
@-webkit-keyframes slidein-img {
	from {
		top: 42%;
		opacity: 0;
	}
	to {
		top: 40%;
		opacity: 1;
	}
}
@-ms-keyframes slidein-img {
	from {
		top: 42%;
		opacity: 0;
	}
	to {
		top: 40%;
		opacity: 1;
	}
}
@-moz-keyframes slidein-img {
	from {
		top: 42%;
		opacity: 0;
	}
	to {
		top: 40%;
		opacity: 1;
	}
}
@keyframes slidein-img {
	from {
		top: 42%;
		opacity: 0;
	}
	to {
		top: 40%;
		opacity: 1;
	}
}

/*fadein*/
@-webkit-keyframes fadein-ttl {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@-ms-keyframes fadein-ttl {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@-moz-keyframes fadein-ttl {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
@keyframes fadein-ttl {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

/*スクロールアニメーション*/
@-webkit-keyframes sdb2 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 240px);
  }
}
@-ms-keyframes sdb2 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 240px);
  }
}
@-moz-keyframes sdb2 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 240px);
  }
}
@keyframes sdb2 {
  0% {
    transform: translate(0, 0);
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 240px);
  }
}

/*ローディング画面*/
#js-loader { background-color: #fff; position: fixed; width: 100%; height: 100%; z-index: 3000 }
@keyframes action-eye {
  0% {
    transform: scaleY(1);
  }
  30% {
    transform: scaleY(0.2);
  }
  45% {
    transform: scaleY(1);
  }
  60% {
    transform: scaleY(0.2);
  }
  100% {
    transform: scaleY(1);
  }
}
@-webkit-keyframes action-eye {
  0% {
    transform: scaleY(1);
  }
  30% {
    transform: scaleY(0.2);
  }
  45% {
    transform: scaleY(1);
  }
  60% {
    transform: scaleY(0.2);
  }
  100% {
    transform: scaleY(1);
  }
}
@-ms-keyframes action-eye {
  0% {
    transform: scaleY(1);
  }
  30% {
    transform: scaleY(0.2);
  }
  45% {
    transform: scaleY(1);
  }
  60% {
    transform: scaleY(0.2);
  }
  100% {
    transform: scaleY(1);
  }
}
@-moz-keyframes action-eye {
  0% {
    transform: scaleY(1);
  }
  30% {
    transform: scaleY(0.2);
  }
  45% {
    transform: scaleY(1);
  }
  60% {
    transform: scaleY(0.2);
  }
  100% {
    transform: scaleY(1);
  }
}
@keyframes loading {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
@-webkit-keyframes loading {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
@-ms-keyframes loading {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
@-moz-keyframes loading {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(10px);
  }
  100% {
    transform: translateY(0);
  }
}
/*点滅*/
@-webkit-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@-moz-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}
@-ms-keyframes blink{
    0% {opacity:0;}
    100% {opacity:1;}
}

@media screen and (min-width: 1001px) ,print {
/*************************************
* 共通
*************************************/
.dsp-no-pc { display: none !important; }
main {  }
.content-inner { width: 90%; margin: auto; padding: 0; max-width: 1100px; height: 100%; }
section { padding-top: 6rem;  display: block; }
.detail-inner { margin: 0; padding: 0; width: 100%; height: 100%; }
#pagetop { position: fixed; width: 50px; height: 50px; bottom: 0; right: 0; z-index: 500; }
.tel { pointer-events: none; font-family: 'Roboto'; font-weight: bold; }
/*スクロール量でフェードイン*/
.effect {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
  transform: translateX(-50px);
}
.effect-u {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
  transform: translateY(10px);
}
.effect-o {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
}
.fadein { opacity: 1; transform: translateX(0px); }
.area-r-pc { text-align: right; }
.area-l-pc { text-align: left; }
.area-c-pc { text-align: center; margin: auto; }
.m-b_5-pc { margin-bottom: 5px; }
.m-b_20-pc { margin-bottom: 20px; }
.m-b_40-pc { margin-bottom: 40px; }
.m-t_5-pc { margin-top: 5px; }
.m-t_20-pc { margin-top: 20px; }
.m-t_40-pc { margin-top: 40px; }
.fl-l-pc { float: left; }
.fl-r-pc { float: right; }
.w-75-pc { width: 75%; }
.w-70-pc { width: 70%; }
.w-65-pc { width: 65%; }
.w-60-pc { width: 60%; }
.w-55-pc { width: 55%; }
.w-50-pc { width: 50%; }
.w-45-pc { width: 45%; }
.w-40-pc { width: 40%; }
.w-35-pc { width: 35%; }
.w-30-pc { width: 30%; }
.w-25-pc { width: 25%; }
.w-20-pc { width: 20%; }
hr.hr-01 { margin: 4rem 0 4rem 0; border-top: 1px solid #ddd; border-bottom: none; }
hr.hr-02 { margin: 1rem 0 1rem 0; border-top: 1px solid #ddd; border-bottom: none; }
.text-overflow { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.detail-area { text-align: justify; margin-bottom: 4rem; }
.detail-area:last-child { margin-bottom: 0; }
/*ぱんくず*/
.pankuzu-area { padding: 5px 0 5px 0; text-align: right; font-size: 0.8rem; }
.pankuzu-area ul, .pankuzu-area ul li { list-style: none; }
.pankuzu-area ul li { display: inline-block; }
/*pagetop*/
#pagetop { position: fixed; width: 45px; height: 30px; bottom: 30px; right: 20px; z-index: 500; }
#pagetop a:before {
	font-family: FontAwesome;
	content: '\f077';
	color: #b2b2b2;
	font-size: 45px;
	padding: 1px;
	display: inline-block;
}
/*************************************
* 見出し
*************************************/
.h2-area { text-align: center; margin-bottom: 3rem; color: #F07700; }
.h2-01 .en { font-size: 3rem; line-height: 3rem; font-family: 'Text Me One', sans-serif; display: block; }
.h2-01 .jp { font-size: 1.1rem; margin-top: 0.5rem; display: block; font-weight: 500; }
.h3-01 { font-size: 1.2rem; text-align: center; font-weight: 500; margin-bottom: 2rem; color: #F07700; }
.h3-02 { background-color: #F07700; color: #fff; padding: 10px; text-align: center; font-size: 1.2rem; font-weight: 700; }
.h3-03 { font-weight: 500; color: #F07700; margin-bottom: 1.5rem; position: relative; font-size: 1.2rem; padding-bottom: 1rem; }
.h3-03:after { position: absolute; width: 60px; border-bottom: 1px solid #F07700; left: 0; bottom: 0; content: " "; }
.h4-01 { font-weight: 500; color: #F07700; margin-bottom: 0.5rem; text-align: center; }
.h4-02 { font-weight: 500; text-align: center; padding: 10px; margin-bottom: 1.5rem; background-color: #EDEDED;  font-weight: bold }
.h5-01 { font-weight: 700; }
.h6-01 { font-weight: 700; }
/*************************************
* テーブル
*************************************/
th {  }
.table-01 { margin-bottom: 1rem; border-top: 1px solid #ddd; width: 100%; }
.table-01 tr { border-bottom: 1px solid #ddd; display: inline-block; line-height: 1.5rem; padding-left: 2.5%; padding-right: 2.5%; width: 95%; }
.table-01 tr > * { padding: 10px 0 10px 0; }
.table-01 th { font-weight: bold; width: 20%; display: inline-block; }
.table-01 td { width: 70%; display: inline-block; margin-left: 5%; }
/*************************************
* リスト
*************************************/
ul.list-01, ul.list-01 li { list-style: none; } 
ul.list-01 li { padding-left: 1.2em; text-indent: -1.2em; }
ul.list-01 li:before {
	font-family: FontAwesome;
	content: '\f111';
	color: #FF9E19;
	margin-right: 0.3em;
}
/*************************************
* ローディング画面
*************************************/
.load-area { width: 597px; position: absolute; left: 50%; top: 50%; margin-top: -190px; margin-left: -298px; }
.loading { position: relative; width: 597px; height: 380px;}
.loading > * { position: absolute; }
.loading .pan01,.loading .pan02,.loading .pan03,.loading .pan04,.loading .ttl,.loading .nyuzen {
  animation: loading 1s infinite;
  animation-timing-function: ease-in-out;
}
.loading .ttl {
	width: 597px;
	left: 50%;
	top: 0;
	margin-left: -298px;
}
.loading .face {
	width: 167px;
	top: 110px;
	left: 50%;
	margin-left: -83px;
}
.loading .eye {
	width: 61px;
	top: 183px;
	left: 50%;
	margin-left: -30px;
	animation: action-eye 0.7s;
	animation-delay: 0.7s;
  animation-timing-function: ease-in-out;
}
.loading .pan01 {
	width: 125px;
	right: 0;
	top: 260px;
	animation-delay: .1s;
}
.loading .pan02 {
	width: 80px;
	right: 125px;
	top: 130px;
	animation-delay: .2s;
}
.loading .pan03 {
	width: 120px;
	left: 90px;
	top: 150px;
	animation-delay: .3s;
}
.loading .pan04 {
	width: 145px;
	top: 240px;
	left: 0;
	animation-delay: .4s;
}
.loading .nyuzen {
	width: 265px;
	left: 50%;
	margin-left: -132px;
	top: 340px;
	animation-delay: 0.2s;
}
/*************************************
* header
*************************************/
.h-home-link {
	position: fixed;
	width: 400px;
	left: 50%;
	margin-left: -200px;
	bottom: 0;
	z-index: 1001;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
	transform-origin: bottom center;
}
.h-menu {
	position: fixed;
	left: 0;
	bottom: 0;
	width: 90%;
	background-color: #FF9E19;
	padding: 1rem 5% 1rem 5%;
	z-index: 1000;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.h-menu ul {
	width: 800px;
	display: block;
	font-size: 0;
	position: relative;
	margin: auto;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.h-menu ul li { width: 100px; text-align: center; font-size: 1rem; display: inline-block; }
.h-menu ul li img { width: 60px; }
.h-menu ul li span { display: block; font-size: 0.9rem; }
.h-menu ul li a { display: block; font-weight: bold; color: #fff; }
.h-menu ul li a:visited { color: #fff; }
.h-menu ul li:nth-child(2), .h-menu ul li:nth-child(3) {  }
.h-menu ul li:nth-child(4) { margin-left: 400px }
#header-top.smaller .h-menu {
	padding: 0.2rem 5% 0.2rem 5%;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
#header-top.smaller .h-menu ul {
	transform: scale(0.8,0.8);
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
#header-top.smaller .h-home-link {
	transform: scale(0.7,0.7);
	transform-origin: bottom center;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
/*SNS*/
.h-sns { position: fixed; left: 20px; top: 20px; z-index: 1002; }
.h-sns a { display: block; width: 40px; float: left; margin-right: 15px; }
/*************************************
* トップページ
*************************************/
/*スライダー*/
.mainvisual-area { position: relative; }
.slider {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.slider:after {
	content: " ";
	background-color: rgba(0,0,0,0.1);
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	position: absolute;
}
.slider p { height: 100vh; text-indent: -9999px; }
.slider-comment {
	position: absolute;
	right: 60px;
	top: 60px;
	width: 90px;
	animation-name: fadein-ttl;
	animation-duration: 1s;
	animation-iteration-count: 1;
	animation-timing-function: ease;
	animation-delay: 2.7s;
	opacity: 0;
	animation-fill-mode: forwards;
}
.taiken {
	position: absolute;
	left: 20px;
	bottom: 150px;
	animation-name: fadein-ttl;
	animation-duration: 1s;
	animation-iteration-count: 1;
	animation-timing-function: ease;
	animation-delay: 2.7s;
	opacity: 0;
	animation-fill-mode: forwards;
}
.taiken  a {
	color: #F07700;
	background-color: #fff;
	border: 2px solid #F07700;
	padding: 5px 20px 5px 20px;
	display: inline-block;
	font-weight: bold;
}
/*スクロール*/
.top-main-scroll-00 {
	position: absolute;
	left: 20px;
	top: 50%;
	margin-top: -100px;
	z-index: 900;
	animation-name: fadein-ttl;
	animation-duration: 1s;
	animation-iteration-count: 1;
	animation-timing-function: ease;
	animation-delay: 2.7s;
	opacity: 0;
	animation-fill-mode: forwards;
	width: 4px;
	height: 200px;
	background-color: #fff;
}
.scroll {
    bottom: 0;
    height: 200px;
    position: absolute;
    width: 4px;
    overflow: hidden;
}
.scroll-wheel {
    animation: sdb2 3s ease-in-out infinite;
    background-color: #F07700;
    height: 40px;
    position: absolute;
    width: 4px;
    top: -40px;
}
.scroll::before {
    background-color: #fff;
    content: " ";
    display: block;
    height: 200px;
    top: 0;
    position: absolute;
    width: 4px;
    left: 50%;
}
/*コンセプト*/
.concept-01 .txt { width: 65%; text-align: justify; float: left }
.concept-01 .img { width: 30%; float: right }
.concept-01 .txt .name span { display: block; font-size: 0.9rem; line-height: 1.3rem; }
.concept-01 .txt .name { font-size: 1.2rem; margin-top: 1.5rem; }
.concept-02 { font-size: 0; }
.concept-02 .point { width: 22%; margin-right: 4%; font-size: 1rem; display: inline-block; vertical-align: top; }
.concept-02 .point:last-child { margin-right: 0; }
.concept-02 .point .img { margin-bottom: 0.7rem; }
.concept-02 .point .comment { font-size: 0.9rem; line-height: 1.5rem; }
/*コース紹介・料金*/
.price-01 { margin-bottom: 2rem; }
.price-01 p { border: 1px solid #F07700; text-align: center; padding: 10px; color: #F07700; font-weight: 500; font-size: 1.1rem;  }
.list-01.lesson li { display: inline-block; margin-right: 1rem; }
.course-comment { margin-bottom: 1.5rem; font-size: 1rem; }
.lesson-inner { font-size: 0; }
.lesson-inner h4 { font-size: 1rem; }
.lesson-detail { width: 47%; margin-right: 6%; display: inline-block; vertical-align: top; font-size: 1rem; margin-bottom: 2.5rem; }
.lesson-detail:nth-child(even) { margin-right: 0; }
.lesson-detail .txt { width: 65%; float: left; }
.lesson-detail .img { width: 30%; float: right; }
.lesson-detail .naiyou { background-color: #FFF8F0; padding: 10px; margin-top: 0.5rem; }
.lesson-detail .naiyou .naiyou-ttl { color: #F07700; font-weight: 700; font-size: 0.9rem; }
.lesson-detail .naiyou .naiyou-detail { font-size: 0.8rem; line-height: 1.1rem; text-align: justify; } 
.lesson-detail .cat { padding: 5px; color: #fff; background-color: #F07700; margin-bottom: 0.3rem; display: inline-block; line-height: 1rem; font-weight: 500; }
.lesson-comment { font-size: 0.9rem; line-height: 1.3rem; display: inline-block; vertical-align: top; }
.lesson-caution { border: 1px solid #F07700; padding: 30px; }
.lesson-caution .onegai { text-align: center; font-weight: 500; margin-bottom: 1.5rem; }
.lesson-caution .list-01 { font-size: 0.8rem; line-height: 1.3rem; }
.link-area { font-size: 0; }
.link-detail {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	overflow: hidden;
	width: 45%;
	margin: 0 2.5% 0 2.5%;
	font-size: 1rem;
	box-sizing: border-box;
	padding: 60px 20px;
}
.link-detail:after {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	content: " ";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.link-detail.link-voice:after { background-image: url(../img/top/bnr-voice@2x.jpg); }
.link-detail.link-blog:after { background-image: url(../img/top/bnr-blog@2x.jpg); }
.link-inner { position: relative; z-index: 3; }
.link-detail:before{
	background-color: rgba(0,0,0,0.2);
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	content: " ";
	z-index: 1
}
.link-detail:hover:after {
	transform: scale(1.2,1.2);
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.h3-link { color: #fff; }
.h3-link .en { font-size: 3rem; line-height: 3rem; font-family: 'Text Me One', sans-serif; color: #fff; display: block; letter-spacing: 0.1em }
.h3-link .jp { margin-top: 0.5rem; font-weight: 500; display: block; font-size: 1.1rem; }
/*追加*/
.p-tax { font-size: 0.9rem; text-align: right; color: #F07700; }
/*---*/

/*入会案内*/
.admission-area { text-align: center; }
.admission-info { font-weight: 500; }
.admission-area .tel { font-size: 1.5rem; display: block; margin: 1rem 0 2rem 0 }
.line-link a { display: block; width: 120px; margin: 1rem auto 0 auto; }
.admission-area .qr { width: 140px; margin: auto; }
/*教室情報*/
.about-area .txt { width: 45%; float: left; }
.about-area .img { width: 45%; float: right; }
.about-area .tel { font-size: 1.5rem; display: inline-block; margin-top: 0.5rem; }
.gmap-area iframe { width: 100%; height: 500px; margin-top: 3rem; }
.schedule-area { margin-top: 3rem }
.schedule-area .h3-03 { text-align: center; }
.schedule-area .h3-03:after { left: 50%; margin-left: -30px; }
section#about { padding-bottom: 20rem; }















}




































@media screen and (max-width: 1000px) {
/*************************************
* 共通
*************************************/
.dsp-no-sp { display: none !important; }
main {  }
.content-inner { width: 90%; margin: auto; padding: 0; max-width: 900px; height: 100%; }
section { padding-top: 3rem;  display: block; }
.detail-inner { margin: 0; padding: 0; width: 100%; height: 100%; }
#pagetop { position: fixed; width: 50px; height: 50px; bottom: 0; right: 0; z-index: 500; }
.tel { font-family: 'Roboto'; font-weight: bold; }
/*スクロール量でフェードイン*/
.effect {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
  transform: translateX(-50px);
}
.effect-u {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
  transform: translateY(10px);
}
.effect-o {
  -webkit-transition: 0.4s ease-in-out;
  -moz-transition: 0.4s ease-in-out;
  -o-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  opacity: 0;
}
.fadein { opacity: 1; transform: translateX(0px); }
.area-r-sp { text-align: right; }
.area-l-sp { text-align: left; }
.area-c-sp { text-align: center; margin: auto; }
.m-b_5-sp { margin-bottom: 5px; }
.m-b_20-sp { margin-bottom: 20px; }
.m-b_40-sp { margin-bottom: 40px; }
.m-t_5-sp { margin-top: 5px; }
.m-t_20-sp { margin-top: 20px; }
.m-t_40-sp { margin-top: 40px; }
.fl-l-sp { float: left; }
.fl-r-sp { float: right; }
.w-75-sp { width: 75%; }
.w-70-sp { width: 70%; }
.w-65-sp { width: 65%; }
.w-60-sp { width: 60%; }
.w-55-sp { width: 55%; }
.w-50-sp { width: 50%; }
.w-45-sp { width: 45%; }
.w-40-sp { width: 40%; }
.w-35-sp { width: 35%; }
.w-30-sp { width: 30%; }
.w-25-sp { width: 25%; }
.w-20-sp { width: 20%; }
hr.hr-01 { margin: 2rem 0 2rem 0; border-top: 1px solid #ddd; border-bottom: none; }
hr.hr-02 { margin: 0.5rem 0 0.5rem 0; border-top: 1px solid #ddd; border-bottom: none; }
.text-overflow { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.detail-area { text-align: justify; margin-bottom: 2rem; }
.detail-area:last-child { margin-bottom: 0; }
/*ぱんくず*/
.pankuzu-area { padding: 5px 0 5px 0; text-align: right; font-size: 10px; color: #b2b2b2; }
.pankuzu-area ul, .pankuzu-area ul li { list-style: none; }
.pankuzu-area ul li a { color: #b2b2b2; }
.pankuzu-area ul li { display: inline-block; }
/*pagetop*/
#pagetop { position: fixed; width: 45px; height: 30px; bottom: 30px; right: 20px; z-index: 500; }
#pagetop a:before {
	font-family: FontAwesome;
	content: '\f077';
	color: #b2b2b2;
	font-size: 45px;
	padding: 1px;
	display: inline-block;
}
/*************************************
* 見出し
*************************************/
.h2-area { text-align: center; margin-bottom: 3rem; color: #F07700; }
.h2-01 .en { font-size: 3rem; line-height: 3rem; font-family: 'Text Me One', sans-serif; display: block; }
.h2-01 .jp { font-size: 1.1rem; margin-top: 0.5rem; display: block; font-weight: 500; }
.h3-01 { font-size: 1.3rem; text-align: center; font-weight: 500; margin-bottom: 2rem; color: #F07700; line-height: 2rem; }
.h3-02 { background-color: #F07700; color: #fff; padding: 10px; text-align: center; font-size: 1.2rem; font-weight: 700; }
.h3-03 { font-weight: 500; color: #F07700; margin-bottom: 1.5rem; position: relative; font-size: 1.2rem; padding-bottom: 1rem; }
.h3-03:after { position: absolute; width: 60px; border-bottom: 1px solid #F07700; left: 0; bottom: 0; content: " "; }
.h4-01 { font-weight: 500; color: #F07700; margin-bottom: 0.5rem; text-align: center; }
.h4-02 { font-weight: 500; text-align: center; padding: 10px; margin-bottom: 1.5rem; background-color: #EDEDED; font-weight: bold }
.h5-01 { font-weight: 700; padding-left: 10px; border-left: 4px solid #F07700; line-height: 1.5rem; font-size: 1.2rem; }
.h6-01 { font-weight: 700; }
/*************************************
* テーブル
*************************************/
th {  }
.table-01 { margin-bottom: 1rem; border-top: 1px solid #ebebeb; width: 100%; }
.table-01 tr { border-bottom: 1px solid #ebebeb; display: inline-block; line-height: 1.5rem; padding-left: 2.5%; padding-right: 2.5%; width: 95%; }
.table-01 tr > * { padding: 10px 0 10px 0; }
.table-01 th { font-weight: bold; width: 20%; display: inline-block; }
.table-01 td { width: 70%; display: inline-block; margin-left: 5%; }
/*************************************
* リスト
*************************************/
ul.list-01, ul.list-01 li { list-style: none; } 
ul.list-01 li { padding-left: 1.2em; text-indent: -1.2em; }
ul.list-01 li:before {
	font-family: FontAwesome;
	content: '\f111';
	color: #FF9E19;
	margin-right: 0.3em;
}
/*************************************
* ローディング画面
*************************************/
.load-area { width: 597px; position: absolute; left: 50%; top: 50%; margin-top: -190px; margin-left: -298px; }
.loading { position: relative; width: 597px; height: 380px;}
.loading > * { position: absolute; }
.loading .pan01,.loading .pan02,.loading .pan03,.loading .pan04 {
  animation: loading 1s infinite;
  animation-timing-function: ease-in-out;
}
.loading .ttl {
	width: 597px;
	left: 50%;
	top: 0;
	margin-left: -298px;
}
.loading .face {
	width: 167px;
	top: 110px;
	left: 50%;
	margin-left: -83px;
}
.loading .eye {
	width: 64px;
	top: 183px;
	left: 50%;
	margin-left: -32px;
	animation: action-eye 0.7s;
	animation-delay: 1s;
  animation-timing-function: ease-in-out;
}
.loading .pan01 {
	width: 125px;
	right: 0;
	top: 260px;
	animation-delay: .1s;
	animation-duration: 1s;
}
.loading .pan02 {
	width: 80px;
	right: 125px;
	top: 130px;
	animation-delay: .7s;
	animation-duration: 1s;
}
.loading .pan03 {
	width: 120px;
	left: 90px;
	top: 150px;
	animation-delay: .1s;
	animation-duration: 1s;
}
.loading .pan04 {
	width: 145px;
	top: 240px;
	left: 0;
	animation-delay: .7s;
	animation-duration: 1s;
}
.loading .nyuzen {
	width: 265px;
	left: 50%;
	margin-left: -132px;
	top: 340px;
	animation-delay: 0.2s;
}
/*************************************
* header
*************************************/
.mainvisual-area { position: relative; }
.h-home-link {
	position: fixed;
	width: 300px;
	left: 50%;
	margin-left: -150px;
	bottom: 0;
	z-index: 1001;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
	transform-origin: bottom center;
}
#header-top.smaller .h-home-link {
	transform: scale(0.7,0.7);
	transform-origin: bottom center;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
#header-top:before {
	content: " ";
	position: fixed;
	width: 100%;
	height: 80px;
	background-color: #FF9E19;
	left: 0;
	bottom: 0;
	z-index: 1000;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
	transform-origin: bottom center;
}
#header-top.smaller:before {
	transform: scaleY(0.7);
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
	transform-origin: bottom center;
}
.h-menu ul li { max-width: 300px; margin: auto;  }
.h-menu ul li a { color: #fff; }
.h-menu ul li a:visited {  }
.h-menu ul li img { width: 40px; display: inline-block; }
.h-menu ul li  span { margin-left: 10px; display: inline-block; }
/*SNS*/
.h-sns { position: fixed; left: 12px; top: 12px; z-index: 1008; }
.h-sns a { display: block; width: 35px; float: left; margin-right: 12px; }
/*グロナビ*/
.global-navi {
	transform: scale(0,0);
	position: fixed;
	height: 100%;
	width: 100%;
	top: 0;
	right: 0;
	z-index: 1005;
	background: rgba(255,149,26,0.98);
	transition: all 0.5s;
	text-align: center;
	-webkit-overflow-scrolling: touch;
	-webkit-transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -ms-transition: all .35s ease-in-out;
    transition: all .35s ease-in-out;
    margin: 0 auto 5rem auto;
    padding: 70px 5% 70px 5%;
    overflow-y:scroll;
    -webkit-overflow-scrolling: touch;
    box-sizing: border-box;
}
.global-navi a { color: #fff; font-weight: 500; padding: 1rem; display: block; }
.h-menu-detail { position: absolute; width: 100%; height: 100%; left: 0; top: 50%; margin-top: -174px; }
/* .global-naviに.activeが追加 */
.global-navi.active {
	transform: scale(1,1);
	opacity: 1;
	-webkit-transition: all .5s ease-out;
    -moz-transition: all .5s ease-out;
    -ms-transition: all .5s ease-out;
    transition: all .5s ease-out;
    box-shadow: -1px 0px 7px rgba(0,0,0,0.4);
}
/*バーガーメニュー*/
#side-bar-menu { position: fixed; right: 0; top: 0; z-index: 2000; }
.nav-toggle {
	position: relative;
	display: block;
	width: 50px;
	height: 50px;
	background-color: #FF9E19;
	box-shadow: 1px 1px 2px rgba(0,0,0,0.3);
	cursor: pointer;
	z-index: 1900;
	-webkit-transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -ms-transition: all .35s ease-in-out;
    transition: all .35s ease-in-out;
}
.nav-toggle span {
	display: block;
	position: absolute; /* .toggleに対して */
	width: 20px;
	margin-top: 13px;
	margin-left: 15px;
	border-bottom: solid 3px #fff;
	-webkit-transition: all .35s ease-in-out;
    -moz-transition: all .35s ease-in-out;
    -ms-transition: all .35s ease-in-out;
    transition: all .35s ease-in-out;
}
.nav-toggle span:nth-child(1) { top: 0; }
.nav-toggle span:nth-child(2) { top: 9px; }
.nav-toggle span:nth-child(3) { top: 18px; }
/***** クリック後のボタン *****/
/* 最初のspanをマイナス45度にする */
.nav-toggle.active span:nth-child(1) {
	top: 9px;
	-webkit-transform: rotate(-45deg);
	-moz-transform: rotate(-45deg);
	transform: rotate(-45deg);
	border-bottom: solid 3px #fff;
	opacity: 1;
}
/* 2番目と3番目のspanを45度にする */
.nav-toggle.active span:nth-child(2),
.nav-toggle.active span:nth-child(3) {
	top: 9px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	transform: rotate(45deg);
	border-bottom: solid 3px #fff;
	opacity: 1;
}
/*************************************
* トップページ
*************************************/
/*スライダー*/
.slider {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.slider p {
	height: 100vh;
	height: calc(var(--vh, 1vh) * 100);
	text-indent: -9999px;
}
.slider-comment {
	position: absolute;
	width: 250px;
	left: 5%;
	top: 50%;
	margin-top: -105px;
	z-index: 10;
	animation-name: fadein-ttl;
	animation-duration: 1s;
	animation-iteration-count: 1;
	animation-timing-function: ease;
	animation-delay: 2.7s;
	opacity: 0;
	animation-fill-mode: forwards;
}
.slider-inner:before {
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.1);
	content: " ";
	z-index: 1;
	top: 0;
	left: 0;
}
.taiken {
	text-align: center;
	margin: 1rem auto 1rem auto;
}
.taiken  a {
	font-size: 0.9rem;
	color: #F07700;
	background-color: #fff;
	border: 2px solid #F07700;
	padding: 5px 20px 5px 20px;
	display: inline-block;
	font-weight: bold;
}
/*スクロール*/
.top-main-scroll-00 {
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -100px;
	z-index: 900;
	animation-name: fadein-ttl;
	animation-duration: 1s;
	animation-iteration-count: 1;
	animation-timing-function: ease;
	animation-delay: 2.7s;
	opacity: 0;
	animation-fill-mode: forwards;
	width: 4px;
	height: 200px;
	background-color: #fff;
}
.scroll {
    bottom: 0;
    height: 200px;
    position: absolute;
    width: 4px;
    overflow: hidden;
}
.scroll-wheel {
    animation: sdb2 3s ease-in-out infinite;
    background-color: #F07700;
    height: 40px;
    position: absolute;
    width: 4px;
    top: -40px;
}
.scroll::before {
    background-color: #fff;
    content: " ";
    display: block;
    height: 200px;
    top: 0;
    position: absolute;
    width: 4px;
    left: 50%;
}
/*コンセプト*/
.concept-01 .txt { width: 65%; text-align: justify; float: left }
.concept-01 .img { width: 30%; float: right }
.concept-01 .txt .name span { display: block; font-size: 0.9rem; line-height: 1.3rem; }
.concept-01 .txt .name { font-size: 1.2rem; margin-top: 1.5rem; }
.concept-02 .point { margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid #ddd; }
.concept-02 .point:first-child { padding-top: 1.5rem; border-top: 1px solid #ddd; }
.concept-02 .point .img { float: right; width: 40%; }
.concept-02 .point .txt { float: left; width: 55%; }
.concept-02 .point .comment { font-size: 0.9rem; line-height: 1.5rem; }
.concept-02 .point .h4-01 { text-align: left; }
/*コース紹介・料金*/
.price-01 { margin-bottom: 2rem; }
.price-01 p { border: 1px solid #F07700; text-align: center; padding: 10px; color: #F07700; font-weight: 500; font-size: 1.1rem;  }
.list-01.lesson li { display: inline-block; margin-right: 1rem; }
.course-comment { margin-bottom: 1.5rem; }
.lesson-inner h4 { font-size: 1rem; }
.lesson-detail { margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 1px solid #ddd; }
.lesson-detail .txt { width: 65%; float: left; }
.lesson-detail .img { width: 30%; float: right; }
.lesson-detail .naiyou { background-color: #FFF8F0; padding: 10px; margin-top: 0.5rem; }
.lesson-detail .naiyou .naiyou-ttl { color: #F07700; font-weight: 700; font-size: 0.9rem; }
.lesson-detail .naiyou .naiyou-detail { font-size: 0.8rem; line-height: 1.1rem; text-align: justify; } 
.lesson-detail .cat { padding: 5px; color: #fff; background-color: #F07700; margin-bottom: 0.3rem; display: inline-block; line-height: 1rem; font-weight: 500; }
.lesson-comment { font-size: 0.9rem; line-height: 1.3rem; margin-bottom: 1.5rem; }
.lesson-caution { border: 1px solid #F07700; padding: 20px; }
.lesson-caution .onegai { font-weight: 500; margin-bottom: 1.5rem; }
.lesson-caution .list-01 { font-size: 0.8rem; line-height: 1.3rem; }
.link-area { font-size: 0; }
.link-detail {
	position: relative;
	display: inline-block;
	vertical-align: middle;
	overflow: hidden;
	width: 45%;
	margin: 0 2.5% 0 2.5%;
	font-size: 1rem;
	box-sizing: border-box;
	padding: 60px 20px;
}
.link-detail:after {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	content: " ";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.link-detail.link-voice:after { background-image: url(../img/top/bnr-voice@2x.jpg); }
.link-detail.link-blog:after { background-image: url(../img/top/bnr-blog@2x.jpg); }
.link-inner { position: relative; z-index: 3; }
.link-detail:before{
	background-color: rgba(0,0,0,0.2);
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	content: " ";
	z-index: 1
}
.link-detail:hover:after {
	transform: scale(1.2,1.2);
	-webkit-transition: 0.4s ease-in-out;
	-moz-transition: 0.4s ease-in-out;
	-o-transition: 0.4s ease-in-out;
	transition: 0.4s ease-in-out;
}
.h3-link { color: #fff; }
.h3-link .en { font-size: 3rem; line-height: 3rem; font-family: 'Text Me One', sans-serif; color: #fff; display: block; letter-spacing: 0.1em }
.h3-link .jp { margin-top: 0.5rem; font-weight: 500; display: block; font-size: 1.1rem; }
/*追加*/
.p-tax { font-size: 0.9rem; text-align: right; color: #F07700; }
/*---*/
/*入会案内*/
.admission-area { text-align: center; }
.admission-info { font-weight: 500; }
.admission-area .tel { font-size: 1.5rem; display: block; margin: 1rem 0 2rem 0 }
.line-link a { display: block; width: 120px; margin: 1rem auto 0 auto; }
.admission-area .qr { width: 140px; margin: auto; }
/*教室情報*/
.about-area { width: 100%; max-width: 500px; margin: auto }
.about-area .txt {  }
.about-area .img { margin-top: 1rem; }
.about-area .tel { font-size: 1.5rem; display: inline-block; margin-top: 0.5rem; }
.gmap-area iframe { width: 100%; height: 500px; margin-top: 3rem; }
.schedule-area { margin-top: 3rem }
.schedule-area .h3-03 { text-align: center; }
.schedule-area .h3-03:after { left: 50%; margin-left: -30px; }
section#about { padding-bottom: 12rem; }



















































































}



@media only screen and (max-width: 768px){
/*************************************
* ローディング画面
*************************************/
.load-area { width: 300px; margin-top: -145px; margin-left: -150px; }
.loading { width: 300px; height: 285px;}
.loading .ttl {
	width: 300px;
	left: 50%;
	top: 0;
	margin-left: -150px;
}
.loading .face {
	width: 130px;
	top: 70px;
	left: 50%;
	margin-left: -65px;
}
.loading .eye {
	width: 48px;
	top: 128px;
	left: 50%;
	margin-left: -24px;
}
.loading .pan01 {
	width: 80px;
	right: 0;
	top: 190px;
}
.loading .pan02 {
	width: 52px;
	right: 40px;
	top: 85px;
}
.loading .pan03 {
	width: 70px;
	left: 18px;
	top: 120px;
}
.loading .pan04 {
	width: 85px;
	top: 190px;
	left: 0;
}
.loading .nyuzen {
	width: 150px;
	left: 50%;
	margin-left: -75px;
	top: 250px;
}
/*************************************
* トップページ
*************************************/
/*concept*/
.concept-01 .txt .name { text-align: center; }
.concept-01 .txt { width: 100%; float: none }
.concept-01 .img { width: 100%; float: none; margin-top: 1.5rem; max-width: 400px; margin-left: auto; margin-right: auto }
/*lesson*/
.link-detail {
	width: 100%;
	margin: 0 0 1.5rem 0;
	padding: 20px 30px;
}





}

@media only screen and (max-width: 650px){
/*************************************
* テーブル
*************************************/
.table-01 { border-top: none; }
.table-01 tr { border-bottom: none; display: block; line-height: 1.5rem; padding-left: 0; padding-right: 0; width: 100%; margin-bottom: 0.3rem; }
.table-01 tr > * { padding: 5px 5px 5px 5px; box-sizing: border-box }
.table-01 th { font-weight: bold; width: 100%; display: block; box-sizing: border-box; background-color: #FFF8F0; font-size: 0.8rem; }
.table-01 td { width: 100%; display: block; margin-left: 0; font-size: 0.8rem; line-height: 1.5rem; }
/*************************************
* header
*************************************/
.h-home-link { width: 250px; margin-left: -125px; }
/*************************************
* トップページ
*************************************/
.slider-comment {
	position: absolute;
	width: 200px;
	left: 5%;
	top: 50%;
	margin-top: -84px;
	z-index: 10;
}












}





@media only screen and (max-width: 500px){

.loading span { font-size: 1.1rem; }


/*************************************
* トップページ
*************************************/
/*concept*/
.concept-02 .point .txt { float: none; width: 100%; }
.concept-02 .point .img { float: none; width: 100%; margin-bottom: 1rem; }
.concept-02 .point .h4-01 { text-align: center; }
/*lesson*/
.lesson-detail .txt { width: 100%; float: none; }
.lesson-detail .img { width: 100%; float: none; margin-top: 1rem; }






}



















