/* ------------------ max640 ------------------ */
@media only screen and (max-width: 640px) {

  body {
    width: 100%;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  }

  p {
    margin: 0;
    padding: 0;
    font-size: 13px;
    line-height: 1.6;
  }

  .inner {
  }

  .onlyPC {
    display: none;
  }

  .onlySP {
    display: block;
  }

  /*============================
  header
  ============================*/
  header {
  }

  header h1 a {
    background: url(../img/sp/logo.png) no-repeat center;
    background-size: 172px 27px;
    height: 27px;
    text-indent: -9999px;
    padding: 10px 0 5px;
    display: block;
  }

  header h1 span {
    display: none;
  }

  header h2 {
    font-size: 18px;
    font-weight: bold;
    background: #F6F2E9;
    text-align: center;
    padding: 4px 0 2px;
  }
  /*============================
  #mainImg
  ============================*/
  #mainImg {
    background: url(../img/sp/img_01_01_2_komi.png) no-repeat;
    background-size: 100%;
    text-indent: -9999px;
    padding-bottom: 79%;
  }

  /* ===================================
  .btnBox01{
  =================================== */
  .btnBox01,
  .btnBox02  {
    border: 5px solid #FFCA00;
  }
  .btnBox01 h2,
  .btnBox02 h2 {
    background: url(../img/sp/img_02.png) no-repeat;
    background-size: 100%;
    text-indent: -9999px;
    padding-bottom: 20%;
  }

  .btnBox01 .btn {
    background: url(../img/sp/btn_bg_01_2_komi.png) no-repeat;
    background-size: 100%;
    margin: -5px 10px 10px;
    padding: 27% 7px 4%;
    text-indent: -9999px;
    position: relative;
  }
  .btnBox02 .btn {
    background: url(../img/sp/btn_bg_01_2_komi.png) no-repeat;
    background-size: 100%;
    margin: -5px 10px 10px;
    padding: 27% 7px 4%;
    text-indent: -9999px;
    position: relative;
  }
  .btnBox03 .btn {
    padding-top: 31%;
  }
  .btnBox01 .btn a,
  .btnBox02 .btn a {
    background-size: 100%;
    text-indent: -9999px;
    padding-bottom: 19%;
    display: block;
  }

  .btnBox01 .btn .btn01,
  .btnBox02 .btn .btn01 {
    background: url(../img/sp/btn_03_01.png) no-repeat;
    background-size: 100%;
  }
  .btnBox01 .btn .btn02,
  .btnBox02 .btn .btn02 {
    background: url(../img/sp/btn_03_02_3.png) no-repeat;
    background-size: 100%;
  }

  /*============================
  #performanceArea
  ============================*/
  #performanceArea {
    background: #F6F2E9;
    margin: 15px 0;
    padding: 10px 0 5px;
  }

  #performanceArea .box01 {
    background: url(../img/sp/img_03.png) no-repeat right 3px top 5px #FFF;
    background-size: 30%;
    margin: 0 10px 10px;
    padding: 3px 5px 2%;
  }

  #performanceArea h2 {
    font-size: 18px;
    font-weight: bold;
    color: #6CC9F7;
    line-height: 20px;
  }

  #performanceArea h2 span {
    font-size: 16px;
  }

  #performanceArea p.date {
    font-size: 12px;
    font-weight: bold;
  }

  #performanceArea .text01 {
    border-top: 1px solid #000;
    font-size: 15px;
    font-weight: bold;
    background: url(../img/sp/ico_01.png) no-repeat 1% 50%;
    background-size: 4%;
    padding: 2px 0px 0 5%;
    width: 190px;
  }

  #performanceArea .text02 {
    background: url(../img/sp/img_04.png) no-repeat center;
    background-size: 98%;
    padding: 0px 0 50%;
    text-indent: -9999px;
  }

  #performanceArea .text02:after {
    content: "";
    background: url(../img/sp/img_05.png) no-repeat bottom;
    background-size: 100%;
  }

  #performanceArea .box02 {
    position: relative;
  }

  #performanceArea .box02 h2 {
    text-align: center;
    background: #FFF;
    margin: 0 10px;
    padding: 8px 0 44%;
  }

  #performanceArea .medal {
    position: absolute;
    top: 25%;
    left: 0;
    background: url(../img/sp/img_06_6.png) no-repeat;
    background-size: 100%;
    padding: 0px 0 38%;
    text-indent: -9999px;
    width: 100%;
  }
  #performanceArea.revise2025 .medal {
    background: url(../img/img_06_6.webp) no-repeat;
    background-size: 100%;
	}

  #performanceArea .textBox01 {
    background: url(../img/sp/img_07.png) no-repeat;
    background-size: 100%;
    text-indent: -9999px;
    padding: 0px 0 35%;
    margin: 8px 0 0;
  }

  #performanceArea .box03 {
    background: url(../img/sp/img_target.png) no-repeat;
    background-size: 100%;
    height: 120px;
    text-indent: -9999px;
    margin: 0 10px;
  }

  #performanceArea .target {
    text-indent: -9999px;
  }

  #performanceArea ul {
    display: none;
  }

  #performanceArea li {
    text-indent: -9999px;
  }

  #performanceArea .rightTxt {
    display: none;
  }

  #performanceArea .textBox02 {
    background: url(../img/sp/img_08.png) no-repeat;
    background-size: 100%;
    text-indent: -9999px;
    padding: 0px 0 55%;
    margin: 5px 0 0;
  }

  /*============================
  #authorArea
  ============================*/
  #authorArea {
    border: 1px solid #6CC9F7;
    margin: 10px;
    background: url(../img/img_04.png) no-repeat left top;
    background-size: 36%;
    padding: 0px 5px 8px;
  }
	#authorArea.revise2025 {
    background: url(../img/img_face.jpg) no-repeat left top;
    background-size: 36%;
	}
  #authorArea h2 {
    font-size: 11.5px;
    font-weight: bold;
    padding: 2% 0 1% 37%;
  }

  #authorArea h2 strong {
    font-size: 20px;
  }
  #authorArea h2 span {
    font-size: 10px;
    font-weight: normal;
  }

  #authorArea .btn a {
    background: url(../img/sp/btn_02.png) no-repeat right 4px center;
    background-size: 100%;
    text-indent: -9999px;
    padding: 0px 0 20%;
    margin-bottom: 5%;
    display: block;
  }

  #authorArea p {
    color: #1F1813;
  }

  #authorArea .btn {
    padding: 4% 0 1% 37%;
  }

  /*============================
  #bookArea
  ============================*/
  #bookArea {
    background: url(../img/sp/bg_01_01_3.png) no-repeat;
    background-size: 100%;
    text-indent: -9999px;
    padding: 0 0 31%;
    margin: 15px 10px 0;
  }
  #bookArea h2 {
    font-size: 15px;
    font-weight: bold;
    color: #FFF;
    text-indent: 0px;
    padding: 8px 0 0 4px;
  }
  #bookArea h2 span {
    font-size: 12px;
  }
  #bookArea.revise2025 {
		min-height:100vw;
    background: url(../img/img_work_2_sp.webp) no-repeat;
    background-size: 100% auto;
		padding:0;
	}
  #bookArea.revise2025 h2 {
		padding:1.6vw 0 0 .5em;
	}
  #bookArea.revise2025 h2 span {
		font-size:4vw;
	}

  /*============================
  #quizArea
  ============================*/
  #quizArea {
    background: url(../img/sp/img_11_2.png) no-repeat 50% 8px #F6F2E9;
    background-size: 95%;
    margin: 15px 0;
    padding-bottom: 1px;
  }

  #quizArea h2 {
    background: url(../img/sp/img_10.png) no-repeat;
    background-size: 70%;
    text-indent: -9999px;
    padding: 0 0 9%;
    margin: 0 10px;
  }

  #quizArea p.question {
    margin: 0 10px 46%;
    width: 65%;
  }

  #quizList dl {
  }

  #quizList dt {
    font-size: 17px;
    font-weight: bold;
    background: url(../img/sp/ico_02.png) no-repeat 7px 0;
    background-size: 14%;
    padding: 3px 5px 4% 53px;
    border-bottom: 1px solid #666;
    position: relative;
    margin-top: 18px;
  }

  #quizList dt .answer {
    position: absolute;
    right: 12px;
    bottom: -14px;
    background: url(../img/sp/btn_answer.png) no-repeat;
    background-size: 100%;
    width: 37%;
    height: auto;
    padding-bottom: 1%;
    z-index: 100;
    text-indent: -9999px;
  }

  #quizList dt .active {
    background: url(../img/sp/btn_answer_on.png) no-repeat;
    background-size: 100%;
  }

  #quizList dd {
    background: #FFF;
    margin-bottom: 30px;
    position: relative;
    padding-bottom: 10%;
  }

  #quizList dd p {
    background: url(../img/ico_03.png) no-repeat 8px 10px #FFF;
    background-size: 14%;
    padding: 4% 0 2% 53px;
    font-size: 15px;
    font-weight: bold;
    line-height: 19px;
  }

  #quizList dd p.point{
    font-size: 10px;
    font-weight: normal;
    background: #DEDEDE;
    display: block;
    padding: 1px 0 0 5px;
    margin: 0 10px;
  }

  #quizList dd p.pTxt {
    font-size: 13px;
    font-weight: normal;
    background: #EEE;
    display: block;
    padding: 4px 5px 2px;
    margin: 0 10px;
  }

  #quizList dd p.pTxt span {
    display: block;
  }

  #quizList dd p a {
    color: #FF7F00;
  }

  #quizList dd .close {
    position: absolute;
    right: 0;
    bottom: 0;
    background: url(../img/sp/ico_05.png) no-repeat;
    background-size: 100%;
    width: 25px;
    height: 25px;
    cursor: pointer;
    text-indent: -9999px;
  }

  #quizArea .bookContentsBox {
    background: #FFF;
    border-radius: 10px;
    padding: 13px 10px 1px;
    margin: 20px 10px 15px;
  }

  #quizArea .bookContentsBox h2 {
    background: url(../img/sp/ico_04.png) no-repeat 0 0;
    background-size: 100%;
    padding: 0 0 7%;
    font-weight: bold;
    color: #6CC9F7;
    border-bottom: 1px solid #D7CAB7;
    margin: 0;
  }

  #quizArea .bookContentsBox #bookList {
    margin: 10px 0;
  }

  #quizArea .bookContentsBox #bookList dt {
    background: #D7CAB8;
    font-size: 13px;
    font-weight: bold;
    color: #FFF;
    width: 23%;
    border-radius: 30px;
    padding: 3px 0 1px;
    text-align: center;
    box-sizing: border-box;
  }

  #quizArea .bookContentsBox #bookList dd {
    font-size: 15px;
    font-weight: bold;
    margin: 5px 0 7px;
  }

  /*============================
  #voiceArea
  ============================*/
  #voiceArea{
    margin: 15px 10px 10px;
  }

  #voiceArea h2 {
    font-size: 15px;
    font-weight: bold;
    color: #FFF;
    background: #6CC9F7;
    text-align: center;
    padding: 7px 0 5px;
    position: relative;
  }

  #voiceArea h2:after {
    content: "";
    background: url(../img/sp/arrow_02.png) no-repeat;
    background-size: 100%;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -4px;
    width: 5px;
    height: 4px;
    margin: 0 auto;
  }

  #voiceArea .voiceBox{
    border: 1px solid #68C8F9;
    margin: 10px 0 0;
    padding: 5px;
  }

  #voiceArea li {
    border: 5px solid #F6F2E9;
    margin: 0 0 5px;
    padding: 5px;
  }

  #voiceArea li:last-child {
    margin-bottom: 0;
  }

  #voiceArea li h3 {
    font-size: 13px;
    background: #D2EDFC;
    padding: 5px 0 2px 8px;
    margin: 0 0 5px;
  }
  #voiceArea li h4 {
    font-size: 15px;
    color: #666;
    margin: 10px 0 5px;
  }

  #voiceArea li p {
    font-size: 13px;
    color: #666;
  }
  /*#voiceArea li p.voice1 {
  height:410px;
}
#voiceArea li p.voice2 {
height:560px;
}
#voiceArea li p.voice3 {
height:125px;
}*/
#voiceArea .voice01{
  background: url(../img/img_voice_01.png) no-repeat center bottom 5px;
  background-size: 97%;
  padding-bottom: 87%;
}
#voiceArea .voice02{
  background: url(../img/img_voice_02.png) no-repeat center bottom 10px;
  background-size: 97%;
  padding-bottom: 100%;
}
#voiceArea .voice03{
  background: url(../img/img_voice_03.png) no-repeat center bottom 10px;
  background-size: 97%;
  padding-bottom: 66%;
}
#voiceArea .voice04{
  background: url(../img/img_voice_04.png) no-repeat center bottom 10px;
  background-size: 97%;
  padding-bottom: 95%;
}
#voiceArea .voice05{
  background: url(../img/img_voice_05.png) no-repeat center bottom 10px;
  background-size: 97%;
  padding-bottom: 95%;
}
#voiceArea .voice06{
  background: url(../img/img_voice_06.png) no-repeat center bottom 10px;
  background-size: 97%;
  padding-bottom: 47%;
}
/* ===================================
#application
=================================== */
#application {
  margin: 0 0 25px;
}

