@charset "utf-8";

/*---------------------------------------------------------------------------------------
	GROPによる追加CSS
----------------------------------------------------------------------------------------*/

/* ■■■既存CSS調整■■■ */
/* margin */
.mt0 {margin-top: 0px !important;}
.mb0 {margin-bottom: 0px!important;}
.mt10 {margin-top: 10px !important;}
.mb10 {margin-bottom: 10px!important;}
.mt20 {margin-top: 20px!important;}
.mb20 {margin-bottom: 20px!important;}
.mt30 {margin-top: 30px!important;}
.mb30 {margin-bottom: 30px!important;}
.mt40 {margin-top: 40px!important;}
.mb40 {margin-bottom: 40px!important;}
.mt50 {margin-top: 50px!important;}
.mb50 {margin-bottom: 50px!important;}
.mt60 {margin-top: 60px!important;}
.mb60 {margin-bottom: 60px!important;}
.mt80 {margin-top: 80px!important;}
.mb80 {margin-bottom: 80px!important;}
.mt100 {margin-top: 100px!important;}
.mb100 {margin-bottom: 100px!important;}

@media screen and (max-width:768px){
  .mt0 {margin-top: 0px!important;}
  .mb0 {margin-bottom: 0px!important;}
  .mt10 {margin-top: 10px!important;}
  .mb10 {margin-bottom: 10px!important;}
  .mt20 {margin-top: 15px!important;}
  .mb20 {margin-bottom: 15px!important;}
  .mt30 {margin-top: 20px!important;}
  .mb30 {margin-bottom: 20px!important;}
  .mt40 {margin-top: 20px!important;}
  .mb40 {margin-bottom: 20px!important;}
  .mt50 {margin-top: 25px!important;}
  .mb50 {margin-bottom: 25px!important;}
  .mt60 {margin-top: 30px!important;}
  .mb60 {margin-bottom: 30px!important;}
  .mt80 {margin-top: 40px!important;}
  .mb80 {margin-bottom: 40px!important;}
  .mt100 {margin-top: 50px!important;}
  .mb100 {margin-bottom: 50px!important;}
}

/* ■■■共通パーツ■■■ */
.buttonArea {
  width: 800px;
  margin: 20px auto;
  padding: 20px 0 1px;
  background-color: #fff;
}

.buttonArea h4.unity {
  width: 100%;
  margin: 0 auto 20px;
  padding: 0;
  color: #666;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
}

.buttonArea h4.unity span {
  font-size: 16px;
}

.buttonArea p {
  margin: 0 auto 10px;
  color: #666;
  text-align: center;
}

.buttonArea p.webCon {
  margin: 15px auto 5px;
  color: #666;
  text-align: center;
}

.buttonBox {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  margin: 10px auto 25px;
  padding: 0;
}

.buttonBoxLink {
  max-width: 220px;
  width: 70%;
  margin: 0 10px;
  padding: 0;
  text-align: center;
}

.btnNormal {
  display: block;
  width: 180px;
  margin: 0 auto;
  padding: 15px 0;
  color: #fff;
  background-color: #faab00;
  border-radius: 10px;
  font-size: 16px;
  text-align: center;
  text-decoration: none;
}

.btnNormal:hover {
  opacity: 0.7;
}

.btnWeb {
  position: relative;
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 15px 0;
  color: #fff;
  background-color: #faab00;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
}

.btnIcon {
  position: absolute;
  top: 50%;
  right: 12px;/*右からの距離*/
  width: 10px;/*アイコンの横幅指定*/
  transform: translateY(-50%);/*この指定で上下中央に*/
}

.btnWeb:hover {
  opacity: 0.7;
}

.btnWeb2 {
  position: relative;
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 15px 0;
  color: #fff;
  background-color: #faab00;
  border-radius: 10px;
  border-bottom: solid 2px #d27d00;/*少し濃い目の色に*/
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.2), 0 2px 2px rgba(0, 0, 0, 0.19);
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
}

.btnWeb2:hover {
  opacity: 0.7;
}

.btnTel {
  display: block;
  width: 240px;
  margin: 0 auto;
  padding: 15px 0;
  color: #faab00;
  background-color: #fff;
  border-radius: 10px;
  border: 2px solid #faab00;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
}

.btnTelIcon {
  width: 20px;/*アイコンの横幅指定*/
  transform: translateY(-10%);/*この指定で上下中央に*/
}

