@charset "UTF-8";
@font-face {
  font-family: "NotoSansJP-Black";
  src: url(../fonts/NotoSansJP-Black.ttf);
}
@font-face {
  font-family: "NotoSansJP-Bold";
  src: url(../fonts/NotoSansJP-Bold.ttf);
}
@font-face {
  font-family: "NotoSansJP-ExtraBold";
  src: url(../fonts/NotoSansJP-ExtraBold.ttf);
}
@font-face {
  font-family: "NotoSansJP-Medium";
  src: url(../fonts/NotoSansJP-Medium.ttf);
}
@font-face {
  font-family: "NotoSansJP-Regular";
  src: url(../fonts/NotoSansJP-Regular.ttf);
}
@font-face {
  font-family: "NotoSansJP-SemiBold";
  src: url(../fonts/NotoSansJP-SemiBold.ttf);
}
@font-face {
  font-family: "Noto sansCJK Black";
  src: url(../fonts/NotoSansCJKjp-Black.otf);
}
@font-face {
  font-family: "Noto sansCJK Bold";
  src: url(../fonts/NotoSansCJKjp-Bold.otf);
}
@font-face {
  font-family: "Noto sansCJK Medium";
  src: url(../fonts/NotoSansCJKjp-Medium.otf);
}
@font-face {
  font-family: "Noto sansCJK Regular";
  src: url(../fonts/NotoSansCJKjp-Regular.otf);
}
@font-face {
  font-family: "Poppins-Black";
  src: url(../fonts/Poppins-Black.ttf);
}
@font-face {
  font-family: "Poppins-Bold";
  src: url(../fonts/Poppins-Bold.ttf);
}
@font-face {
  font-family: "Poppins-BoldItalic";
  src: url(../fonts/Poppins-BoldItalic.ttf);
}
@font-face {
  font-family: "Poppins-Light";
  src: url(../fonts/Poppins-Light.ttf);
}
@font-face {
  font-family: "Poppins-Italic";
  src: url(../fonts/Poppins-Italic.ttf);
}
@font-face {
  font-family: "Poppins-Medium";
  src: url(../fonts/Poppins-Medium.ttf);
}
@font-face {
  font-family: "Poppins-Regular";
  src: url(../fonts/Poppins-Regular.ttf);
}
@font-face {
  font-family: "Poppins-SemiBold";
  src: url(../fonts/Poppins-SemiBold.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Black";
  src: url(../fonts/ZenMaruGothic-Black.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Bold";
  src: url(../fonts/ZenMaruGothic-Bold.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Medium";
  src: url(../fonts/ZenMaruGothic-Medium.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Regular";
  src: url(../fonts/ZenMaruGothic-Regular.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Light";
  src: url(../fonts/ZenMaruGothic-Light.ttf);
}
@font-face {
  font-family: "HostGrotesk-Bold";
  src: url(../fonts/HostGrotesk-Bold.ttf);
}
@font-face {
  font-family: "HostGrotesk-Light";
  src: url(../fonts/HostGrotesk-Light.ttf);
}
@font-face {
  font-family: "HostGrotesk-ExtraBold";
  src: url(../fonts/HostGrotesk-ExtraBold.ttf);
}
@font-face {
  font-family: "HostGrotesk-Medium";
  src: url(../fonts/HostGrotesk-Medium.ttf);
}
@font-face {
  font-family: "HostGrotesk-Regular";
  src: url(../fonts/HostGrotesk-Regular.ttf);
}
@font-face {
  font-family: "HostGrotesk-SemiBold";
  src: url(../fonts/HostGrotesk-SemiBold.ttf);
}
@font-face {
  font-family: "GildaDisplay-Regular";
  src: url(../fonts/GildaDisplay-Regular.ttf);
}
@font-face {
  font-family: "FunnelSans-Bold";
  src: url(../fonts/FunnelSans-Bold.ttf);
}
@font-face {
  font-family: "FunnelSans-ExtraBold";
  src: url(../fonts/FunnelSans-ExtraBold.ttf);
}
@font-face {
  font-family: "FunnelSans-Light";
  src: url(../fonts/FunnelSans-Light.ttf);
}
@font-face {
  font-family: "FunnelSans-Medium";
  src: url(../fonts/FunnelSans-Medium.ttf);
}
@font-face {
  font-family: "FunnelSans-Regular";
  src: url(../fonts/FunnelSans-Regular.ttf);
}
@font-face {
  font-family: "FunnelSans-SemiBold";
  src: url(../fonts/FunnelSans-SemiBold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Black";
  src: url(../fonts/FiraSansCondensed-Black.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Bold";
  src: url(../fonts/FiraSansCondensed-Bold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-ExtraBold";
  src: url(../fonts/FiraSansCondensed-ExtraBold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Medium";
  src: url(../fonts/FiraSansCondensed-Medium.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Regular";
  src: url(../fonts/FiraSansCondensed-Regular.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-SemiBold";
  src: url(../fonts/FiraSansCondensed-SemiBold.ttf);
}
/*	com-color
サイト内で主に使用する色の変数
------------------------------------ */
/*	transition,hover
ホバー時のtransition秒数を統一、ホバーアクション
------------------------------------ */
/*	media-screen
画面サイズごとのcss設定に使用
------------------------------------ */
@media screen and (min-width: 768px) {
  .sp-only {
    display: none !important;
  }
}
/*	layout
その他パーツ
------------------------------------ */
@font-face {
  font-family: "NotoSansJP-Black";
  src: url(../fonts/NotoSansJP-Black.ttf);
}
@font-face {
  font-family: "NotoSansJP-Bold";
  src: url(../fonts/NotoSansJP-Bold.ttf);
}
@font-face {
  font-family: "NotoSansJP-ExtraBold";
  src: url(../fonts/NotoSansJP-ExtraBold.ttf);
}
@font-face {
  font-family: "NotoSansJP-Medium";
  src: url(../fonts/NotoSansJP-Medium.ttf);
}
@font-face {
  font-family: "NotoSansJP-Regular";
  src: url(../fonts/NotoSansJP-Regular.ttf);
}
@font-face {
  font-family: "NotoSansJP-SemiBold";
  src: url(../fonts/NotoSansJP-SemiBold.ttf);
}
@font-face {
  font-family: "Noto sansCJK Black";
  src: url(../fonts/NotoSansCJKjp-Black.otf);
}
@font-face {
  font-family: "Noto sansCJK Bold";
  src: url(../fonts/NotoSansCJKjp-Bold.otf);
}
@font-face {
  font-family: "Noto sansCJK Medium";
  src: url(../fonts/NotoSansCJKjp-Medium.otf);
}
@font-face {
  font-family: "Noto sansCJK Regular";
  src: url(../fonts/NotoSansCJKjp-Regular.otf);
}
@font-face {
  font-family: "Poppins-Black";
  src: url(../fonts/Poppins-Black.ttf);
}
@font-face {
  font-family: "Poppins-Bold";
  src: url(../fonts/Poppins-Bold.ttf);
}
@font-face {
  font-family: "Poppins-BoldItalic";
  src: url(../fonts/Poppins-BoldItalic.ttf);
}
@font-face {
  font-family: "Poppins-Light";
  src: url(../fonts/Poppins-Light.ttf);
}
@font-face {
  font-family: "Poppins-Italic";
  src: url(../fonts/Poppins-Italic.ttf);
}
@font-face {
  font-family: "Poppins-Medium";
  src: url(../fonts/Poppins-Medium.ttf);
}
@font-face {
  font-family: "Poppins-Regular";
  src: url(../fonts/Poppins-Regular.ttf);
}
@font-face {
  font-family: "Poppins-SemiBold";
  src: url(../fonts/Poppins-SemiBold.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Black";
  src: url(../fonts/ZenMaruGothic-Black.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Bold";
  src: url(../fonts/ZenMaruGothic-Bold.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Medium";
  src: url(../fonts/ZenMaruGothic-Medium.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Regular";
  src: url(../fonts/ZenMaruGothic-Regular.ttf);
}
@font-face {
  font-family: "ZenMaruGothic-Light";
  src: url(../fonts/ZenMaruGothic-Light.ttf);
}
@font-face {
  font-family: "HostGrotesk-Bold";
  src: url(../fonts/HostGrotesk-Bold.ttf);
}
@font-face {
  font-family: "HostGrotesk-Light";
  src: url(../fonts/HostGrotesk-Light.ttf);
}
@font-face {
  font-family: "HostGrotesk-ExtraBold";
  src: url(../fonts/HostGrotesk-ExtraBold.ttf);
}
@font-face {
  font-family: "HostGrotesk-Medium";
  src: url(../fonts/HostGrotesk-Medium.ttf);
}
@font-face {
  font-family: "HostGrotesk-Regular";
  src: url(../fonts/HostGrotesk-Regular.ttf);
}
@font-face {
  font-family: "HostGrotesk-SemiBold";
  src: url(../fonts/HostGrotesk-SemiBold.ttf);
}
@font-face {
  font-family: "GildaDisplay-Regular";
  src: url(../fonts/GildaDisplay-Regular.ttf);
}
@font-face {
  font-family: "FunnelSans-Bold";
  src: url(../fonts/FunnelSans-Bold.ttf);
}
@font-face {
  font-family: "FunnelSans-ExtraBold";
  src: url(../fonts/FunnelSans-ExtraBold.ttf);
}
@font-face {
  font-family: "FunnelSans-Light";
  src: url(../fonts/FunnelSans-Light.ttf);
}
@font-face {
  font-family: "FunnelSans-Medium";
  src: url(../fonts/FunnelSans-Medium.ttf);
}
@font-face {
  font-family: "FunnelSans-Regular";
  src: url(../fonts/FunnelSans-Regular.ttf);
}
@font-face {
  font-family: "FunnelSans-SemiBold";
  src: url(../fonts/FunnelSans-SemiBold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Black";
  src: url(../fonts/FiraSansCondensed-Black.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Bold";
  src: url(../fonts/FiraSansCondensed-Bold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-ExtraBold";
  src: url(../fonts/FiraSansCondensed-ExtraBold.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Medium";
  src: url(../fonts/FiraSansCondensed-Medium.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-Regular";
  src: url(../fonts/FiraSansCondensed-Regular.ttf);
}
@font-face {
  font-family: "FiraSansCondensed-SemiBold";
  src: url(../fonts/FiraSansCondensed-SemiBold.ttf);
}
/*	com-color
サイト内で主に使用する色の変数
------------------------------------ */
/*	transition,hover
ホバー時のtransition秒数を統一、ホバーアクション
------------------------------------ */
/*	media-screen
画面サイズごとのcss設定に使用
------------------------------------ */
@media screen and (min-width: 768px) {
  .sp-only {
    display: none !important;
  }
}
/*	layout
その他パーツ
------------------------------------ */
/*	font-size
スマホ時にフォントサイズを自動で変更
※13px以下は文字が読めないためPC/SP同じサイズ
------------------------------------ */
/************************************************

    SP layout
    スマホ時のcss

************************************************/
/* =========================================
    body  SP
    全体
========================================= */
/* =========================================
    main  SP
========================================= */
/*	cmn parts  SP
------------------------------------ */
.com-inner {
  padding: 50px 15px;
}

.com-sub-inner {
  padding: 50px 15px;
  margin: auto;
}

.com-note {
  line-height: 1;
}

.com-box01 {
  margin-top: 40px;
  padding: 25px 15px;
}

.com-btn01 {
  width: 300px;
  height: 60px;
}

.com-ttl01::before {
  height: 15px;
}
.com-ttl01-sp {
  position: relative;
}
.com-ttl01-sp::before {
  position: absolute;
  content: "";
}
.com-ttl01-sp::before {
  width: 100%;
  height: 15px;
  transform: translateX(-50%);
  left: 50%;
  bottom: 0;
  background: url(/img/all/pat04.jpg) left top;
  z-index: -1;
}

.com-txt p:nth-of-type(n + 2) {
  margin-top: 20px;
}

.com-sv {
  padding-top: 50vw;
}

.com-table01 tr:last-of-type th {
  border-bottom: 1px solid #95ed8d;
}
.com-table01 tr:nth-of-type(n + 2) th {
  border-top: 2px solid #45c53b;
}
.com-table01 th {
  display: block;
  width: 100%;
  padding: 10px;
}
.com-table01 td {
  display: block;
  padding: 15px 10px;
  border-bottom: none;
}

/* =========================================
    top  sp
    top-news
========================================= */
#top-news .container {
  position: relative;
  display: block;
  padding-bottom: 100px;
}
#top-news .container-box {
  width: 100%;
  min-height: auto;
  position: unset;
}
#top-news .list {
  display: block;
  margin-left: 0;
  margin-right: 0;
  gap: 0;
}
#top-news .list-item {
  width: 100%;
  max-width: 340px;
  margin: 0 auto;
}
#top-news .list-item:nth-of-type(n + 2) {
  margin-top: 25px;
}
#top-news .btn {
  position: absolute;
  transform: translateX(-50%);
  left: 50%;
  bottom: 0;
}

/* =========================================
    top  sp
    top-season
========================================= */
#top-season .season {
  height: unset;
  padding: 35px 15px 120px;
}
#top-season .season-ttl {
  background: linear-gradient(transparent 80%, #fff69c 0%);
}
#top-season .season-ttl-sp {
  background: linear-gradient(transparent 68%, #fff69c 0%);
}
#top-season .season-txt {
  text-align: left;
  margin-top: 25px;
}

#spring .season::before {
  width: 100px;
  height: 125px;
  left: 5px;
  bottom: -20px;
}
#spring .season::after {
  width: 111px;
  height: 139px;
  right: 5px;
  bottom: -15px;
}

#summer .season::before {
  width: 143px;
  height: 124px;
  left: 5px;
  bottom: -16px;
}
#summer .season::after {
  width: 122px;
  height: 134px;
  right: 10px;
  bottom: -25px;
}

#autumn .season::before {
  width: 168px;
  height: 102px;
  left: 5px;
}
#autumn .season::after {
  width: 138px;
  height: 154px;
  right: 10px;
  bottom: -35px;
}

#winter .season::before {
  width: 170px;
  height: 135px;
  left: 10px;
}
#winter .season::after {
  width: 147px;
  height: 148px;
  right: 10px;
  bottom: -25px;
}

/* =========================================
    top  sp
    top-about
========================================= */
#top-about .bg::before {
  min-height: 23px;
}
#top-about .bg::after {
  width: 160px;
  height: 130px;
  right: 10px;
}
#top-about .inner {
  padding: 50px 15px 140px;
}
#top-about .wrap {
  display: block;
  margin-top: 20px;
}
#top-about .wrap-img {
  width: 320px;
  min-width: 320px;
  margin: 0 auto;
}
#top-about .wrap-img::before {
  width: 160px;
  height: 160px;
  top: 135px;
  right: -5px;
}
#top-about .wrap-box {
  margin-left: 0;
  margin-top: 50px;
}

