@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: 100%;
  margin: 20px auto;
  padding: 0;
  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 5px;
  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: 0 auto 20px;
  padding: 0;
}

.buttonBoxLink {
  width: 280px;
  margin: 0 10px 20px;
  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: 1101px) {
  .pcArea {
    display:none; 
  }
}

/* PCのみ表示 */
@media screen and (max-width:769px) {
  .pcArea2 {
    display:none; 
  }
}

/* タブレットのみ表示 */
.tabArea {
  display:none; 
}

@media screen and (min-width:769px) and ( max-width:1100px) {
  .tabArea {
    display:block; 
  }
}

/* SPのみ表示 */
.spArea {
  display:none; 
}

@media screen and (max-width: 768px) {
  .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%;
}

.picW640 {
  max-width: 640px;
  width: 90%;
  margin: 0 auto;
  padding: 0;
}

.picW640 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 20px;
    padding: 0;
    font-size: 20px;
  }

  .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;
  }
  
  .descW640 {
    max-width: 640px;
    width: 90%;
    margin: 30px auto;
    padding: 0;
  }

  .buttonBox {
    width: 100%;
    margin: 0 auto 20px;
    padding: 0;
  }

  table{
    width: 90%;
    border: 1px solid #ccc;
  }

  table th,table td{
    display: block;
    width: 100%;
  }
}


/* ■■■教養探究■■■ */

.descW640 p.caption {
  width: 100%;
  margin: 0;
  padding: 0 0 0 1em;
  text-indent: -1em;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6;
  text-align:left;
}

.blogArea {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding: 2rem 1rem;
  border: 2px solid #faab00;
  border-radius: 8px;	
}

.blogArea h3 {
  color: #faab00;
  font-size: 30px;
  font-weight: 700;
  line-height: 1.3;
  text-align:center;
}

.blogArea h3 span {
  font-size: 22px;
}