.btnTel:hover {
  background-color: #ffeec8;
}

.strOrange {
  color: #faab00 !important;
}

/* タブレット用 */
@media screen and (max-width: 1100px) {
  .buttonArea {
    max-width: 800px;
    width: 100%;
    margin: 20px auto;
    padding: 0;
    background-color: #fff;
  }
}

/* スマホ用 */
@media screen and (max-width: 768px) {

}


/* PC限定改行（<br class="brPc">と記述） */
@media screen and (max-width: 768px) {
  .brPc {
    display:none; 
  }
}

/* SP限定改行（<br class="brSp">と記述） */
.brSp {
  display:none; 
}

@media screen and (max-width: 768px) {
  .brSp {
    display:block; 
  }
}

/* PCのみ表示 */
@media screen and (max-width: 1025px) {
  .pcArea {
    display:none; 
  }
}

/* タブレットのみ表示 */
.tabArea {
  display:none; 
}

@media screen and (min-width:760px) and ( max-width:1024px) {
  .tabArea {
    display:block; 
  }
}

/* SPのみ表示 */
.spArea {
  display:none; 
}

@media screen and (max-width: 759px) {
  .spArea {
    display:block; 
  }
}


/* ■■■デザイン統一■■■ */
/* 見出し */
h2.unity {
  max-width: 1100px;
  margin: 0 auto 40px;
  padding: 0 10%;
  color: #333;
  font-size: 36px;
  font-weight: 700;
  text-align: center;
  line-height: 1.4;
  position: relative;
}

h3.unity {
  max-width: 800px;
  width: 100%;
  margin: 0 auto 20px;
  padding: 10px 0;
  border-bottom: 3px solid #ffdc91;
  color: #333;
  font-size: 28px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  position: relative;
}

h3.unity:before {
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 30%;
  height: 3px;
  content: '';
  background: #faab00;
}

h4.unity {
  width: 100%;
  margin: 0 auto 20px;
  padding: 0;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}

h5.unity {
  width: 100%;
  margin: 0 auto 20px;
  padding: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}


/* リンク */
a.uline {
  color: #3399ff;
  text-decoration: underline;
}


/* 枠組み */
.wrap {
  clear: both;
  box-sizing: content-box;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 5%;
  padding-right: 5%;
}

.container {
  max-width: 800px;
  margin: 0 auto;
  padding: 0;
}


/* 画像 */
.picW800 {
  max-width: 800px;
  margin: 0 auto;
  padding: 0;
}

.picW800 img {
  width: 100%;
}

.picW800s {
  max-width: 800px;
  margin: 0 auto;
  padding: 0;
}

.picW800s img {
  width: 100%;
}

.picW640 {
  max-width: 640px;
  margin: 0 auto;
  padding: 0;
}

.picW640 img {
  width: 100%;
}

.picW480 {
  max-width: 480px;
  width: 90%;
  margin: 0 auto;
  padding: 0;
}

.picW480 img {
  width: 100%;
}

/* 本文 */
.descW640 {
  max-width: 640px;
  margin: 30px auto;
  padding: 0;
}

.descW640 p {
  margin: 12px 0;
  font-size: 16px;
  line-height: 1.6;
}

.descW640 p.infoAreaD {
  width: 100%;
  margin: 10px auto;
  padding: 10px 15px;
  border: 3px dashed #999;
  font-size: 14px;
  font-weight: normal;
}

.descW640 p.infoAreaG {
  width: 100%;
  margin: 10px auto;
  padding: 10px 15px;
  background-color: #f5f5f7;
  border-radius: 3px;
  font-size: 14px;
  font-weight: normal;
}

.descW640 p span {
  color: #333;
  font-size: 16px;
  font-weight: 700;
}

.descW640 p span.strongOrange {
  color: #fa8100;
  font-size: 16px;
  font-weight: 700;
}

.descW640 p span.supplement {
  color: #000;
  font-size: 14px;
  font-weight: normal;
}

.descW640 p span.caution {
  color: #000;
  font-size: 12px;
  font-weight: normal;
  line-height: 1.4;
}


/* テーブル */
table{
  width: 100%;
  margin: 0 auto 20px;
  padding: 0;
  border: 1px solid #ccc;
}

table th, table td{
  padding: 10px 1.5em;
  border: 1px solid #ccc;
  font-size: 16px;
}