/* =========================================
    top  sp
    top-course
========================================= */
#top-course .bg::before {
  min-height: 23px;
}
#top-course .inner {
  padding: 50px 15px 100px;
}
#top-course .ttl-sp::before {
  background: url(/img/all/pat05.jpg) left top;
}
#top-course .wrap-box {
  flex-wrap: wrap;
  flex-direction: column-reverse;
  margin-top: 25px;
}
#top-course .wrap-box-item {
  width: 300px;
  height: 95px;
  line-height: 1.6;
  margin: 0 auto;
}
#top-course .wrap-box-item:first-of-type {
  margin-top: 25px;
}
#top-course .wrap-link::before {
  content: "";
  width: 18px;
  height: 14px;
  margin-right: 15px;
  background: url(/img/all/arw.png) no-repeat;
}
#top-course .wrap-link::after {
  display: none;
}
#top-course .list {
  display: block;
  margin-top: 25px;
}
#top-course .list-item:nth-of-type(n + 2) {
  margin-top: 25px;
}
#top-course .list-link {
  width: 100%;
  height: 100px;
}

/* =========================================
    top  sp
    top-teacher
========================================= */
#top-teacher .bg::before {
  min-height: 26px;
}
#top-teacher .bg::after {
  width: 200px;
  height: 120px;
  bottom: -20px;
  left: 5px;
}
#top-teacher .inner {
  padding: 100px 15px;
}
#top-teacher .inner::before {
  width: 200px;
  height: 183px;
  right: 5px;
}
#top-teacher .wrap {
  display: block;
  margin-top: 25px;
}
#top-teacher .wrap-img {
  width: 300px;
  margin: 0 auto;
}
#top-teacher .wrap-txt {
  margin-left: 0;
  margin-top: 25px;
}
#top-teacher .list {
  display: block;
  margin-top: 25px;
}
#top-teacher .list-item:nth-of-type(n + 2) {
  margin-left: 0;
  margin-top: 15px;
}
#top-teacher .list-link {
  width: 280px;
  height: 60px;
  margin: 0 auto;
}