#application h2 {
  background: url(../img/sp/bg_03_2.png) no-repeat left top;
  background-size: 103px 151px;
  font-size: 16px;
  font-weight: bold;
  padding: 15px 0 27px 110px;
  margin: 0 10px;
}

#application h2 br {
  line-height: 26px;
}

#application h3.bookTit {
  background: url(../img/sp/img_12_01.png) no-repeat;
  background-size: 100%;
  height: 72px;
  text-indent: -9999px;
  margin: 0 10px;
}

#application .bookInfo {
  margin: 7px 0 15px 10px;
}

#application .bookInfo li {
  line-height: 20px;
  text-indent: -4em;
  margin-left: 4em;
  font-size: 13px;
}

#application .bookInfo li span {
  font-size: 11.5px;
}

#application .btn {
  background: url(../img/sp/btn_bg_02_komi.png) no-repeat;
  background-size: 100%;
  margin: -5px 10px 10px;
  padding: 20% 7px 2%;
  text-indent: -9999px;
  position: relative;
}

#application .btn a {
  background-size: 97%;
  text-indent: -9999px;
  display: block;
}

#application .btn a,
#application .contactBtn a {
  text-indent: -9999px;
  padding-bottom: 17%;
  display: block;
}

#application .btn .btn01,
#application .btn .btn01 {
  background: url(../img/sp/btn_03_01.png) no-repeat;
  background-size: 100%;
}
#application .btn .btn02,
#application .btn .btn02 {
  background: url(../img/sp/btn_03_02_3.png) no-repeat;
  background-size: 100%;
  margin-top: -4px;
}

