@charset "utf-8";
/*ページネーション*/
/*pagenavi*/
.pagenavi-outer {padding:0px 0; text-align:center; border-top:dashed 1px #ccc;}
.wp-pagenavi {padding:20px 0px;}
.wp-pagenavi a, .wp-pagenavi span {
  text-decoration: none;
  border: 1px solid #ccc;
  padding: 10px 10px;
  margin: 2px;
  font-size:15px;
  display:inline-block;
  font-weight: bold;
  color:#2e910f;
  background-color:#fff;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
  border-color: #ccc;
  color:#fff;
  background-color:#2e910f;
}
.wp-pagenavi span.current {border-color:#2e910f;}
.wp-pagenavi span.pages {display:none;}

@media(min-width:769px){
.flex{
  display:flex;
  float:left;
  width:100%;
}
}
.center{text-align:center!important;}
.tar{text-align:right;}
.tal{text-align:left;}
.fw700{font-weight:700;}
.mr10 {margin-right:10px!important;}
.mr20 {margin-right:20px!important;}
.ml10 {margin-left:10px!important;}
.ml20 {margin-left:20px!important;}
.mt10 {margin-top:10px!important;}
.mt20 {margin-top:20px!important;}
.mt30 {margin-top:30px!important;}
.mt40 {margin-top:40px!important;}
.mt60 {margin-top:60px!important;}
.mb10 {margin-bottom:10px!important;}
.mb20 {margin-bottom:20px!important;}
.mb40 {margin-bottom:40px!important;}
.mb60 {margin-bottom:60px!important;}
.pt10 {padding-top:10px!important;}
.pt20 {padding-top:20px!important;}
.pt60 {padding-top:60px!important;}
.pb10 {padding-bottom:10px!important;}
.pr5 {padding-right:5px!important;}
.pr10 {padding-right:10px!important;}
.pl10 {padding-left:10px!important;}
.fs90 {font-size:90%!important;}
.fs110 {font-size:110%!important;}
.fs120 {font-size:120%!important;}
.displayflex {display:flex;}
.displayinline {display:inline-block;}
/*コメントBOX*/
.combox img{
  width:40px;
  border-radius:50%;
  margin:5px 10px 10px 0px;
}
.combox{
  border:solid 3px #a7cff3;
  border-radius:5px;
}
.combox2 img{
  width:50px;
  border-radius:50%;
  margin:5px 10px 10px 0px;
}
.combox2{
  border:solid 3px #a7cff3;
  border-radius:5px;
}
.comment-text{
  display: flex;
  align-items: center;
  border-bottom: 1px dotted #ccc;
  padding-bottom: 1px;
  margin:10px 5px 5px;
}
.comment-text h5{
  margin-bottom:3px;
}
.combox p{
  margin-bottom:0;
  line-height:18px;
}
.combox .star{
  color:#FFB400;
}
/*TOP体験授業口コミ*/
ul {list-style: none;}
.flex-list img {
  width: 60px;
  height:60px;
  margin: 5px;
  float: left;
}
.flex-list {
  display: flex;
  flex-wrap: wrap;
}
.flex-list li {
  flex: auto;
  border: solid 2px #6da011;
  border-radius: 10px;
  width: 25%;
  margin: 5px;
}
/*FAQ*/
.faq span{
  margin-bottom:2px;
}
.faq {
  margin-bottom: 32px; /* 各Q&Aの下に余白 */
}
.faq__dd{
　line-height:12px
}
.faq__dt, .faq__dd {
  position: relative;
  padding-left: 24px;
}
.faq__dt::before, .faq__dd::before {
  font-weight: bold;
  position: absolute;
  left: 0;
  top: 0;
}
.faq__dt {
  font-weight: bold; /* 質問文は太字にしてみました */
  border-bottom: 1px solid #999;
  margin-bottom: 5px; /* 下にちょい余白 */
  font-size:16px;
}
.faq__dt::before {
  content: 'Q.';
  color: #c80021; /* 「Q」の文字色 */
}
.faq__dd::before {
  content: 'A.';
  color: #0085C8; /* 「A」の文字色 */
}
/*囲い*/
.kakoi {
  padding:10px;
  border:solid 3px #E9F2D9;
}
.kakoi {
  line-height: 1.5; /*文の行高*/
  padding: 10px; /*前後の文との余白*/
}
@media(min-width:769px){
.kakoi{
  margin:0 100px;
  margin-bottom:30px;
}
}
/*網掛け*/
.amikake {
  background-color:rgba( 233, 242, 217, 0.45);
  padding:10px;
  border:solid 0px #2e910f;
}
.amikake {
  line-height: 1.5; /*文の行高*/
  margin: 10px 0; /*前後の文との余白*/
}
/* パソコンで見たときは"pc"のclassがついた画像が表示される */
@media  (min-width: 769px) {
.pc { display: block; }
.sp { display: none; }
.sp-se { display: none; }
}
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media  (max-width: 768px) {
.pc { display: none; }
.sp { display: block; }
.sp-se { display: none; }
}
/*スマホ改行*/
@media(min-width:769px){
.br-sp{ display:none; }
}
/*画像レスポンシブ*/
.img-center {
  margin:30px auto!important;
  width:100%;
}
.aligncenter{
  vertical-align:bottom;
}
/*問い合わせボタン*/
.btn-square-shadow {
  display: inline-block;
  padding: 0.7em 2.2em 0.9em 2.2em;
  text-decoration: none;
  background: #1286A9;/*ボタン色*/
  color: #FFF;
  border-bottom: solid 2px #627295;
  border-radius: 4px;
  font-weight:800;
  text-shadow: 0px 0px 1px #000;
}
.btn-square-shadow:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.btn-square-shadow blue {
  background: #05799C;
  background: linear-gradient(#1589aC, #05799C);
  text-shadow: -1px -1px 1px #05597C, 1px 1px 1px #05597C;
  border-bottom: solid 2px #05597C;
}
.center i{
  position: absolute;
  padding-left: 10px;
}
/*↓アコーディオンコード↓*/
Result
EDIT ON
/*ボックス全体*/
.accbox {
  margin: 2em 0;
  padding: 0;
  max-width: 800px;
}
/*ラベル*/
.accbox label {
  display: block;
  margin: 1.5px 0;
  padding : 13px 12px;
  color :#ffffff;
  font-weight: bold;
  background :#2e910f;
  cursor :pointer;
  transition: all 0.5s;
  border-radius:5px;
}
.accbox label:before {
  content: '\f054';
  font-family: 'FontAwesome';
  padding-right: 8px;
}
/*ラベルホバー時*/
.accbox label:hover {
  background :#99cc33;
}
/*チェックは隠す*/
.accbox input {
  display: none;
}
/*中身を非表示にしておく*/
.accbox .accshow {
  height: 0;
  padding: 0;
  overflow: hidden;
  opacity: 0;
  transition: 0.8s;
}
/*クリックで中身表示*/
.cssacc:checked + .accshow {
  height: auto;
  padding: 5px;
  background :#ffffff;
  border: 4px solid #E9F2D9;
  opacity: 1;
}
.accbox .accshow p{
  margin: 15px 10px
}
/*アイコンを入れ替える*/
.cssacc:checked + label:before {
  content: '\f078';
}
/*フォントサイズ*/
.mokuji p {font-size: 16px;}
/*改行レスポンシブ*/
@media(min-width:769px) {
  .br-sp {display: none;}
}
/*中学受験対策ページ仕様*/
.ver1{
  font-size:16px;
  width:auto;
}
.ver1 h2{
  color: #494949;
  background: #f4f4f4;
  border-left: solid 5px #6da011;
  border-bottom: solid 2px #d7d7d7;
  margin-top:20px;
}
.amikake {
 background-color:rgba( 233, 242, 217, 0.45);
 padding:10px;
 border:solid 0px #2e910f;
}
.amikake {
 line-height: 1.5; /*文の行高*/
 padding: 10px; /*前後の文との余白*/
}
.ver1 h3 {
  padding: 0.4em 0.5em;/*文字の上下 左右の余白*/
  color: #494949;/*文字色*/
  background: #f4f4f4;/*背景色*/
  border-left: solid 5px #6da011;/*左線*/
  border-bottom: solid 3px #d7d7d7;/*下線*/
}
/*画面の大きさが~670pxの時のレスポンシブデザイン*/
@media(max-width:670px) {
  .flex-list {flex-wrap: wrap;}
  .flex-list li {width: 100%;}
}
.features:hover{
  opacity:0.7;
}
#footer #footer_district ul li{
  font-size: 13px;
}
/*ファーストビュー画像*/
#main-header.single-list {
  background-image: url('/wp-content/uploads/head-kyoushi.jpg');
}
#main-header.customer {
  background-image: url('/wp-content/themes/otkt20180616/images/head-katei.png');
}
#main-header.service {
  background-image: url('/wp-content/themes/otkt20180616/images/head-about.png');
}
#main-header.teacher {
  background-image: url('/wp-content/themes/otkt20180616/images/head-kyoushi.png');
}
#main-header.price {
  background-image: url('/wp-content/themes/otkt20180616/images/head-ryoukin.png');
}
#main-header.school {
  background-image: url('/wp-content/themes/otkt20180616/images/head-kyoushi.png');
}
#main-header.flow {
  background-image: url('/wp-content/themes/otkt20180616/images/head-faq.png');
}
#main-header.rinen {
  background-image: url('/wp-content/themes/otkt20180616/images/head-rinen.png');
}
/*トップページファーストビュー*/
#tv-outer{
  width:100%;
  height:auto;
  background-repeat:no-repeat;
  background-size:cover;
  background-repeat:no-repeat;
  background-position:center top;
  display:block;
  background-color: #cde0e7;
}
#tv-outer #tv-inner{
  width:100%;
  height:50vh;
  max-width: 1200px;
  max-height: 500px;
  box-sizing:border-box;
  margin:0 auto;
  text-align:center;
  background-color:#cde0e7;
  position:relative;
  overflow:hidden;
}
#tv-outer #tv-inner>img{
  width:auto;
  position:relative;
  top:-100px;
  margin: 0 auto;
}
@media only screen and (min-width: 769px) and (max-width: 1100px){
#tv-outer #tv-inner>img{
  opacity: 0.3;
}
}
#tv-outer #tv-inner #tv-copy04{
  width:auto;
  height:40vh;
  max-height: 400px;
  position:absolute;
  top:5vh;
  right:10%;
  text-align:center;
}
#tv-outer #tv-inner #tv-copy04>img{
  width:auto;
  height:100%;
}
#tv-outer #tv-inner #tv-copy01{
  width:100%;
  position:absolute;
  top:50%;
  left:0;
  text-align:center;
}
#tv-outer #tv-inner #tv-copy01>img{
  width:60%;
  height:auto;
}
#tv-outer #tv-inner #tv-copy02{
  width:100%;
  position:absolute;
  top:70%;
  left:0%;
  text-align:center;
  display:block;
}
#tv-outer #tv-inner #tv-copy02>span{
  width:60%;
  padding-bottom:10px;
  display:inline-block;
  border-bottom:solid 4px #2e910f;
}
#tv-outer #tv-inner #tv-copy02>span>img{
  width:100%;
  height:auto;
}
#tv-outer #tv-inner #tv-logo{
  width:160px;
  height:auto;
  position:absolute;
  bottom:5px;
  right:40px;
}
#tv-outer #tv-inner #tv-logo>img{
  width:100%;
  height:auto;
}
@media only screen and (max-width: 768px){
  #tv-outer{
    display:block;
    background:#fff;
    width:100%;
    height:auto;
    min-width:0;
    min-height:216px;
  }
  #tv-outer #tv-inner{
    width:100%;
    height:auto;
    padding:0;
    background-color:#ccdee7;
    overflow:hidden;
    position:relative;
    box-sizing:border-box;
    margin:0 auto;
  }
  #tv-outer #tv-inner>img{
    width:auto;
    border-radius:0;
    box-shadow:none;
    position:unset;
    margin-left: unset;
	max-width:100%;
	height:auto;
  }
  #tv-outer #tv-inner #tv-copy04{
    width:60%;
    height:auto;
    position:absolute;
    top:10%;
    right:2%;
    text-align:center;
    display:block;
    line-height:1em;
    margin:0 auto;
  }
  #tv-outer #tv-inner #tv-copy04>img{
    width:100%;
    max-width:250px;
    height:auto;
  }
  #tv-outer #tv-inner #tv-logo{
    bottom: 5px;
    right: 10px;
  }
  #tv-outer #tv-inner-sp {
    background: #fff;
	text-align: center;
  }
  #tv-outer #tv-inner-sp img{
    width: 100%;
    height: auto;
    max-width: 300px;
    padding: 20px;
  }
}
#footertop-contact-outer {
  display: block;
  width: 100%;
  height: auto;
}
@media only screen and (min-width: 769px) {
  #footertop-contact-outer #pcfooter-contact {
    display: block;
    margin-top: 20px;
  }
  #footertop-contact-outer #spfooter-contact {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  #footertop-contact-outer #pcfooter-contact {
    display: none;
  }
  #footertop-contact-outer #spfooter-contact {
    display: block;
    margin-top: 20px;
  }
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner {
  min-width: 1000px;
  padding: 10px 2% 10px 2%;
  display: flex;
  justify-content: center;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-contact-area a.blue {
  background: #05799C;
  background: linear-gradient(#1589ac, #05799c);
  text-shadow: -1px -1px 1px #05597C, 1px 1px 1px #05597C;
  border-bottom: solid 4px #05597C;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-contact-area a {
  display: block;
  width: 240px;
  text-decoration: none;
  text-align: center;
  padding: 20px 15px 20px 70px;
  color: #fff;
  font-size: 26px;
  font-weight: bold;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #1eb9ee), color-stop(0, #2ec9fe));
  background: -webkit-linear-gradient(#2ec9fe, #1eb9ee);
  background: -moz-linear-gradient(#2ec9fe, #1eb9ee);
  background: -o-linear-gradient(#2ec9fe, #1eb9ee);
  background: -ms-linear-gradient(#2ec9fe, #1eb9ee);
  background: linear-gradient(#2ec9fe, #1eb9ee);
  position: relative;
  border-bottom: solid 4px #0e99ce;
  border-radius: 12px;
  -moz-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  -webkit-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-contact-area a img {
  position: absolute;
  top: 12px;
  left: 21px;
  width: 40px;
  height: auto;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-a {
  float: left;
  position: relative;
  padding: 10px 0 0 70px;
  margin-left: 10px;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-a .icon-phone {
  display: block;
  width: 50px;
  height: auto;
  position: absolute;
  top: 15px;
  left: 15px;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-a .free-phone {
  font-size: 18px;
  font-weight: bold;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-a .phone-number {
  font-size: 40px;
  font-weight: bold;
  color: #960000;
  font-family: "Arial Black", "Arial", sans-serif;
  text-align: center;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-b {
  float: left;
  position: relative;
  padding: 24px 0 0 20px;
}
#footertop-contact-outer #pcfooter-contact #pcfooter-contact-inner .pc-footer-tel-area .floats-b .datetime {
  font-size: 18px;
  margin-bottom: 8px;
}
#footertop-contact-outer #spfooter-contact .lead {
  color: #366255;
  padding: 6px 0 3px 0;
  font-size: 14px;
  text-align: center;
  font-weight: bold;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner {
  background-color: white;
  padding: 5px 5% 5px 5%;
  text-align: center;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .inlines-a.blue {
  background: #05799C;
  background: linear-gradient(#1589ac, #05799c);
  text-shadow: -1px -1px 1px #05597C, 1px 1px 1px #05597C;
  border-bottom: solid 4px #05597C;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .inlines-a {
  display: block;
  height: 50px;
  text-align: center;
  background: -webkit-linear-gradient(#2ec9fe, #1eb9ee);
  background: -moz-linear-gradient(#2ec9fe, #1eb9ee);
  background: -o-linear-gradient(#2ec9fe, #1eb9ee);
  background: -ms-linear-gradient(#2ec9fe, #1eb9ee);
  background: linear-gradient(#2ec9fe, #1eb9ee);
  border-bottom: solid 4px #0e99ce;
  border-radius: 12px;
  -moz-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  -webkit-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-contact-area {
  display: inline-block;
  position: relative;
  text-align: left;
  margin-top: 5px;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-contact-area .in-contact {
  display: block;
  text-decoration: none;
  text-align: left;
  color: #fff;
  padding: 15px 0px 0px 28px;
  font-size: 14px;
  font-weight: bold;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-contact-area .in-contact img {
  position: absolute;
  top: 10px;
  left: 0px;
  width: 20px;
  height: auto;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .inlines-b.red {
  background: #960000;
  background: linear-gradient(#a60000, #960000);
  text-shadow: -1px -1px 1px #760000, 1px 1px 1px #760000;
  border-bottom: solid 4px #760000;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .inlines-b {
  display: block;
  height: 50px;
  margin-bottom: 5px;
  text-align: center;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(1, #1eb9ee), color-stop(0, #2ec9fe));
  background: -webkit-linear-gradient(#2ec9fe, #1eb9ee);
  background: -moz-linear-gradient(#2ec9fe, #1eb9ee);
  background: -o-linear-gradient(#2ec9fe, #1eb9ee);
  background: -ms-linear-gradient(#2ec9fe, #1eb9ee);
  background: linear-gradient(#2ec9fe, #1eb9ee);
  border-bottom: solid 4px #0e99ce;
  border-radius: 12px;
  -moz-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  -webkit-text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
  text-shadow: -1px -1px 1px #0e99ce, 1px 1px 1px #0e99ce;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-tel-area {
  display: inline-block;
  position: relative;
  text-align: left;
  margin-top: 5px;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-tel-area .in-tel {
  display: block;
  text-decoration: none;
  text-align: left;
  color: #fff;
  padding: 15px 0px 0px 30px;
  font-size: 14px;
  font-weight: bold;
}
#footertop-contact-outer #spfooter-contact #spfooter-contact-inner .sp-footer-tel-area .in-tel img {
  position: absolute;
  top: 10px;
  left: 0px;
  width: 20px;
  height: auto;
}
#footertop-contact-outer #spfooter-contact .end {
  padding: 3px 0 6px 0;
  font-size: 12px;
  text-align: center;
  font-weight: 700;
}
/* toppage */
#main-area #main-area-inner #main-cont .one-column #tc08-outer {
  background-color: #f8f8f9;
  padding: 40px 0 0 0;
}
#main-area #main-area-inner #main-cont .one-column #tc08 {
  width: 100%;
  margin: 0 auto;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex.left {
  -webkit-flex-flow: row-reverse;
  flex-flow: row-reverse;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-align-items: center;
  align-items: center;
  margin-bottom: 60px;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div.w40 {
  width: 40%;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div img {
  width: auto;
  height: auto;
  max-height: 250px;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex.right>div img {
  float: right;
  margin-left: 10px;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex.left>div img {
  float: left;
  margin-right: 10px;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div.w55 {
  width: 55%;
  box-sizing: border-box;
  padding-left: 5%;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex h3 {
  font-size: 27px;
  padding-bottom: 5px;
  font-weight: bold;
  margin-bottom: 40px;
  position: relative;
  color: #111;
  line-height: 1.4em;
}
#main-area #main-area-inner #main-cont .one-column #tc08 h2>span {
  display: block;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div .rsp-on {
  display: none;
}
#main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div.w55.pr {
  padding-left: 0;
  padding-right: 5%;
}
@media only screen and (max-width: 768px) {
    #main-area #main-area-inner #main-cont .one-column #tc08-outer.top-outer {
        padding: 0 0 10px 0;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08-outer {
        margin-bottom: 0;
        padding-bottom: 0;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08 {
        width: 100%;
        box-sizing: border-box;
        padding: 0 5vw;
	}
    #main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div img {
        width: unset;
        max-width: 100%;
        height: auto;
        margin-bottom: 20px;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08 .box-flex {
        display: block;
        margin-bottom: 40px;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div.w40 {
        display: none;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div.w55 {
        width: 100%;
        padding-left: 0;
    }
    #main-area #main-area-inner #main-cont .one-column #tc08 .box-flex>div .rsp-on {
        display: block;
    }
}
#main-area #main-area-inner #main-cont .one-column #tc09 {
  width: 80%;
  margin: 0 auto;
  max-width: 1200px;
}
#main-area #main-area-inner #main-cont .one-column #tc09 h2 {
  text-align: center;
  margin-bottom: 40px;
  position: relative;
  letter-spacing: 2px;
}
#main-area #main-area-inner #main-cont .one-column #tc09 h2>span>a {
  background: linear-gradient(#3ea11f, #2e910f);
  text-shadow: -1px -1px 1px #0e810f, 1px 1px 1px #0e810f;
  border-bottom: solid 2px #0e810f;
  border-radius: 4px;
  color: #fff;
  font-weight: bold;
  position: absolute;
  right: 0;
  top: -10px;
  display: block;
  padding: 5px 25px 5px 15px;
  font-size: 14px;
  text-decoration: none;
}
#main-area #main-area-inner #main-cont .one-column #tc09 h2>span>a:hover {
  opacity: 0.7;
}
#main-area #main-area-inner #main-cont .one-column #tc09 h2>span>a>span {
  position: absolute;
  right: 10px;
  top: 50%;
  margin-top: -12px;
}
#main-area #main-area-inner #main-cont .one-column #tc09 .faq-box {
  width: 100%;
  box-sizing: border-box;
  padding: 20px;
  margin-bottom: 20px;
  border: solid 1px #ccc;
  background: #fff;
}
#main-area #main-area-inner #main-cont .one-column #tc09 .faq-box .faq-q {
  padding-bottom: 10px;
  text-indent: -26px;
  padding-left: 26px;
  border-bottom: dashed 2px #ccc;
  font-weight: bold;
  line-height: 1.8em;
}
#main-area #main-area-inner #main-cont .one-column #tc09 .faq-box .faq-q span {
  padding: 0 4px;
  color: #0e810f;
  font-weight: bold;
}
#main-area #main-area-inner #main-cont .one-column #tc09 .faq-box .faq-a {
  padding-top: 10px;
  text-indent: -26px;
  padding-left: 26px;
  line-height: 1.8em;
}
@media only screen and (max-width: 768px) {
    #main-area #main-area-inner #main-cont .one-column #tc09 h2 {
        text-align: left;
    }
}

#main-area #main-area-inner #main-cont .school-list ul {
  padding: 0px;
  list-style: none;
}
#main-area #main-area-inner #main-cont .school-list ul li {
  min-width: 88px;
  float: left;
  margin-right: 10px;
  margin-bottom: 10px;
  line-height:1.8em;
}
#main-area #main-area-inner #main-cont .school-list ul li a {
  width: 100%;
  border-top: solid 1px #ccc;
  border-left: solid 1px #ccc;
  border-right: solid 1px #ccc;
  border-bottom: solid 2px #999;
  display: block;
  padding: 5px 10px;
  text-decoration: none;
  font-size: 95%;
  font-weight: bold;
  box-sizing: border-box;
  border-radius: 4px;
  color: #111;
  -webkit-transition-delay: 0s;
  -webkit-transition-duration: 0.2s;
  -webkit-transition-property: all;
  -webkit-transition-timing-function: linear;
  transition-delay: 0s;
  transition-duration: 0.2s;
  transition-property: all;
  transition-timing-function: linear;
}
.bgwhite {
  background:#fff;
}
.mb20 {
  margin-bottom:20px;
}
#pan-outer {
  background: #fff;
}
#main-header-outer {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
@media only screen and (min-width: 769px) {
#main-area #main-area-inner #rsp-main-copy-c {
  position: absolute;
  top: 35%;
  height: 40%;
  left: 5%;
  margin-left: 10px;
  box-sizing: border-box;
  margin-top: 0px;
  z-index: 20;
}
#main-area #main-area-inner #rsp-main-copy-c>span {
  text-align: left;
  position: relative;
  font-size: min(2.6vw,200%);
  font-weight: 700;
  color: #fff;
  letter-spacing: 2px;
  display: block;
  top: 25%;
  left: 0;
  margin-top: -14px;
  line-height: 1.2em;
}
#main-area #main-area-inner #rsp-main-copy-c>span.school {
  top: 10%;
  margin-top: -25px;
  line-height: 1.4em;
}
#main-area #main-area-inner #rsp-main-copy-d {
  position: absolute;
  top: 35%;
  height: 40%;
  left: 5%;
  margin-left: 10px;
  box-sizing: border-box;
  margin-top: 0px;
  z-index: 20;
}
#main-area #main-area-inner #rsp-main-copy-d>span {
  text-align: left;
  position: relative;
  font-size: min(2.6vw,200%);
  font-weight: bold;
  color: #fff;
  letter-spacing: 2px;
  display: block;
  top: 25%;
  left: 0;
  margin-top: -14px;
  line-height: 1.2em;
}
}
@media only screen and (max-width: 768px) {
#main-area #main-area-inner #rsp-main-copy-c {
  display: block;
  font-size: 140%;
  font-weight: 700;
  line-height: 1.4em;
  color: #fff;
  background-color: #247b08;
  padding: 15px 10px 15px 10px;
  box-sizing: border-box;
  text-align: center;
}
#main-area #main-area-inner #rsp-main-copy-d {
  display: block;
  color: #fff;
  background:#247b08;
  text-align: center;
  line-height: 1.3;
  padding: 10px;
  font-weight: 700;
}
#main-area #main-area-inner #rsp-main-copy-d>span {
  top:25%;
  font-size:140%;
  line-height: 1.4;
 }
}
@media only screen and (max-width: 768px) {
.popup {
  background: #fef6d7;
  height: 2rem;
  width: 350px;
  position: fixed;
  z-index: 9999;
  bottom: 75px;
  right: 0;
  border-radius: 20px;
  line-height: 2.0;
  text-align: center;
  font-size: 90%;
  padding: 2px;
}
}
@media only screen and (min-width: 769px) {
.popup {
  background: #fef6d7;
  height: 65px;
  width: 350px;
  position: fixed;
  z-index: 9999;
  bottom: 105px;
  right: 0;
  border-radius: 0 20px 20px 0;
  line-height: 1.8;
  text-align: center;
  padding: 5px;
}
.popup img {
  float: left;
}
}
.popup a{
  font-weight: 600;
  color: #05597c;
  text-decoration: underline;
  text-underline-offset: 5px;
}
.popup a span{
  margin-left: 5px;
}
.pc-footer-tel-area {
  padding-right: 30px;
}
.pc-footer-contact-area {
  position: relative;
}
.pc-footer-contact-area .fa-caret-right {
  position: absolute;
  top: 35%;
  right: 15px;
  font-size: 150%;
  color: #fff;
}
#main-area #main-area-inner #main-cont #left-area h1.single-list {
  font-size: 160%;
  font-weight: bold;
  box-sizing: border-box;
  padding: 40px 0px 0px 0px;
  margin-bottom: 60px;
  line-height: 1.2em;
  position: relative;
}
#main-area #main-area-inner #main-cont #left-area h1.single-list>span {
  display: block;
  line-height: 1.4;
}
#main-area #main-area-inner #main-cont #left-area h1.single-list>span:after {
  content: '';
  background-color: #2e910f;
  height: 2px;
  margin-left: 0px;
  position: absolute;
  bottom: -20px;
  left: 0px;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  #main-area #main-area-inner #main-cont #left-area h1.single-list {
    font-size: 130%;
    line-height: 1.4;
    margin-bottom: 40px;
    padding-top: 0;
  }
  #main-area #main-area-inner #main-cont #left-area h1.single-list>span:after {
    content: '';
    background-color: #2e910f;
    height: 2px;
    margin-left: 0px;
    position: absolute;
    bottom: -10px;
    left: 0px;
    width: 100%;
  }
  #main-area #main-area-inner #main-cont #left-area h1.news-title {
    font-size: 130%;
    line-height: 1.4;
    margin-bottom: 40px;
    padding-top: 0;
  }
  #main-area #main-area-inner #main-cont #left-area h1.news-title>span {
    display: block;
  }
  #main-area #main-area-inner #main-cont #left-area h1.news-title>span:after {
    content: '';
    background-color: #2e910f;
    height: 2px;
    margin-left: 0px;
    position: absolute;
    bottom: -10px;
    left: 0px;
    width: 100%;
  }
}
#main-area #main-area-inner #main-cont #left-area h1.news-title {
  font-size: 160%;
  font-weight: bold;
  box-sizing: border-box;
  padding: 40px 0px 0px 0px;
  margin-bottom: 60px;
  line-height: 1.2em;
  position: relative;
}
#main-area #main-area-inner #main-cont #left-area h1.news-title>span {
  display: block;
  line-height: 1.4;
}
#main-area #main-area-inner #main-cont #left-area h1.news-title>span:after {
  content: '';
  background-color: #2e910f;
  height: 2px;
  margin-left: 0px;
  position: absolute;
  bottom: -20px;
  left: 0px;
  width: 100%;
}
#h1-outer-sp p {
  font-weight: 600;
  font-size: 90%;
  padding: 10px 20px;
  box-sizing: border-box;
  max-width: 1200px;
  margin: 0 auto;
}
#h1-outer-sp p a{
    text-decoration: none;
    color: #fff;
}
@media only screen and (max-width: 768px) {
  #h1-outer-sp p {
    display: block;
    padding: 5px 10px;
    margin: 0;
    min-width: 0;
    font-size: 12px;
    background: #005b01;
    line-height: 1.3;
  }
  #h1-outer-sp p a{
    color: #fff;
  }
}
@media only screen and (min-width: 769px) {
  #header {
    position: sticky;
    top: 0;
    z-index: 9999;
  }
  .pcnav {
     background-color: #eee;
  }
}
@media only screen and (max-width: 768px) {
  /* #header .sp-header-tel-area p{position:relative;padding-top:12px;font-weight:bold;font-family:"Arial Black","Arial",sans-serif}#header .sp-header-tel-area p span{position:absolute;top:0px;left:0px;font-weight:normal;font-size:9px;letter-spacing:-1px} */
  .sp-header-tel-area {
    width: 75px;
    height: 35px;
    padding: 5px;
    border-radius: 12px;
    background: #960000;
    background: linear-gradient(#a60000, #960000);
    text-shadow: -1px -1px 1px #760000, 1px 1px 1px #760000;
	text-align: center;
  }
  .sp-header-tel-area .modal-checkbox {
    display: none;
  }
  .sp-header-tel-area .modal-open-button img {
    width: 100%;
  }
  .sp-header-tel-area .modal-open-button {
    cursor: pointer;
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
  }
  .sp-header-tel-area .modal {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-color: rgb(0 0 0 / 60%);
    text-align: left;
  }
  .sp-header-tel-area .open {
    opacity: 0;
	scale: 0;
    transition: opacity 0.5s, scale 0s 0.5s;
  }
  .sp-header-tel-area #modalToggle:checked ~ #modal.open {
    opacity: 1;
	scale: 1;
    transition: opacity 0.5s;
  }
  .sp-header-tel-area .close {
    position: absolute;
    top: 20px;
    right: 20px;
    font-size: 24px;
    color: #000;
    text-decoration: none;
    cursor: pointer;
    transform: translate(50%, -50%);
	text-shadow: none;
  }
  .sp-header-tel-area .modal-wrapper {
    position: relative;
    width: 80%;
    max-width: 500px;
    max-height: 70%;
    padding: 20px;
    margin: auto;
    overflow: scroll;
    background-color: #FEFEFE;
    border-radius: 5px;
  }
  .sp-header-tel-area .modal-content {
    text-shadow: none;
  }
  .sp-header-tel-area .modal-content p.title {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 20px;
    font-weight: bold;
    box-sizing: border-box;
    padding: 0px 0px 0px 0px;
    margin-bottom: 40px;
    line-height: 1.4em;
    position: relative;
  }
  .sp-header-tel-area .modal-content p {  
    font-size: 100%;
    line-height: 1.8em;
  }
  .sp-header-tel-area .phone {
    font-size: 160%!important;
  }
  .sp-header-tel-area .phone img {
    margin: 0 10px;
    vertical-align: middle;
  }
  #main-area #main-area-inner #main-cont .one-column .area-ken-button .kc-01 {
    width: 100%!important;
  }
}
#footer-contact-outer #sp-contact #sp-contact-inner .inlines-b {
  display:block;
  width:40%;
  text-align:center;
  border-radius:12px;
  background: linear-gradient(#3ea11f, #2e910f);
  text-shadow: -1px -1px 1px #0e810f, 1px 1px 1px #0e810f;
  border-bottom: solid 4px #0e810f;
/*  background:-webkit-gradient(linear, left top, left bottom, color-stop(1, #1eb9ee), color-stop(0, #2ec9fe));
  background:-webkit-linear-gradient(#2ec9fe, #1eb9ee);
  background:-moz-linear-gradient(#2ec9fe, #1eb9ee);
  background:-o-linear-gradient(#2ec9fe, #1eb9ee);
  background:-ms-linear-gradient(#2ec9fe, #1eb9ee);
  background:linear-gradient(#2ec9fe,#1eb9ee);
  -moz-text-shadow:-1px -1px 1px #0e99ce,1px 1px 1px #0e99ce;
  -webkit-text-shadow:-1px -1px 1px #0e99ce,1px 1px 1px #0e99ce;
  text-shadow:-1px -1px 1px #0e99ce,1px 1px 1px #0e99ce;
  border-bottom:solid 4px #0e99ce;*/
 }