/* =========================================
    top  sp
    link-list
========================================= */
#link-list .inner {
  padding: 50px 15px 170px;
}
#link-list .inner::before {
  width: 220px;
  height: 160px;
}
#link-list .wrap::before {
  width: 320px;
  height: 255px;
  transform: translateX(-50%);
  left: 50%;
  top: 50px;
}
#link-list .wrap:nth-of-type(2)::before {
  left: 50%;
  right: unset;
}
#link-list .wrap:nth-of-type(n + 2) {
  margin-top: 50px;
}
#link-list .wrap-box {
  width: 100%;
  text-align: center;
}
#link-list .wrap-txt {
  text-align: left;
  margin-top: 275px;
}
#link-list .btn {
  margin: 25px auto 0;
}

/* =========================================
    top  sp
    com-contact
========================================= */
#com-contact .container::before {
  width: 125px;
  height: 130px;
  left: -20px;
  bottom: -56px;
}
#com-contact .container::after {
  width: 100px;
  height: 108px;
  right: -15px;
  top: -50px;
}
#com-contact .list {
  display: block;
  margin-top: 35px;
}
#com-contact .list-item:nth-of-type(n + 2) {
  margin-left: 0;
  margin-top: 15px;
}
#com-contact .list-link {
  width: 280px;
  height: 60px;
  margin: 0 auto;
}
#com-contact .list-line::before {
  width: 22px;
  height: 22px;
  margin-right: 7px;
}
#com-contact .list-line::after {
  right: 15px;
}
#com-contact .list-mail::before {
  width: 22px;
  height: 16px;
  margin-right: 7px;
}
#com-contact .list-mail::after {
  right: 15px;
}
#com-contact .com-tel {
  display: block;
  text-align: center;
}
#com-contact .com-tel-num {
  padding-left: 32px;
  background: url(/img/all/tel-ico.png) no-repeat left 5px/22px;
}
#com-contact .com-tel-box {
  width: 100%;
  margin-left: 0;
  padding-top: 10px;
}
#com-contact .com-tel-box::before {
  width: 280px;
  height: 2px;
  transform: translateX(-50%);
  left: 50%;
  top: 0;
}