/* ===================================
footer
=================================== */
footer {
  border-top: 3px solid #6CC9F7;
}

footer .inner {
  margin: 0 10px;
}

footer .pageTop a {
  background: url(../img/sp/pagetop.png) no-repeat center;
  background-size: 120px 12px;
  height: 12px;
  text-indent: -9999px;
  display: block;
  margin: 10px 0 20px;
}

footer h1 {
  text-align: center;
}

footer h1 a {
  background: url(../img/sp/foot_logo.png) no-repeat center;
  background-size: 230px 29px;
  height: 29px;
  text-indent: -9999px;
  display: block;
}

footer h1 span {
  display: block;
  padding: 0 0 4px;
}

footer .address {
  text-align: center;
  line-height: 17px;
}

footer .tel a {
  background: url(../img/sp/foot_tel_2.png) no-repeat center top;
  background-size: 100%;
  height: 41px;
  text-indent: -9999px;
  display: block;
  margin: 10px 0 0;
  color: #000;
}

footer .tel span {
  display: block;
  text-indent: 0px;
  padding: 3px 0 10px;
  text-align: center;
}

.copyright {
  border-top: 1px solid #6CC9F7;
}

.copyright p {
  font-size: 10px;
  text-align: center;
  line-height: 16px;
  margin: 7px 0 5px;
}

/* 2020/04/10 時間変更 */
.emeNotes {
  width: 100%;
  margin: 10px auto;
  padding: 15px;
  font-size: 12px;
  border: 2px solid #F00;
  box-sizing: border-box;
  background: #FFF;
}
.emetitle {
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 700;
  line-height: 120%;
}
.emeHours {
  margin: 10px 0 0 0;
  font-size: 14px;
  font-weight: bold;
  color: #F00;
  line-height: 120%;
}
.emeLink {
  display: block;
  margin: 5px 0;
}
.emeLinkTxt {
  font-size: 14px;
  color: #1D3992;
}
}

/* ------------------ max480 ------------------ */
@media only screen and (max-width: 480px) {
}

/* ------------------ max425 ------------------ */
@media only screen and (max-width: 425px) {
}

/* ------------------ max414 ------------------ */
@media only screen and (max-width: 414px) {
}

/* ------------------ max375 ------------------ */
@media only screen and (max-width: 375px) {
}

/* ------------------ max360 ------------------ */
@media only screen and (max-width: 360px) {
}

/* ------------------ max320 ------------------ */
@media only screen and (max-width: 320px) {
  #header .headerList:after {
    right: 0;
  }
}