#main-area #main-area-inner #main-cont #left-area .area-ken-button .kc-01>span.left {
  left: 15px;
  right: unset;
}
#main-area #main-area-inner #main-cont .one-column .area-ken-button {
  padding: 40px;
}
#main-area #main-area-inner #main-cont .one-column .area-ken-button .kc-01 {
  display: block;
  width: 50%;
  background: linear-gradient(#3ea11f, #2e910f);
  text-shadow: -1px -1px 1px #0e810f, 1px 1px 1px #0e810f;
  border-bottom: solid 2px #0e810f;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  text-decoration: none;
  padding: 15px 0;
  border-radius: 4px;
  margin: 0 auto;
  position: relative;
}
#main-area #main-area-inner #main-cont .one-column .area-ken-button .kc-01>span.left {
  position: absolute;
  left: 15px;
  top: 50%;
  margin-top: -9px;
}
#main-area #main-area-inner #main-cont #left-area .kyoushi-kanren .kk-box .kk-box-inner .kk-gakubu {
  font-size: 100%;
}
#main-area #main-area-inner #main-cont #left-area .kyoushi-kanren .kk-box .kk-box-inner .kk-sub {
  font-size: 100%;
}
#main-area #main-area-inner #main-cont #left-area .kyoushi-kanren .kk-box .kk-box-inner .kk-box-text {
  padding: 0 10px;
}
#footer-contact-outer #sp-contact #sp-contact-inner .inlines-a.white {
  background: #fff;
  background: linear-gradient(#fff, #d1d1d1);
  border-bottom: solid 2px #760000;
  text-shadow: none;
}
#footer-contact-outer #sp-contact #sp-contact-inner .inlines-b.white {
  background: #fff;
  background: linear-gradient(#fff, #d1d1d1);
  border-bottom: solid 2px #0c80a3;
  text-shadow: none;
}
#footer-contact-outer #sp-contact #sp-contact-inner .inlines-a.white .sp-footer-contact-area .in-contact {
  color: #760000;
  text-decoration: underline;
  text-underline-offset: 5px;
}
#footer-contact-outer #sp-contact #sp-contact-inner .inlines-b.white .sp-footer-tel-area .in-tel {
  color: #0c80a3;
  text-decoration: underline;
  text-underline-offset: 5px;
}
.tag-area {
  display: flex;
}
.tag-area a{
  background: #369917;
  max-width: 200px;
  padding: 5px 10px;
  border-radius: 10px;
  text-align: center;
  line-height: 1.4;
  display: block;
  margin: 10px;
  color: #fff;
  text-decoration: none;
}