table th{
  width: 15%;
  padding: 10px .5em;
  white-space: nowrap;
  text-align: center;
  vertical-align: middle;
  background: #eee;
}

table th.w100{
  width: 100%;
  background: #ccc;
}

table td{
  width: 85%;
}


/* 文字位置 */
.taCenter {
  text-align: center !important;
}

.taLeft {
  text-align: left !important;
}

.taRight {
  text-align: right !important;
}

/* タブレット用 */
@media screen and (max-width: 1100px) {

}

/* スマホ用 */
@media screen and (max-width: 768px) {
  h2.unity {
    max-width: 1100px;
    width: 90%;
    margin: 0 auto;
    padding: 0;
    font-size: 28px;
    text-align: center;
  }

  h3.unity {
    width: 100%;
    margin: 0 auto 20px;
    padding: 10px 0;
    font-size: 24px;
  }

  h3.unityTaL {
    width: 100%;
    margin: 0 auto 20px;
    padding: 10px 0;
    font-size: 24px;
  }

  h4.unity {
    width: 100%;
    margin: 0 auto 20px;
    padding: 0;
    font-size: 22px;
  }

  h5.unity {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    font-size: 18px;
  }

  .wrap {
    padding-left: 0;
    padding-right: 0;
  }

  .container {
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }

  .descW640 {
    max-width: 640px;
    width: 90%;
    margin: 30px auto;
    padding: 0;
  }

  .picW800 {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }

  .picW800s {
    max-width: 800px;
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  .descW640 {
    max-width: 640px;
    width: 90%;
    margin: 30px auto;
    padding: 0;
  }

  .buttonBox {
    width: 100%;
    margin: 10px auto 25px;
    padding: 0;
  }

  table{
    width: 90%;
    border: 1px solid #ccc;
  }

  table th,table td{
    display: block;
    width: 100%;
  }
}


/* ■■■オンライン自習室「WAO25」■■■ */
#omosiro .comment {
  margin: 0 auto;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  text-align: center;
}

#omosiro .descW640 ul {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

#omosiro .descW640 ul li {
  margin: 0 auto 10px;
  padding: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
  text-align: left;
  padding-left: 1em;
  text-indent: -1em;
}

#omosiro .descW640 ol.gokui {
  counter-reset:list;
  list-style-type:none;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.6;
  padding:0;
}

#omosiro .descW640 ol.gokui li {
  position:relative;
  margin: 7px 0 7px 0px;
  padding-left:40px;
  font-weight: bold;
  font-size:18px;
  line-height: 40px;
  border: solid 1px #FAAB00;
  border-radius: 10px;
}

#omosiro .descW640 ol.gokui li:before{
  counter-increment: list;
  content: counter(list);
  position: absolute;
  left: -10px;
  width: 40px;
  height: 40px;
  text-align: center;
  color: #fff;
  line-height:40px;
  background: #FAAB00;
  border-radius: 50%;
  top: 50%;
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}

#omosiro .descW640 p span {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
}

#omosiro .contentsBox {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  max-width: 800px;
  width: 90%;
  margin: 20px auto;
  padding: 10px;
}

#omosiro .contentsBoxPic {
  width: 48%;
  margin: 0 auto 15px;
  padding: 0;
}

#omosiro .contentsBoxPic p {
  width: 100%;
  margin: 10px auto 0;
  padding: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}

#omosiro .contentsBox .contentsBoxTxt {
  width: 80%;
  margin: 0 auto;
  padding: 0 0 0 20px;
}

#omosiro .contentsBox .contentsBoxTxt h4 {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}

#omosiro .contentsBox .contentsBoxTxt h5 {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  text-align: left;
}

#omosiro .contentsBoxTxt p {
  width: 100%;
  margin: 10px auto;
  padding: 0;
  font-size: 14px;
  line-height: 1.6;
  text-align: left;
}

#omosiro .fs18 {
  font-size: 18px;
}

#omosiro .kadomaru130 {
  border-radius: 130px;
}

#omosiro img.waku {
  border: 1px solid #999;
}

#omosiro p.info {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  padding: 8px;
  color: #000;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
  border: 1px solid #999;
  border-radius: 8px;
}

#omosiro p.caution {
  width: 90%;
  max-width: 640px;
  margin: 0 auto;
  padding: 0;
  color: #000;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5;
}

.fs18 {
  font-size: 18px;
  line-height: 1.5;
}

