@charset "UTF-8";
@import url("https://use.fontawesome.com/releases/v5.15.4/css/all.css");
@import url("https://fonts.googleapis.com/css2?family=Hind:wght@500&family=Noto+Sans+JP:wght@400;500;700;900&display=swap");
.gmenu {
  background-color: #5dccdd;
  width: 100%;
  text-align: center;
  width: 100%;
  height: 60px;
  transition: all 0.35s ease;
  font-weight: bold;
}
.gmenu_list {
  max-width: 1130px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto;
}
.gmenu__home {
  border-right: 1px solid;
  border-color: #fff0a4;
  flex: 1 1 0%;
}
.gmenu__home a {
  font-size: 14px;
  height: 60px;
  display: block;
  display: flex;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  color: #ffffff;
}
.gmenu__home a:hover {
  background: #fee446;
}

.menu__mega {
  border-right: 1px solid;
  border-color: #fff0a4;
  height: 60px;
  line-height: 1;
  text-align: center;
  font-size: 14px;
  flex: 1 1 0%;
  color: #ffffff;
  position: relative;
}
.menu__mega .title {
  font-size: 17px;
  margin: 0 0 10px 0;
  float: none;
  font-weight: bold;
}
.menu__mega .title a {
  font-size: 14px;
  font-weight: bold;
}
.menu__mega ul li a {
  color: #ffffff;
  text-decoration: none;
  font-size: 14px;
  padding: 0;
}
.menu__mega ul li a:hover {
  opacity: 1;
  background-color: #4f96c7;
}
.menu__mega ul li:hover {
  background-color: #4f96c7;
}
.menu__mega:hover {
  background-color: #4f96c7;
}
.menu__mega:first-child {
  border-left: 1px solid #fff0a4;
}
.menu__mega a, .menu__mega:first-of-type a {
  display: flex;
  align-items: center;
  text-decoration: none;
  justify-content: flex-start;
  color: #ffffff;
  font-size: 14px;
  height: 60px;
}
.menu__mega a:hover, .menu__mega:first-of-type a:hover {
  transition: 0.3s;
  opacity: 1;
}
.menu__mega:hover .menu__first-level {
  visibility: visible;
  opacity: 1;
}
.menu__first-level {
  position: absolute;
  top: 60px;
  left: 0;
  box-sizing: border-box;
  width: 100%;
  padding: 0;
  transition: all 0s default;
  z-index: 99;
  background: #5dccdd;
  visibility: hidden;
  opacity: 0;
  z-index: 5;
  transition: 0.3s;
}
.menu > li:hover {
  transition: all 0.5s;
}
.menu:before {
  content: " ";
  display: table;
}
.menu:after {
  content: " ";
  display: table;
  clear: both;
}

.main_menu {
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #ffffff;
  text-decoration: none;
  text-align: center;
  font-size: 14px;
}

#nav-content .gmenu_list {
  width: 780px;
}

.main_menu {
  cursor: pointer;
}

.mega_li {
  float: none;
  width: 100% !important;
  padding: 0 0 0 20px;
  margin: 0;
  border-bottom: #ffffff solid 1px;
}
.mega_li:last-child {
  border: none;
}
.mega_li a {
  justify-content: flex-start;
  text-align: left;
}

@media screen and (max-width: 767px) {
  /* ハンバーガーメニュー */
  .nav_btn {
    background: #fff;
    width: 60px;
    height: 60px;
    top: 0;
    right: 0;
    z-index: 300;
    cursor: pointer;
    position: absolute;
  }
  .hamburger_line {
    width: 30px;
    height: 2px;
    position: absolute;
    background-color: #000;
    transition: all 0.6s;
    left: 50%;
    transform: translateX(-50%);
  }
  .hamburger_line1 {
    top: 18px;
  }
  .hamburger_line2 {
    top: 27.5px;
  }
  .hamburger_line3 {
    top: 37px;
  }
  .nav_bg {
    width: 100vw;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    visibility: hidden;
    opacity: 0;
    z-index: 100;
    transition: all 0.6s;
    background-color: #838383;
    mix-blend-mode: multiply;
    cursor: pointer;
  }
  .nav__open {
    padding: 0;
    width: 60px;
    height: 60px;
    margin-right: 10px;
  }
  .nav__open:hover {
    background: #fee446;
  }
  .nav__body {
    display: none;
    background-color: #85dcdd;
  }
  #nav-content {
    justify-content: flex-start;
    right: 0;
    background-color: #37c7dd;
    padding: 12vw 0;
    width: 80vw;
    height: 100%;
    position: fixed;
    top: 0;
    right: -85vw;
    transition: all 0.4s;
    overflow-y: auto;
    z-index: 200;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    align-items: flex-start;
  }
  #nav-content li {
    font-size: 4vw;
    font-weight: bold;
    border-bottom: solid 1px #ffffff;
  }
  #nav-content li:last-child {
    border-bottom: none;
  }
  #nav-content img {
    width: 100%;
  }
  #nav-content .gmenu_list {
    display: block;
    width: 100%;
    height: auto;
    padding-bottom: 100px;
  }
  #nav-content .gmenu_list li {
    font-size: 4vw;
    font-weight: 700;
    border: none;
  }
  #nav-content .gmenu_list li a {
    text-align: left;
    color: #656161;
    text-decoration: none;
    display: block;
    padding: 1em;
  }
  #nav-content .gmenu_list li ul {
    width: 100%;
    padding: 0 0 0 25px;
    top: 0;
    left: 0;
    height: 150px;
    position: static;
    visibility: visible;
    opacity: 1;
  }
  #nav-content .gmenu_list li ul.menu_course {
    height: 200px;
  }
  #nav-content .gmenu_list li ul li {
    padding: 0;
  }
  .nav_open.nav_btn {
    background: transparent;
  }
  .nav_open #nav-content {
    right: 0;
  }
  .nav_open .nav_bg {
    opacity: 0.8;
    visibility: visible;
  }
  .nav_open .hamburger_line1 {
    transform: rotate(45deg);
    top: 25px;
    left: 10px;
    background-color: #fff;
  }
  .nav_open .hamburger_line2 {
    display: none;
  }
  .nav_open .hamburger_line3 {
    transform: rotate(-45deg);
    background-color: #fff;
    top: 25px;
    left: 10px;
  }
  .gmenu__home {
    padding: 0;
    border-right: none;
    width: 100%;
    flex: none;
    width: 100%;
    font-weight: 400;
  }
  .gmenu__home a {
    padding: 0 0 0 20px;
    display: flex;
    justify-content: flex-start;
    color: #ffffff;
    text-decoration: none;
    font-weight: 400;
  }
  .gmenu__home a:hover {
    background-color: #37c7dd;
  }
  .main_menu {
    font-weight: 400;
    color: #ffffff;
    text-decoration: none;
    padding: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }
  .menu__mega {
    font-weight: 400;
    width: 100%;
    flex: none;
    color: #ffffff;
  }
  .menu__mega a {
    color: #ffffff;
    text-decoration: none;
    padding: 0;
  }
  .menu__mega:first-child {
    border-left: none;
  }
  .menu__mega:hover {
    background-color: #37c7dd;
  }
}
body {
  font-family: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
}