/* =========================================

    sub layout  SP
    下層ページのスマホ時css
		sub-sp

========================================= */
/* =========================================
    sub  SP
    sub-cram
========================================= */
#sub-cram .bg::before {
  min-height: 23px;
}
#sub-cram .ttl::before {
  display: none;
}
#sub-cram .list {
  margin-top: 35px;
  padding: 30px 15px 130px;
  background: url(/img/cram/sec01-deco01.png) no-repeat 10px bottom/70px, url(/img/cram/sec01-deco02.png) no-repeat calc(100% - 10px) bottom/120px, #f0f4ef;
  border-radius: 15px;
}
#sub-cram .list-item {
  padding-left: 30px;
  background: url(/img/all/check-ico.png) no-repeat left 7px/20px;
}
#sub-cram .list-item:nth-of-type(n + 2) {
  margin-top: 15px;
}

#sub-learn .wrap {
  flex-wrap: wrap;
  flex-direction: column-reverse;
  margin-top: 35px;
}
#sub-learn .wrap-img {
  width: 320px;
  margin: 0 auto;
}
#sub-learn .wrap-box {
  width: 100%;
  margin-right: 0;
}
#sub-learn .list {
  display: block;
  margin-top: 35px;
}
#sub-learn .list-item:nth-of-type(n + 2) {
  margin-left: 0;
  margin-top: 15px;
}
#sub-learn .list-link {
  width: 320px;
  height: 80px;
  margin: 0 auto;
}
#sub-learn .list-link::after {
  left: 10px;
}