.picW360 {
  width: 70%;
  max-width: 360px;
  margin: 0 auto;
  padding: 0;
}

.picW360 img {
  width: 100%;
}

#omosiro dl {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  max-width: 640px;
  width: 90%;
  margin: 0 auto;
  padding: 0;
}

#omosiro dt {
  width: 20%;
  margin: 0 auto 10px;
  padding: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.6;
  text-align: left;
}

#omosiro dd {
  width: 80%;
  margin: 0 auto;
  padding: 3px 0;
  font-size: 16px;
  line-height: 1.6;
  text-align: left;
}

#omosiro .movieArea {
  width: 50%;
  margin: 0 auto;
  padding: 0;
}

#omosiro .movieAreaPv {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

#omosiro .movieAreaShort {
  width: 50%;
  margin: 0 auto;
  padding: 0;
}

#omosiro .movieBox {
  margin: 0 15px 30px;
  padding: 0;
  flex-basis: 46%;
}

#omosiro .movieBoxShort {
  margin: 0 auto 30px;
  padding: 0;
  flex-basis: 46%;
}

#omosiro .movieBox .youtube {
  position: relative;
  height: 0;
  padding-top: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
  overflow: hidden;
}

#omosiro .movieBox .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

#omosiro .movieBoxShort .youtube {
  position: relative;
  height: 0;
  padding-top: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
  overflow: hidden;
}

#omosiro .movieBoxShort .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}


#omosiro .programArea {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  max-width: 800px;
  width: 90%;
  margin: 0 auto 40px;
  padding: 0;
}

#omosiro .programBox {
  max-width: 380px;
  width: 48%;
  margin: 20px auto 0;
  padding: 0;
}

#omosiro .programBox img {
  width: 100%;
}

#formArea {
  padding-top: 90px;
  margin-top:-90px;
}


/* タブレット用 */
@media screen and (max-width: 1100px) {
  #omosiro .movieBox {
    margin: 0 auto 20px;
    padding: 0;
    flex-basis: 45%;
  }
}

/* スマホ用 */
@media screen and (max-width: 768px) {
  .buttonArea p {
    margin: 0 auto 10px;
    font-size: 14px;
  }

  #omosiro .descW640 ul.haichi li {
    font-size: 16px;
    font-weight: 700;
  }

  #omosiro dt {
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  
  #omosiro dd {
    width: 100%;
    margin: 0 auto 10px;
    padding: 0;
  }

  #omosiro .contentsBox {
    width: 95%;
    margin: 40px auto;
    padding: 10px 5px;
  }

  #omosiro .contentsBoxPic {
    width: 100%;
    margin: 0 auto 15px;
    padding: 0;
  }
  
  #omosiro .contentsBox .contentsBoxTxt {
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  #omosiro .contentsBox .contentsBoxTxt h4 {
    font-size: 18px;
  }

  #omosiro .contentsBox .contentsBoxTxt h5 {
    font-size: 16px;
  }


  #formArea {
    padding-top: 60px;
    margin-top:-60px;
  }

  #omosiro .descW640 ol.gokui li {
    position:relative;
    margin: 7px 0 7px 0px;
    padding: 5px 5px 5px 40px;
    font-weight: bold;
    font-size:16px;
    line-height: 24px;
    border: solid 1px #FAAB00;
    border-radius: 10px;
  }

  .fs18 {
    font-size: 16px;
  }

  #omosiro dt {
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  
  #omosiro dd {
    width: 100%;
    margin: 0 auto 10px;
    padding: 0;
  }

  #omosiro .movieArea {
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  #omosiro .movieAreaShort {
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  #omosiro .movieBox {
    margin: 0 auto 20px;
    padding: 0;
    flex-basis: 90%;
  }

  #omosiro .movieBoxShort {
    margin: 0 auto 20px;
    padding: 0;
    flex-basis: 100%;
  }

  #omosiro .movieBoxShort .youtube {
    position: relative;
    height: 0;
    padding-top: 177.83%; 
    overflow: hidden;
  }
  
  #omosiro .movieBoxShort .youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
  }


  #omosiro .programArea {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    max-width: 800px;
    width: 90%;
    margin: 0 auto 40px;
    padding: 0;
  }
  
  #omosiro .programBox {
    max-width: 390px;
    width: 100%;
    margin: 20px auto 0;
    padding: 0;
  }
}