.blogArea .blogBox {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-evenly;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.blogArea .blogBox .contentBox {
  width: 48%;
  max-width:350px; 
  margin: 0 0 30px;
  padding: 0;
}

.blogArea .blogBox .contentBox img {
  width: 100%;
}

.blogArea .blogBox .contentBox .contentBoxTxt {
  width: 100%; 
  margin: 1rem auto 0;
  padding: 0;
}

.blogArea .blogBox .contentBox .contentBoxTxt .tagBox {
  width: fit-content;
  margin: 0 0 10px;
  padding: 2px 1.5rem;
  background: #e7e7e7;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.3;
  text-align:center;
}

.blogArea .blogBox .contentBox .contentBoxTxt p {
  width: 100%;
  margin: 0.5rem 0;
  padding: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
}

.blogArea .blogBox .contentBox .contentBoxTxt2 p {
  width: 100%;
  margin: 1rem 0 2rem;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
}

.blogArea2 {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0;
}

.blogArea2 .blogBox {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.blogArea2 .blogBox .contentBox {
  width: 23%;
  max-width:350px; 
  margin: 0 6px 30px;
  padding: 0;
}

.blogArea2 .blogBox .contentBox img {
  width: 100%;
}

.blogArea2 .blogBox .contentBox .contentBoxTxt {
  width: 100%; 
  margin: 1rem auto 0;
  padding: 0;
}

.blogArea2 .blogBox .contentBox .contentBoxTxt .tagBox {
  width: fit-content;
  margin: 0;
  padding: 2px 1rem;
  background: #e7e7e7;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.3;
  text-align:center;
}

.blogArea2 .blogBox .contentBox .contentBoxTxt p {
  width: 100%;
  margin: 0.5rem 0;
  padding: 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-align: left;
}

.blogArea2 .blogBox .contentBox .contentBoxTxt2 p {
  width: 100%;
  margin: 1rem 0 2rem;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
}

.explain {
  width: 95%;
  max-width: 640px;
  margin: 0 auto;
  padding: 1.5rem 1rem;
  background-color: #fff1b9;
  border: solid 1px #fff1b9;
  border-radius: 8px;
}

.explain p {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  padding-left: 1.5rem ;
  text-indent: -1.5rem;
}

.linkArea {
  width: 100%;
  max-width: 640px;
  margin: 10px auto 0;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: right;
}

.movieArea {
  width: 90%;
  max-width: 640px;
  margin: 0 auto;
  padding: 0;
}

.movieBox {
  margin: 0 0 20px;
  padding: 0;
  flex-basis: 46%;
}

.blogArea2 .blogBox .contentBox .movieBox {
  margin: 0;
  padding: 0;
  flex-basis: 46%;
}

.movieBox .youtube {
  position: relative;
  height: 0;
  padding-top: 56.25%; /*アスペクト比 16:9の場合の縦幅*/
  overflow: hidden;
}

.movieBox .youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.linkArea2 {
  width: 95%;
  max-width: 640px;
  margin: 0 auto;
  padding: 2rem 1rem ;
  background-color: #f5f5f7;
  border: solid 1px #f5f5f7;
  border-radius: 8px;
}

.linkArea2 ul {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.linkArea2 ul li {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
}


/*ダイレクトリンクタブ*/
.all_area {
  width: 100%;
  max-width: 800px;
  background: #fff;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
}

.all_area div.content_area{
  width: 100%;
  max-width: 800px;
  margin: 0;
  padding: 0;
}

.tab_area{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-around;
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
}

.tab_area div {
  width: 30%;
  max-width: 200px;
  margin: 0;
  padding: 8px 0;
  cursor: pointer;
  color:#333;
  background-color: #F5F5F7;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  text-align:center;
}

.tab_area div span {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  text-align:center;
}

.tab_area div:hover {
  color:#333;
  background-color: #dce1e4;
}


.tab_area div.select{
  color: #fff;
  background-color: #FAAB00;
}

.hide{
  display:none;
}

.menuArea {
  max-width: 800px;
  width: 90%;
  margin: 20px auto 0;
  padding: 20px 0 1px;
  background-color: #fff;
}

.menuBox {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  width: 100%;
  margin: 10px auto 25px;
  padding: 0;
}

.menuBoxLink {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  max-width: 240px;
  width: 70%;
  margin: 5px;
  padding: 0;
  text-align: center;
  border: solid 2px #FAAB00;
  border-radius: 10px;
}

.menuBoxLink a{
  position: relative;
  display: block;
  width: 100%;
  margin: 0 auto;
  padding: 15px 0;
  display: block;
  color: #faab00;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  text-decoration: none;
}

.descW640 p.fs18 {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}


/* タブレット用 */
@media screen and (max-width: 1100px) {

}

/* スマホ用 */
@media screen and (max-width: 768px) {
  .caption {
    font-size: 14px;
  }

  .blogArea {
    width: 95%;
    margin: 0 auto;
    padding: 1.5rem 0.5rem;
  }
  
  .blogArea h3 {
    font-size: 26px;
  }
  
  .blogArea h3 span {
    font-size: 18px;
  }
  
  .blogArea .blogBox {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-evenly;
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  
  .blogArea .blogBox .contentBox {
    width: 95%;
    max-width:400px; 
    margin: 0 0 30px;
    padding: 0;
  }
  
  .blogArea .blogBox .contentBoxTxt {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    margin: 1rem auto 0;
    padding: 0;
  }
  
  .blogArea .blogBox .contentBoxTxt .tagBox {
    width: 50%;
    max-width: 200px;
    margin: 0 0 10px;
    padding: 2px 1.5rem;
  }
  
  .blogArea .blogBox .contentBoxTxt .linkBox {
    width: 35%;
    max-width: 200px;
    margin: 0;
    padding: 0;
    font-size: 16px;
  }

  .blogArea2 {
    width: 95%;
    margin: 0 auto;
    padding: 0;
  }
  
  .blogArea2 .blogBox {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-evenly;
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  
  .blogArea2 .blogBox .contentBox {
    width: 95%;
    max-width:400px; 
    margin: 0 0 20px;
    padding: 0;
  }
  
  .blogArea2 .blogBox .contentBoxTxt {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    margin: 1rem auto 0;
    padding: 0;
  }
  
  .blogArea2 .blogBox .contentBoxTxt .tagBox {
    width: 50%;
    max-width: 230px;
    margin: 0;
    padding: 2px 1.5rem;
  }
  
  .blogArea2 .blogBox .contentBoxTxt .linkBox {
    width: 35%;
    max-width: 200px;
    margin: 0;
    padding: 0;
    font-size: 16px;
  }

  .explain {
    width: 95%;
    max-width: 640px;
    margin: 0 auto;
    padding: 1.5rem 1rem;
  }
  
  .explain p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
    padding-left: 1.5rem ;
    text-indent: -1.5rem;
  }
  
  .linkArea {
    width: 90%;
    max-width: 640px;
    margin: 10px auto 0;
    padding: 0;
  }

  .movieArea {
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  .movieBox {
    margin: 0 auto 20px;
    padding: 0;
    flex-basis: 90%;
  }

  .linkArea2 {
    width: 95%;
    max-width: 640px;
    margin: 0 auto;
    padding: 1.5rem 1rem ;
  }
  
  .linkArea2 ul {
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  
  .linkArea2 ul li {
    width: 100%;
    margin: 0 auto 10px;
    padding: 0;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    text-align: left;
  }

  .menuArea {
    width: 100%;
    margin: 20px auto 0;
    padding: 0 0 1px;
    background-color: #fff;
  }

  .menuBoxLink {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    max-width: 300px;
    width: 45%;
    margin: 5px;
    padding: 0;
    text-align: center;
    border: solid 2px #FAAB00;
    border-radius: 10px;
  }
  
  .menuBoxLink a{
    position: relative;
    display: block;
    width: 100%;
    margin: 0 auto;
    padding: 15px 0;
    display: block;
    color: #faab00;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
    text-decoration: none;
  }

  .descW640 p.fs18 {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.5;
  }
}