#sub-merit .bg::before {
  min-height: 26px;
}
#sub-merit .inner {
  padding: 50px 15px 100px;
}
#sub-merit .inner::before {
  width: 185px;
  height: 112px;
  bottom: -10px;
  left: 5px;
}
#sub-merit .list {
  padding: 50px 15px;
}
#sub-merit .list::after {
  width: 88px;
  height: 107px;
  top: -60px;
}
#sub-merit .list-item:nth-of-type(n + 2) {
  margin-top: 15px;
}
#sub-merit .list-num {
  width: 55px;
  margin-top: 5px;
}
#sub-merit .list-box {
  margin-left: 10px;
}

#sub-voice .bg::after {
  width: 175px;
  min-width: unset;
  height: 130px;
  min-height: unset;
  right: 5px;
}
#sub-voice .inner {
  padding: 50px 15px 100px;
}
#sub-voice .list {
  margin-top: 35px;
  padding: 30px 15px;
}
#sub-voice .list-item:nth-of-type(n + 2) {
  margin-top: 15px;
}
#sub-voice .list-link {
  padding-left: 45px;
}
#sub-voice .list-link::after {
  width: 30px;
  height: 30px;
  top: 2px;
}
#sub-voice .list-ttl {
  width: 100%;
  max-width: unset;
}