/* 料金概要 */
#price-widget {
    margin: 60px 0;
}
#price-widget .relative {
    position: relative;
}
#price-widget .flex-price {
    display: flex;
}
#price-widget .flex-column {
    flex-direction: column;
}
#price-widget .flex-grow {
    flex-grow: 1;
}
#price-widget .absolute {
    position: absolute;
}
#price-widget .absolute-left-center {
    left: 50%;
    transform: translate(-50%, 0);
}
#price-widget .table {
    display: table;
    margin: 10px auto 0;
}
#price-widget .table-row {
    display: table-row;
}
#price-widget .table-cell {
    display: table-cell;
}
#price-widget .bd-color-site {
    border-color: #005b01;
}
#price-widget .color-reverse {
    color: #FFF;
}
#price-widget .color-site {
    color: #005b01;
}
#price-widget .bg-color-site {
    background-color: #005b01;
}
#price-widget .color-light {
    color: #555;
}
#price-widget .border-radius {
    border-radius: 10px;
}
#price-widget .align-self-center {
    align-self: center;
}
#price-widget .text-center {
    text-align: center;
}
#price-widget .text-right {
    text-align: right;
}
#price-widget .bold {
    font-weight: bold;
}
#price-widget .font-ex-huge {
    font-size: 34px;
}
#price-widget .font-ex-large {
    font-size: 20px!important;
}
#price-widget .font-large {
    font-size: 18px;
}
#price-widget .font-semi-small {
    font-size: 14px;
}
#price-widget .top-margin-single {
    margin-top: 10px;
}
#price-widget .top-margin-triple {
    margin-top: 30px;
}
#price-widget .bottom-padding-double {
    padding-bottom: 20px;
}
#price-widget .left-padding-single {
    padding-left: 10px;
}
#price-widget .y-padding-single {
    padding-top: 10px;
    padding-bottom: 10px;
}
#price-widget .y-padding-double {
    padding-top: 20px;
    padding-bottom: 20px;
}
#price-widget .x-padding-double {
    padding-left: 20px;
    padding-right: 20px;
}
#price-widget .x-padding-triple {
    padding-left: 30px;
    padding-right: 30px;
}
#price-widget .cross img {
    width: 50px;
}
#price-widget .enclosure {
    border-style: solid;
    border-width: 1px;
}
#price-widget .enclosure .enclosure-head {
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
}
#price-widget p.bottom-balloon {
    background-color: #960000;
    top: -25px;
    padding: 5px 30px !important;
    font-weight: 600;
	width:120px;
}
#price-widget p.bottom-balloon::before {
    content: "";
    position: absolute;
    border-width: 15px;
    border-left-width: 10px;
    border-right-width: 10px;
    border-color: transparent;
    border-style: solid;
    border-top-color: #960000;
    bottom: -25px;
    left: 50%;
    transform: translate(-50%, 0);
}
#price-widget .charge .table-cell-caption {
    width: 38%;
}
#price-widget .promise .table-cell-caption {
    width: 80%;
}