header {
  z-index: 999;
  width: 100%;
  top: 0;
  left: 0;
}

@media screen and (min-width: 768px) {
  .sp {
    display: none;
  }
  main {
    padding-top: 0;
  }
  .header {
    font-family: "Noto Sans JP", sans-serif;
  }
  .header * {
    box-sizing: border-box;
  }
  .header__wrapper {
    height: auto;
    background: #fff;
  }
  .header__inner {
    max-width: 1130px;
    padding: 0 0;
    margin: 0 auto;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100px;
  }
  .header__flexBox--left {
    display: flex;
    align-items: center;
  }
  .header__flexBox--right {
    display: flex;
    align-items: center;
  }
  .header__text {
    font-size: 14px;
    position: relative;
    font-weight: 500;
    margin: 0 40px;
    flex: 1 1 0%;
    font-family: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
  }
  .header__logo img {
    aspect-ratio: auto 270/47;
    height: auto;
  }
  .header__toshoImg {
    display: inline-block;
    margin: 0 10px 0 30px;
    aspect-ratio: auto 50/58;
    height: auto;
    width: 40px;
  }
  .header__toshoText {
    display: inline-block;
    font-size: 10px;
  }
  .header__info {
    height: 50px;
    margin-right: 10px;
  }
  .header__tel {
    font-size: 32px;
    font-family: "Hind", sans-serif;
    line-height: 1;
    letter-spacing: 0.08em;
    padding-top: 5px;
  }
  .header__tel::before {
    content: "\f879";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    display: inline-block;
    font-size: 25px;
    padding-right: 10px;
  }
  .header__time {
    font-size: 10px;
    letter-spacing: -0.06em;
    line-height: 1;
  }
  .header__btns {
    height: 50px;
    display: flex;
  }
  .header__btnWrap {
    width: 150px;
    line-height: 50px;
    text-align: center;
    font-size: 18px;
  }
  .header__btn--request {
    color: #fff;
    background: #b2cc34;
    display: block;
    text-decoration: none;
  }
  .header__btn--counselling {
    color: #fff;
    background: #05a;
    display: block;
    text-decoration: none;
  }
  .header__btn--touroku {
    color: #fff;
    background: #999;
    display: block;
    text-decoration: none;
  }
  .cvbox {
    background: url(../images/common/cvbox_bg.jpg) no-repeat top center/cover;
    padding: 60px 0;
    font-family: "Noto Sans JP", sans-serif;
  }
  .cvbox * {
    box-sizing: border-box;
  }
  .cvbox a {
    text-decoration: none;
  }
  .cvbox__inner {
    width: 930px;
    max-width: 100%;
    margin: 0 auto;
    padding: 0 30px;
  }
  .cvbox__title {
    font-size: 32px;
    font-weight: bold;
    text-align: center;
    color: #fff !important;
    padding-bottom: 0.5em;
    font-family: "Noto Sans JP", sans-serif !important;
    margin: 0 !important;
  }
  .cvbox__title::before {
    content: url(../images/common/contact.png);
    display: block;
    padding-bottom: 5px;
  }
  .cvbox__bnrWrap {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  .cvbox__bnr--01, .cvbox__bnr--02 {
    width: 46.5%;
    padding: 25px;
    outline: 2px solid #fff;
    outline-offset: -10px;
    color: #fff;
    text-align: center;
    position: relative;
    margin-bottom: 20px;
  }
  .cvbox__bnr--01::after, .cvbox__bnr--02::after {
    content: "\f054";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 18px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 20px;
  }
  .cvbox__bnr--01 {
    background: #f49b00;
    margin-right: 60px;
  }
  .cvbox__bnr--02 {
    background: #84ce10;
  }
  .cvbox__subText {
    font-size: 17px;
    border: 1px solid #fff;
    border-radius: 10px;
    padding: 5px 30px;
    display: inline-block;
    margin: 0;
  }
  .cvbox__text {
    font-size: 28px;
    font-weight: bold;
    margin: 5px 0 0;
    letter-spacing: 0.14em;
  }
  .cvbox__bnrTel {
    background: rgba(255, 255, 255, 0.3);
    border: solid 2px #fff;
    padding: 10px;
    width: 525px;
    max-width: 100%;
    color: #fff;
  }
  .cvbox__telText {
    font-size: 18px;
    margin: 0;
    padding-bottom: 5px;
    text-align: center;
  }
  .cvbox__telWrap {
    margin: 0 auto;
    width: -moz-fit-content;
    width: fit-content;
  }
  .cvbox__tel {
    font-family: "Hind", sans-serif;
    font-size: 50px;
    letter-spacing: 0.14em;
    margin: 0;
    line-height: 1;
  }
  .cvbox__tel::before {
    content: "\f879";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    display: inline-block;
    padding-right: 10px;
    font-size: 35px;
  }
  .cvbox__time {
    margin: 0;
    font-size: 14px;
  }
  /* cvboxS_pc 2か所共通
  ---------------------------------------- */
  .cvboxS_pc {
    width: 980px;
    padding-top: 25px;
    padding-bottom: 25px;
    position: relative;
    margin: 0 auto;
    border-bottom: dashed 1px #d2daeb;
  }
  .cvboxS_pc .container {
    display: flex;
    justify-content: space-between;
  }
  .cvboxS_pc .contact {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .cvboxS_pc .contact .tel {
    margin-left: 30px;
  }
  .cvboxS_pc .btns {
    display: flex;
    justify-content: space-between;
    width: 455px;
  }
  .cvboxS_pc .btns a {
    display: block;
    width: 200px;
    padding: 15px 10px;
    color: #fff;
    font-size: 20px;
    text-decoration: none;
    font-weight: bold;
    text-align: center;
    line-height: 1;
  }
  .cvboxS_pc .btns a .small {
    font-size: 13px;
    font-weight: 300;
  }
  .cvboxS_pc .btns div a {
    border-radius: 5px;
  }
  .cvboxS_pc .btns .btn_request a {
    background-color: #f49b00;
  }
  .cvboxS_pc .btns .btn_trial a {
    background-color: #84ce10;
  }
  .footer {
    padding-bottom: 60px;
  }
  #footbtn {
    position: fixed;
    bottom: 0;
    left: 0;
    background: #214678;
    width: 100%;
    padding: 15px 0;
    z-index: 999;
  }
  #footbtn .footbtn_text {
    color: #fff;
    text-align: center;
    padding-bottom: 5px;
    font-size: 16px;
  }
  #footbtn .footbtn_wrap {
    display: flex;
    justify-content: center;
    padding: 0 15px;
  }
  #footbtn .foot_tel,
  #footbtn .foot_taiken,
  #footbtn .foot_request {
    color: #fff;
    text-align: center;
    width: 250px;
    border-radius: 10px;
    font-size: 28px;
    font-weight: 700;
    line-height: 50px;
    height: 50px;
    max-width: calc((100% - 40px) / 3);
    box-sizing: border-box;
    text-decoration: none;
  }
  #footbtn .foot_tel {
    background-color: #eb3b2d;
    line-height: 1.2;
    margin-right: 20px;
    padding-top: 5px;
    pointer-events: none;
  }
  #footbtn .foot_tel .tel_num {
    display: block;
    font-size: 24px;
  }
  #footbtn .foot_tel .tel_text {
    font-size: 14px;
    font-weight: 400;
    line-height: 1;
    display: block;
  }
  #footbtn .foot_taiken {
    background: #5cc99f;
    margin-right: 20px;
  }
  #footbtn .foot_request {
    background: #ff7b62;
  }
  /* メインビジュアル部
  ---------------------------------------- */
  /* ページタイトル
  ---------------------------------------- */
  /* 20220124追加　新しいページタイトル
  ---------------------------------------- */
  /* 202007追加　説明ページ　ｈ２ h3 共通デザインclass
  ---------------------------------------- */
  /* メインコンテンツ　角丸、白背景ブロック
  ---------------------------------------- */
  /* ページコンテンツブロック
  ---------------------------------------- */
  /* 見出し系
  ---------------------------------------- */
  /* アイコン付き見出し */
  /* 背景色ネイビー見出し */
  /* 背景色ネイビー見出し（吹き出し付き） */
  /* 穴あき風見出し */
  /* テーブル系
  ---------------------------------------- */
  /* ページコンテンツ下部
  ---------------------------------------- */
  /* バナー　2020.4追記
  ---------------------------------------- */
  /* ランキングバナー　2021.12追記
  ---------------------------------------- */
  /* フッター　
  ---------------------------------------- */
  /* ページトップへ戻る */
  /* footer */
  /* ボタン系
  ---------------------------------------- */
  /* グレーボタン */
  /* グレーボタンS */
  /* グレーボタンL */
  /* ブルーボタン */
  /* お近くの家庭教師を探す */
  /* 詳しく見る */
  /* 青いボタンを２つ並べる */
  /* スピード検索 */
  /* スマートフォンサイトを見る */
  /* 文字強調・文字色
  ---------------------------------------- */
  /* インデント付きテキスト */
  /*----------------------------------------
  	【adjust】
  ----------------------------------------*/
}
@media screen and (min-width: 768px) and (max-width: 1350px) {
  footer .footer__middle .succeed_wrap {
    width: 100%;
  }
  footer .footer__middle .succeed_wrap img {
    max-width: 85%;
  }
  footer .footer__middle .heading {
    width: 100%;
  }
}
@media screen and (min-width: 768px) and (min-width: 1101px) {
  .footer__serch--list {
    width: 12.5%;
  }
  .footer__serch--link {
    font-size: 14px;
  }
  .footer__serch--btn {
    font-size: 14px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  .footer__serch--list {
    width: auto;
  }
  .footer__serch--link {
    padding: 8px 4px;
    font-size: 1.6vw;
  }
  .footer__serch--btn {
    font-size: 1.6vw;
  }
}
@media screen and (min-width: 768px) and (max-width: 1030px) {
  header .header__logo {
    max-width: 60%;
  }
  header .header__toshoImg {
    padding: 0 5px;
  }
  header .header__btnWrap {
    width: 100px;
  }
  header .header__tel {
    font-size: 20px;
  }
  header .header__tel::before {
    font-size: 18px;
    padding-right: 0;
  }
}
@media screen and (min-width: 768px) {
  .main_visual {
    margin-bottom: 0px;
    width: 960px;
    margin-right: 10px;
    margin-left: 10px;
    zoom: 1;
    position: relative;
    /* メインイメージ */
    /* ローカルナビ */
    /* ページタイトル */
  }
  .main_visual .image,
  .main_visual .image_k {
    background-repeat: no-repeat;
    background-position: center top;
    height: 0;
    overflow: hidden;
    padding-top: 362px;
    margin-bottom: 0px;
    position: relative;
  }
  .main_visual .image .btn_trial1 {
    width: 272px;
    position: absolute;
    left: 35px;
    bottom: 20px;
  }
  .main_visual .image .btn_trial1 a {
    display: block;
    background: url(../img/common/btn_trial1.png) no-repeat center top;
    width: 272px;
    height: 0;
    overflow: hidden;
    padding-top: 84px;
  }
  .main_visual .image .btn_trial1 a:hover {
    opacity: 0.8;
  }
  .main_visual .image .btn_trial2 {
    width: 372px;
    position: absolute;
    left: 35px;
    bottom: 22px;
  }
  .main_visual .image .btn_trial2 a {
    display: block;
    background: url(../img/common/btn_trial2.png) no-repeat center top;
    width: 372px;
    height: 0;
    overflow: hidden;
    padding-top: 83px;
  }
  .main_visual .image .btn_trial2 a:hover {
    opacity: 0.8;
  }
  .main_visual .image .btn_trial3 {
    width: 369px;
    position: absolute;
    left: 35px;
    bottom: 22px;
  }
  .main_visual .image .btn_trial3 a {
    display: block;
    background: url(../img/common/btn_trial3.png) no-repeat center top;
    width: 369px;
    height: 0;
    overflow: hidden;
    padding-top: 83px;
  }
  .main_visual .image .btn_trial3 a:hover {
    opacity: 0.8;
  }
  .main_visual .image .btn_trial4 {
    width: 369px;
    position: absolute;
    left: 35px;
    bottom: 22px;
  }
  .main_visual .image .btn_trial4 a {
    display: block;
    background: url(../img/common/btn_trial4.png) no-repeat center top;
    width: 369px;
    height: 0;
    overflow: hidden;
    padding-top: 83px;
  }
  .main_visual .image .btn_trial4 a:hover {
    opacity: 0.8;
  }
  .main_visual .image .btn_search {
    width: 201px;
    position: absolute;
    left: 250px;
    bottom: -10px;
  }
  .main_visual .image .btn_search a {
    display: block;
    background: url(../img/common/btn_search.png) no-repeat center top;
    width: 201px;
    height: 0;
    overflow: hidden;
    padding-top: 77px;
  }
  .main_visual .image .btn_search a:hover {
    opacity: 0.8;
  }
  .page_title_wrap {
    background-color: #eef5fe;
    padding-top: 16px;
    padding-right: 20px;
    padding-bottom: 16px;
    padding-left: 20px;
  }
  .page_title_wrap h1.page_title {
    display: inline-block;
    color: #142551;
    font-size: 28px;
    vertical-align: middle;
  }
  .page_title_wrap .sub_text {
    display: inline-block;
    border-left: solid 1px #ffffff;
    padding: 6px 30px 4px;
    color: #ffffff;
    font-size: 15px;
    line-height: 1.4;
    vertical-align: middle;
  }
  .page_title_wrap .description {
    font-weight: bold;
    color: #fff;
    padding: 0px;
    margin-top: -8px;
    margin-right: 0px;
    margin-bottom: 0px;
    margin-left: 0px;
  }
  .page_tit {
    background-color: #fbfbfb;
    text-align: center;
    padding: 40px 0 40px 0;
  }
  .page_tit h1 {
    color: #164883;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 5px;
    font-family: "Noto Sans JP", sans-serif;
  }
  .subtitle_h2 {
    background-color: #1d63ad;
    padding: 20px 0;
    color: #fff;
    font-size: 25px;
    line-height: 40px;
    letter-spacing: 3px;
    font-weight: bold;
    text-align: center;
  }
  .subtitle_h3 {
    text-align: center;
    color: #0a5ea9;
    padding: 10px;
    font-size: 22px;
    font-weight: bold;
    border-top: 1px #0a5ea9 solid;
    border-bottom: 1px #0a5ea9 solid;
    letter-spacing: 2px;
  }
  .bg_round_white {
    background-color: #ffffff;
    zoom: 1;
    position: relative;
  }
  .pd25 {
    padding: 25px;
  }
  .bg_round_blue {
    background-color: #eff5fc;
    border-radius: 10px;
    padding: 25px;
    zoom: 1;
    position: relative;
    margin-left: 25px;
    margin-right: 25px;
  }
  .content_block {
    margin-bottom: 15px;
  }
  .content_block .block_head {
    border-radius: 10px 10px 0 0;
    background-image: url(../img/common/icon_pencil.png);
    background-repeat: no-repeat;
    background-position: 20px 16px;
    padding: 14px 20px 12px 60px;
    color: #ffffff;
    font-size: 26px;
    font-weight: bold;
    line-height: 1.2;
  }
  .content_block .block_body {
    border-radius: 0 0 10px 10px;
    padding: 15px;
    margin-bottom: 20px;
  }
  .content_block .block_body .text {
    font-size: 14px;
    line-height: 30px;
    color: #444;
  }
  .content_block .block_body .bg_round_white {
    border-radius: 5px;
  }
  .block_body .bg_round_white .subtitle {
    color: #003;
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 10px;
  }
  .block_body .bg_round_white .text_2 {
    font-size: 14px;
    line-height: 30px;
    color: #444;
    margin-top: 10px;
    margin-bottom: 20px;
  }
  .content_unit {
    padding: 0;
    margin-bottom: 10px;
  }
  .content_unit .unit_head {
    padding: 10px 20px 8px;
    border-bottom: solid 1px #dae2f0;
    color: #142551;
    font-size: 23px;
    font-weight: bold;
    text-align: center;
  }
  .content_unit .unit_body {
    padding: 20px 20px 5px;
  }
  .content_unit .unit_body dl dt {
    margin-bottom: 8px;
  }
  .content_unit .unit_body dl dd {
    margin-bottom: 15px;
    overflow: hidden;
  }
  .icon_head {
    background-repeat: no-repeat;
    background-position: left top;
    padding-left: 30px;
    margin-bottom: 20px;
    color: #142551;
    font-size: 20px;
    font-weight: bold;
    line-height: 1.2;
  }
  .course .icon_head {
    background-image: url(../img/common/icon_flag.png);
  }
  .lecturer .icon_head {
    background-image: url(../img/common/icon_person.png);
    background-position: left 2px;
  }
  .result .icon_head {
    background-image: url(../img/common/icon_result.png);
    background-position: left 3px;
  }
  .success .icon_head {
    background-image: url(../img/common/icon_success.png);
    padding-top: 1px;
  }
  .navy_head {
    background-color: #101a3f;
    padding: 8px 15px 6px;
    border-radius: 5px;
    color: #ffffff;
    font-size: 15px;
    font-weight: bold;
    position: relative;
    zoom: 1;
  }
  .navy_head_left_baloon {
    background-color: #101a3f;
    padding: 4px 15px 2px;
    border-radius: 5px;
    color: #ffffff;
    font-size: 18px;
    font-weight: bold;
    position: relative;
    zoom: 1;
  }
  .navy_head_left_baloon:before {
    content: "";
    display: block;
    background: url(../img/common/baloon_left_navy.png) no-repeat center top;
    width: 8px;
    height: 8px;
    position: absolute;
    right: 100%;
    top: 50%;
    margin-top: -4px;
  }
  .hole_head {
    background: #eaeefa url(../img/common/icon_hole.png) no-repeat 20px center;
    border-radius: 5px;
    padding: 10px 0 7px 45px;
    color: #142551;
    font-size: 16px;
    font-weight: bold;
    position: relative;
    zoom: 1;
  }
  td.noborder {
    padding: 5px;
    border: none;
  }
  .lightblue_table {
    width: 100%;
  }
  .lightblue_table th,
  .lightblue_table td {
    border: solid 1px #dae2f0;
    padding: 5px 10px;
    vertical-align: top;
  }
  .lightblue_table th {
    background-color: #ecf1fc;
    font-weight: bold;
  }
  .contents_tail {
    background-image: url(../img/common/footer_img_01.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    padding: 50px 0 40px;
    padding-left: 230px;
  }
  .contents_tail .text {
    color: #142551;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.5;
  }
  .contents_tail.fujishiro {
    background-image: url(../img/common/footer_img_01.png);
    background-position: 20px bottom;
  }
  .contents_tail.saito {
    background-image: url(../img/common/footer_img_01.png);
    background-position: 30px bottom;
  }
  #banner {
    background-color: #f5f5f4;
    width: 100%;
  }
  #banner .wrap {
    width: 1080px;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    flex-direction: row;
    flex-wrap: wrap;
    padding: 40px 0;
    max-width: 100%;
  }
  #banner .wrap img {
    display: block;
    margin: 10px;
    box-shadow: 10px 10px 10px rgba(0, 0, 0, 0.1);
  }
  #rank-bnr {
    width: 100%;
    text-align: center;
    margin: 70px auto;
  }
  #rank-bnr img {
    width: 100%;
    max-width: 850px;
  }
  .backtotop {
    padding: 0;
    position: fixed;
    right: 50px;
    bottom: 50px;
    z-index: 999;
    cursor: pointer;
  }
  .backtotop .move-page-top {
    display: block;
    transition: all 0.3s;
  }
  .footer * {
    box-sizing: border-box;
  }
  .footer__serch {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .footer__serch--head {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px;
  }
  .footer__serch--inner {
    padding: 0 0 30px;
    width: 100%;
    max-width: 1280px;
    text-align: center;
    margin: auto;
  }
  .footer__serch--box {
    justify-content: center;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    align-items: flex-start;
    width: 100%;
  }
  .footer__serch--list {
    border-radius: 0;
    line-height: 1.2;
    position: relative;
  }
  .footer__serch--list__btn {
    position: relative;
    background-color: #fff;
  }
  .footer__serch--list__btn:before {
    content: "";
    width: 1px;
    height: 65%;
    top: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    position: absolute;
    border-right: 1px solid #05a;
  }
  .footer__serch--list:first-child .footer__serch--list__btn {
    border-radius: 5px 0 0 5px;
  }
  .footer__serch--list:last-child .footer__serch--list__btn {
    border-right: none;
    border-radius: 0 5px 5px 0;
  }
  .footer__serch--list:last-child .footer__serch--list__btn:before {
    content: none;
  }
  .footer__serch--list__txt {
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column;
    padding: 15px 0;
    line-height: 1.8;
    font-size: 14px;
  }
  .footer__serch--link {
    font-weight: bold;
    padding: 8px 8px;
    box-sizing: border-box;
    color: #05a;
    display: block;
    text-decoration: none;
  }
  .footer__serch--link:visited {
    color: #05a;
  }
  .footer__serch--link__txt {
    text-decoration-line: none;
    color: #fff;
  }
  .footer__serch--btn {
    border-radius: 5px;
    line-height: 1.2;
    font-weight: bold;
    padding: 8px;
    background-color: #fff;
    color: #05a;
    box-sizing: border-box;
    display: block;
    width: -moz-fit-content;
    width: fit-content;
    margin: auto;
    text-decoration: none;
  }
  .footer__serch--btn:visited {
    color: #05a;
  }
  .footer__serch--btn:hover {
    opacity: 1;
    color: rgba(0, 85, 170, 0.8);
  }
  .footer__pc {
    color: #fff;
    background: #05a;
    padding: 60px 10px 0;
  }
  .footer__pc .fnav {
    display: flex;
    justify-content: space-between;
    padding-bottom: 20px;
    width: 83%;
  }
  .footer__pc .fnav .menu_group + .menu_group {
    margin-left: 10px;
    margin-right: 15px;
  }
  .footer__pc .fnav .menu_group .head {
    padding-bottom: 1em;
    font-size: 14px;
    text-decoration: none;
    line-height: 1.2;
  }
  .footer__pc .fnav .menu_group .list li {
    padding-bottom: 0.5em;
  }
  .footer__pc .fnav .menu_group .list li a {
    color: #fff;
    text-decoration: none;
    font-size: 12px;
    display: inline-block;
    padding-left: 0px;
    line-height: 1.2;
  }
  .footer__inner {
    border-top: 1px solid #fff;
    max-width: 1280px;
    padding: 30px 0;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .footer__logoWrap {
    width: 21%;
    padding: 40px 10px 40px 0;
    border-right: solid 1px #fff;
    margin-right: 50px;
  }
  .footer__logo {
    margin-bottom: 30px;
  }
  .footer__toshoImg {
    display: inline-block;
  }
  .footer__toshoText {
    display: inline-block;
    padding-left: 20px;
  }
  .footer__under {
    padding: 60px 0 80px;
    background: #05a;
    text-align: center;
  }
  .footer__under small {
    color: #fff;
    font-size: 11px;
  }
  .footer__middle {
    background: #05a;
    margin: auto;
    padding: 0 30px;
  }
  .footer__middle .succeed_wrap {
    width: 1280px;
    margin: 0 auto;
    background-color: #fff;
    border-radius: 15px;
    padding: 20px 10px;
    min-height: 70px;
  }
  .footer__middle .succeed_wrap ul {
    display: flex;
  }
  .footer__middle .succeed_wrap img {
    max-width: 200px;
  }
  .footer__middle .succeed_wrap .img-box {
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .footer__middle .succeed_wrap .bnr {
    width: 25%;
    letter-spacing: 1;
    margin: auto;
  }
  .footer__middle .succeed_wrap .bnr a {
    color: #05a;
    text-align: center;
    font-size: 12px;
  }
  .footer__middle .service {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 2px;
  }
  .footer__middle .heading {
    color: #fff;
    width: 1280px;
    margin: 0 auto;
    display: block;
    text-align: left;
    padding: 30px 0;
  }
  .footer__middle .small {
    width: 100%;
    font-size: 13px;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    white-space: nowrap;
  }
  .footer__middle .small::after {
    background-color: #fff;
    content: "";
    height: 1px;
    width: calc(100% - 24px - 1em);
    margin-left: 24px;
    display: block;
  }
  .btn_grey a {
    display: block;
    border: solid 1px #bdbdbd;
    border-radius: 5px;
    background: url(../img/common/btn_grandit.png) no-repeat top;
    background-repeat: repeat-x;
    height: 22px;
    padding-top: 10px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
    line-height: 1.2;
    position: relative;
    zoom: 1;
  }
  .btn_grey a:hover {
    background-image: url(../img/common/btn_grandit_hover.png);
  }
  .btn_grey_s {
    width: 58px;
  }
  .btn_grey_s a {
    display: block;
    background: url(../img/common/btn_grey_s_sprite.png) no-repeat 0 0;
    width: 58px;
    height: 24px;
    padding-top: 6px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
  }
  .btn_grey_s a:hover {
    background-position: 0 -35px;
  }
  .btn_grey_l {
    width: 160px;
  }
  .btn_grey_l a {
    display: block;
    background: url(../img/common/btn_grey_l_sprite.png) no-repeat 0 0;
    width: 160px;
    height: 26px;
    padding-top: 8px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
  }
  .btn_grey_l a:hover {
    background-position: 0 -39px;
  }
  .btn_blue {
    clear: both;
    margin-top: 5px;
    margin-bottom: 5px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .btn_blue a {
    display: block;
    padding-top: 10px;
    padding-bottom: 10px;
    color: #fff;
    background: #0066cb;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    text-align: center;
    width: 55%;
    margin: 0 auto;
  }
  .btn_search_lecturer {
    width: 300px;
    margin-top: 20px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 0;
    height: 65px;
  }
  .btn_detail {
    width: 110px;
    text-align: center;
    margin-top: 10px;
    margin-right: auto;
    margin-bottom: 10px;
    margin-left: auto;
  }
  .btn_detail a {
    display: block;
    border: solid 1px #b6b6b6;
    border-radius: 5px;
    background: url(../img/common/btn_grandit.png) repeat-x center;
    height: 32px;
    color: #142551;
    font-weight: bold;
    line-height: 32px;
    text-decoration: none;
  }
  .btn_detail a:hover {
    background-image: url(../img/common/btn_grandit_hover.png);
  }
  .blue_btns {
    overflow: hidden;
    width: 515px;
    margin: 0 auto 20px;
  }
  .blue_btns .banner {
    width: 250px;
    padding: 0;
  }
  .blue_btns .banner.bnr_pro {
    float: left;
    width: 250px;
  }
  .blue_btns .banner.bnr_graduate {
    float: right;
    width: 250px;
  }
  .btn_speed_search {
    width: 291px;
    margin: 0 auto;
  }
  .btn_speed_search a {
    display: block;
    background: url(../img/kateikyoshi_search/btn_speed_search_sprite.png) no-repeat 0 0;
    width: 291px;
    height: 62px;
    overflow: hidden;
  }
  .btn_speed_search2 a {
    display: block;
    background: url(../img/kateikyoshi_search/btn_speed_search_sprite.png) no-repeat 0 0;
    width: 291px;
    height: 62px;
    overflow: hidden;
  }
  .splink {
    display: block;
    border: solid 1px #b6b6b6;
    border-radius: 6px;
    background: url(../img/common/btn_grandit.png) repeat-x center;
    background-size: 100% 100%;
    height: 100px;
    color: #142551;
    font-weight: bold;
    line-height: 100px;
    text-decoration: none;
    text-align: center;
    width: 90%;
    margin: 20px 5% 0 5%;
    font-size: 250%;
    position: relative;
  }
  .splink img {
    display: inline;
    height: 50px;
    width: auto;
    position: relative;
    top: -25px;
  }
  .clr_red {
    color: #f00;
  }
  .indent_text {
    margin-left: 15px;
    text-indent: -1em;
  }
  .mgb_0 {
    margin-bottom: 0 !important;
  }
  .mgb_5 {
    margin-bottom: 5px !important;
  }
  .mgb_10 {
    margin-bottom: 10px !important;
  }
  .mgb_15 {
    margin-bottom: 15px !important;
  }
  .mgb_20 {
    margin-bottom: 20px !important;
  }
  .mgb_25 {
    margin-bottom: 25px !important;
  }
  .mgb_30 {
    margin-bottom: 30px !important;
  }
  .mgb_35 {
    margin-bottom: 35px !important;
  }
  .mgb_40 {
    margin-bottom: 40px !important;
  }
  .mgb_45 {
    margin-bottom: 45px !important;
  }
  .mgb_50 {
    margin-bottom: 50px !important;
  }
  .mgb_55 {
    margin-bottom: 55px !important;
  }
  .mgb_60 {
    margin-bottom: 60px !important;
  }
  .mgb_65 {
    margin-bottom: 65px !important;
  }
  .mgb_70 {
    margin-bottom: 70px !important;
  }
  .mgb_75 {
    margin-bottom: 75px !important;
  }
  .mgb_80 {
    margin-bottom: 80px !important;
  }
  .mgb_85 {
    margin-bottom: 85px !important;
  }
  .mgb_90 {
    margin-bottom: 90px !important;
  }
  .mgb_95 {
    margin-bottom: 95px !important;
  }
  .mgb_100 {
    margin-bottom: 100px !important;
  }
  .mgt_0 {
    margin-top: 0 !important;
  }
  .mgtn_5 {
    margin-top: -5px !important;
  }
  .mgtn_10 {
    margin-top: -10px !important;
  }
  .mgtn_15 {
    margin-top: -15px !important;
  }
  .mgtn_20 {
    margin-top: -20px !important;
  }
  .mgtn_25 {
    margin-top: -25px !important;
  }
  .mgtn_30 {
    margin-top: -30px !important;
  }
  .mgtn_35 {
    margin-top: -35px !important;
  }
  .mgtn_40 {
    margin-top: -40px !important;
  }
  .pdb_0 {
    padding-bottom: 0 !important;
  }
  .fs_10 {
    font-size: 10px;
  }
  .fs_11 {
    font-size: 11px;
  }
  .fs_12 {
    font-size: 12px;
  }
  .fs_13 {
    font-size: 13px;
  }
  .fs_14 {
    font-size: 14px;
  }
  .fs_15 {
    font-size: 15px;
  }
  .fs_16 {
    font-size: 16px;
  }
  .fs_17 {
    font-size: 17px;
  }
  .fs_18 {
    font-size: 18px;
  }
  .fs_19 {
    font-size: 19px;
  }
  .fs_20 {
    font-size: 20px;
  }
  .fc_red {
    color: #de0515;
  }
  .fw_n {
    font-weight: normal;
  }
  .fw_b {
    font-weight: bold;
  }
  .ta_l {
    text-align: left;
  }
  .ta_c {
    text-align: center;
  }
  .ta_r {
    text-align: right;
  }
  .color_red {
    color: red;
  }
  .bold {
    font-weight: bold;
  }
  .remodal {
    display: none;
  }
  .conv_button_01 {
    display: block;
    font-family: "游ゴシック体", "Yu Gothic", Arial, sans-serif;
    padding: 10px 30px;
    margin: 20px auto;
    font-size: 20px;
    font-weight: bold;
    text-decoration: none;
    text-align: center;
    color: #fff;
    background: #ef5f5f;
    border-radius: 50px;
  }
  #sec01 .conv_button_01 {
    margin-top: -40px;
    margin-bottom: 30px;
  }
  .error404 .content_block .block_head {
    background-color: #1f90e2;
  }
  .error404 .content_block .block_body {
    background-color: #d4e7fa;
  }
  .error404 .block1 .block_body {
    border-radius: 0;
    border-bottom: solid 1px #c9daf5;
  }
  .error404 .block1 .unit {
    padding: 15px 20px;
    margin-bottom: 15px;
    overflow: hidden;
  }
  .error404 .block1 .unit .navy_head {
    margin-bottom: 10px;
  }
  .error404 .block1 .unit1 .text {
    float: left;
    width: 410px;
  }
  .error404 .block1 .unit1 .image {
    float: right;
    width: 179px;
  }
  .error404 .btn_grey_l.top {
    margin-right: auto;
    margin-left: auto;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
  header {
    position: fixed;
    width: 100%;
    z-index: 999;
  }
  header.header_dialogue {
    position: static;
  }
  .header {
    font-family: "Noto Sans JP", sans-serif;
    position: fixed;
    width: 100%;
    background: rgb(255, 255, 255);
  }
  .header__inner {
    height: 60px;
  }
  .header__logo {
    width: auto;
    display: block;
    padding: 8px 0 0 10px;
  }
  .header__logo img {
    width: auto;
    height: 44px;
    max-width: 100%;
  }
  .header--sp {
    background: rgb(255, 255, 255);
    font-family: "Noto Sans JP", sans-serif;
  }
  .header--sp p {
    height: 60px;
    box-sizing: border-box;
  }
  .footer {
    background: #05a;
    padding: 25px 25px 18vw;
    color: #fff;
    width: 100%;
    box-sizing: border-box;
  }
  .footer__sp {
    display: flex !important;
    flex-direction: row;
    margin: 10px 0 20px;
    justify-content: space-around;
  }
  .footer__sp li {
    padding: 5px 0;
  }
  .footer__sp li a {
    color: #fff;
    font-size: 13px;
    display: block;
    padding: 5px 0;
    text-decoration: none;
  }
  .footer__sp li a:hover {
    text-decoration: underline;
  }
  .footer__sp li a:visited {
    text-decoration: none;
  }
  .footer__sp ul {
    margin-right: 30px;
  }
  .footer .succeed_wrap {
    width: 95%;
    margin: 0 auto;
    background-color: #fff;
    border-radius: 15px;
    padding: 20px 0;
    height: auto;
  }
  .footer .succeed_wrap ul {
    display: flex;
    flex-wrap: wrap;
  }
  .footer .succeed_wrap img {
    max-width: 100%;
  }
  .footer .succeed_wrap .img-box {
    height: 60px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .footer .succeed_wrap .bnr {
    width: 43%;
    font-size: 3vw;
    padding-bottom: 20px;
    letter-spacing: 1px;
    margin: auto;
  }
  .footer .succeed_wrap .bnr a {
    color: #05a;
    text-align: center;
    font-size: 2.5vw;
  }
  .footer .service {
    font-size: 3.5vw;
    font-weight: 700;
    letter-spacing: 2px;
    margin-right: 15px;
  }
  .footer .heading {
    color: #fff;
    display: flex;
    width: 95%;
    margin: 0 auto;
    text-align: left;
    padding: 30px 0;
  }
  .footer .heading p {
    word-break: keep-all;
  }
  .footer .small {
    width: 100%;
    font-size: 3vw;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    white-space: nowrap;
  }
  .footer .small::after {
    background-color: #fff;
    content: "";
    height: 1px;
    width: calc(100% - 24px - 1em);
    margin-left: 24px;
    display: block;
  }
  .footer .copyright {
    font-size: 9px;
    color: #fff;
    margin: 45px 0 20px;
    text-align: center;
  }
  #footbtn {
    width: 100%;
    position: fixed;
    bottom: -4px;
    z-index: 50000;
    box-sizing: border-box;
  }
  #footbtn .footbtn_wrap {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: space-between;
    align-items: flex-end;
    height: 14vw;
  }
  #footbtn a {
    box-sizing: border-box;
    display: block;
    position: relative;
    color: #fff;
    text-align: center;
    height: 100%;
    line-height: 1.2;
    font-weight: bold;
    font-size: 4.5vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding-bottom: 2vw;
    text-decoration: none;
    box-sizing: border-box;
  }
  #footbtn a:before {
    width: calc(100% - 6px);
    height: 0;
    display: block;
    position: absolute;
    left: 0;
    content: "";
    bottom: 100%;
    box-sizing: content-box;
  }
  #footbtn a.foot_tel {
    width: 56%;
    background-color: #eb3b2d;
    letter-spacing: 1px;
    padding-top: 1vw;
  }
  #footbtn a.foot_tel i {
    font-size: 5vw;
    transform: rotate(8deg);
  }
  #footbtn a.foot_tel span {
    display: block;
  }
  #footbtn a.foot_tel span.tel_num {
    font-size: 6vw;
  }
  #footbtn a.foot_tel span.tel_text {
    font-size: 3vw;
    padding-bottom: 4px;
    font-weight: normal;
  }
  #footbtn a.foot_tel:before {
    border-bottom: solid 6px #eb3b2d;
    border-right: solid 6px transparent;
  }
  #footbtn a.foot_taiken {
    width: 22%;
    background-color: #5cc99f;
  }
  #footbtn a.foot_taiken:before {
    border-bottom: solid 6px #5cc99f;
    border-right: solid 6px transparent;
    width: calc(100% - 12px);
    left: 6px;
  }
  #footbtn a.foot_taiken:after {
    width: calc(100% - 12px);
    height: 0;
    display: block;
    position: absolute;
    right: 6px;
    content: "";
    bottom: 100%;
    border-left: solid 6px transparent;
    border-bottom: solid 6px #5cc99f;
    box-sizing: content-box;
  }
  #footbtn a.foot_request {
    width: 22%;
    background-color: #ff7b62;
    padding-left: 6px;
  }
  #footbtn a.foot_request:before {
    border-left: solid 6px transparent;
    border-bottom: solid 6px #ff7b62;
  }
  /* 東証マザーズロゴ　2022.01.17追記
  ---------------------------------------- */
  #banner .tosho {
    display: flex;
    width: 75%;
    padding: 5% 0;
    align-items: center;
    align-self: center;
    place-content: center;
  }
  #banner .tosho img {
    width: 20vw;
    height: 22.22vw;
    max-width: 50px;
    max-height: 58px;
    box-shadow: unset;
    margin: 0 auto;
  }
  #banner .tosho p {
    letter-spacing: 3px;
    line-height: 1.6;
    font-size: 3.7vw;
  }
  #banner .tosho p:nth-child(2) {
    padding-left: 5%;
  }
  /*----------------------------------------------------------------【上に戻るボタン】*/
  .backtotop {
    padding: 0;
    position: fixed;
    right: 25px;
    bottom: 100px;
    z-index: 999;
  }
  .backtotop .move-page-top {
    width: 60px;
    height: auto;
    display: block;
    transition: all 0.3s;
    color: transparent;
  }
  .backtotop .move-page-top img {
    aspect-ratio: auto 78/78;
    height: auto;
    max-width: 100%;
  }
  /* ボタン系
  ---------------------------------------- */
  /* グレーボタン */
  .btn_grey a {
    display: block;
    border: solid 1px #bdbdbd;
    border-radius: 5px;
    background: url(../img/common/btn_grandit.png) no-repeat top;
    background-repeat: repeat-x;
    height: 22px;
    padding-top: 10px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
    line-height: 1.2;
    position: relative;
    zoom: 1;
  }
  .btn_grey a:hover {
    background-image: url(../img/common/btn_grandit_hover.png);
  }
  /* グレーボタンS */
  .btn_grey_s {
    width: 58px;
  }
  .btn_grey_s a {
    display: block;
    background: url(../img/common/btn_grey_s_sprite.png) no-repeat 0 0;
    width: 58px;
    height: 24px;
    padding-top: 6px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
  }
  .btn_grey_s a:hover {
    background-position: 0 -35px;
  }
  /* グレーボタンL */
  .btn_grey_l {
    width: 160px;
  }
  .btn_grey_l a {
    display: block;
    background: url(../img/common/btn_grey_l_sprite.png) no-repeat 0 0;
    width: 160px;
    height: 26px;
    padding-top: 8px;
    text-decoration: none;
    color: #142551;
    font-weight: bold;
    text-align: center;
  }
  .btn_grey_l a:hover {
    background-position: 0 -39px;
  }
  .btn_blue {
    clear: both;
    margin-top: 5px;
    margin-bottom: 5px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .btn_blue a {
    display: block;
    padding-top: 10px;
    padding-bottom: 10px;
    color: #fff;
    background: #0066cb;
    font-size: 18px;
    font-weight: bold;
    text-decoration: none;
    text-align: center;
    width: 55%;
    margin: 0 auto;
  }
  /* お近くの家庭教師を探す */
  .btn_search_lecturer a {
    display: block;
    background: url(../img/toppage/btn_search_sprite.png) no-repeat 0 -67px;
    width: 312px;
    margin: 0 auto;
    height: 0;
    overflow: hidden;
    padding-top: 62px;
  }
  .btn_search_lecturer a:hover {
    background-position: 0 0;
  }
  /* 詳しく見る */
  .btn_detail {
    width: 90%;
    text-align: center;
    margin-top: 10px;
    margin-right: auto;
    margin-bottom: 10px;
    margin-left: auto;
  }
  .btn_detail a {
    display: block;
    border: solid 1px #b6b6b6;
    border-radius: 5px;
    background: url(../img/common/btn_grandit.png) repeat-x center;
    height: 32px;
    color: #142551;
    font-weight: bold;
    line-height: 32px;
    text-decoration: none;
  }
  .btn_detail a:hover {
    background-image: url(../img/common/btn_grandit_hover.png);
  }
  /* コンテンツ内バナーの設定
  ---------------------------------------- */
  .main .top_banner img {
    width: 100%;
    height: auto;
  }
  /* コース一覧　 */
  .block.course .course_group.elementary .head {
    border: solid 1px #279b49;
    background-color: #39b574;
    padding: 10px;
    display: block;
    color: #fff;
  }
  .block.course .course_group.juniorhigh .head {
    border: solid 1px #f0364e;
    background-color: #f46376;
    padding: 10px;
    display: block;
    color: #fff;
  }
  .block.course .course_group.high .head {
    border: solid 1px #8b509f;
    background-color: #a674b5;
    padding: 10px;
    display: block;
    color: #fff;
  }
  .block.course .course_group.other .head {
    border: solid 1px #d2dbed;
    background-color: #d6d6d6;
    background-color: #1875ce;
    padding: 10px;
    display: block;
    color: #fff;
  }
  .block.course .btns div a {
    display: block;
    padding: 10px 15px 8px;
    border-radius: 8px;
    background: #2390e1 url(../img/common/icon_arrow_right_white.png) no-repeat 95% center;
    color: #ffffff;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
  }
  .block.course .btns .btn_pro {
    margin-top: 5px;
    width: 90%;
    margin-right: auto;
    margin-left: auto;
  }
  .block.course .btns .btn_graduate {
    margin-top: 5px;
    clear: both;
    width: 90%;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 30px;
  }
  /* 文字強調・文字色
  ---------------------------------------- */
  .strong {
    font-weight: bold;
  }
  .clr_red {
    color: #f00;
  }
  .clr_yellow {
    color: #ffff00;
  }
  /*----------------------------------------
  	【adjust】
  ----------------------------------------*/
  .mgb_0 {
    margin-bottom: 0 !important;
  }
  .mgb_5 {
    margin-bottom: 5px !important;
  }
  .mgb_10 {
    margin-bottom: 10px !important;
  }
  .mgb_15 {
    margin-bottom: 15px !important;
  }
  .mgb_20 {
    margin-bottom: 20px !important;
  }
  .mgb_25 {
    margin-bottom: 25px !important;
  }
  .mgb_30 {
    margin-bottom: 30px !important;
  }
  .mgb_35 {
    margin-bottom: 35px !important;
  }
  .mgb_40 {
    margin-bottom: 40px !important;
  }
  .mgb_45 {
    margin-bottom: 45px !important;
  }
  .mgb_50 {
    margin-bottom: 50px !important;
  }
  .mgb_55 {
    margin-bottom: 55px !important;
  }
  .mgb_60 {
    margin-bottom: 60px !important;
  }
  .mgb_65 {
    margin-bottom: 65px !important;
  }
  .mgb_70 {
    margin-bottom: 70px !important;
  }
  .mgb_75 {
    margin-bottom: 75px !important;
  }
  .mgb_80 {
    margin-bottom: 80px !important;
  }
  .mgb_85 {
    margin-bottom: 85px !important;
  }
  .mgb_90 {
    margin-bottom: 90px !important;
  }
  .mgb_95 {
    margin-bottom: 95px !important;
  }
  .mgb_100 {
    margin-bottom: 100px !important;
  }
  .mgt_0 {
    margin-top: 0 !important;
  }
  .mgtn_5 {
    margin-top: -5px !important;
  }
  .mgtn_10 {
    margin-top: -10px !important;
  }
  .mgtn_15 {
    margin-top: -15px !important;
  }
  .mgtn_20 {
    margin-top: -20px !important;
  }
  .mgtn_25 {
    margin-top: -25px !important;
  }
  .mgtn_30 {
    margin-top: -30px !important;
  }
  .mgtn_35 {
    margin-top: -35px !important;
  }
  .mgtn_40 {
    margin-top: -40px !important;
  }
  .pdb_0 {
    padding-bottom: 0 !important;
  }
  .fc_red {
    color: #de0515;
  }
  .fw_n {
    font-weight: normal;
  }
  .fw_b {
    font-weight: bold;
  }
  .ta_l {
    text-align: left;
  }
  .ta_c {
    text-align: center;
  }
  .ta_r {
    text-align: right;
  }
  .bold {
    font-weight: bold;
  }
  .conv_button_01 {
    display: block;
    font-family: "游ゴシック体", "Yu Gothic", Arial, sans-serif;
    padding: 10px 30px;
    margin: 20px auto;
    font-size: 20px;
    font-weight: bold;
    text-decoration: none;
    text-align: center;
    color: #fff;
    background: #ef5f5f;
    border-radius: 50px;
  }
  #sec01 .conv_button_01 {
    margin-top: 0;
  }
  .error404 .content_block .block_head {
    background-color: #1f90e2;
  }
  .error404 .content_block .block_body {
    background-color: #d4e7fa;
  }
  .error404 .btn_grey_l.top {
    margin-right: auto;
    margin-left: auto;
  }
}