#sub-voice-detail .wrap {
  margin-top: 35px;
  padding: 20px 15px;
  border-radius: 15px;
}
#sub-voice-detail .wrap-box {
  margin-top: 15px;
}

/* =========================================
    sub  SP
    sub-classroom
========================================= */
#sub-cram .classroom-list {
  background: url(/img/classroom/sec01-deco01.png) no-repeat 10px bottom/110px, url(/img/classroom/sec01-deco02.png) no-repeat right bottom/165px, #f0f4ef;
}

#sub-classroom-learn .bg::before {
  min-height: 23px;
}
#sub-classroom-learn .inner {
  padding: 50px 15px 140px;
}
#sub-classroom-learn .inner::before {
  width: 166px;
  height: 134px;
  left: 5px;
  bottom: 0px;
}
#sub-classroom-learn .wrap {
  padding: 30px 15px;
  border-radius: 15px;
}
#sub-classroom-learn .wrap::before {
  display: none;
}
#sub-classroom-learn .wrap-img {
  width: 100%;
  max-width: 406px;
  margin: 15px auto 0;
}
#sub-classroom-learn .wrap-ttl {
  margin-top: 15px;
}
#sub-classroom-learn .wrap-btm {
  margin-top: 15px;
}
#sub-classroom-learn .list-item {
  padding-left: 25px;
  background: url(/img/all/check-ico.png) no-repeat left 5px/18px;
}
#sub-classroom-learn .list-item:nth-of-type(n + 2) {
  margin-top: 15px;
}
#sub-classroom-learn .btn {
  width: 300px;
  height: 70px;
  margin: 35px auto 0;
}

/* =========================================
    sub  PC
    sub-teacher
========================================= */
#btn-link .list {
  display: block;
}
#btn-link .list-item {
  width: 320px;
  margin: 0 auto;
}
#btn-link .list-item:nth-of-type(n + 2) {
  margin-left: auto;
  margin-top: 15px;
}
#btn-link .list-link {
  height: 70px;
}

#sub-teacher .bg::before {
  min-height: 23px;
}
#sub-teacher .inner::after {
  width: 165px;
  height: 100px;
  bottom: -10px;
  right: 0;
}
#sub-teacher .wrap {
  display: block;
  margin-top: 35px;
}
#sub-teacher .wrap-box {
  margin-left: 0;
  margin-top: 15px;
}
#sub-teacher .wrap-img {
  text-align: center;
}
#sub-teacher .box {
  display: block;
}
#sub-teacher .qualification {
  margin-top: 35px;
}