@media only screen and (min-width: 769px) {
	#price-widget .hide-pc {
        display: none !important;
    }
	#price-widget .justify-spacebetween-pc {
        justify-content: space-between;
    }
	#price-widget .flex-row-pc {
        flex-direction: row;
    }
	#price-widget .cost-container > div:first-child {
        width: 40%;
    }
	#price-widget .cost-container > div:last-child {
        width: 40%;
    }
	#price-widget .custom-font-size-price {
        font-size: 40px;
    }
	#price-widget .top-margin-triple-pc {
        margin-top: 30px;
    }
	#price-widget .promise {
        height: 100%;
    }
	#price-widget .promise div.table {
        height: 100%;
    }
}

@media only screen and (max-width: 768px) {
    #price-widget .flex-column-sp {
        flex-direction: column;
    }
	#price-widget .font-ex-huge {
        font-size: 30px;
    }
	#price-widget .font-ex-large {
        font-size: 20px;
    }
	#price-widget .font-large {
        font-size: 18px;
    }
	#price-widget .font-semi-small {
        font-size: 12px;
    }
	#price-widget .top-margin-double-sp {
        margin-top: 20px;
    }
	#price-widget .custom-font-size-price {
        font-size: 32px;
    }
}
.card-layout {
  background: #fbfbfb;
  padding: 20px;
  margin: 20px;
  width: 40%;
  display: inline-block;
  vertical-align: text-top;
}
.card-layout a {
  text-decoration: none;
  color: #005b01;
}
.card-layout h2 {
  margin-bottom: 30px!important;
  padding-top: 20px !important;
}
.card-layout p {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.card-layout time {
  margin-top: 20px;
  display: block;
  text-align: right;
}
.main-middle-cta-container {
  max-width: 700px;
  margin: 40px auto 0;
}
.coach-style img{
  max-width: 100%;
  height: auto;
}
.flex-box {
  display: flex;
}
.flex-box-item {
  flex: 1;
  box-sizing: border-box;
  border-top: solid 1px #ccc;
  border-left: solid 1px #ccc;
  border-right: solid 1px #ccc;
  border-bottom: solid 2px #ccc;
  padding: 20px;
  border-radius: 4px;
  margin: 0 10px 20px;
}
.flex-box-item ul {
  line-height: 1.4;
}
.flex-box-item li {
  padding: 10px 5px 0;
}
.bgcolor1 {
  background-color: #d7ebfe;
  font-weight: 700;
  padding: 10px!important;
}
.bgcolor2 {
  background-color: #d6e9b2;
  font-weight: 700;
  padding: 10px!important;
}
.bgcolor3 {
  background-color: #ffe1e1;
  font-weight: 700;
  padding: 10px!important;
  margin-bottom: 10px;
}
.h3-parent {
  height: 80px;
  display: table;
  width: 90%;
  margin: 5% auto;
  border-radius: 10px;
}
.h3-parent h3 {
  display: table-cell;
  vertical-align: middle;
}
.button2 {
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-around;
  justify-content: space-around;
  max-width: 700px;
  margin: 0 auto;
}
.button2>div {
  width: 48%;
  height: auto;
}
@media screen and (max-width: 768px) {
.flex-box,
.button2 {
  display: block!important;
}
.button2>div {
  width: 100%;
}
}