#sub-interview .list {
  margin-top: 35px;
}
#sub-interview .list-ttl {
  padding-left: 65px;
}
#sub-interview .list-ttl::before {
  width: 72px;
  height: 59px;
  left: -10px;
}
#sub-interview .list-wrap {
  flex-wrap: wrap;
  flex-direction: column-reverse;
  margin-top: 10px;
}
#sub-interview .list-img {
  width: 100px;
  margin-left: auto;
}
#sub-interview .list-box {
  display: block;
  margin-top: 30px;
  margin-right: 0;
  padding: 20px 15px;
}
#sub-interview .list-box::after {
  width: 33px;
  height: 33px;
  top: -27px;
  right: 30px;
  transform: rotate(-90deg);
}
#sub-interview .list-box-img {
  margin: 10px auto;
}
#sub-interview .list-box-img img {
  width: 100%;
}

/* =========================================
    sub  SP
    sub-about
========================================= */
#sub-flow .list {
  margin-top: 35px;
  padding: 30px 15px;
}
#sub-flow .list::before {
  width: 68px;
  height: 82px;
  right: -10px;
  top: -50px;
}
#sub-flow .list::after {
  width: 145px;
  height: 85px;
  right: -10px;
  bottom: -50px;
}
#sub-flow .list-item {
  display: block;
}
#sub-flow .list-item:nth-of-type(n + 2) {
  margin-top: 35px;
}
#sub-flow .list-num {
  width: 60px;
  top: -20px;
  left: -10px;
}
#sub-flow .list-img img {
  width: 100%;
}
#sub-flow .list-box {
  margin-left: 0;
  margin-top: 15px;
}

#sub-comics .bg::before {
  min-height: 23px;
  bottom: -7px;
}
#sub-comics .bg::after {
  width: 155px;
  height: 95px;
  right: 10px;
  bottom: 0px;
}
#sub-comics .inner {
  padding: 50px 15px 100px;
}
#sub-comics .comics {
  width: 100%;
  margin: 50px auto 0;
}

#sub-about .wrap {
  margin-top: 35px;
  padding: 20px 15px;
}

#sub-map .map {
  height: 250px;
}

/* =========================================
    sub  SP
    sub-news
========================================= */
#sub-news .btn:nth-of-type(3n + 1) {
  margin-left: 10px;
}
#sub-news .com-news-post-flex {
  display: block;
}
#sub-news .com-news-post-link {
  padding: 30px 15px;
}
#sub-news .com-news-post-img {
  width: 250px;
  margin: 0 auto 25px;
}
#sub-news .com-news-post-con {
  width: 100%;
}
#sub-news .news-post-flex {
  display: block;
}
#sub-news .news-post-time {
  margin-left: 5px;
}

/* =========================================
  タグセレクト
	ボタンテンプレート
========================================= */
#tag-btn-list .list {
  justify-content: center;
  margin-top: 50px;
}

/* =========================================
    sub  SP
    news-detail
========================================= */
#news-detail .detail-inner {
  padding: 80px 10px;
}
#news-detail .detail-list {
  margin-top: 10px;
  padding: 0 10px;
}
#news-detail .detail-content {
  margin-top: 30px;
  padding: 0 10px;
}

/* =========================================
    sub  SP
    sub-contact
========================================= */
#sub-contact .wrap {
  margin-top: 35px;
  padding: 30px 15px;
}
#sub-contact .com-btn01 {
  width: 250px;
}

.contact-form-table {
  margin: 0 auto;
}
.contact-form-table td {
  padding: 10px;
}

/* =========================================
    sub  SP
    sub-site
========================================= */
#sub-site .list {
  margin: 40px auto 0;
}

/* =========================================
    sub  SP
    sub-privacy
========================================= */
#sub-privacy .ttl {
  margin-bottom: 10px;
}
#sub-privacy .privacy-box {
  margin-top: 25px;
}

/* =========================================
    sub  SP
    sub-complete
========================================= */
#sub-complete .link {
  margin: 50px auto 0;
}
#sub-complete .container-box {
  margin: 25px auto 0;
  text-align: left;
  max-width: 465px;
}

/* =========================================
    sub  SP
    sub-error
========================================= */
#sub-error .ttl {
  font-size: 25px;
}