/**
** 見出し
**
===================================================================*/
/*
* 資格講座一覧表示ページタイトル
*-----------------------------------------------*/
.kouza_list_head_area {
  position: relative;
  margin: 0 auto;
  padding: 0 0 50px 0;
  width: 100%;
  background: #fff;
}

.kouza_list_head_area .kouza_list_title {
  margin: 0 0 5px 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #0068b7;
  text-align: center;
  line-height: 3.2rem;
}

.kouza_list_head_area .kouza_list_en_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.5rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #db2b18;
  text-align: center;
}

.kouza_list_head_area .kouza_list_lead {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 85%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #092046;
  line-height: 2rem;
}

/*
* 【固定ページ】ページタイトル
*-----------------------------------------------*/
.one_column_title {
  margin: 0 auto 40px auto;
  padding: 0;
  width: 92%;
}

.one_column_title .main_title {
  margin: 0 0 10px 0;
  padding: 0;
  width: 100%;
  font-size: 1.75rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #fc840b;
}

.one_column_title .title_lead {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #b96817;
  line-height: 1.8rem;
}

.one_column_title.mt80 {
  margin-top: 50px;
}

/*
* 【固定ページ】ページ内セクションタイトル
*-----------------------------------------------*/
/* .page_st_setting, */
.page_section_title {
  position: relative;
  margin: 0 auto;
  padding: 0 0 5px 15px;
  width: 100%;
  font-size: 1.625rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #000;
  border-bottom: 3px solid #ddd;
}

/* .page_st_setting::before, */
.page_section_title::before {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 20%;
  height: 3px;
  background: #0068b7;
}

/* .page_st_setting .title_emp, */
.page_section_title .title_emp {
  font-size: 2rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #0068b7;
}

/* .page_st_setting > i, */
.page_section_title > i {
  margin-right: 15px;
  font-size: 2.0625rem;
  color: #0068b7;
}

.page_section_title::before {
  background: #0068b7;
}

.page_section_title .title_emp {
  color: #0068b7;
}

.page_section_title > i {
  color: #0068b7;
  vertical-align: bottom;
}

.page_section_title.pst_red::before {
  background: #f04030;
}

.page_section_title.pst_red .title_emp,
.pst_red > i {
  color: #f04030;
}

/**
** メイン画像
**
===================================================================*/
/*
* 【固定ページ】ページメイン画像
*-----------------------------------------------*/
.page_main_image {
  position: relative;
  margin: 0 auto 50px auto;
  padding: 0;
  width: 100%;
  height: 300px;
  overflow: hidden;
}

.page_main_image .img_area {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 300px;
  overflow: hidden;
}

.page_main_image .img_area > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  -o-object-position: 50% 30%;
     object-position: 50% 30%;
}

.page_main_image .pagename_area {
  position: absolute;
  top: 45%;
  left: 5%;
  transform: translateY(-45%);
  margin: 0;
  padding: 25px 30px 20px 30px;
  width: 55%;
  background: rgba(104, 135, 188, 0.6);
  border-radius: 5px;
  z-index: 1;
}

.page_main_image .pagename_area .page_category {
  display: flex;
  align-items: center;
  margin: 0 0 7px 0;
  padding: 0;
  width: 100%;
}

.page_main_image .pagename_area .page_category .category_name {
  margin: 0;
  padding: 5px 0;
  width: 40%;
  font-size: 0.875rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #022A4D;
  text-align: center;
  background: rgba(173, 212, 219, 0.7);
  border-radius: 5px;
}

.page_main_image .pagename_area .page_category::after {
  content: "";
  height: 1px;
  flex-grow: 1;
  background-color: #2E6771;
}

.page_main_image .pagename_area .page_name {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.875rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #fff;
  border-radius: 5px;
}

.page_main_image .kouza_point {
  display: none;
}

/**
** 資格取得講座一覧
**
===================================================================*/
/*
* 一覧トップ画面カテゴリー表示
*-----------------------------------------------*/
.top_kouza_list_category {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 40px auto;
  padding: 0;
  /* width: 85%; */
  width: 100%;
}

.top_kouza_list_category::before {
  content: "";
  display: block;
  width: 24.5%;
  order: 1;
}

.top_kouza_list_category::after {
  content: "";
  display: block;
  width: 24.5%;
}

.top_kouza_list_category li {
  margin: 0 0 6px 0;
  padding: 0;
  width: 24.5%;
  height: 140px;
  border-radius: 5px;
}

.top_kouza_list_category li > a {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.top_kouza_list_category li > a:hover > .category_title {
  background: rgba(18, 55, 75, 0.8);
  transition: ease-in-out 0.3s;
}

.top_kouza_list_category li > a > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.top_kouza_list_category li > a > img:hover {
  transform: scale(1.2);
  transition: all 0.3s;
}

.top_kouza_list_category li > a .category_title {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  margin: 0 auto;
  padding: 0;
  width: 100%;
  height: 50px;
  /* font-size: 0.9375rem; */
  font-size: 16px;
  color: #fff;
  text-align: center;
  /* background: rgba(68, 115, 161, 0.5); */
  background: rgba(68, 115, 161, 0.7);
  z-index: 1;
  border-top-width: 5px;
  border-top-style: solid;
}

/*
* 各講座一覧ページ内資格カテゴリー
*-----------------------------------------------*/
.other_course_category {
  margin: 50px auto 0 auto;
  padding: 40px 30px 30px 30px;
  width: 100%;
  background: #f8f8f8;
  border-top: 4px solid #3455AB;
}

.other_course_category .list_title {
  margin: 0 auto 30px auto;
  padding: 0;
  width: 100%;
  font-size: 26px;
  font-weight: bold;
  color: #3455AB;
  text-align: center;
}

.kouza_list_category {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  /* width: 85%; */
  width: 100%;
}

.kouza_list_category::before {
  content: '';
  display: block;
  width: 24.5%;
  order: 1;
}

.kouza_list_category::after {
  content: '';
  display: block;
  width: 24.5%;
}

.kouza_list_category li {
  margin: 0 0 10px 0;
  padding: 0;
  width: 24.5%;
  height: 100px;
  border-radius: 5px;
}

.kouza_list_category li > a {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.kouza_list_category li > a:hover > .category_title {
  background: rgba(18, 55, 75, 0.8);
  transition: ease-in-out 0.3s;
}

.kouza_list_category li > a > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.kouza_list_category li > a .category_title {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  margin: 0 auto;
  padding: 0;
  width: 100%;
  height: 50px;
  font-size: 0.9375rem;
  color: #fff;
  text-align: center;
  background: rgba(68, 115, 161, 0.5);
  z-index: 1;
  border-top-width: 5px;
  border-top-style: solid;
}

/*
* 資格講座コンテンツ
*-----------------------------------------------*/
.kouza_list_section {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_list_section .kouza_category_title {
  position: relative;
  display: inline-block;
  margin: 30px 0 50px 0;
  padding: 0;
  width: 50%;
  height: 70px;
  color: #fff;
}

.kouza_list_section .kouza_category_title::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 0px;
  height: 0px;
  border-width: 35px 20px 35px 0px;
  border-style: solid;
  z-index: 1;
}

.kouza_list_section .kouza_category_title[data-category=shinri]::after {
  border-color: transparent #ffeff3 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=drink]::after {
  border-color: transparent #e6eeff transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=syugei]::after {
  border-color: transparent #f7eae4 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=fashion]::after {
  border-color: transparent #fde8f1 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=uranai]::after {
  border-color: transparent #f8ebff transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=design]::after {
  border-color: transparent #edfdf9 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=cad]::after {
  border-color: transparent #ecf5fc transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=business]::after {
  border-color: transparent #eff1ff transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=seitai]::after {
  border-color: transparent #fde3e9 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=food]::after {
  border-color: transparent #fff1ee transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=sweets]::after {
  border-color: transparent #ffeaea transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=pet]::after {
  border-color: transparent #fff7ee transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=flower]::after {
  border-color: transparent #ebfffe transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=life]::after {
  border-color: transparent #e7effc transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=cooking]::after {
  border-color: transparent #ffe9e3 transparent transparent;
}

.kouza_list_section .kouza_category_title[data-category=kokkashikaku]::after {
  border-color: transparent #e9ecff transparent transparent;
}

.kouza_list_section .kouza_category_title .category_title {
  margin: 0;
  padding: 10px 0 5px 40px;
  font-size: 1.875rem;
  border-bottom: 1px solid #fff;
}

.kouza_list_section .list_section_inner {
  margin: 0 auto;
  padding: 0 50px 60px 50px;
  width: 100%;
}

.kouza_list_section .list_section_inner .kouza_list_header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.kouza_list_section .list_section_inner .kouza_list_header .list_img {
  position: relative;
  margin: 0;
  padding: 0;
  width: 48%;
  height: 300px;
  overflow: hidden;
}

.kouza_list_section .list_section_inner .kouza_list_header .list_img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.kouza_list_section .list_section_inner .kouza_list_header .list_summary {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 48%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
  line-height: 2rem;
}

.kouza_list_section .list_section_inner .list_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_list_section .list_section_inner .list_body::after {
  content: "";
  display: block;
  width: 32.6666666667%;
}

.kouza_list_section .list_section_inner .list_body > li {
  margin: 0 0 1% 0;
  padding: 20px;
  width: 32.6666666667%;
  background: #fff;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #433006;
}

.kouza_list_section .list_section_inner .list_body > li > a:hover .kouza_title {
  color: #bb2b2b;
  transition: all .3s ease;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_title::after {
  display: block;
  content: "W資格取得講座";
}

.kouza_list_section .list_section_inner .list_body > li .add_course::after {
  display: block;
  content: "3資格取得講座";
}

.kouza_list_section .list_section_inner .list_body > li .cad_course::after {
  display: none;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_img {
  position: relative;
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  height: 110px;
  border: 1px solid #ccc;
  overflow: hidden;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_img > img {
  /* position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%; */
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.kouza_list_section .list_section_inner .list_body > li > a:hover .kouza_img >img {
  transform: scale(1.2);
  transition: all .3s ease;
}


.kouza_list_section .list_section_inner .list_body > li .kouza_lead {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
  line-height: 1.4rem;
}

.kouza_list_section .list_section_inner .list_body > li .special_txt {
  margin: 15px 0 0 0;
  padding: 6px 0;
  width: 100%;
  font-size: 0.875rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #433006;
  text-align: center;
  background: #EADEDE;
  border-radius: 4px;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dt {
  margin: 0;
  padding: 3px 0;
  width: 100%;
  font-size: 0.75rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #574D17;
  text-align: center;
  background: #E5DCD3;
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  background: #F2F1F0;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd .shikaku_txt {
  margin: 0;
  padding: 0;
  width: 100%;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd .shikaku_txt > li {
  margin: 0 0 5px 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #333;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd .shikaku_txt > li::before {
  margin-right: 5px;
  content: "\f152";
  /* font-weight: 600; */
  font-weight: bold;
  color: #174a85;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_link_btn {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  height: 55px;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_link_btn > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background: #B399D6;
  border-radius: 5px;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_link_btn > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.kouza_list_section .list_section_inner .list_body > li .kouza_link_btn > a:hover {
  background: #9274b9;
}

/* 202310追記 */
/*
* 人気資格講座ランキング
*-----------------------------------------------*/
.popular_kouza {
  margin: 30px auto 0 auto;
  padding: 0 0 30px 0;
  width: 100%;
  background-color: #f0f7fa;
}

.popular_kouza .popular_title {
  display: flex;
  align-items: center;
  position: relative;
  padding: 0 20px;
  width: 100%;
  height: 50px;
  font-size: 1.6rem;
  color: #693901;
  background: #F2EFD1;
  border-left: 66px solid #E8C946;
}

.popular_kouza .popular_title::before {
  content: "\f559";
  position: absolute;
  top: 50%;
  left: -4%;
  transform: translateY(-50%);
  padding: 0;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
}

.popular_kouza .popular_title::after {
  content: "POPULAR RANKING";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20%;
  height: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #c2a525;
  background: #FAF9F0;
}

.popular_kouza .popular_kouza_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 94%;
}

.popular_kouza .popular_kouza_list::after {
  content: "";
  display: block;
  width: 32.6666666667%;
}

.popular_kouza .popular_kouza_list > li {
  margin: 0 0 8px 0;
  padding: 0;
  width: 32.6666666667%;
}

.popular_kouza .popular_kouza_list > li > a {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.popular_kouza .popular_kouza_list > li > a:hover {
  opacity: 0.8;
}

.popular_kouza .popular_kouza_list > li > a .list_contents {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 200px;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dt {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  z-index: 0;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dt > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dd {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  padding: 0;
  width: 90%;
  z-index: 1;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info {
  margin: 0;
  padding: 0;
  width: 100%;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dt {
  margin: 0;
  padding: 3px 20px;
  width: 100%;
  font-size: 0.8rem;
  color: #fff;
  border-radius: 7px 7px 0 0;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dd {
  margin: 0;
  padding: 8px 12px 15px 12px;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #fff;
  background: rgba(64, 100, 116, 0.7);
  border-radius: 0 0 7px 7px;
}

.popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dd::after {
  display: block;
  content: "W資格取得講座";
  font-size: 0.8rem;
  font-weight: normal;
}

/* ランキングリスト */
.kouza_ranking_list {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_ranking_list .ranking_list {
  margin: 0 auto 30px auto;
  padding: 15px 0;
  width: 100%;
  background: #fff;
  border-radius: 5px;
  border: 1px solid #3EABB4;
}

.kouza_ranking_list .ranking_list.ranking_1 {
  border: 2px solid #eece41;
}

.kouza_ranking_list .ranking_list.ranking_2 {
  border: 2px solid #ACACAC;
}

.kouza_ranking_list .ranking_list.ranking_3 {
  border: 2px solid #B57C2F;
}

.kouza_ranking_list .ranking_list .contents_title_area {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #f7e99f;
}

.kouza_ranking_list .ranking_list .contents_title_area .ranking_no {
  position: relative;
  margin: 0;
  padding: 0;
  width: 160px;
  height: 80px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
}

.kouza_ranking_list .ranking_list.ranking_11-20 .contents_title_area .ranking_no {
  position: relative;
  margin: 0;
  padding: 0;
  width: 160px;
  height: 70px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
}

.kouza_ranking_list .ranking_list.ranking_1 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_01.svg") center no-repeat;
}

.kouza_ranking_list .ranking_list.ranking_2 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_02.svg") center no-repeat;
}

.kouza_ranking_list .ranking_list.ranking_3 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_03.svg") center no-repeat;
}

.kouza_ranking_list .ranking_list.ranking_4-10 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_04-10.svg") center no-repeat;
}

.kouza_ranking_list .ranking_list .contents_title_area .ranking_no .rank_num {
  position: absolute;
  left: 40%;
  transform: translateX(-40%);
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 3rem;
  font-weight: bold;
}

.kouza_ranking_list .ranking_list.ranking_11-20 .contents_title_area .ranking_no .rank_num {
  position: absolute;
  left: 40%;
  transform: translateX(-40%);
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 2.2rem;
  font-weight: bold;
}

.kouza_ranking_list .ranking_list .contents_title_area .ranking_no .rank_unit {
  margin: 0 0 0 6px;
  padding: 16px 0 0 0;
  font-size: 1.4rem;
  color: #fff;
}

.kouza_ranking_list .ranking_list .contents_title_area .title_area {
  margin: 0 3% 0 0;
  padding: 0;
  width: calc(100% - 220px);
}

.kouza_ranking_list .ranking_list .contents_title_area .title_area .kouza_category {
  margin: 0;
  padding: 1px 0 3px 0;
  width: 35%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}

.kouza_ranking_list .ranking_list .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 2rem;
  font-weight: bold;
  color: #a37303;
}

.kouza_ranking_list .ranking_list .detail_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .photo_course {
  margin: 0;
  padding: 0;
  width: 38%;
  height: 300px;
  overflow: hidden;
}

.kouza_ranking_list .ranking_list .detail_area .photo_course > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents {
  margin: 0;
  padding: 0;
  width: 60%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
  border: 1px solid #BEA13D;
  border-radius: 5px;
  background: #fbf8ed;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .get_shikaku_title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  padding: 0;
  width: 70%;
  height: 35px;
  font-size: 0.9rem;
  color: #fff;
  background: #b27948;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .shikaku_list {
  margin: 0;
  padding: 15px;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents li {
  margin: 0;
  padding: 8px 0;
  width: 49%;
  font-size: 0.9rem;
  font-weight: bold;
  color: #682828;
  text-align: center;
  background: #e1d0c2;
  border-radius: 5px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 15px auto 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working {
  margin: 0;
  padding: 0 0 15px 0;
  width: 49%;
  background: #fff;
  border: 1px solid #BEA13D;
  border-radius: 5px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend .recommend_title,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working .working_title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 80%;
  height: 30px;
  font-size: 0.9rem;
  color: #fff;
  background: #d2691e;
  overflow: hidden;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend .recommend_cont,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working .working_cont {
  margin: 15px auto 0 auto;
  padding: 0 30px;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working .working_cont .cont_list {
  margin: 0;
  padding: 0;
  width: 100%;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list > li,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working .working_cont .cont_list > li {
  margin: 0 0 5px 15px;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #444;
  line-height: 1.2rem;
  list-style-type: disc;
  list-style-position: outside;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list > li:last-child,
.kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working .working_cont .cont_list > li:last-child {
  margin-bottom: 0;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  height: 40px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #a16a0a;
  text-decoration: none;
  border: 1px solid #cb821a;
  border-radius: 5px;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn > a::after {
  margin-left: 16px;
  content: "\f054";
  font-weight: bold;
}

.kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn > a:hover {
  color: #fff;
  background: #996606;
}

.more_ranking {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
  height: 60px;
}

.more_ranking > a {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 70%;
  height: 100%;
  font-size: 1.1rem;
  color: #d63985;
  border: 1px solid #d63985;
  border-radius: 5px;
  text-decoration: none;
}

.more_ranking > a:hover {
  color: #fff;
  background: #d63985;
}

/**
** スクールについて
**
===================================================================*/
/*
* ページ内メニュー
*---------------------------------------------------*/
.school_page_menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 20px auto;
  padding: 0;
  width: 100%;
}

.school_page_menu > li {
  position: relative;
  margin: 0;
  padding: 0;
  width: 19.6%;
  height: 60px;
  border-radius: 5px;
}

.school_page_menu > li > a {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 0.9rem;
  color: #0068b7;
  text-decoration: none;
}

.school_page_menu > li > a:hover {
  transition: all 0.3s;
}

.school_page_menu > li.inner {
  background: #cee6f1;
}

.school_page_menu > li.inner > a:hover {
  background: #c2dce7;
}

.school_page_menu > li.outer {
  background: #e8f5d3;
}

.school_page_menu > li.outer > a:hover {
  background: #d8e6c2;
}

/*
* スクールについて概要
*---------------------------------------------------*/
.school_head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 20px auto;
  padding: 30px 50px;
  width: 100%;
  background: #F5F2ED;
}

.school_head .summary_area {
  margin: 0;
  padding: 0;
  width: 77%;
}

.school_head .summary_area .summary_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.625rem;
  color: #c08008;
}

.school_head .summary_area .summary_txt {
  margin: 8px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.9375rem;
  color: #333;
  line-height: 1.8rem;
}

.school_head .ryo_meaning {
  margin: 0;
  padding: 15px;
  width: 20%;
  background: #fff;
  border-radius: 5px;
}

.school_head .ryo_meaning .meaning_cont {
  margin: 0;
  padding: 0;
  width: 100%;
}

.school_head .ryo_meaning .meaning_cont > dt {
  margin: 0;
  padding: 10px 0;
  width: 100%;
  font-size: 1.25rem;
  color: #fff;
  text-align: center;
  line-height: 1.4rem;
  background: #0068b7;
  border-radius: 5px;
}

.school_head .ryo_meaning .meaning_cont > dt .hiragana {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
}

.school_head .ryo_meaning .meaning_cont > dd {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #235b9b;
  /* font-weight: 500; */
  font-weight: bold;
  text-align: center;
}

/*
* 諒設計アーキテクトラーニング概要
*---------------------------------------------------*/
.school_tbl {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 95%;
  border-collapse: collapse;
  border: 1px solid #ccc;
}

.school_tbl th {
  margin: 0;
  padding: 10px 3%;
  width: 20%;
  font-size: 1rem;
  font-weight: normal;
  color: #fff;
  text-align: left;
  background: #0068b7;
  border-bottom: 1px solid #ccc;
}

.school_tbl td {
  margin: 0;
  padding: 10px 15px;
  font-size: 1rem;
  color: #333;
  line-height: 1.8rem;
  border-bottom: 1px solid #ddd;
  background: #fff;
}

.school_tbl .td_01 {
  width: 60%;
}

.school_tbl .td_02 {
  padding: 0;
  width: 40%;
  text-align: center;
  border-left: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

.school_tbl .td_02 > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: auto;
}

/*
* 諒設計とは？
*---------------------------------------------------*/
.sekkei_summary {
  margin: 0 auto;
  padding: 30px;
  width: 100%;
}

.sekkei_summary > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.375rem;
  color: #206186;
}

.sekkei_summary > dd {
  margin: 15px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.sekkei_tbl {
  margin: 0 auto;
  padding: 0;
  width: 95%;
  border-collapse: collapse;
  border: 1px solid #ccc;
}

/*
* 沿革
*---------------------------------------------------*/
.history_area {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 92%;
}

.history_area .history_row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0 0 20px 0;
  border-bottom: 1px dotted #ddd;
}

.history_area .history_row + dl {
  margin-top: 30px;
}

.history_area .history_row > dt {
  position: relative;
  margin: 0;
  padding: 0 0 0 15px;
  width: 10%;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #9b750c;
}

.history_area .history_row > dt::before {
  content: "\f054";
  position: absolute;
  top: 8%;
  left: 0;
  margin: 0;
  font-size: 0.875rem;
  /* font-weight: 600; */
  font-weight: bold;
}

.history_area .history_row > dt.current {
  color: #b11818;
}

.history_area .history_row > dd {
  margin: 0;
  padding: 0;
  width: 86%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

/*
* ページリンクエリア
*---------------------------------------------------*/
.others_link_area {
  margin: 30px 0 50px auto;
  padding: 0;
  width: 50%;
}

.others_link_area > a {
  display: block;
  margin: 0;
  padding: 20px 30px;
  width: 100%;
  height: 100%;
  background: #F7F6ED;
  border-radius: 5px;
  text-decoration: none;
}

.others_link_area > a:hover {
  background: #ebe8d2;
}

.others_link_area > a .link_cont {
  margin: 0;
  padding: 0;
  width: 100%;
}

.others_link_area > a .link_cont > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.125rem;
  color: #9D430A;
}

.others_link_area > a .link_cont > dd {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.5rem;
  color: #083B55;
}

.others_link_area > a .link_cont > dd::after {
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 45%;
  transform: translateY(-50%);
  /* font-weight: 600; */
  font-weight: bold;
}

/*
* お申し込み・お支払いについて
*---------------------------------------------------*/
/*
* お申し込み
*---------------------------------------------------*/
.order_tel_title {
  margin: 40px auto 0 auto;
  padding: 7px 20px;
  width: 80%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #184b68;
  background: #cee3f1;
  border-bottom: 3px solid #0068b7;
}

.order_tel_summary {
  margin: 15px auto 0 auto;
  padding: 0;
  width: 80%;
  font-size: 1rem;
  line-height: 1.6rem;
}

.tel_fax_number {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 80%;
}

.tel_fax_number > li {
  margin: 0;
  padding: 0;
  width: 49%;
  border: 1px solid #ddd;
}

.tel_fax_number > li .number_body {
  margin: 0;
  padding: 0;
  width: 100%;
}

.tel_fax_number > li .number_body > dt {
  margin: 0;
  padding: 6px 20px 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #fff;
  background: #678d9e;
}

.tel_fax_number > li .number_body > dd {
  margin: 0;
  padding: 20px;
  width: 100%;
  background: #fff;
}

.kouza_order {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_order > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  padding: 0;
  width: 30%;
  height: 50px;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: #af2020;
  border-radius: 5px;
}

.kouza_order > a::after {
  content: "\f054";
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  /* font-weight: 600; */
  font-weight: bold;
}

.kouza_order > a:hover {
  background: #d42a2a;
  transition: all 0.3s;
}

/*
* お支払いについて
*---------------------------------------------------*/
.payment_summary {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 90%;
  font-size: 1rem;
  line-height: 1.6rem;
}

.payment_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
  width: 90%;
}
.payment_list::before {
  content: "";
  display: block;
  width: 24.5%;
  order: 1;
}
.payment_list::after {
  content: "";
  display: block;
  width: 24.5%;
}

.payment_list > li {
  margin: 0 0 8px 0;
  padding: 0;
  width: 24.5%;
  height: 40px;
}

.payment_list > li > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 0.875rem;
  color: #fff;
  text-decoration: none;
  background: #5f9236;
  border-radius: 5px;
}

.payment_list > li > a::after {
  content: "\f078";
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  font-size: 0.625rem;
  /* font-weight: 600; */
  font-weight: bold;
}

.payment_list > li > a:hover {
  background: #d6d895;
}

/*
* オススメのお支払い
*---------------------------------------------------*/
.payment_recommend {
  margin: 30px auto 0 auto;
  padding: 20px;
  width: 90%;
  background: #efe1f3;
  border-radius: 5px;
}

.payment_recommend > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #751e8f;
}

.payment_recommend > dt .pay_emp {
  margin: 0 3px;
  padding: 1px 15px 3px 15px;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  background: #21793e;
}

.payment_recommend > dd {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.6rem;
}

/*
* 代金引換
*---------------------------------------------------*/
.pay_daibiki {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}

.pay_daibiki > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}

.pay_daibiki > dd {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}

.pay_daibiki > dd .e-collect_img {
  margin: 0;
  padding: 0;
  width: 20%;
}

.pay_daibiki > dd .e-collect_img > img {
  max-width: 100%;
  height: auto;
}

.pay_daibiki > dd .txt_lead {
  display: block;
  margin: 0;
  padding: 0;
  width: 78%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.daibiki_method {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 10px 30px 50px 30px;
  width: 90%;
  background: #fff;
}

.daibiki_method > li {
  margin: 0;
  padding: 0;
  width: 32.6666666667%;
  border: 1px solid #6c9ecc;
}

.daibiki_method > li .method_body {
  margin: 0 auto 5px auto;
  padding: 0;
  width: 100%;
}

.daibiki_method > li .method_body > dt {
  margin: 0;
  padding: 8px 10px;
  width: 100%;
  font-size: 0.8125rem;
  color: #fff;
  background: #69aac9;
}

.daibiki_method > li .method_body > dt .method_name {
  display: block;
  margin: 0 0 5px 0;
  padding: 4px 0;
  width: 100%;
  font-size: 0.75rem;
  color: #fff;
  text-align: center;
  background: #1a8558;
}

.daibiki_method > li .method_body .pay_term {
  margin: 0;
  padding: 10px 5px;
  width: 100%;
  text-align: right;
  border-bottom: 1px solid #69aac9;
}

.daibiki_method > li .method_body .pay_term .ikkatsu {
  margin: 0 5px;
  padding: 2px 15px;
  font-size: 0.875rem;
  color: #b83535;
  text-align: center;
  border: 1px solid #b83535;
  border-radius: 4px;
}

.daibiki_method > li .method_body .pay_term .bunkatsu {
  margin: 0 5px;
  padding: 3px 15px;
  font-size: 0.875rem;
  color: #2da17b;
  text-align: center;
  border: 1px solid #2da17b;
  border-radius: 4px;
}

.daibiki_method > li .method_body .method_txt {
  margin: 0;
  padding: 10px 10px;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.5rem;
}

.daibiki_method > li .method_body .method_txt .card_img {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
}

.daibiki_method > li .method_body .method_txt .card_img > img {
  max-width: 100%;
  height: auto;
}

.daibiki_method > li .method_body .method_txt .debit {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}

.daibiki_method > li .method_body .method_txt .debit .debit_img {
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 100%;
  text-align: center;
}

.daibiki_method > li .method_body .method_txt .debit .debit_txt {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.75rem;
  color: #333;
  line-height: 1.4rem;
}

/*
* 後払い
*---------------------------------------------------*/
.pay_atobarai {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}

.pay_atobarai > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}

.pay_atobarai > dd {
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}

.pay_atobarai > dd .txt_lead {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.pay_atobarai > dd .img_atobarai {
  display: flex;
  justify-content: center;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.pay_atobarai > dd .img_atobarai > img {
  max-width: 100%;
  height: auto;
}

/*
* クレジットカード決済
*---------------------------------------------------*/
.pay_credit {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}

.pay_credit > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}

.pay_credit > dd {
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}

.pay_credit > dd .txt_lead {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.pay_credit > dd .img_credit {
  display: flex;
  justify-content: center;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.pay_credit > dd .img_credit > img {
  max-width: 100%;
  height: auto;
}

/*
* PayPay
*---------------------------------------------------*/
.pay_paypay {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}
@media screen and (max-width: 480px) {
  .pay_paypay {
    width: 100%;
  }
}
.pay_paypay > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}
.pay_paypay > dd {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}
.pay_paypay > dd .paypay_logo {
  margin: 0;
  padding: 0;
  width: 20%;
  height: 180px;
}
@media screen and (max-width: 480px) {
  .pay_paypay > dd .paypay_logo {
    margin: 0 auto;
    width: 40%;
    height: auto;
  }
}
.pay_paypay > dd .paypay_logo > img {
  -o-object-fit: cover;
     object-fit: cover;
  max-width: 100%;
  max-height: 100%;
}
.pay_paypay > dd .txt_lead {
  display: block;
  margin: 0;
  padding: 0;
  width: 76%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}
@media screen and (max-width: 480px) {
  .pay_paypay > dd .txt_lead {
    width: 100%;
    font-size: 0.9rem;
  }
}
.pay_paypay > dd .img_atobarai {
  display: flex;
  justify-content: center;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}
.pay_paypay > dd .img_atobarai > img {
  max-width: 100%;
  height: auto;
}

/*
* AmazonPay
*---------------------------------------------------*/
.pay_amazonpay {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}
@media screen and (max-width: 480px) {
  .pay_amazonpay {
    width: 100%;
  }
}
.pay_amazonpay > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}
.pay_amazonpay > dd {
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}
.pay_amazonpay > dd .amazonpay_logo {
  margin: 0;
  padding: 0;
  width: 30%;
  height: 60px;
}
@media screen and (max-width: 480px) {
  .pay_amazonpay > dd .amazonpay_logo {
    margin: 0 auto;
    width: 70%;
  }
}
.pay_amazonpay > dd .amazonpay_logo > img {
  -o-object-fit: cover;
     object-fit: cover;
  max-width: 100%;
  max-height: 100%;
}
.pay_amazonpay > dd .txt_lead {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}
@media screen and (max-width: 480px) {
  .pay_amazonpay > dd .txt_lead {
    font-size: 0.9rem;
  }
}
.pay_amazonpay > dd .img_atobarai {
  display: flex;
  justify-content: center;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}
.pay_amazonpay > dd .img_atobarai > img {
  max-width: 100%;
  height: auto;
}

/*
* オリコの教育ローン
*---------------------------------------------------*/
.pay_orico {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}

.pay_orico > dt {
  margin: 0;
  padding: 8px 20px;
  width: 100%;
  font-size: 1.125rem;
  color: #214799;
  border-left: 10px solid #214799;
  border-top: 1px solid #214799;
  border-bottom: 1px solid #214799;
  border-right: 1px solid #214799;
  background: #eef9fc;
}

.pay_orico > dd {
  margin: 0 auto;
  padding: 30px;
  width: 100%;
  background: #fff;
}

.pay_orico > dd .orico_process {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 20px;
  width: 100%;
  border: 1px solid #ddd;
}

.pay_orico > dd .orico_process > dt {
  margin: 0;
  padding: 6px 20px 10px 5px;
  width: 100%;
  font-size: 1.0625rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #384f80;
  border-bottom: 1px dotted #384f80;
}

.pay_orico > dd .orico_process > dt .process_no {
  margin: 0 10px 0 0;
  padding: 0 15px 2px 15px;
  font-size: 1.125rem;
  color: #fff;
  background: #254b7c;
  border-radius: 4px;
}

.pay_orico > dd .orico_process > dd {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
  width: 90%;
}

.pay_orico > dd .orico_process > dd .process_img {
  margin: 0;
  padding: 0;
  width: 5%;
}

.pay_orico > dd .orico_process > dd .process_txt {
  display: block;
  margin: 0;
  padding: 0;
  width: 92%;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.4rem;
}

.pay_orico > dd .step_down_triangle {
  display: flex;
  justify-content: center;
  margin: 20px auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.orico_simu_notice {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
}

.orico_simu_notice .orico_simu {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 20px 0;
  width: 30%;
}

.orico_simu_notice .orico_notice {
  margin: 0;
  padding: 0;
  width: 67%;
}

.orico_simu_notice .orico_notice > dt {
  margin: 0 0 7px 0;
  padding: 0 0 0 15px;
  width: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #a02c2c;
}

.orico_simu_notice .orico_notice > dt::before {
  content: "\f071";
  margin-right: 5px;
  /* font-weight: 600; */
  font-weight: bold;
}

.orico_simu_notice .orico_notice > dd {
  margin: 0;
  padding: 15px;
  width: 100%;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.4rem;
  border: 1px solid #ddd;
}

/*
* 【トップページ】トラブル01
*-----------------------------------------------*/
.trouble01 {
  margin: 0 auto;
  padding: 70px 0 0 0;
  width: 92%;
  background: url("../../images/top/img_trouble_bg.svg") top center no-repeat;
}
@media screen and (max-width: 480px) {
  .trouble01 {
    margin: 30px auto 0 auto;
    padding: 0;
    width: 96%;
    height: auto;
  }
}

.trouble01 .trouble01_contents {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
}

.trouble01 .trouble01_contents::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 190px;
  height: 190px;
  background: #e7f0f7;
  border-radius: 50%;
  z-index: -1;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_contents::before {
    top: 15%;
    left: 0;
    width: 90px;
    height: 90px;
  }
}

.trouble01 .trouble01_contents::after {
  content: url("../../images/top/img_trouble_01.svg");
  position: absolute;
  top: -10%;
  right: 0;
  transform: translateY(-10%);
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_contents::after {
    display: inline-block;
    top: -14%;
    right: -7%;
    transform: translate(7%, -14%) scale(0.5);
  }
}

.trouble01 .trouble01_contents > dt {
  margin: 0;
  padding: 0 0 0 70px;
  width: 100%;
  font-size: 1.875rem;
  font-weight: bold;
  color: #9F326C;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_contents > dt {
    padding: 0 0 0 20px;
    width: 75%;
    font-size: 1.25rem;
  }
}

.trouble01 .trouble01_contents > dd {
  margin: 10px 0 0 0;
  padding: 0 0 0 70px;
  width: 85%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_contents > dd {
    margin: 40px auto 0 auto;
    padding: 0 15px;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
}

.trouble01 .trouble01_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 60px 0 0 0;
  padding: 0;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_list {
    margin: 20px auto 0 auto;
  }
}

.trouble01 .trouble01_list .list_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_list .list_body {
    width: 100%;
  }
}

.trouble01 .trouble01_list .list_body > li {
  display: flex;
  align-items: center;
  margin: 0 0 1% 0;
  padding: 0 30px;
  width: 24.75%;
  height: 170px;
  font-size: 1.125rem;
  font-weight: bold;
  color: #333;
  text-align: center;
  line-height: 2rem;
  background: #EDF5F8;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_list .list_body > li {
    width: 49.5%;
    height: 100px;
    padding: 0 15px;
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
}

.trouble01 .trouble01_list .list_body > li:nth-child(2), .trouble01 .trouble01_list .list_body > li:nth-child(3) {
  background: #FAF2F6;
}

.trouble01 .trouble01_list .school_video {
  position: relative;
  margin: 0;
  padding: 0;
  width: 47%;
  height: 345px;
  overflow: hidden;
  border: 1px solid #ccc;
}
.trouble01 .trouble01_list .school_video lite-youtube {
  height: 100%;
}
@media screen and (max-width: 480px) {
  .trouble01 .trouble01_list .school_video {
    width: 100%;
    height: 220px;
  }
}

/*
* 【トップページ】トラブル02
*-----------------------------------------------*/
.trouble02 {
  margin: 0 auto;
  padding: 90px 0 0 0;
  width: 92%;
  background: url("../../images/top/img_trouble_bg.svg") top center no-repeat;
}
@media screen and (max-width: 480px) {
  .trouble02 {
    margin: 0 auto;
    padding: 30px 0 0 0;
    width: 96%;
    height: auto;
  }
}

.trouble02 .trouble02_contents {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.trouble02 .trouble02_contents::before {
  content: url("../../images/top/img_trouble_02.svg");
  position: absolute;
  top: -5%;
  left: 0;
  transform: translateY(-5%);
}
@media screen and (max-width: 480px) {
  .trouble02 .trouble02_contents::before {
    display: inline-block;
    top: -22%;
    left: -8%;
    transform: translateX(-11%) scale(0.5);
  }
}

.trouble02 .trouble02_contents::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 170px;
  height: 170px;
  background: #f0eaf3;
  border-radius: 50%;
  z-index: -1;
}
@media screen and (max-width: 480px) {
  .trouble02 .trouble02_contents::after {
    top: 13%;
    nav-right: 0;
    width: 90px;
    height: 90px;
  }
}

.trouble02 .trouble02_contents > dt {
  margin: 0 0 0 25%;
  padding: 0 70px 0 0;
  width: 75%;
  font-size: 1.875rem;
  font-weight: bold;
  color: #024A31;
}
@media screen and (max-width: 480px) {
  .trouble02 .trouble02_contents > dt {
    margin: 0 auto;
    padding: 0 0 0 36%;
    width: 100%;
    font-size: 1.25rem;
  }
}

.trouble02 .trouble02_contents > dd {
  margin: 10px 0 0 25%;
  padding: 0 70px 0 0;
  width: 75%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}
@media screen and (max-width: 480px) {
  .trouble02 .trouble02_contents > dd {
    margin: 20px auto 0 auto;
    padding: 0 15px;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
}

.trouble02 .school_impression {
  margin: 50px auto 0 auto;
  padding: 40px 25px;
  width: 100%;
  background-color: #f2effc;
}
@media screen and (max-width: 480px) {
  .trouble02 .school_impression {
    margin: 20px auto 0 auto;
    padding: 25px;
  }
}

.trouble02 .school_impression .impression_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.trouble02 .school_impression .impression_body > li {
  margin: 0;
  padding: 0 0 20px 0;
  width: 32%;
  background: #fff;
  border-radius: 5px;
}
@media screen and (max-width: 480px) {
  .trouble02 .school_impression .impression_body > li {
    margin: 0 0 10px 0;
    width: 100%;
  }
}

.trouble02 .school_impression .impression_body > li .impression_contents {
  margin: 0;
  padding: 0;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .trouble02 .school_impression .impression_body > li .impression_contents {
    margin: 0;
    padding: 0;
    width: 100%;
  }
}

.trouble02 .school_impression .impression_body > li .impression_contents > dt {
  position: relative;
  display: inline-block;
  margin: 20px 0 0 -10px;
  padding: 10px 15px;
  width: 95%;
  font-size: 1rem;
  color: #fff;
  border-radius: 0 8px 8px 0;
  background: #61a1bb;
}
@media screen and (max-width: 480px) {
  .trouble02 .school_impression .impression_body > li .impression_contents > dt {
    width: 98%;
    font-size: 0.875rem;
  }
}

.trouble02 .school_impression .impression_body > li .impression_contents > dt:before {
  position: absolute;
  bottom: -10px;
  left: 0;
  width: 0;
  height: 0;
  content: "";
  border-top: 10px solid #2F6477;
  border-left: 10px solid transparent;
}

.trouble02 .school_impression .impression_body > li .impression_contents .contents_txt {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 85%;
  font-size: 1rem;
  color: #555;
  line-height: 1.8rem;
}
@media screen and (max-width: 480px) {
  .trouble02 .school_impression .impression_body > li .impression_contents .contents_txt {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
}

.trouble02 .school_impression .impression_body > li .impression_contents .graph {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 85%;
  text-align: center;
}

/*
* 【トップページ】スクールアピールテキスト
*-----------------------------------------------*/
.school_appeal_txt {
  position: relative;
  margin: 50px auto 0 auto;
  padding: 0;
  width: 60%;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt {
    margin: 30px auto 0 auto;
    width: 96%;
  }
}

.school_appeal_txt::before, .school_appeal_txt::after {
  content: "";
  position: absolute;
  display: inline-block;
  top: 50%;
  width: 90px;
  height: 2px;
  background-color: #4183B4;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt::before, .school_appeal_txt::after {
    top: 50%;
    width: 70px;
  }
}

.school_appeal_txt::before {
  left: 0;
  transform: rotate(70deg);
}
@media screen and (max-width: 480px) {
  .school_appeal_txt::before {
    left: -6%;
  }
}

.school_appeal_txt::after {
  right: 0;
  transform: rotate(-70deg);
}
@media screen and (max-width: 480px) {
  .school_appeal_txt::after {
    right: -6%;
  }
}

.school_appeal_txt > dt {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 50%;
  height: 54px;
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  line-height: 54px;
  background: #d82851;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt > dt {
    width: 60%;
    height: 40px;
    font-size: 1rem;
    line-height: 40px;
  }
}

.school_appeal_txt > dt::before, .school_appeal_txt > dt::after {
  content: "";
  position: absolute;
  top: 0;
  display: block;
  border: 27px solid #d82851;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt > dt::before, .school_appeal_txt > dt::after {
    border: 20px solid #d82851;
  }
}

.school_appeal_txt > dt::before {
  left: -40px;
  border-left-width: 15px;
  border-left-color: transparent;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt > dt::before {
    left: -30px;
    border-left-width: 15px;
    border-left-color: transparent;
  }
}

.school_appeal_txt > dt::after {
  right: -40px;
  border-right-width: 15px;
  border-right-color: transparent;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt > dt::after {
    right: -30px;
    border-right-width: 15px;
    border-right-color: transparent;
  }
}

.school_appeal_txt > dt > span {
  position: relative;
  display: block;
}

.school_appeal_txt > dd {
  margin: 15px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.375rem;
  font-weight: bold;
  color: #084dc5;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .school_appeal_txt > dd {
    margin: 10px auto 0 auto;
    font-size: 0.875rem;
  }
}

.appeal_title {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 92%;
  font-size: 1.75rem;
  font-weight: bold;
  color: #c00e49;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .appeal_title {
    width: 94%;
    font-size: 1.375rem;
  }
}

/*
* 【トップページ】スクールの紹介
*-----------------------------------------------*/
.school_intro {
  position: relative;
  margin: 40px auto 0 auto;
  padding: 90px 0 70px 0;
  width: 100%;
  background-color: #FDF5F8;
}
@media screen and (max-width: 480px) {
  .school_intro {
    margin: 20px auto 0 auto;
    padding: 60px 0 40px 0;
  }
}

.school_intro::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-top: 40px solid #F4D1DD;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
}

.school_intro .contents_wrapper {
  margin: 0 auto;
  padding: 0;
  width: 83%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper {
    width: 94%;
  }
}

.school_intro .contents_wrapper .school_point {
  position: relative;
  margin: 0;
  padding: 0 0 0 8%;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .school_point {
    height: 460px;
    background: url("../../images/top/img_school_appeal.png") center 230px no-repeat;
    background-size: 90%;
  }
}

.school_intro .contents_wrapper .school_point::after {
  content: url("../../images/top/img_school_appeal.png");
  position: absolute;
  top: -7%;
  right: 0;
  transform: translateY(-7%);
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .school_point::after {
    display: none;
  }
}

.school_intro .contents_wrapper .school_point > dt {
  display: inline;
  margin: 0;
  padding: 0 0 2px 0;
  width: 100%;
  font-size: 3.75rem;
  font-weight: bold;
  line-height: 6rem;
  background: linear-gradient(transparent 94%, #e46965 0%);
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .school_point > dt {
    font-size: 2.5rem;
    line-height: 4rem;
  }
}

.school_intro .contents_wrapper .school_point > dd {
  margin: 30px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.875rem;
  font-weight: bold;
  color: #0068b7;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .school_point > dd {
    margin: 15px 0 0 0;
    font-size: 1.5rem;
  }
}

.school_intro .contents_wrapper .decide_reason {
  margin: 90px auto 0 auto;
  padding: 0;
  width: 90%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .decide_reason {
    margin: 20px auto 0 auto;
    width: 100%;
  }
}

.school_intro .contents_wrapper .decide_reason > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.625rem;
  font-weight: bold;
  color: #BC0870;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .decide_reason > dt {
    font-size: 1.375rem;
  }
}

.school_intro .contents_wrapper .decide_reason > dd {
  position: relative;
  margin: 10px 0 0 0;
  padding: 15px 30px 15px 20%;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #00256E;
  line-height: 1.8rem;
  background: #fff;
  border-right: 5px;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .decide_reason > dd {
    padding: 35% 20px 15px 20px;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
}

.school_intro .contents_wrapper .decide_reason > dd::before {
  content: url("../images/top/img_decide_reason.svg");
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .decide_reason > dd::before {
    top: -7%;
    left: 50%;
    transform: translateX(-50%) scale(0.7);
  }
}

.school_intro .contents_wrapper .no1_sponsor {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 20px auto;
  padding: 0;
  width: 90%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor {
    margin: 20px auto;
    width: 100%;
  }
}

.school_intro .contents_wrapper .no1_sponsor .no1_area {
  margin: 0;
  padding: 0;
  width: 49%;
  border: 1px solid #eee;
  background: #fff;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .no1_area {
    padding: 10px 0;
    width: 100%;
    background: none;
    border: none;
  }
}

.school_intro .contents_wrapper .no1_sponsor .no1_area .pc {
  display: block;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .no1_area .pc {
    display: none;
  }
}

.school_intro .contents_wrapper .no1_sponsor .no1_area .sp {
  display: none;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .no1_area .sp {
    display: block;
  }
}

.school_intro .contents_wrapper .no1_sponsor .no1_area > img {
  max-width: 100%;
  height: auto;
}

.school_intro .contents_wrapper .no1_sponsor .sponsor {
  margin: 0;
  padding: 0;
  width: 49%;
  border: 1px solid #eee;
  background: #fff;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .sponsor {
    margin: 10px auto 0 auto;
    width: 100%;
  }
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dt {
  margin: 0;
  padding: 10px 50px;
  width: 100%;
  font-size: 1.5rem;
  font-weight: bold;
  color: #0c2d53;
  background: #F2D243;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .sponsor > dt {
    padding: 6px 0;
    font-size: 1.125rem;
    text-align: center;
  }
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dd {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_txt {
  margin: 0;
  padding: 0;
  width: 60%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_txt {
    width: 100%;
  }
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_txt > p {
  margin: 17px 0 0 0;
  padding: 0 0 0 30px;
  width: 100%;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.4rem;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_txt > p {
    margin: 10px auto 0 auto;
    padding: 0 15px;
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_img {
  margin: -30px 0 0 0;
  padding: 0;
  width: 40%;
}
@media screen and (max-width: 480px) {
  .school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_img {
    margin: 10px auto 0 auto;
    width: 70%;
  }
}

.school_intro .contents_wrapper .no1_sponsor .sponsor > dd .sponsor_img > img {
  max-width: 100%;
  height: auto;
}

/*
* 【トップページ】スクールのメリット
*-----------------------------------------------*/
.school_merit_area {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .school_merit_area {
    margin: 30px auto;
  }
}

.school_merit_area .contents_wrapper {
  margin: 0 auto;
  padding: 0;
  width: 80%;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper {
    width: 94%;
  }
}

.school_merit_area .contents_wrapper .school_merit_title {
  position: relative;
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.875rem;
  font-weight: bold;
  color: #144A93;
  text-align: center;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .school_merit_title {
    margin: 0 auto;
    padding-left: 50px;
    width: 94%;
    font-size: 1.375rem;
    text-align: left;
  }
}

.school_merit_area .contents_wrapper .school_merit_title::before {
  margin-right: 15px;
  content: "\f445";
  font-size: 2.25rem;
  font-weight: bold;
  color: #eecd39;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .school_merit_title::before {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
  }
}

.school_merit_area .contents_wrapper .merit_list_part {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 80px auto 0 auto;
  padding: 0;
  width: 100%;
  counter-reset: number 0;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .merit_list_part {
    margin: 60px auto 0 auto;
  }
}

.school_merit_area .contents_wrapper .merit_list_part::after {
  display: block;
  content: "";
  width: 32%;
}

.school_merit_area .contents_wrapper .merit_list_part li {
  margin: 0 0 60px 0;
  padding: 0 0 30px 0;
  width: 32.6666666667%;
  background: #FCF4FF;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .merit_list_part li {
    margin: 0;
    width: 100%;
  }
}

@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .merit_list_part li + li {
    margin-top: 50px;
  }
}
.school_merit_area .contents_wrapper .merit_list_part li .list_no {
  position: relative;
  margin: -20px 0 0 10px;
  padding: 0 0 0 85px;
  width: 80%;
  height: 40px;
  font-size: 1.25rem;
  color: #fff;
  line-height: 40px;
  background: #fd5e70;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_no::before {
  counter-increment: number 1;
  content: counter(number);
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  padding: 0em;
  width: 65px;
  height: 65px;
  font-size: 1.875rem;
  color: #fd5e70;
  text-align: center;
  line-height: 57px;
  background: #fff;
  border: 1px solid #fd5e70;
  border-radius: 50%;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_no::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: -20px;
  height: 30px;
  border: 20px solid #fd5e70;
  border-right-width: 15px;
  border-right-color: transparent;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body {
  margin: 30px auto 0 auto;
  padding: 0 30px;
  width: 100%;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body dt {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 130px;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body dt .list_title {
  margin: 0;
  padding: 5px 0 0 0;
  width: 70%;
  font-size: 1.625rem;
  font-weight: bold;
  color: #f54d60;
  line-height: 2.6rem;
}
@media screen and (max-width: 480px) {
  .school_merit_area .contents_wrapper .merit_list_part li .list_body dt .list_title {
    font-size: 1.5rem;
  }
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body dt .list_illust {
  margin: 0;
  padding: 0;
  width: 30%;
  max-height: 130px;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body dt .list_illust > img {
  max-width: 100%;
  height: auto;
}

.school_merit_area .contents_wrapper .merit_list_part li .list_body dd {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9375rem;
  color: #363636;
  line-height: 1.6rem;
}

/*
* 【トップページ】記事監修
*-----------------------------------------------*/
#supervision {
  margin: 0 auto;
  padding: 50px 0 0 0;
  width: 100%;
}
@media screen and (max-width: 480px) {
  #supervision {
    padding: 30px 0 0 0;
  }
}

#supervision .section_inner {
  margin: 0 auto;
  padding: 20px;
  width: 80%;
  border: 1px solid #f5ccd4;
  border-radius: 7px;
  background: #fdf8f9;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner {
    padding: 20px 15px;
    width: 94%;
  }
}

#supervision .section_inner .supervision_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.2rem;
  font-weight: bold;
  color: #c71c1c;
  text-align: center;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .supervision_title {
    font-size: 1.4rem;
  }
}

#supervision .section_inner .contents_area {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

#supervision .section_inner .contents_area .supervision_summary {
  margin: 0;
  padding: 20px;
  width: 35%;
  background: #fff;
  font-size: 1rem;
  color: #000;
  line-height: 2.2rem;
  border-radius: 6px;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .contents_area .supervision_summary {
    width: 100%;
    font-size: 0.9rem;
    line-height: 1.6rem;
  }
}

#supervision .section_inner .person_detail {
  margin: 0;
  padding: 0;
  width: 63%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .person_detail {
    width: 94%;
    flex-direction: column-reverse;
  }
}

#supervision .section_inner .person_detail .detail_txt {
  margin: 0;
  padding: 0;
  width: 70%;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .person_detail .detail_txt {
    margin: 10px auto 0 auto;
    width: 100%;
  }
}

#supervision .section_inner .person_detail .detail_txt > dt {
  margin: 8px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.6rem;
  font-weight: bold;
  color: #000;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .person_detail .detail_txt > dt {
    font-size: 1.4rem;
    text-align: center;
  }
}

#supervision .section_inner .person_detail .detail_txt > dd {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #333;
  line-height: 1.6rem;
}

#supervision .section_inner .person_detail .person_photo {
  margin: 0;
  padding: 0;
  width: 28%;
  height: 220px;
}
@media screen and (max-width: 480px) {
  #supervision .section_inner .person_detail .person_photo {
    margin: 15px auto 10px auto;
    width: 60%;
  }
}

#supervision .section_inner .person_detail .person_photo > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/*
* 雑誌・メディア掲載実績
*---------------------------------------------------*/
/*
* タイトルリード小文字
*---------------------------------------------------*/
.smt {
  font-size: 0.875rem;
  font-weight: normal;
}

/*
* カテゴリタイトル
*---------------------------------------------------*/
.jisseki_cat_title {
  margin: 0 auto;
  padding: 10px 0;
  width: 100%;
  font-size: 1.375rem;
  color: #fff;
  text-indent: 30px;
  border-left: 15px solid #19396F;
  background: #0068b7;
}

.jisseki_cat_title:not(:first-child) {
  margin-top: 40px;
}

.jisseki_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 94%;
}

.jisseki_contents > li {
  margin: 0 0 20px 0;
  padding: 0;
  width: 49%;
  background: #fff;
  border: 1px solid #ddd;
}

.jisseki_contents > li .contents_list {
  margin: 0;
  padding: 0;
  width: 100%;
}

.jisseki_contents > li .contents_list > dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 13px 20px;
  width: 100%;
  min-height: 75px;
  font-size: 1rem;
  color: #fff;
  background: #4482AF;
}

.jisseki_contents > li .contents_list > .update_date {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 96%;
  font-size: 0.875rem;
  color: #666;
  text-align: right;
}

.jisseki_contents > li .contents_list > .cont_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 10px auto 20px auto;
  padding: 0;
  width: 92%;
}

.jisseki_contents > li .contents_list > .cont_body .cont_img {
  margin: 0;
  padding: 0;
  width: 25%;
  height: 160px;
}

.jisseki_contents > li .contents_list > .cont_body .cont_img > img {
  max-width: 100%;
  height: auto;
}

.jisseki_contents > li .contents_list > .cont_body .cont_txt {
  margin: 0;
  padding: 0;
  width: 72%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

/*
* 口コミ評判
*---------------------------------------------------*/
/*
* 一覧ページカテゴリーリスト
*---------------------------------------------------*/
.voice_category_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 30px 50px;
  width: 100%;
  background: #F5F2ED;
}

.voice_category_list::after {
  content: "";
  display: block;
  width: 32.6666666667%;
}

.voice_category_list li {
  margin: 0 0 30px 0;
  padding: 0;
  width: 32.6666666667%;
  /* border: 1px solid #fff; */
}

.voice_category_list li .vc_contents {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

.voice_category_list li .vc_contents dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 6px 15px;
  width: 100%;
  min-height: 40px;
  font-size: 1rem;
  color: #fff;
}

.voice_category_list li .vc_contents dd {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 160px;
  overflow: hidden;
}

.voice_category_list li .vc_contents dd > a {
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

.voice_category_list li .vc_contents dd > a:hover > img {
  transform: scale(1.2);
  transition: all 0.3s;
}

.voice_category_list li .vc_contents dd > a > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.voice_category_list li .vc_contents dd.voice_link {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 35px;
}

.voice_category_list li .vc_contents dd.voice_link > a {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #fff;
  text-decoration: none;
  background: #496de4;
}

.voice_category_list li .vc_contents dd.voice_link > a:hover {
  background: #2e4db1;
  transition: all 0.3s;
}

/*
* カテゴリーリスト
*---------------------------------------------------*/
.kouza_category_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 30px auto;
  padding: 30px 50px;
  width: 100%;
  background: #F5F2ED;
}

.kouza_category_list::before {
  content: "";
  display: block;
  width: 24.5%;
  order: 1;
}

.kouza_category_list::after {
  content: "";
  display: block;
  width: 24.5%;
}

.kouza_category_list > li {
  position: relative;
  margin: 0 0 1% 0;
  padding: 0;
  width: 24.5%;
  height: 45px;
}

.kouza_category_list > li:hover .category_kouza_list {
  visibility: visible;
  opacity: 1;
  transition: 0.5s;
}

.kouza_category_list > li > a {
  position: relative;
  display: block;
  margin: 0;
  padding: 0 0 0 10%;
  width: 100%;
  height: 100%;
  font-size: 0.9rem;
  color: #fff;
  line-height: 45px;
  text-decoration: none;
  border-radius: 5px;
}

.kouza_category_list > li > a:hover {
  opacity: 0.8;
}

.kouza_category_list > li > a::after {
  content: "\f107";
  position: absolute;
  top: 50%;
  right: 8%;
  transform: translateY(-50%);
  /* font-weight: 600; */
  font-weight: bold;
  color: #fff;
}

/*
* 口コミ一覧リスト
*---------------------------------------------------*/
/*
* 口コミカテゴリータイトル
*---------------------------------------------------*/
.kuchikomi_category_title_area {
  margin: 0 auto 40px auto;
  padding: 0;
  width: 100%;
}

.kuchikomi_category_title_area .kuchikomi_category_title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #ff720e;
  text-align: center;
}

.kuchikomi_category_title_area .kuchikomi_category_title::before {
  margin-right: 15px;
  content: "\f4ff";
  font-size: 2.5rem;
  /* font-weight: 600; */
  font-weight: bold;
  color: #ebbc39;
}

.kuchikomi_category_title_area .kuchikomi_en_title {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.5rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #e02d1a;
  text-align: center;
}

/*
* 口コミリスト
*---------------------------------------------------*/
.kuchikomi_list {
  margin: 0 auto 30px auto;
  padding: 0;
  width: 100%;
  background: #fff;
}

.kuchikomi_list .kuchikomi_title {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 50px;
  width: 100%;
  height: 60px;
  font-size: 1.375rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #835808;
  background: #EADEB8;
}

.kuchikomi_list .kuchikomi_title::before {
  margin-right: 13px;
  content: "\f086";
  font-size: 1.75rem;
  /* font-weight: 600; */
  font-weight: bold;
}

.kuchikomi_list .kuchikomi_title::after {
  /* content: '講座の口コミ評判'; */
  content: "講座の受講生の声";
}

.kuchikomi_list .kuchikomi_body {
  margin: 0;
  padding: 25px 40px;
  width: 100%;
}

.kuchikomi_list .kuchikomi_body .body_inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile {
  margin: 0;
  padding: 0;
  width: 23%;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_photo {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 180px;
  overflow: hidden;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_photo > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_name {
  margin: 0;
  padding: 20px 0 0 0;
  width: 100%;
  font-size: 1.5rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #4D1F06;
  text-align: center;
  background: #FDF4F4;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_name::after {
  content: "さん";
  font-size: 1.125rem;
}

.kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_age {
  margin: 0;
  padding: 0 0 25px 0;
  width: 100%;
  font-size: 1rem;
  color: #4d1f06;
  text-align: center;
  background: #fdf4f4;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt {
  margin: 0;
  padding: 0;
  width: 74%;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_lead {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 80px;
  font-size: 1.375rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #d6580a;
  line-height: 2rem;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li {
  margin: 0;
  padding: 0;
  width: 49%;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body {
  margin: 0;
  padding: 0;
  width: 100%;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 30px;
  width: 100%;
  height: 40px;
  font-size: 1.125rem;
  color: #4D1F02;
  background: #F8E9DF;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dt::before {
  margin-right: 12px;
  content: "\f4ad";
  font-size: 1.5rem;
  color: #c91740;
}

.kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dd {
  margin: 0 0 20px 0;
  padding: 15px 10px;
  width: 100%;
  font-size: 0.9375rem;
  color: #333;
  line-height: 1.6rem;
}

.kuchikomi_list .kuchikomi_body .link_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  margin: 10px auto 0 auto;
  padding: 20px 0 0 0;
  width: 100%;
  border-top: 1px solid #ddd;
}

.kuchikomi_list .kuchikomi_body .link_area > li {
  margin: 0;
  padding: 0;
  width: 320px;
}

.kuchikomi_list .kuchikomi_body .link_area > li + li {
  margin-left: 15px;
}

.kuchikomi_list .kuchikomi_body .link_area > li > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 40px;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  text-decoration: none;
  border-radius: 5px;
}

.kuchikomi_list .kuchikomi_body .link_area > li > a::after {
  position: absolute;
  top: 50%;
  right: 7%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.kuchikomi_list .kuchikomi_body .link_area .kouza_link > a {
  background: #AF7406;
}

.kuchikomi_list .kuchikomi_body .link_area .kouza_link > a::before {
  margin-right: 10px;
  content: "\f0eb";
  font-size: 1.25rem;
}

.kuchikomi_list .kuchikomi_body .link_area .kouza_link > a:hover {
  background: #8b5c05;
}

.kuchikomi_list .kuchikomi_body .link_area .more_kuchikomi > a {
  background: #0F9050;
}

.kuchikomi_list .kuchikomi_body .link_area .more_kuchikomi > a::before {
  margin-right: 10px;
  content: "\f086";
  font-size: 1.25rem;
  /* font-weight: 600; */
  font-weight: bold;
}

.kuchikomi_list .kuchikomi_body .link_area .more_kuchikomi > a:hover {
  background: #0b7540;
}

/*
* 受講サポート
*---------------------------------------------------*/
/*
* サポートイラスト
*---------------------------------------------------*/
.support_illust {
  margin: 0;
  padding: 0;
  width: 15%;
  border-radius: 5px;
  text-align: right;
}

.support_illust > img {
  max-width: 90%;
  height: auto;
}

/*
* スクールアピール（ここが違う！）
*---------------------------------------------------*/
.support_school_appeal {
  position: relative;
  margin: 50px auto 0 auto;
  padding: 40px 40px 0 40px;
  width: 100%;
  background: #fff;
  border-radius: 5px;
}

.support_school_appeal .appeal_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 120px auto -40px auto;
  padding: 0;
  width: 100%;
}

.support_school_appeal .appeal_list li {
  margin: 0 0 50px 0;
  padding: 0 30px 40px 30px;
  width: 49%;
  background: #F2F7FF;
  border-radius: 8px;
}

.support_school_appeal .appeal_list li .appeal_illust {
  margin: -72px auto 0 auto;
  padding: 0;
  width: 144px;
  height: 144px;
}

.support_school_appeal .appeal_list li .appeal_body {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
}

.support_school_appeal .appeal_list li .appeal_body dt {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 70px;
  font-size: 1.375rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #e62d18;
  text-align: center;
  line-height: 2rem;
}

.support_school_appeal .appeal_list li .appeal_body dd {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9375rem;
  color: #555;
  line-height: 1.8rem;
}

/*
* スクールポイント
*---------------------------------------------------*/
.support_list {
  margin: 50px auto 0 auto;
  padding: 50px 0;
  width: 100%;
  background-color: #F7F5FD;
}

.support_list .list_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.support_list .list_contents > li {
  margin: 0;
  padding: 25px;
  width: 32.6666666667%;
  background: #fff;
  border-radius: 5px;
}

.support_list .list_contents > li .contents_body {
  margin: 0;
  padding: 0;
  width: 100%;
}

.support_list .list_contents > li .contents_body > dt {
  margin: 0 0 20px 0;
  padding: 0;
  width: 100%;
  height: 100px;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #205C90;
  line-height: 1.8rem;
  border-bottom: 3px solid #205C90;
}

.support_list .list_contents > li .contents_body .contents_img {
  margin: 0;
  padding: 0;
  width: 100%;
}

.support_list .list_contents > li .contents_body .contents_img > img {
  max-width: 100%;
  height: auto;
}

.support_list .list_contents > li .contents_body .contents_txt {
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.8rem;
}

.support_list .list_contents > li .contents_body .horizontal {
  margin: 0;
  padding: 0;
  width: 100%;
}

.support_list .list_contents > li .contents_body .horizontal .horizontal_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-direction: row-reverse;
  margin: 0;
  padding: 0;
  width: 100%;
}

.support_list .list_contents > li .contents_body .horizontal .horizontal_body .body_img {
  margin: 0;
  padding: 0;
  width: 35%;
}

.support_list .list_contents > li .contents_body .horizontal .horizontal_body .body_img > img {
  max-width: 100%;
  height: auto;
}

.support_list .list_contents > li .contents_body .horizontal .horizontal_body .body_txt {
  margin: 0;
  padding: 0;
  width: 63%;
  font-size: 1rem;
  color: #333;
  line-height: 1.8rem;
}

.support_list .document_txt {
  margin: 40px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.375rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #205C90;
  text-align: center;
  line-height: 2rem;
}

/*
* 無料で資料請求
*---------------------------------------------------*/
.docu_request_area {
  position: relative;
  margin: 0 auto;
  padding: 80px 0 60px 0;
  width: 100%;
  background: #f1eeff;
}

.docu_request_area::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-top: 35px solid #DDD6F0;
  border-left: 50px solid transparent;
  border-right: 50px solid transparent;
}

.docu_request_area .area_inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  width: 80%;
}

.docu_request_area .area_inner .req_txt {
  margin: 0;
  padding: 0;
  width: 60%;
  text-align: center;
}

.docu_request_area .area_inner .req_txt > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #da2727;
}

.docu_request_area .area_inner .req_txt .sub_txt {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
}

.docu_request_area .area_inner .req_txt .req_btn {
  margin: 40px auto 0 auto;
  padding: 0;
  width: 50%;
  border-radius: 5px;
  background: #22993a;
}

.docu_request_area .area_inner .req_txt .req_btn > a {
  position: relative;
  display: block;
  margin: 0;
  padding: 15px 20px 15px 10px;
  width: 100%;
  height: 100%;
  font-size: 1.375rem;
  color: #fff;
  text-decoration: none;
  border-radius: 5px;
}

.docu_request_area .area_inner .req_txt .req_btn > a::before {
  margin-right: 15px;
  content: "\f5da";
  /* font-weight: 600; */
  font-weight: bold;
}

.docu_request_area .area_inner .req_txt .req_btn > a::after {
  position: absolute;
  top: 50%;
  right: 7%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.docu_request_area .area_inner .req_txt .req_btn > a:hover {
  background: #1b8631;
}

.docu_request_area .area_inner .req_txt .guidebook {
  margin: 40px auto 0 auto;
  padding: 30px 40px;
  width: 80%;
  background: #e9e6fc;
  border-radius: 5px;
}

.docu_request_area .area_inner .req_txt .guidebook .guidebook_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
}

.docu_request_area .area_inner .req_txt .guidebook .guidebook_body .book_img {
  margin: 0;
  padding: 0;
  width: 25%;
}

.docu_request_area .area_inner .req_txt .guidebook .guidebook_body .book_img > img {
  max-width: 100%;
  height: auto;
}

.docu_request_area .area_inner .req_txt .guidebook .guidebook_body .book_txt {
  margin: 0;
  padding: 0;
  width: 69%;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #0068b7;
  line-height: 1.8rem;
  text-align: left;
}

.docu_request_area .area_inner .pamphlet_img {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 40%;
}

/*
* 受講生専用ページ
*---------------------------------------------------*/
/*
* コンテンツエリア
*---------------------------------------------------*/
.student_support {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 92%;
  background: #fff;
  border-radius: 5px;
}

/*
* カテゴリータイトル
*---------------------------------------------------*/
.st_category_title {
  position: relative;
  margin: 0 auto;
  padding: 0 0 10px 15px;
  width: 100%;
  font-size: 1.625rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #000;
  border-bottom: 3px solid #ddd;
}

.st_category_title:not(:first-child) {
  margin-top: 60px;
}

.st_category_title::before {
  content: "\f51c";
  margin-right: 15px;
  font-size: 2.0625rem;
  color: #0068b7;
  /* font-weight: 600; */
  font-weight: bold;
}

/*
* サポートリスト
*---------------------------------------------------*/
.st_support_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 70px auto 0 auto;
  padding: 0;
  width: 90%;
}

.st_support_list > li {
  margin: 0;
  padding: 30px 40px;
  width: 49%;
  background: #fdfbf5;
  border: 1px solid #eee;
  border-radius: 5px;
}

.st_support_list > li .support_illust {
  display: flex;
  justify-content: center;
  margin: -60px auto 10px auto;
  padding: 0;
  width: 100%;
  height: 100px;
}

.st_support_list > li .list_body {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.st_support_list > li .list_body > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.375rem;
  color: #965e14;
  text-align: center;
}

.st_support_list > li .list_body > .list_txt {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.st_support_list > li .list_body .link_btn_area {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.st_support_list > li .list_body .link_btn_area .link_btn {
  position: relative;
  margin: 0;
  padding: 10px 30px;
  width: 60%;
  font-size: 1rem;
  color: #fff;
  border: none;
  border-radius: 5px;
  background: #215394;
  cursor: pointer;
}

.st_support_list > li .list_body .link_btn_area .link_btn::after {
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
}

.st_support_list > li .list_body .link_btn_area .link_btn:hover {
  background: #2c64ad;
  transition: all 0.3s;
}

/*
* 人気資格ランキング
*---------------------------------------------------*/
/*
* ランキングタイトル
*---------------------------------------------------*/
.ranking_title_area {
  margin: 0 auto 40px auto;
  padding: 0;
  width: 100%;
}

.ranking_title_area .ranking_title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #ff720e;
  text-align: center;
}

.ranking_title_area .ranking_title .title_head_img {
  margin-top: -3px;
  margin-right: 10px;
}

.ranking_title_area .ranking_en_title {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.5rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #e02d1a;
  text-align: center;
}

/*
* ランキングページタイトル
*--------------------------------------------*/
.ranking_page_title {
  margin: 0 auto 40px auto;
  padding: 0;
  width: 92%;
}

.ranking_page_title .main_title {
  margin: 0 0 10px 0;
  padding: 0;
  width: 100%;
  font-size: 1.75rem;
  font-weight: bold;
  color: #fc840b;
}

.ranking_page_title .title_lead {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #b96817;
  line-height: 1.8rem;
}

.one_column_title.mt80 {
  margin-top: 50px;
}

/*
* ランキングカテゴリーリスト
*---------------------------------------------------*/
/* .ranking_category_list {
	margin: 0 auto 40px auto;
	padding: 30px 0;
	width: 100%;
	background-color: #FAF9F0;
	border-radius: 5px;
}

.ranking_category_list .category_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	padding: 0;
	width: 92%;
}

.ranking_category_list .category_list li {
	margin: 0 0 1% 0;
	padding: 0;
	width: calc(98% / 4);
	height: 110px;
	border-radius: 5px;
}

.ranking_category_list .category_list li > a {
	position: relative;
	display: block;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
	border-radius: 5px;
	overflow: hidden;
}

.ranking_category_list .category_list li > a:hover > .ranking_title {
	background: rgba(18, 55, 75, 0.8);
	transition: ease-in-out 0.3s;
}

.ranking_category_list .category_list li > a .list_img {
	margin: 0;
	padding: 0;
	width: 100%;
}

.ranking_category_list .category_list li > a .list_img > img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	min-width: 100%;
	min-height: 100%;
}

.ranking_category_list .category_list li > a .ranking_title {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 90%;
	left: 50%;
	transform: translate(-50%, -90%);
	margin: 0 auto;
	padding: 0;
	width: 96%;
	height: 60px;
	font-size: 0.9375rem;
	color: #fff;
	text-align: center;
	background: rgba(18, 55, 75, 0.5);
	border-radius: 5px;
	z-index: 1;
} */
.ranking_category_list {
  /* display: flex;
  flex-wrap: wrap;
  justify-content: space-between; */
  /* margin: 0 auto 40px auto; */
  margin: 40px auto 0 auto;
  padding: 15px 15px 10px 15px;
  /* width: 92%; */
  width: 100%;
  background-color: #FAF9F0;
  border-radius: 5px;
}

.ranking_category_list.rank30_page {
  width: 84%;
}

/* .ranking_category_list .category_list_main {
	margin: 0;
	padding: 0;
	width: 30%;
}

.ranking_category_list .category_list_main > li {
	display: block;
	margin: 0 0 5px 0;
	padding: 0;
	width: 100%;
	height: 49%;
}

.ranking_category_list .category_list_main > li > a {
	position: relative;
	display: block;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
	border-radius: 5px;
	overflow: hidden;
}

.ranking_category_list .category_list_main > li > a:hover > .ranking_title {
	background: rgba(18, 55, 75, 0.8);
	transition: ease-in-out 0.3s;
}

.ranking_category_list .category_list_main > li > a .list_img {
	margin: 0;
	padding: 0;
	width: 100%;
	height: 100%;
}

.ranking_category_list .category_list_main > li > a .list_img > img {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	min-width: 100%;
	min-height: 100%;
}

.ranking_category_list .category_list_main > li > a .ranking_title {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 90%;
	left: 50%;
	transform: translate(-50%, -90%);
	margin: 0 auto;
	padding: 0;
	width: 96%;
	height: 60px;
	font-size: 1rem;
	color: #fff;
	text-align: center;
	background: rgba(18, 55, 75, 0.5);
	border-radius: 5px;
	z-index: 1;
} */
.ranking_category_list .category_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_category_list .category_list li {
  margin: 0 0 6px 0;
  padding: 0;
  width: 19.6%;
  height: 110px;
  border-radius: 5px;
}

.ranking_category_list .category_list li > a {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  border-radius: 5px;
  overflow: hidden;
}

.ranking_category_list .category_list li > a:hover > .ranking_title {
  background: rgba(18, 55, 75, 0.8);
  transition: ease-in-out 0.3s;
}

.ranking_category_list .category_list li > a .list_img {
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_category_list .category_list li > a .list_img > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.ranking_category_list .category_list li > a .ranking_title {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 90%;
  left: 50%;
  transform: translate(-50%, -90%);
  margin: 0 auto;
  padding: 0;
  width: 96%;
  height: 60px;
  font-size: 0.9375rem;
  color: #fff;
  text-align: center;
  background: rgba(18, 55, 75, 0.5);
  border-radius: 5px;
  z-index: 1;
}

/*
* ランキングリスト
*---------------------------------------------------*/
/* 1〜3位 */
.ranking_contents {
  margin: 0 auto 30px auto;
  padding: 15px 0 0 0;
  width: 100%;
  background: #fff;
  border-radius: 5px;
}

.ranking_contents .contents_title_area {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #f7e99f;
}

.ranking_contents .contents_title_area .ranking_no {
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 7px 0;
  width: 13%;
  height: 80px;
  color: #fff;
  text-align: center;
  line-height: 80px;
  vertical-align: middle;
  box-sizing: border-box;
}

.ranking_contents .contents_title_area .ranking_no::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 0px;
  height: 0px;
  border-width: 40px 20px 40px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
  z-index: 1;
}

.ranking_contents .contents_title_area .ranking_no .rank_num {
  margin: 0;
  padding: 0 15px 0 0;
  font-size: 3.125rem;
  line-height: 53px;
  vertical-align: middle;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.ranking_contents .contents_title_area .ranking_no .rank_num::after {
  margin-left: 5px;
  content: "位";
  font-size: 1.625rem;
}

.ranking_contents .contents_title_area .title_area {
  margin: 0 3% 0 0;
  padding: 0;
  width: 81%;
}

.ranking_contents .contents_title_area .title_area .kouza_category {
  margin: 0;
  padding: 1px 0 3px 0;
  width: 35%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}

.ranking_contents .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #a37303;
}

.ranking_contents .detail_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}

.ranking_contents .detail_area .photo_course {
  margin: 0;
  padding: 0;
  width: 38%;
}

.ranking_contents .detail_area .photo_course dt {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 260px;
  overflow: hidden;
}

.ranking_contents .detail_area .photo_course dt > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.ranking_contents .detail_area .photo_course dd {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}

.ranking_contents .detail_area .photo_course dd .course_info {
  margin: 0;
  padding: 0;
  width: 100%;
  border-collapse: collapse;
}

.ranking_contents .detail_area .photo_course dd .course_info tr:last-child th,
.ranking_contents .detail_area .photo_course dd .course_info tr:last-child td {
  border-bottom: none;
}

.ranking_contents .detail_area .photo_course dd .course_info th {
  margin: 0;
  padding: 3px 15px;
  width: 42%;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #fff;
  text-align: left;
  border-bottom: 5px solid #fff;
}

.ranking_contents .detail_area .photo_course dd .course_info .term {
  background: #070A69;
}

.ranking_contents .detail_area .photo_course dd .course_info .term::before {
  margin-right: 10px;
  content: "\f073";
}

.ranking_contents .detail_area .photo_course dd .course_info .course {
  background: #69094F;
}

.ranking_contents .detail_area .photo_course dd .course_info .course::before {
  margin-right: 10px;
  content: "\f157";
  /* font-weight: 600; */
  font-weight: bold;
}

.ranking_contents .detail_area .photo_course dd .course_info td {
  margin: 0;
  padding: 3px 20px 3px 10px;
  width: 58%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  background: #fff;
  border-bottom: 5px solid #fff;
}

.ranking_contents .detail_area .photo_course dd .course_info td .special_exam {
  margin: 0 0 0 10px;
  padding: 2px 10px 4px 10px;
  font-size: 0.75rem;
  color: #dd2424;
  text-align: center;
  background: #F7ECEC;
}

.ranking_contents .detail_area .photo_course dd .course_info .term_txt .saitan {
  font-size: 0.875rem;
}

.ranking_contents .detail_area .photo_course dd .course_info .course_fee {
  color: #df2020;
}

.ranking_contents .detail_area .txt_contents {
  margin: 0;
  padding: 0;
  width: 58%;
}

.ranking_contents .detail_area .txt_contents .kouza_summary {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #a37303;
  line-height: 2rem;
}

.ranking_contents .detail_area .txt_contents .get_shikaku_title {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #574D17;
}

.ranking_contents .detail_area .txt_contents .get_shikaku_title > i {
  margin-right: 10px;
  color: #574D17;
}

.ranking_contents .detail_area .txt_contents .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 7px 0 0 0;
  padding: 0;
  width: 100%;
}

.ranking_contents .detail_area .txt_contents .get_shikaku_list li {
  margin: 0 0 5px 0;
  padding: 8px 0;
  width: 49.5%;
  font-size: 0.95rem;
  font-weight: normal;
  color: #000;
  text-align: center;
  background: #f5ece4;
  border-radius: 5px;
}

.ranking_contents .detail_area .txt_contents .kouza_explain {
  margin: 30px 0 0 0;
  padding: 20px 30px;
  width: 100%;
  font-size: 0.875rem;
  font-weight: normal;
  color: #555;
  line-height: 1.6rem;
  background: #F9F9EE;
}

.ranking_contents .detail_area .txt_contents .kouza_explain_2 {
  margin: 7px 0 0 0;
  padding: 20px 30px;
  width: 100%;
  font-size: 0.875rem;
  font-weight: normal;
  color: #555;
  line-height: 1.6rem;
  background: #F9F9EE;
}

.ranking_contents .detail_area .txt_contents .link_btn {
  display: flex;
  justify-content: space-between;
  margin: 25px 0 0 0;
  padding: 0 0 0 15%;
  width: 100%;
}

.ranking_contents .detail_area .txt_contents .link_btn .detail_link {
  margin: 0;
  width: 250px;
  height: 40px;
}

.ranking_contents .detail_area .txt_contents .link_btn .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}

.ranking_contents .detail_area .txt_contents .link_btn .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_contents .detail_area .txt_contents .link_btn .detail_link > a:hover {
  background: #996606;
}

.ranking_contents .detail_area .txt_contents .link_btn .document_link {
  margin: 0;
  width: 250px;
  height: 40px;
}

.ranking_contents .detail_area .txt_contents .link_btn .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}

.ranking_contents .detail_area .txt_contents .link_btn .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  font-weight: 600;
}

.ranking_contents .detail_area .txt_contents .link_btn .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_contents .detail_area .txt_contents .link_btn .document_link > a:hover {
  background: #1b8631;
}

/* 202310追記 */
.ranking_contents .kouza_point_area {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 95%;
}

.ranking_contents .kouza_point_area .kouza_title {
  margin: 0;
  padding: 2px 0;
  width: 100%;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  /* background: #1c8060; */
}

.ranking_contents .kouza_point_area .kouza_title .rank_num {
  position: relative;
  display: inline-block;
  margin: 0 30px 0 0;
  padding: 0 0 0 50px;
  letter-spacing: 0.2rem;
  background-image: url("../images/ranking/icon_crown_white.svg");
  background-size: 40px;
  background-repeat: no-repeat;
  background-position: left center;
}

.ranking_contents .kouza_point_area .point_inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 96%;
}

.ranking_contents .kouza_point_area .point_inner .recommend_point {
  margin: 0;
  padding: 0;
  width: 60%;
}

.ranking_contents .kouza_point_area .point_inner .recommend_point .recommend_title {
  margin: 0 auto 20px auto;
  padding: 0;
  width: 78%;
  height: 58px;
  font-size: 1.8rem;
  font-weight: bold;
  color: #333;
  text-align: center;
  background-image: url("../images/ranking/background_ribbon.svg");
  background-repeat: no-repeat;
  background-size: 100%;
}

.ranking_contents .kouza_point_area .point_inner .recommend_point .point_cont {
  margin: 0 auto 14px auto;
  padding: 0 0 0 50px;
  width: 96%;
  font-size: 1.4rem;
  font-weight: 600;
  color: #222;
  background-image: url("../images/ranking/icon_checkmark.svg");
  background-repeat: no-repeat;
  background-size: 40px;
  background-position: center left;
}

.ranking_contents .kouza_point_area .point_inner .point_img {
  margin: 0;
  padding: 0;
  width: 40%;
}

.ranking_contents .kouza_point_area .point_inner .point_img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  /* height: 100%; */
  height: auto;
}

/* 202404追記 */
.kouza_popular_point {
  margin: 16px auto 0 auto;
  padding: 0;
  width: 100%;
}
.kouza_popular_point .kouza_title {
  margin: 0;
  padding: 0.3em 0;
  width: 100%;
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #A87D4E;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .kouza_title {
    padding: 0.7em 0 0.3em 0;
    font-size: 1rem;
  }
}
.kouza_popular_point .kouza_title::before {
  content: "";
  display: inline-block;
  margin: 0 20px 0 0;
  padding: 0;
  width: 40px;
  height: 34px;
  background-image: url("../images/ranking/icon_crown_white.svg");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .kouza_title::before {
    margin-right: 8px;
    width: 34px;
    height: 28px;
  }
}
.kouza_popular_point .point_inner {
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 96%;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner {
    gap: 0;
  }
}
.kouza_popular_point .point_inner .point_img {
  margin: 0;
  padding: 0;
  width: 50%;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .point_img {
    width: 100%;
  }
}
.kouza_popular_point .point_inner .point_img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.kouza_popular_point .point_inner .recommend_area {
  margin: 0;
  padding: 0;
  width: 48%;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .recommend_area {
    margin-top: 16px;
    width: 100%;
  }
}
.kouza_popular_point .point_inner .recommend_area .recommend_point {
  margin: 0;
  padding: 0;
  width: 100%;
}
.kouza_popular_point .point_inner .recommend_area .recommend_point .point_list {
  margin: 0 auto;
  padding: 0;
  width: 96%;
  font-size: 1.2rem;
  font-weight: 600;
  color: #222;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .recommend_area .recommend_point .point_list {
    font-size: 1rem;
  }
}
.kouza_popular_point .point_inner .recommend_area .recommend_point .point_list::before {
  content: "";
  display: inline-block;
  margin: 0 10px 0 0;
  padding: 0;
  width: 34px;
  height: 34px;
  background-image: url("../images/ranking/icon_flowerring.png");
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .recommend_area .recommend_point .point_list::before {
    width: 28px;
    height: 28px;
  }
}
.kouza_popular_point .point_inner .recommend_area .recommend_point .point_list:not(:last-child) {
  margin-bottom: 8px;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .recommend_area .recommend_point .point_list:not(:last-child) {
    margin-bottom: 6px;
  }
}
.kouza_popular_point .point_inner .recommend_area .point_summary {
  margin: 16px auto 0 auto;
  padding: 1.5em;
  width: 96%;
  font-size: 1rem;
  color: #222;
  line-height: 1.4rem;
  border-radius: 8px;
  background: #F2ECE5;
}
@media screen and (max-width: 480px) {
  .kouza_popular_point .point_inner .recommend_area .point_summary {
    width: 100%;
  }
}

/* // 202404追記 */
/* 202407追記・修正 */
.ranking_contents_new {
  margin: 0 auto 30px auto;
  padding: 15px 0 0 0;
  width: 100%;
  background: #fff;
  border-radius: 5px;
}
.ranking_contents_new .contents_title_area {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  margin: 0;
  padding: 0 2em 10px 2em;
  border-bottom: 1px solid #f7e99f;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .contents_title_area {
    padding: 0 1em 10px 1em;
  }
}
.ranking_contents_new .contents_title_area .title_area {
  margin: 0;
  padding: 0;
  width: 100%;
}
.ranking_contents_new .contents_title_area .title_area .kouza_category {
  margin: 0;
  padding: 1px 0 3px 0;
  width: 35%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .contents_title_area .title_area .kouza_category {
    width: 60%;
    font-size: 0.9rem;
  }
}
.ranking_contents_new .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 2rem;
  font-weight: bold;
  color: #a37303;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .contents_title_area .title_area .kouza_name {
    font-size: 1.6rem;
  }
}
.ranking_contents_new .detail_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area {
    padding: 20px 16px;
  }
}
.ranking_contents_new .detail_area .photo_course {
  margin: 0;
  padding: 0;
  width: 38%;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .photo_course {
    width: 100%;
  }
}
.ranking_contents_new .detail_area .photo_course > dt {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 260px;
  overflow: hidden;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .photo_course > dt {
    height: 180px;
  }
}
.ranking_contents_new .detail_area .photo_course > dt > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.ranking_contents_new .detail_area .photo_course > dd {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info {
  margin: 0;
  padding: 0;
  width: 100%;
  border-collapse: collapse;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info tr:last-child th,
.ranking_contents_new .detail_area .photo_course > dd .course_info tr:last-child td {
  border-bottom: none;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info th {
  margin: 0;
  padding: 3px 15px;
  width: 42%;
  font-size: 0.9rem;
  font-weight: 400;
  color: #fff;
  text-align: left;
  border-bottom: 5px solid #fff;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .term {
  background: #070A69;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .term::before {
  margin-right: 10px;
  content: "\f073";
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .course {
  background: #69094F;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .course::before {
  margin-right: 10px;
  content: "\f157";
  /* font-weight: 600; */
  font-weight: bold;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info td {
  margin: 0;
  padding: 3px 20px 3px 10px;
  width: 58%;
  font-size: 1.125rem;
  font-weight: bold;
  background: #fff;
  border-bottom: 5px solid #fff;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info td .special_exam {
  margin: 0 0 0 10px;
  padding: 2px 10px 4px 10px;
  font-size: 0.75rem;
  color: #dd2424;
  text-align: center;
  background: #F7ECEC;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .term_txt .saitan {
  font-size: 0.875rem;
}
.ranking_contents_new .detail_area .photo_course > dd .course_info .course_fee {
  color: #df2020;
}
.ranking_contents_new .detail_area .txt_contents {
  margin: 0;
  padding: 0;
  width: 58%;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents {
    width: 100%;
  }
}
.ranking_contents_new .detail_area .txt_contents .get_shikaku_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #574D17;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .get_shikaku_title {
    margin-top: 16px;
  }
}
.ranking_contents_new .detail_area .txt_contents .get_shikaku_title:nth-of-type(2n) {
  margin-top: 16px;
}
.ranking_contents_new .detail_area .txt_contents .get_shikaku_title > i {
  margin-right: 10px;
  color: #574D17;
}
.ranking_contents_new .detail_area .txt_contents .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 7px 0 0 0;
  padding: 0;
  width: 100%;
}
.ranking_contents_new .detail_area .txt_contents .get_shikaku_list > li {
  margin: 0 0 5px 0;
  padding: 8px 0;
  width: 49.5%;
  font-size: 0.95rem;
  font-weight: normal;
  color: #000;
  text-align: center;
  background: #f5ece4;
  border-radius: 5px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .get_shikaku_list > li {
    width: 100%;
    font-size: 0.9rem;
  }
}
.ranking_contents_new .detail_area .txt_contents .kouza_explain {
  margin: 7px 0 0 0;
  padding: 20px 30px;
  width: 100%;
  font-size: 0.875rem;
  font-weight: normal;
  color: #555;
  line-height: 1.6rem;
  background: #F9F9EE;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .kouza_explain {
    padding: 1.2em 1em;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn {
  display: flex;
  justify-content: space-between;
  margin: 25px 0 16px 0;
  padding: 0 0 0 15%;
  width: 100%;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn {
    margin: 16px 0 0 0;
    padding: 0;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .detail_link {
  margin: 0;
  width: 250px;
  height: 40px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .detail_link {
    width: 48%;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .detail_link > a {
    font-size: 0.9rem;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .detail_link > a::after {
    right: 6%;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .detail_link > a:hover {
  background: #996606;
}
.ranking_contents_new .detail_area .txt_contents .link_btn .document_link {
  margin: 0;
  width: 250px;
  height: 40px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .document_link {
    width: 48%;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a {
    font-size: 0.9rem;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  font-weight: 600;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a::before {
    margin-right: 6px;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}
@media screen and (max-width: 480px) {
  .ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a::after {
    right: 5%;
  }
}
.ranking_contents_new .detail_area .txt_contents .link_btn .document_link > a:hover {
  background: #1b8631;
}

.page_conclusion {
  margin: 20px auto;
  padding: 1.5em 2em;
  width: 100%;
  font-size: 0.95rem;
  color: #333;
  line-height: 1.6rem;
  background: #fbfeff;
}
@media screen and (max-width: 480px) {
  .page_conclusion {
    margin-top: 10px;
    font-size: 0.9rem;
  }
}

/* 202407追記・修正ここまで */
/*
* リライトページ
*-------------------------*/
.kouza_img {
  display: block;
  margin: 0 auto;
  padding: 10px 30px;
  width: 100%;
}

.kouza_img > img {
  width: 100%;
  height: 100%;
}

.ranking_contents .link_btn_new {
  display: flex;
  justify-content: flex-end;
  margin: 25px 0 0 0;
  padding: 10px 15px;
  width: 100%;
  background: #f0f0f0;
}

.ranking_contents .link_btn_new .detail_link {
  margin: 0 10px 0 0;
  width: 250px;
  height: 40px;
}

.ranking_contents .link_btn_new .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}

.ranking_contents .link_btn_new .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_contents .link_btn_new .detail_link > a:hover {
  background: #996606;
}

.ranking_contents .link_btn_new .document_link {
  margin: 0;
  width: 250px;
  height: 40px;
}

.ranking_contents .link_btn_new .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}

.ranking_contents .link_btn_new .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  font-weight: bold;
}

.ranking_contents .link_btn_new .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_contents .link_btn_new .document_link > a:hover {
  background: #1b8631;
}

/* 4位〜5位 */
.next_ranking {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.next_ranking li {
  margin: 0;
  padding: 0;
  width: 49%;
}

.next_ranking li .next_ranking_contents {
  margin: 0 auto 30px auto;
  padding: 15px 0;
  width: 100%;
  background: #fff;
  border: 2px solid #2F91B5;
  border-radius: 5px;
}

.next_ranking li .next_ranking_contents .contents_title_area {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #f7e99f;
}

.next_ranking li .next_ranking_contents .contents_title_area .ranking_no {
  position: relative;
  display: inline-block;
  margin: 0;
  padding: 7px 0;
  width: 23%;
  height: 70px;
  color: #fff;
  text-align: center;
  line-height: 70px;
  vertical-align: middle;
  box-sizing: border-box;
  background: #2F91B5;
}

.next_ranking li .next_ranking_contents .contents_title_area .ranking_no::after {
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 0px;
  height: 0px;
  border-width: 35px 20px 35px 0px;
  border-color: transparent #fff transparent transparent;
  border-style: solid;
  z-index: 1;
}

.next_ranking li .next_ranking_contents .contents_title_area .ranking_no .rank_num {
  margin: 0;
  padding: 0 15px 0 0;
  font-size: 2.75rem;
  line-height: 45px;
  vertical-align: middle;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.next_ranking li .next_ranking_contents .contents_title_area .ranking_no .rank_num::after {
  margin-left: 3px;
  content: "位";
  font-size: 1.375rem;
}

.next_ranking li .next_ranking_contents .contents_title_area .title_area {
  margin: 0 3% 0 0;
  padding: 0;
  width: 72%;
}

.next_ranking li .next_ranking_contents .contents_title_area .title_area .kouza_category {
  margin: 8px 0 0 0;
  padding: 1px 0 3px 0;
  width: 60%;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}

.next_ranking li .next_ranking_contents .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #a37303;
}

.next_ranking li .next_ranking_contents .detail_area {
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}

.next_ranking li .next_ranking_contents .detail_area .kouza_photo {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 140px;
  overflow: hidden;
}

.next_ranking li .next_ranking_contents .detail_area .kouza_photo > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.next_ranking li .next_ranking_contents .detail_area .kouza_summary {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #2F91B5;
  line-height: 2rem;
}

.next_ranking li .next_ranking_contents .detail_area .get_shikaku_title {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #574D17;
}

.next_ranking li .next_ranking_contents .detail_area .get_shikaku_title > i {
  margin-right: 10px;
  color: #574D17;
}

.next_ranking li .next_ranking_contents .detail_area .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 7px 0 0 0;
  padding: 0;
  width: 100%;
}

.next_ranking li .next_ranking_contents .detail_area .get_shikaku_list li {
  margin: 0;
  padding: 8px 0;
  width: 49%;
  font-size: 0.8125rem;
  font-weight: normal;
  color: #333333;
  text-align: center;
  background: #f5ece4;
  border-radius: 5px;
}

.next_ranking li .next_ranking_contents .detail_area .course_info {
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
  border-collapse: collapse;
}

.next_ranking li .next_ranking_contents .detail_area .course_info tr:last-child th,
.next_ranking li .next_ranking_contents .detail_area .course_info tr:last-child td {
  border-bottom: none;
}

.next_ranking li .next_ranking_contents .detail_area .course_info th {
  margin: 0;
  padding: 3px 15px;
  width: 44%;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #fff;
  text-align: left;
  border-bottom: 5px solid #fff;
}

.next_ranking li .next_ranking_contents .detail_area .course_info th > i {
  margin-right: 30px;
  font-size: 1rem;
}

.next_ranking li .next_ranking_contents .detail_area .course_info .term {
  background: #070A69;
}

.next_ranking li .next_ranking_contents .detail_area .course_info .term::before {
  margin-right: 10px;
  content: "\f073";
}

.next_ranking li .next_ranking_contents .detail_area .course_info .course {
  background: #69094F;
}

.next_ranking li .next_ranking_contents .detail_area .course_info .course::before {
  margin-right: 10px;
  content: "\f157";
  /* font-weight: 600; */
  font-weight: bold;
}

.next_ranking li .next_ranking_contents .detail_area .course_info td {
  margin: 0;
  padding: 3px 20px;
  width: 56%;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  background: #fff;
  border-bottom: 5px solid #fff;
}

.next_ranking li .next_ranking_contents .detail_area .course_info td .special_exam {
  margin: 0 0 0 10px;
  padding: 2px 10px 4px 10px;
  font-size: 0.75rem;
  color: #dd2424;
  text-align: center;
  background: #F7ECEC;
}

.next_ranking li .next_ranking_contents .detail_area .course_info .term_txt .saitan {
  font-size: 0.875rem;
}

.next_ranking li .next_ranking_contents .detail_area .course_info .course_fee {
  color: #df2020;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn {
  display: flex;
  justify-content: space-between;
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .detail_link {
  margin: 0;
  width: 49%;
  height: 40px;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .detail_link > a:hover {
  background: #996606;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .document_link {
  margin: 0;
  width: 49%;
  height: 40px;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  /* font-weight: 600; */
  font-weight: bold;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.next_ranking li .next_ranking_contents .detail_area .link_btn .document_link > a:hover {
  background: #1b8631;
}

.rank_01 {
  border: 2px solid #eece41;
}

.rank_01 .ranking_no {
  background: #eece41;
}

.rank_02 {
  border: 2px solid #ACACAC;
}

.rank_02 .ranking_no {
  background: #ACACAC;
}

.rank_03 {
  border: 2px solid #B57C2F;
}

.rank_03 .ranking_no {
  background: #B57C2F;
}

.rank_04 {
  border: 2px solid #2F91B5;
}

.rank_04 .ranking_no {
  background: #2F91B5;
}

.rank_05 {
  border: 2px solid #2F91B5;
}

.rank_05 .ranking_no {
  background: #2F91B5;
}

/* 202302追記 */
/* 1位〜10位 */
.ranking_top30_1-20 {
  margin: 0 auto 30px auto;
  padding: 15px 0;
  width: 100%;
  background: #fff;
  border-radius: 5px;
  border: 1px solid #3EABB4;
}

.ranking_top30_1-20.ranking_1 {
  border: 2px solid #eece41;
}

.ranking_top30_1-20.ranking_2 {
  border: 2px solid #ACACAC;
}

.ranking_top30_1-20.ranking_3 {
  border: 2px solid #B57C2F;
}

.ranking_top30_1-20.ranking_11-20 {
  border: 1px solid #3E70B4;
}

.ranking_top30_1-20 .contents_title_area {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #f7e99f;
}

.ranking_top30_1-20 .contents_title_area .ranking_no {
  position: relative;
  margin: 0;
  padding: 0;
  width: 160px;
  height: 80px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
}

.ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no {
  position: relative;
  margin: 0;
  padding: 0;
  width: 160px;
  height: 70px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
}

.ranking_top30_1-20.ranking_1 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_01.svg") center no-repeat;
}

.ranking_top30_1-20.ranking_2 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_02.svg") center no-repeat;
}

.ranking_top30_1-20.ranking_3 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_03.svg") center no-repeat;
}

.ranking_top30_1-20.ranking_4-10 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_04-10.svg") center no-repeat;
}

.ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no {
  background: url("../images/ranking/ranking_11-20.svg") center no-repeat;
}

.ranking_top30_1-20 .contents_title_area .ranking_no .rank_num {
  position: absolute;
  left: 40%;
  transform: translateX(-40%);
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 3.2rem;
  font-weight: bold;
}

.ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no .rank_num {
  position: absolute;
  left: 40%;
  transform: translateX(-40%);
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 2.2rem;
  font-weight: bold;
}

.ranking_top30_1-20 .contents_title_area .ranking_no .rank_unit {
  margin: 0 0 0 6px;
  padding: 16px 0 0 0;
  font-size: 1.4rem;
  color: #fff;
}

.ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no .rank_unit {
  margin: 0 0 0 6px;
  padding: 8px 0 0 0;
  font-size: 1.4rem;
  color: #fff;
}

.ranking_top30_1-20 .contents_title_area .title_area {
  margin: 0 3% 0 0;
  padding: 0;
  width: calc(100% - 220px);
}

.ranking_top30_1-20 .contents_title_area .title_area .kouza_category {
  margin: 0;
  padding: 1px 0 3px 0;
  width: 35%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}

.ranking_top30_1-20 .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  font-weight: bold;
  color: #a37303;
}

.ranking_top30_1-20.ranking_11-20 .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.8rem;
  font-weight: bold;
  color: #25418d;
}

.ranking_top30_1-20 .detail_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .photo_course {
  margin: 0;
  padding: 0;
  width: 38%;
}

.ranking_top30_1-20 .detail_area .photo_course dt {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 260px;
  overflow: hidden;
}

.ranking_top30_1-20 .detail_area .photo_course dt > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.ranking_top30_1-20 .detail_area .photo_course dd {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info {
  margin: 0;
  padding: 0;
  width: 100%;
  border-collapse: collapse;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info tr:last-child th,
.ranking_top30_1-20 .detail_area .photo_course dd .course_info tr:last-child td {
  border-bottom: none;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info th {
  margin: 0;
  padding: 3px 15px;
  width: 44%;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #fff;
  text-align: left;
  border-bottom: 5px solid #fff;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .term {
  background: #070A69;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .term::before {
  margin-right: 10px;
  content: "\f073";
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .course {
  background: #69094F;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .course::before {
  margin-right: 10px;
  content: "\f157";
  font-weight: bold;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info td {
  margin: 0;
  padding: 3px 10px;
  width: 56%;
  font-size: 1.125rem;
  font-weight: bold;
  background: #fff;
  border-bottom: 5px solid #fff;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info td .special_exam {
  margin: 0 0 0 10px;
  padding: 2px 10px 4px 10px;
  font-size: 0.75rem;
  color: #dd2424;
  text-align: center;
  background: #F7ECEC;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .term_txt .saitan {
  font-size: 0.875rem;
}

.ranking_top30_1-20 .detail_area .photo_course dd .course_info .course_fee {
  color: #df2020;
}

.ranking_top30_1-20 .detail_area .txt_contents {
  margin: 0;
  padding: 0;
  width: 58%;
}

.ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
  border: 1px solid #BEA13D;
  border-radius: 5px;
  background: #fbf8ed;
}

.ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .get_shikaku_title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  padding: 0;
  width: 70%;
  height: 35px;
  font-size: 0.9rem;
  color: #fff;
  background: #b27948;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .shikaku_list {
  margin: 0;
  padding: 15px;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents li {
  margin: 0;
  padding: 8px 0;
  width: 49%;
  font-size: 0.9rem;
  font-weight: bold;
  color: #682828;
  text-align: center;
  background: #e1d0c2;
  border-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 15px auto 0 auto;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working {
  margin: 0;
  padding: 0 0 15px 0;
  width: 49%;
  background: #fff;
  border: 1px solid #BEA13D;
  border-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend .recommend_title,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working .working_title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 80%;
  height: 30px;
  font-size: 0.9rem;
  color: #fff;
  background: #d2691e;
  overflow: hidden;
  border-bottom-left-radius: 5px;
  border-bottom-right-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend .recommend_cont,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working .working_cont {
  margin: 15px auto 0 auto;
  padding: 0 30px;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working .working_cont .cont_list {
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list > li,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working .working_cont .cont_list > li {
  margin: 0 0 5px 15px;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #444;
  line-height: 1.2rem;
  list-style-type: disc;
  list-style-position: outside;
}

.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend .recommend_cont .cont_list > li:last-child,
.ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working .working_cont .cont_list > li:last-child {
  margin-bottom: 0;
}

.ranking_top30_1-20 .detail_area .kouza_explain_img {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .kouza_explain {
  margin: 20px 0 0 0;
  padding: 20px 30px;
  width: 100%;
  font-size: 0.9rem;
  font-weight: normal;
  color: #555;
  line-height: 1.5rem;
  background: #F9F9EE;
  border-radius: 5px;
}

.ranking_top30_1-20 .detail_area .kouza_explain > br {
  display: block;
  content: "";
  margin-top: 0.6rem;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn {
  display: flex;
  justify-content: space-between;
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .detail_link,
.ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link {
  margin: 0;
  width: 48%;
  height: 50px;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .detail_link > a:hover {
  background: #996606;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  font-weight: bold;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link > a:hover {
  background: #1b8631;
}

/* 21位〜30位 */
.ranking_top30_21-30 {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_21-30 li {
  margin: 0;
  padding: 0;
  width: 49%;
}

.ranking_top30_21-30 li .ranking21-30_contents {
  margin: 0 auto 30px auto;
  padding: 15px 0;
  width: 100%;
  background: #fff;
  border: 1px solid #87B43E;
  border-radius: 5px;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  margin: 0;
  padding: 0 0 10px 0;
  border-bottom: 1px solid #f7e99f;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no {
  position: relative;
  margin: 0;
  padding: 0;
  width: 130px;
  height: 60px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  background: url("../images/ranking/ranking_21-30.svg") center no-repeat;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no .rank_num {
  display: flex;
  align-items: center;
  position: absolute;
  left: 40%;
  transform: translateX(-40%);
  margin: 0;
  padding: 0;
  height: 100%;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no .rank_num::after {
  margin-left: 3px;
  padding-top: 8px;
  content: "位";
  font-size: 1.2rem;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area {
  margin: 0 3% 0 0;
  padding: 0;
  width: 72%;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area .kouza_category {
  margin: 8px 0 0 0;
  padding: 1px 0 3px 0;
  width: 60%;
  font-size: 0.875rem;
  color: #fff;
  text-align: center;
  border-radius: 20px;
}

.ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area .kouza_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.25rem;
  font-weight: bold;
  color: #a37303;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area {
  margin: 0;
  padding: 30px 30px 10px 30px;
  width: 100%;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .kouza_photo {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 140px;
  overflow: hidden;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .kouza_photo > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .kouza_summary {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1.125rem;
  font-weight: bold;
  color: #2F91B5;
  line-height: 2rem;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_title {
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #574D17;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_title > i {
  margin-right: 10px;
  color: #574D17;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 7px 0 0 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_list li {
  margin: 0;
  padding: 8px 0;
  width: 49%;
  font-size: 0.8125rem;
  font-weight: normal;
  color: #333333;
  text-align: center;
  background: #f5ece4;
  border-radius: 5px;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info {
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
  border-collapse: collapse;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info tr:last-child th,
.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info tr:last-child td {
  border-bottom: none;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info th {
  margin: 0;
  padding: 3px 15px;
  width: 44%;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #fff;
  text-align: left;
  border-bottom: 5px solid #fff;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info th > i {
  margin-right: 30px;
  font-size: 1rem;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .term {
  background: #070A69;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .term::before {
  margin-right: 10px;
  content: "\f073";
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .course {
  background: #69094F;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .course::before {
  margin-right: 10px;
  content: "\f157";
  font-weight: bold;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info td {
  margin: 0;
  padding: 3px 20px;
  width: 56%;
  font-size: 1.125rem;
  font-weight: bold;
  background: #fff;
  border-bottom: 5px solid #fff;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info td .special_exam {
  margin: 0 0 0 10px;
  padding: 2px 10px 4px 10px;
  font-size: 0.75rem;
  color: #dd2424;
  text-align: center;
  background: #F7ECEC;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .term_txt .saitan {
  font-size: 0.875rem;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .course_fee {
  color: #df2020;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn {
  display: flex;
  justify-content: space-between;
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .detail_link {
  margin: 0;
  width: 49%;
  height: 40px;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .detail_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #AF7406;
  border-radius: 5px;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .detail_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .detail_link > a:hover {
  background: #996606;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link {
  margin: 0;
  width: 49%;
  height: 40px;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  color: #fff;
  text-decoration: none;
  background: #22993a;
  border-radius: 5px;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link > a::before {
  margin-right: 10px;
  content: "\f5da";
  font-size: 1.25rem;
  font-weight: bold;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  font-weight: bold;
}

.ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link > a:hover {
  background: #1b8631;
}

/* 202302追記ここまで */
/* 202305追記 */
.main_midashi {
  margin: 0 auto;
  padding: 5px 20px;
  width: 90%;
  font-size: 1.6rem;
  font-weight: bold;
  color: #c27905;
  text-align: center;
  background: #f9f0d6;
  /* border-left: 10px solid #c27905; */
}

.section_lead {
  margin: 15px auto;
  padding: 0;
  width: 90%;
  font-size: 1rem;
  color: #000;
  line-height: 1.8rem;
}

.img_midashi {
  margin: 30px auto 15px auto;
  padding: 8px 0;
  width: 80%;
  font-size: 1.4rem;
  font-weight: bold;
  color: #224c9a;
  text-align: center;
  border: 1px solid #224c9a;
}

.syumi_img {
  display: block;
  margin: 0 auto 60px auto;
  padding: 0;
  width: 80%;
}

.ranking_summary {
  margin: 0 auto 30px auto;
  padding: 20px;
  width: 90%;
  font-size: 1.1rem;
  /* font-weight: bold; */
  color: #753908;
  line-height: 1.8rem;
  background: #fcf6f6;
}

/* ランキングタイトル：趣味におすすめ */
.syumi_ranking_title_area {
  margin: 50px auto 30px auto;
  padding: 0;
  width: 100%;
}

.syumi_ranking_title_area .ranking_title {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.125rem;
  font-weight: bold;
  color: #ff720e;
  text-align: center;
}

.syumi_ranking_title_area .ranking_title .title_head_img {
  margin-top: -3px;
  margin-right: 10px;
}

/* 202305追記ここまで */
/* 202310追記 */
.article_area {
  margin: 60px auto 0 auto;
  padding: 0;
  width: 100%;
}

.article_area .ranking_article_title {
  display: flex;
  align-items: center;
  margin: 0 auto;
  padding: 0 20px;
  width: 100%;
  height: 60px;
  font-size: 1.3rem;
  font-weight: bold;
  color: #fff;
  background: #28a239;
  box-sizing: border-box;
}

.article_area .article_img {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  height: 520px;
}

.article_area .article_img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.article_area .article_summary {
  margin: 20px auto 0 auto;
  padding: 20px;
  width: 100%;
  font-size: 1rem;
  color: #222;
  line-height: 1.6rem;
  background: #f0f0f0;
}

.article_area .article_midashi {
  position: relative;
  display: flex;
  align-items: center;
  margin: 30px auto 0 auto;
  padding: 0 20px 0 40px;
  width: 100%;
  height: 40px;
  font-size: 1.1rem;
  font-weight: bold;
  color: #222;
  background: #e6fcf0;
}

.article_area .article_midashi::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
  margin-right: 16px;
  width: 5px;
  height: 80%;
  background: #3a6a51;
}

.article_area .article_body_txt {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 94%;
  font-size: 1rem;
  color: #222;
  line-height: 1.6rem;
}

/* 202310追記ここまで */
/*
* 著作権・免責事項について
*---------------------------------------------------*/
.chosaku_notice {
  margin: 30px auto 0 auto;
  padding: 30px;
  width: 90%;
  border: 1px solid #ddd;
  background: #fff;
}

.chosaku_notice > li {
  margin: 0;
  padding: 0;
  width: 100%;
}

.chosaku_notice > li.japanese {
  font-size: 0.9375rem;
  line-height: 1.6rem;
}

.chosaku_notice > li.english {
  margin-top: 20px;
  font-size: 0.875rem;
  line-height: 1.5rem;
}

/*
* 個人情報の取り扱いについて
*---------------------------------------------------*/
.privacy_list {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 90%;
}

.privacy_list > dt {
  margin: 0 auto 8px auto;
  padding: 3px 15px;
  width: 99%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #295597;
  border-left: 5px solid #295597;
}

.privacy_list > dd {
  margin: 15px auto 30px auto;
  padding: 20px 30px;
  width: 100%;
  font-size: 0.9375rem;
  color: #333;
  line-height: 1.6rem;
  background: #f0f0f0;
}

.privacy_contact {
  margin: 30px auto 0 auto;
  padding: 30px;
  width: 90%;
  background: #fff;
}

.privacy_contact > dt {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
}

.privacy_contact > dd {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

/*
* 特定商取引法に基づく表示
*---------------------------------------------------*/
.tokusho_lead {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 94%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.tokusho_lead .up_date {
  display: block;
  margin: 20px auto 0 auto;
  width: 100%;
  text-align: right;
}

.tokusho_tbl {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 90%;
  border-collapse: collapse;
}

.tokusho_tbl th {
  margin: 0;
  padding: 10px 15px 10px 30px;
  width: 25%;
  font-size: 0.9375rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
  text-align: left;
  background: #b8dce0;
  border-bottom: 1px solid #fff;
}

.tokusho_tbl td {
  margin: 0;
  padding: 10px 15px;
  width: 75%;
  font-size: 0.875rem;
  font-weight: normal;
  color: #333;
  line-height: 1.6rem;
  background: #fff;
  border-bottom: 1px solid #ddd;
}

/*
* 受講前のお問い合わせ
* 学習内容に関するお問い合わせ
* 各種お手続きに関するお問い合わせ
*---------------------------------------------------*/
/*
* コンテンツエリア（コンタクトフォーム共通）
*---------------------------------------------------*/
.contact_area {
  margin: 0 auto;
  padding: 30px 40px 50px 40px;
  width: 92%;
}

.contact_area + section {
  margin-top: 20px;
}

/*
* コンタクトフォームエリアタイトル
*---------------------------------------------------*/
.contact_title {
  position: relative;
  margin: 0 auto;
  padding: 0 0 10px 15px;
  width: 100%;
  font-size: 1.625rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #000;
  border-bottom: 3px solid #ddd;
}

.contact_title::before {
  content: "\f658";
  margin-right: 15px;
  font-size: 2.0625rem;
  color: #0068b7;
  /* font-weight: 600; */
  font-weight: bold;
}

/*
* コンタクト注意事項
*---------------------------------------------------*/
.notice_area {
  margin: 30px auto 0 auto;
  padding: 20px 30px;
  width: 90%;
  background: #fcf4e5;
  border-radius: 5px;
}

.notice_area ul.notice_list {
  margin: 0;
  padding: 0;
  width: 100%;
}

.notice_area ul.notice_list > li {
  margin: 0 auto;
  padding: 0;
  width: 94%;
  list-style: outside disc;
  font-size: 0.875rem;
}

.notice_area ul.notice_list > li + li {
  margin-top: 6px;
}

.notice_area .mail_notice {
  margin: 20px auto 0 auto;
  padding: 15px 20px;
  font-size: 0.8125rem;
  list-style: none;
  background: #fddede;
}

/*
* 他のフォームへのリンク
*---------------------------------------------------*/
.other_contact_link {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 90%;
}

.other_contact_link .link_cont {
  margin: 0 auto;
  padding: 20px 30px;
  width: 100%;
  background: #f1efea;
  border-radius: 5px;
}

.other_contact_link .link_cont > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #333;
}

.other_contact_link .link_cont > dd {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
}

.other_contact_link .link_cont > dd > a {
  font-size: 1.125rem;
  color: #083B55;
  text-decoration: none;
}

.other_contact_link .link_cont > dd > a:hover {
  color: #a82d2d;
}

.other_contact_link .link_cont > dd > a::after {
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 65%;
  transform: translateY(-50%);
  /* font-weight: 600; */
  font-weight: bold;
}

/*
* コンタクトテキスト
*---------------------------------------------------*/
.contact_txt {
  margin: 20px auto 0 auto;
  padding: 10px 0;
  width: 90%;
  font-size: 1rem;
  color: #5c135c;
  text-align: center;
  line-height: 1.6rem;
  background: #fff;
  border: 1px solid #ddd;
}

.contact_txt .form_notice {
  display: block;
  margin: 7px auto 0 auto;
  padding: 5px 0;
  width: 80%;
  font-size: 0.95rem;
  color: #a82929;
  background: #fde7e7;
  border-radius: 4px;
}

/*
* 問い合わせフォーム
*---------------------------------------------------*/
.form_area {
  margin: 30px auto 0 auto;
  padding: 40px 40px 20px 40px;
  width: 80%;
  border: 1px solid #dfc67f;
  background: #faf4eb;
  border-radius: 5px;
}

.form_area .form_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.form_area .form_body > dt {
  position: relative;
  margin: 0 0 20px 0;
  padding: 0 0 25px 55px;
  width: 30%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #7a5e0e;
  border-bottom: 1px solid #ebcc77;
}

.form_area .form_body > dt:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

.form_area .form_body > dt .must {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-8%);
  margin: 5px 15px 0 0;
  padding: 1px 10px 2px 10px;
  font-size: 0.6875rem;
  color: #fff;
  text-align: center;
  background: #aa1212;
}

.form_area .form_body > dd {
  margin: 0 0 20px 0;
  padding: 0 0 25px 20px;
  width: 70%;
  border-bottom: 1px solid #ebcc77;
}

.form_area .form_body > dd:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

.form_area .form_body > dd > input,
.form_area .form_body > dd > select {
  padding: 3px 5px;
  font-size: 0.875rem;
}

.form_area .form_body > dd > textarea {
  padding: 10px;
  width: 100%;
  font-size: 0.875rem;
}

/* 質問箇所追加 */
.form_area .form_body > dd.q_area {
  margin: 0 auto;
  padding: 20px;
  width: 100%;
  background: #f7efd8;
  border: none;
}

.form_area .form_body > dd.second_title {
  margin: 0;
  padding: 20px 0 10px 0;
  width: 100%;
  font-size: 1.1rem;
  font-weight: bold;
  color: #917322;
  text-align: center;
  border: none;
}

.form_area .form_body > dd.q_area .inner_question {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.form_area .form_body > dd.q_area .inner_question > dt {
  position: relative;
  margin: 0 0 20px 0;
  padding: 0 0 25px 55px;
  width: 30%;
  font-size: 1rem;
  font-weight: bold;
  color: #7a5e0e;
  border-bottom: 1px solid #ebcc77;
}

.form_area .form_body > dd.q_area .inner_question.no-padding > dt {
  padding: 0 0 25px 10px;
}

.form_area .form_body > dd.q_area .inner_question > dt:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

.form_area .form_body > dd.q_area .inner_question > dt .must {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-8%);
  margin: 5px 15px 0 0;
  padding: 1px 10px 2px 10px;
  font-size: 0.6875rem;
  color: #fff;
  text-align: center;
  background: #aa1212;
}

.form_area .form_body > dd.q_area .inner_question > dd {
  margin: 0 0 20px 0;
  padding: 0 0 25px 10px;
  width: 70%;
  border-bottom: 1px solid #ebcc77;
}

.form_area .form_body > dd.q_area .inner_question > dd:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

.form_area .form_body > dd.q_area .inner_question > dd > textarea {
  padding: 10px;
  width: 100%;
  font-size: 0.875rem;
}

.form_area .form_body > dd.q_area .inner_question > dd .txt_count {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  text-align: right;
}

/* INPUTサイズ */
.form_area .form_body > dd .sizeS,
.form_area .form_body > dd.q_area .inner_question > dd .sizeS {
  width: 20%;
}

.form_area .form_body > dd .sizeSM,
.form_area .form_body > dd.q_area .inner_question > dd .sizeSM {
  width: 40%;
}

.form_area .form_body > dd .sizeM,
.form_area .form_body > dd.q_area .inner_question > dd .sizeM {
  width: 50%;
}

.form_area .form_body > dd .sizeL,
.form_area .form_body > dd.q_area .inner_question > dd .sizeL {
  width: 90%;
}

.submit_btn {
  margin: 40px auto 0 auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.submit_btn input[type=submit] {
  position: relative;
  margin: 0;
  padding: 15px 0;
  width: 40%;
  font-size: 1.125rem;
  color: #fff;
  border: none;
  border-radius: 5px;
  background: #c94923;
  cursor: pointer;
}

.submit_btn input[type=submit]::after {
  content: "\f105";
  position: absolute;
  top: 50%;
  right: 20%;
  transform: translateY(-50%);
  /* font-weight: 600; */
  font-weight: bold;
}

.submit_btn input[type=submit]:hover {
  background: #c92823;
  transition: all 0.3s;
}

/* 送信未許可メッセージ */
.form_limit {
  margin: 50px auto;
  padding: 30px;
  width: 80%;
  font-size: 1rem;
  color: #941b1b;
  line-height: 1.8rem;
  background: #fbf1f1;
  border: 1px solid #da7d7d;
  border-radius: 5px;
}

/* 利用規約 */
.policy_area {
  margin: 20px auto;
  padding: 20px;
  width: 80%;
  height: 260px;
  background: #fff;
  border: 1px solid #ccc;
  overflow-y: scroll;
}

.policy_area .policy_title {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.5rem;
  font-weight: bold;
  color: #183680;
  text-align: center;
}

.policy_area .policy_cont {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
}

.policy_area .policy_cont > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.1rem;
  font-weight: bold;
  color: #2b5693;
}

.policy_area .policy_cont > dd {
  margin: 0;
  padding: 0;
  width: 100%;
}

.policy_area .policy_cont > dd > ol {
  margin: 10px auto;
  padding: 0;
  width: 94%;
}

.policy_area .policy_cont > dd > ol > li {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  line-height: 1.6rem;
  list-style-position: outside;
}

.policy_area .policy_cont > dd > ol > li + li {
  margin-top: 6px;
}

.policy_area .policy_cont > dd > ol > li .inner_list {
  margin: 10px auto;
  padding: 0;
  width: 98%;
}

.policy_area .policy_cont > dd > ol > li .inner_list > li {
  margin: 0;
  padding: 0;
  width: 100%;
  list-style-type: disc;
}

.policy_area .policy_cont > dd > ol > li .inner_list > li + li {
  margin-top: 6px;
}

.policy_check {
  margin: 0 auto;
  padding: 8px 0;
  width: 80%;
  font-size: 1rem;
  text-align: center;
  background: #ddd;
}

/*
* 受講体験談
*---------------------------------------------------*/
/*
* 選考と謝礼について
*---------------------------------------------------*/
.exp_notice {
  margin: 30px auto 0 auto;
  padding: 20px 40px;
  width: 90%;
  background: #fcf4e5;
  border-radius: 5px;
}

.exp_notice > dt {
  margin: 0;
  padding: 0 0 8px 0;
  width: 100%;
  font-size: 1.25rem;
  color: #a07119;
  border-bottom: 1px dotted #a07119;
}

.exp_notice > dt::before {
  content: "\f4fc";
  margin-right: 15px;
  /* font-weight: 600; */
  font-weight: bold;
}

.exp_notice > dd {
  margin: 8px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9375rem;
  color: #333;
  line-height: 1.6rem;
}

/*
* お問い合わせ送信完了
*---------------------------------------------------*/
.complete_txt {
  margin: 30px auto 0 auto;
  padding: 20px 30px;
  width: 90%;
  font-size: 1rem;
  color: #751e1e;
  text-align: center;
  line-height: 2rem;
  background: #fcf4e5;
  border-radius: 5px;
}

.back_to_home {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.back_to_home > a {
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #19286b;
  text-align: center;
  text-decoration: none;
}

.back_to_home > a:hover {
  color: #7e2222;
  text-decoration: underline;
}

/*
* 卒業証明・修了証明バナー
*---------------------------------------------------*/
/*
* コンテンツエリア
*---------------------------------------------------*/
.proof_area {
  margin: 0 auto;
  padding: 30px 60px 50px 60px;
  width: 92%;
}

/*
* コンテンツ
*---------------------------------------------------*/
.area_title {
  margin: 0 auto;
  padding: 15px 0;
  width: 100%;
  font-size: 1.375rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #2D5EBC;
}

ul.intro_area {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  margin: 20px auto 80px auto;
  padding: 0;
  width: 100%;
}

ul.intro_area .intro_txt {
  margin: 0;
  padding: 30px;
  width: 50%;
  font-size: 0.9375rem;
  color: #333;
  line-height: 1.5rem;
  background: #fff;
  border-radius: 5px;
}

ul.intro_area .intro_img {
  margin: 0;
  padding: 0;
  width: 46%;
}

ul.intro_area::after {
  position: absolute;
  content: "";
  right: 0;
  bottom: -60px;
  left: 0;
  width: 0;
  height: 0;
  margin: auto;
  border-style: solid;
  border-color: #f7d6d6 transparent transparent transparent;
  border-width: 40px 50px 0 50px;
}

.appeal_txt {
  margin: 0 auto 30px auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #810a01;
  text-align: center;
  line-height: 1.6rem;
}

ul.proof_merit {
  margin: 50px auto;
  padding: 0;
  width: 90%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

ul.proof_merit li {
  margin: 0;
  padding: 0;
  width: 31.3333333333%;
}

ul.proof_merit li .merit_content {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

ul.proof_merit li .merit_content > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  z-index: 0;
}

ul.proof_merit li .merit_content > dt > img {
  max-width: 100%;
  height: auto;
}

ul.proof_merit li .merit_content .merit_title {
  position: relative;
  margin: -20px auto 0 auto;
  padding: 6px 0;
  width: 100%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  background: #0469B6;
  z-index: 10;
  border-radius: 4px;
}

ul.proof_merit li .merit_content .merit_txt {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #604C3F;
  line-height: 1.5rem;
}

.blog_intro {
  margin: 0 auto;
  padding: 15px 0;
  width: 100%;
  background: #fcf1f1;
}

.blog_intro dt.lead_title {
  margin: 0 auto 10px auto;
  padding: 0;
  width: 100%;
  font-size: 1.125rem;
  font-weight: bold;
  color: #AD5757;
  text-align: center;
}

.blog_intro dd.lead_txt {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.9375rem;
  color: #604C3F;
  text-align: center;
  line-height: 1.6rem;
}

ul.recommend_blog {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 90%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

ul.recommend_blog li {
  margin: 0;
  padding: 20px 30px;
  box-sizing: border-box;
  width: 49%;
  background: #EDF4FF;
}

ul.recommend_blog li:nth-of-type(3), ul.recommend_blog li:nth-of-type(4) {
  margin-top: 15px;
}

ul.recommend_blog li .blog_content {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

ul.recommend_blog li .blog_content > .blog_img {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 100%;
  text-align: center;
  overflow: hidden;
}

ul.recommend_blog li .blog_content > .blog_img > a > img {
  max-width: 100%;
  height: auto;
  border: 1px solid #ddd;
}

ul.recommend_blog li .blog_content > .blog_img > a > img:hover {
  transform: scale(1.2);
  transition: all 0.3s;
}

ul.recommend_blog li .blog_content .blog_title {
  margin: 20px auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

ul.recommend_blog li .blog_content .blog_title > a {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.0625rem;
  font-weight: bold;
  color: #604C3F;
  line-height: 1.5rem;
}

ul.recommend_blog li .blog_content .blog_title > a:hover {
  color: #ad204f;
  text-decoration: underline;
  transition: all 0.3s;
}

ul.recommend_blog li .blog_content .blog_summary {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #333;
  line-height: 1.5rem;
}

.get_proof {
  position: relative;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
  background: #fcf1e7;
}

.get_proof::before {
  position: absolute;
  content: "";
  right: 0;
  top: 0;
  left: 0;
  width: 0;
  height: 0;
  margin: auto;
  border-style: solid;
  border-color: #B52525 transparent transparent transparent;
  border-width: 30px 30px 0 30px;
}

.get_proof .get_title {
  margin: 0 auto;
  padding: 50px 0 0 0;
  width: 100%;
  font-size: 1.5rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #B52525;
  text-align: center;
}

.get_proof .get_lead {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 90%;
  font-size: 0.9375rem;
  color: #604C3F;
  text-align: center;
  line-height: 1.5rem;
}

.get_proof .shikaku_select {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 94%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.get_proof .shikaku_select .shikaku_list {
  margin: 0 0 20px 0;
  padding: 0;
  width: 49%;
  background: #ddf0f7;
}

.get_proof .shikaku_select .shikaku_list > dt {
  margin: 0 auto;
  padding: 8px 0;
  width: 100%;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  background: #5CB08F;
  border-radius: 4px;
}

.get_proof .shikaku_select .shikaku_list > dd {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.get_proof .shikaku_select .shikaku_list > dd .shikaku_contents {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto;
  padding: 20px;
  width: 100%;
}

.get_proof .shikaku_select .shikaku_list > dd .shikaku_contents::after {
  content: "";
  display: block;
  width: 49%;
}

.get_proof .shikaku_select .shikaku_list > dd .shikaku_contents > li {
  margin: 0 auto 5px auto;
  padding: 0;
  width: 49%;
  font-size: 0.875rem;
  color: #000;
}

.get_proof .shikaku_select .shikaku_list > dd .shikaku_contents > li input[type=radio] {
  margin-right: 5px;
}

.view_title {
  margin: 30px auto 0 auto;
  padding: 8px 0;
  width: 94%;
  font-size: 1.125rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #193a92;
}

.view_area {
  margin: 15px auto 30px auto;
  padding: 0 0 20px 0;
  width: 94%;
}

.view_area .view_banner {
  margin: 20px auto 30px auto;
  padding: 0;
  width: 94%;
}

.view_area .view_banner > p {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #000;
  text-align: center;
}

.view_area .view_banner .example_img {
  display: flex;
  justify-content: center;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.view_area .get_address {
  margin: 40px auto 0 auto;
  padding: 15px 25px;
  box-sizing: border-box;
  width: 94%;
  background: #dff0f5;
  border-radius: 5px;
}

.view_area .get_address .get_title {
  margin: 0 auto;
  padding: 8px 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: #5f97a8;
}

.view_area .get_address > p {
  margin: 15px auto 0 auto;
  padding: 0;
  width: 94%;
  font-size: 0.875rem;
  color: #000;
  line-height: 1.5rem;
}

.view_area .get_address .banner_address {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.view_area .get_address .banner_address .address_url {
  margin: 0 auto;
  padding: 10px;
  width: 90%;
  height: 100px;
  font-size: 0.875rem;
  line-height: 1.3rem;
  resize: none;
}

.view_area .get_address .copy_btn {
  margin: 10px auto 20px auto;
  padding: 0;
  width: 100%;
  text-align: center;
}

.view_area .get_address .copy_btn > button {
  margin: 0 auto;
  padding: 8px 0;
  width: 260px;
  font-size: 1.0625rem;
  color: #fff;
  background: #184ea0;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}

.view_area .get_address .copy_btn > button::before {
  content: "\f138";
  margin-right: 10px;
  /* font-weight: 600; */
  font-weight: bold;
}

.view_area .get_address .copy_btn > button:disabled {
  background: #ccc;
  cursor: not-allowed;
}

.view_area .get_address .copy_btn > .copied {
  background: #1f5ee6;
}

.view_area .notice {
  margin: 30px auto 10px auto;
  padding: 0;
  width: 100%;
}

.view_area .notice > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.25rem;
  color: #79083d;
  text-align: center;
}

.view_area .notice > dd {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  text-align: center;
  line-height: 1.7rem;
}

/*
* 自分に合う講座を探す
*---------------------------------------------------*/
.shikaku_find_area {
  position: relative;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 92%;
}

.shikaku_find_area ul.inner_menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 50px auto;
  padding: 0;
  width: 100%;
}

.shikaku_find_area ul.inner_menu > li {
  margin: 0;
  padding: 0;
  width: 32.6666666667%;
  height: 60px;
  border-radius: 5px;
}

.shikaku_find_area ul.inner_menu > li > a {
  position: relative;
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1.125rem;
  color: #A33919;
  text-decoration: none;
}

.shikaku_find_area ul.inner_menu > li > a::before {
  margin: 8px 15px 0 12%;
  content: url("../../images/shikaku_search/search_illust.svg");
}

.shikaku_find_area ul.inner_menu > li > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f078";
  /* font-weight: 600; */
  font-weight: bold;
}

.shikaku_find_area ul.inner_menu > li.m_test {
  background: #FDF5F8;
}

.shikaku_find_area ul.inner_menu > li.m_test:hover {
  background: #ecd5dd;
  transition: all 0.3s;
}

.shikaku_find_area ul.inner_menu > li.m_ranking {
  background: #EFECF7;
}

.shikaku_find_area ul.inner_menu > li.m_ranking:hover {
  background: #dbd4ee;
  transition: all 0.3s;
}

.shikaku_find_area ul.inner_menu > li.m_voice {
  background: #FAFAEF;
}

.shikaku_find_area ul.inner_menu > li.m_voice:hover {
  background: #ececd0;
  transition: all 0.3s;
}

.shikaku_find_area .test_find {
  margin: 30px auto 60px auto;
  padding: 40px 0;
  background-color: #FDF5F8;
  border-radius: 5px;
}

.shikaku_find_area .test_find .test_img {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.shikaku_find_area .test_find .test_txt {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 0 auto;
  padding: 0;
  width: 78%;
}

.shikaku_find_area .test_find .test_txt .txt_body {
  margin: 0;
  padding: 0;
  width: 50%;
  font-size: 1.25rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #0068b7;
}

.shikaku_find_area .test_find .test_txt .link_btn {
  margin: 0;
  padding: 0;
  width: 50%;
}

.shikaku_find_area .test_find .test_txt .link_btn > a {
  margin: 0;
  padding: 0;
  width: 100%;
}

.shikaku_find_area .test_find .test_txt .link_btn > a > button {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 60px;
  font-size: 1.125rem;
  color: #fff;
  border: none;
  background: #CB2D4C;
  border-radius: 5px;
  cursor: pointer;
}

.shikaku_find_area .test_find .test_txt .link_btn > a > button::before {
  position: absolute;
  top: 50%;
  left: 14%;
  transform: translateY(-50%);
  content: "\f0a4";
  margin-right: 15px;
  font-size: 1.75rem;
}

.shikaku_find_area .test_find .test_txt .link_btn > a > button::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.shikaku_find_area .test_find .test_txt .link_btn > a > button:hover {
  background: #eb2b51;
  transition: all 0.3s;
}

.shikaku_find_area .ranking_find {
  margin: 30px auto 60px auto;
  padding: 40px;
  background: #EFECF7;
  border-radius: 5px;
}

.shikaku_find_area .ranking_find .lead_txt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #113096;
  line-height: 1.8rem;
}

.shikaku_find_area .ranking_find .ranking_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 40px auto 0 auto;
  padding: 0;
  width: 100%;
}

.shikaku_find_area .ranking_find .ranking_list::after {
  content: "";
  display: block;
  width: 32.6666666667%;
}

.shikaku_find_area .ranking_find .ranking_list > li {
  margin: 0 0 1% 0;
  padding: 20px;
  width: 32.6666666667%;
  background: #fff;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_title {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 50px;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  line-height: 1.6rem;
  color: #740356;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_img {
  position: relative;
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  height: 110px;
  border: 1px solid #ccc;
  overflow: hidden;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_img > img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 100%;
  min-height: 100%;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_lead {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
  line-height: 1.4rem;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn {
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100%;
  height: 45px;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background: #D699BF;
  border-radius: 5px;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn > a:hover {
  background: #c26ea2;
}

.shikaku_find_area .voice_find {
  margin: 30px auto 60px auto;
  padding: 0 0 40px 0;
  background: #fff;
}

.shikaku_find_area .voice_find .lead_txt {
  margin: 0 auto;
  padding: 0;
  width: 90%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #113096;
  line-height: 1.8rem;
}

.shikaku_find_area .voice_find .voice_list_part {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 60px auto 0 auto;
  padding: 0;
  width: 100%;
}

.shikaku_find_area .voice_find .voice_list_part li {
  margin: 0;
  padding: 0 0 30px 0;
  width: 32.6666666667%;
  background: #FAFAEF;
}

.shikaku_find_area .voice_find .voice_list_part li .list_img {
  position: relative;
  margin: -20px 0 0 10px;
  padding: 0 0 0 70px;
  width: 85%;
  height: 40px;
  font-size: 1.125rem;
  color: #fff;
  line-height: 38px;
  background: #932D2D;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
}

.shikaku_find_area .voice_find .voice_list_part li .list_img::before {
  position: absolute;
  content: "\f4ad";
  /* font-weight: 600; */
  font-weight: bold;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  padding: 0em;
  width: 55px;
  height: 55px;
  font-size: 1.875rem;
  text-align: center;
  line-height: 50px;
  background: #b84141;
  border-radius: 50%;
}

.shikaku_find_area .voice_find .voice_list_part li .list_img::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  right: -20px;
  height: 30px;
  border: 20px solid #932D2D;
  border-right-width: 15px;
  border-right-color: transparent;
}

.shikaku_find_area .voice_find .voice_list_part li .student_name {
  margin: 5px 0 0 0;
  padding: 0;
  width: 90%;
  font-size: 0.875rem;
  color: #333;
  text-align: right;
}

.shikaku_find_area .voice_find .voice_list_part li .list_body {
  margin: 20px auto 0 auto;
  padding: 0 30px;
  width: 100%;
}

.shikaku_find_area .voice_find .voice_list_part li .list_body dt {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 80px;
  font-size: 1.125rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #932D2D;
}

.shikaku_find_area .voice_find .voice_list_part li .list_body dd {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.875rem;
  color: #575757;
  line-height: 1.6rem;
}

.shikaku_find_area .voice_find .link_btn {
  margin: 40px auto 0 auto;
  padding: 0;
  width: 40%;
}

.shikaku_find_area .voice_find .link_btn > a {
  margin: 0;
  padding: 0;
  width: 100%;
}

.shikaku_find_area .voice_find .link_btn > a > button {
  position: relative;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 60px;
  font-size: 1.125rem;
  color: #fff;
  border: none;
  background: #CB2D4C;
  border-radius: 5px;
  cursor: pointer;
}

.shikaku_find_area .voice_find .link_btn > a > button::before {
  position: absolute;
  top: 50%;
  left: 14%;
  transform: translateY(-50%);
  content: "\f0a4";
  margin-right: 15px;
  font-size: 1.75rem;
}

.shikaku_find_area .voice_find .link_btn > a > button::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.shikaku_find_area .voice_find .link_btn > a > button:hover {
  background: #eb2b51;
  transition: all 0.3s;
}

/*
* 講座検索結果
*---------------------------------------------------*/
.search_list_body {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 50px auto 0 auto;
  padding: 0;
  width: 100%;
}

.search_list_body::after {
  content: "";
  display: block;
  width: 32.6666666667%;
}

.search_list_body > li {
  display: flex;
  flex-direction: column;
  margin: 0 0 1% 0;
  padding: 20px;
  width: 32.6666666667%;
  height: 350px;
  background: #fff;
}

.search_list_body > li .kouza_title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #433006;
}

.search_list_body > li .kouza_img {
  position: relative;
  margin: 15px 0 0 0;
  padding: 0;
  width: 100%;
  height: 110px;
  border: 1px solid #ccc;
  overflow: hidden;
}

.search_list_body > li .kouza_img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.search_list_body > li .kouza_lead {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.85rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #333;
  line-height: 1.4rem;
}

.search_list_body > li .kouza_link_btn {
  /* margin: 20px auto 0 auto; */
  margin: auto auto 0 auto;
  padding: 0;
  width: 100%;
  height: 55px;
}

.search_list_body > li .kouza_link_btn > a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 1.1rem;
  /* font-weight: 500; */
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  background: #B399D6;
  border-radius: 5px;
}

.search_list_body > li .kouza_link_btn > a::after {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  content: "\f054";
  /* font-weight: 600; */
  font-weight: bold;
}

.search_list_body > li .kouza_link_btn > a:hover {
  background: #9274b9;
}

/* 該当講座なし */
.no_result {
  margin: 60px auto 0 auto;
  padding: 20px;
  width: 80%;
  font-size: 1rem;
  color: #333;
  text-align: center;
  background: #d6e1e9;
}

/*
* 記事監修者一覧
*---------------------------------------------------*/
.author_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto;
  padding: 30px;
  width: 100%;
  background: #f8f8f8;
  border-radius: 8px;
}

.author_list::before,
.author_list::after {
  content: "";
  display: block;
  width: 24.5%;
}

.author_list::before {
  order: 1;
}

.author_list > li {
  margin: 0 0 15px 0;
  padding: 0;
  width: 24.5%;
  border: 1px solid #ccc;
  background: #fff;
}

.author_list > li .kouza_name {
  margin: 0;
  padding: 8px 0;
  width: 100%;
  font-size: 0.9rem;
  color: #fff;
  text-align: center;
  background: #0952A8;
}

.author_list > li .author_list_cont {
  margin: 10px 0;
  padding: 0 10px;
  width: 100%;
}

.author_list > li .author_list_cont > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 120px;
  overflow: hidden;
}

.author_list > li .author_list_cont > dt > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  -o-object-position: center -50px;
     object-position: center -50px;
}

.author_list > li .author_list_cont .author_name {
  margin: 10px 0 0 0;
  padding: 6px 10px;
  width: 100%;
  font-size: 1rem;
  color: #740696;
  text-align: center;
  background: #FFEBFE;
}

.author_list > li .author_list_cont .author_history {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #333;
  line-height: 1.4rem;
}

.author_list > li .author_list_cont .author_link {
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
}

.author_list > li .author_list_cont .author_link > a {
  position: relative;
  display: block;
  margin: 0;
  height: 100%;
  padding: 8px;
  font-size: 0.9rem;
  color: #0952A8;
  text-decoration: none;
  text-align: center;
  background: #E1E8F5;
}

.author_list > li .author_list_cont .author_link > a::after {
  content: "\f054";
  font-weight: bold;
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
}

.author_list > li .author_list_cont .author_link > a:hover {
  background: #bcc9e2;
}

.author_list > li .author_list_cont .kouza_link {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
}

.author_list > li .author_list_cont .kouza_link > a {
  position: relative;
  display: block;
  margin: 0;
  height: 100%;
  padding: 8px;
  font-size: 0.9rem;
  color: #8309a8;
  text-decoration: none;
  text-align: center;
  background: #eee1f5;
}

.author_list > li .author_list_cont .kouza_link > a::after {
  content: "\f054";
  font-weight: bold;
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
}

.author_list > li .author_list_cont .kouza_link > a:hover {
  background: #d2badf;
}

/*
* 利用規約・教材について
*---------------------------------------------------*/
.usage_area {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 92%;
}

.usage_area .usage_row {
  /* display: flex;
  flex-wrap: wrap;
  justify-content: space-between; */
  margin: 0;
  padding: 0 0 20px 0;
  border-bottom: 1px dotted #ddd;
}

.usage_area .usage_row + dl {
  margin-top: 30px;
}

.usage_area .usage_row.mt50 {
  margin-top: 50px;
}

.usage_area .usage_row > dt {
  position: relative;
  margin: 0 0 20px 0;
  padding: 0 0 0 20px;
  /* width: 10%; */
  width: 100%;
  font-size: 1.25rem;
  font-weight: bold;
  color: #9b750c;
}

.usage_area .usage_row > dt::before {
  content: "\f054";
  position: absolute;
  top: 16%;
  left: 0;
  margin: 0;
  font-size: 0.875rem;
  font-weight: bold;
}

.usage_area .usage_row > dd {
  margin: 0;
  padding: 0;
  /* width: 86%; */
  width: 100%;
  font-size: 1rem;
  color: #333;
  line-height: 1.6rem;
}

.enactment {
  margin-right: 0;
  margin-left: auto;
  padding: 0;
  width: 40%;
}

.enactment > dt {
  margin: 0 0 7px 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #8c0d0d;
}

.enactment > dd {
  margin: 0;
  padding: 20px;
  width: 100%;
  font-size: 0.9rem;
  color: #333;
  line-height: 1.6rem;
  border: 1px solid #ddd;
}

/**
* NEW - 無料資料請求
*------------------------------------------------------------*/
/**
* 資料請求 - 全講座選択画面
*/
.doc-container .ttl__header {
  margin: 0 auto;
  padding: 0 0 12px 0;
  width: 100%;
  font-family: メイリオ, Meiryo, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #0068b7;
  border-bottom: 1px solid #0068b7;
}

.doc-container .doc-notice {
  margin: 20px auto 0 auto;
  padding: 10px 0;
  width: 100%;
  font-size: 1rem;
  color: #333;
  text-align: center;
  /* border: 1px solid #eb6da5; */
  box-sizing: border-box;
  background: #fff0fc;
}

.doc-container .doc-notice .offer-alert {
  display: block;
  margin: 5px auto 0 auto;
  padding: 0 30px;
  font-size: 0.8rem;
  color: #9b2e2e;
}

.doc-container h3.area-title {
  position: relative;
  display: block;
  margin: 40px auto 20px auto;
  padding: 0 0 10px 0;
  width: 100%;
  font-size: 1.4rem;
  font-weight: normal;
  /* color: #333; */
  color: #0068b7;
  text-align: left;
  border-bottom: 1px solid #ddd;
  background: #fff;
}

.doc-container h3.area-title > i {
  margin: 0 5px 0 0;
  padding: 0;
  width: 25px;
}

/* キーワード検索 */
.search_result_title {
  position: relative;
  display: flex;
  align-items: center;
  margin: 30px auto 0 auto;
  padding: 0 20px;
  width: 100%;
  height: 50px;
  font-size: 1.2rem;
  font-weight: bold;
  color: #fff;
  background: #fff;
  box-sizing: border-box;
}
.search_result_title::before {
  content: "";
  position: absolute;
  top: 6px;
  left: -3px;
  width: 39px;
  height: 39px;
  background-image: var(--bg-image);
  background-repeat: no-repeat;
  background-position: center;
}
.search_result_title .toggle_mark {
  position: absolute;
  top: 50%;
  right: 4%;
  transform: translateY(-50%) rotate(135deg);
  transition: transform 0.3s ease-in-out, top 0.3s ease-in-out;
  display: block;
  width: 8px;
  height: 8px;
  border-right: 2px solid #fff;
  border-top: 2px solid #fff;
}
.search_result_title.open .toggle_mark {
  transform: rotate(-45deg) !important;
  transition: transform 0.3s ease-in-out, top 0.3s ease-in-out !important;
}

#search_result {
  background: #a642e4;
}

.result_num {
  margin: 12px auto 16px auto;
  padding: 0 0 12px 10px;
  width: 100%;
  font-size: 0.9rem;
  color: #000;
  border-bottom: 1px solid #ddd;
  box-sizing: border-box;
}
@media screen and (max-width: 480px) {
  .result_num {
    font-size: 0.84rem;
  }
}
.result_num .txt_red {
  margin-right: 3px;
  font-size: 1.2rem;
  font-weight: bold;
  color: #be1414;
}
@media screen and (max-width: 480px) {
  .result_num .txt_red {
    font-size: 1rem;
  }
}

.popular_keyword_title {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #222;
}

.keyword_list {
  margin: 16px auto 30px auto;
  padding: 0 0 16px 0;
  width: 100%;
  border-bottom: 1px solid #ccc;
}
@media screen and (max-width: 480px) {
  .keyword_list {
    margin-bottom: 20px;
  }
}
.keyword_list > li {
  display: inline-block;
  margin: 0 0 5px 0;
  padding: 0;
}
.keyword_list > li .srch_wd_btn {
  margin: 0;
  padding: 5px 10px;
  font-size: 0.9rem;
  color: #222;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 4px;
}

.doc-container .search-wrapper #keyword-search {
  margin: 0 auto;
  padding-left: 50px;
  font-size: 1.1rem;
  border-radius: 4px;
  border: 2px solid #bfc2f8;
}

.search_btn_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 8px auto 0 auto;
  padding: 0;
  width: 60%;
}
.search_btn_area > li {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 49%;
  height: 40px;
  font-size: 1rem;
  font-weight: bold;
  color: #222;
  border-radius: 4px;
  cursor: pointer;
}
.search_btn_area > li.run_search {
  background: #ffda35;
}
.search_btn_area > li.run_search:hover {
  background: #d2b11e;
  transition: all 0.3s ease;
}
.search_btn_area > li.clear_search {
  background: #f0f0f0;
}
.search_btn_area > li.clear_search:hover {
  background: #ddd;
  transition: all 0.3s ease;
}

/* 人気ランキング */
.list__ranking {
  margin: 0;
  padding: 0;
  width: 100%;
}

.list__ranking .list__item {
  margin: 0;
  padding: 0;
  width: 100%;
}

.list__ranking .list__item .ranking__name {
  margin-left: 15px;
}

.list__ranking .list__item .ranking__name > a {
  color: #10488d;
  text-decoration: none;
}

/* カテゴリー */
.doc-container .util-area .category-area {
  margin: 0 auto 30px auto;
  padding: 0;
  width: 100%;
}

.doc-container .util-area .category-area .category-list::after {
  display: block;
  content: "";
  width: 32.6666666667%;
}

.doc-container .util-area .category-area .category-list {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.doc-container .util-area .category-area .category-list .list__category-item {
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 0 10px 0;
  padding: 0 15px;
  width: 32.6666666667%;
  height: 30px;
  border-radius: 4px;
  box-sizing: border-box;
}

.doc-container .util-area .category-area .category-list .list__category-item:after {
  content: "";
  position: absolute;
  top: 0.8rem;
  right: 1rem;
  width: 6px;
  height: 6px;
  transform: rotate(-45deg);
  transition: all 0.3s;
  border: 2px solid #fff;
  border-top-color: transparent;
  border-left-color: transparent;
}

.doc-container .util-area .category-area .category-list .list__category-item:hover::after {
  right: 0.6rem;
}

.doc-container .util-area .category-area .category-list .list__category-item > a {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  font-size: 0.9rem;
  color: #fff;
}

.doc-container #search-area .category-title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  margin: 0 auto 16px auto;
  padding: 0 20px;
  width: 100%;
  height: 40px;
  font-size: 1.3rem;
  color: #fff;
}

/* 各カテゴリーごとの講座 */
.line {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.line .category__item {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 5px 0;
  padding: 8px;
  width: 49%;
  background: #f4f4f4;
}

.category__item .item__name {
  margin: 0;
  padding: 0;
  width: 72%;
}

.category__item .item__name > a {
  font-size: 1rem;
  color: #22489a;
  text-decoration: none;
}

.category__item .btn {
  margin: 0;
  padding: 0;
  min-width: 28%;
  height: 40px;
  font-size: 0.9rem;
  background: #2a76b5;
  box-shadow: 0 2px 0 #183c70;
}

.category__item .btn-select.selected {
  width: 32%;
  font-size: 0.9rem;
  background: #ef552f;
}

/* 下部講座選択エリア */
.nav__controller {
  height: auto;
  background: rgba(33, 75, 160, 0.9) !important;
}

.nav__controller .nav_txt {
  margin: 0 auto 15px auto;
  padding: 0;
  width: 100%;
  font-size: 1.2rem;
  color: #fff;
  text-align: center;
}

.nav__controller .row {
  display: block;
  box-sizing: border-box;
}

.nav__controller .row .course__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 8px auto;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}

.course__list .selected__course {
  margin: 0;
  padding: 0;
  width: 49%;
  box-sizing: border-box;
}

.course__list .selected__course .course-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 6px 30px 6px 10px;
  width: 100%;
  min-height: 36px;
  color: #fff;
  box-sizing: border-box;
  background: #c15512;
}

.course__list .selected__course .course-frame.kouza-sel {
  color: #333;
  background: #fff;
}

.course__list .selected__course .course-frame .course-name {
  font-size: 0.9rem;
  font-weight: normal;
  line-height: 1.3rem;
}

.document-form .btn-request {
  position: relative;
  margin: 10px auto 0 auto;
  padding: 15px 0;
  color: #5c2b05;
  background: #ffcc15;
  box-shadow: 0 3px 0 #936901;
}

.document-form .btn-request::after {
  content: "\f101";
  font-family: "Font Awesome 5 Free";
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  font-weight: 900;
}

/* 講座追加時のポップアップウィンドウ */
.info-window {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  top: 30%;
  left: -50%;
  transform: translateY(-30%);
  width: 50%;
  height: 15vh;
  font-size: 2rem;
  background: rgba(0, 104, 183, 0.85);
  border-top-right-radius: 5px;
  border-bottom-right-radius: 5px;
  z-index: 1000;
}

.info-message {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 0 0 20px;
  width: 80%;
  height: 80%;
  font-size: 1.2rem;
  color: #fff;
  border-left: 5px solid #cfcc30;
}

/**
* 資料請求 - 講座追加画面
*/
.select-document {
  margin: 40px auto;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}

.select-document .select-txt {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #333;
}

.select-list {
  margin: 15px auto 0 auto;
  padding: 0;
  width: 100%;
  border: 1px solid #ddd;
}

.select-list .list-title {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 15px;
  width: 100%;
  height: 45px;
  font-size: 1rem;
  color: #fff;
  background: #275baa;
  box-sizing: border-box;
}

.select-list .selected-course {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 15px 0 25px;
  width: 100%;
  height: 50px;
  font-size: 1.1rem;
  color: #333;
  box-sizing: border-box;
}

.select-list .selected-course + .selected-course {
  border-top: 1px solid #ddd;
  box-sizing: border-box;
}

.select-list .selected-course .course-name {
  display: inline-block;
  margin: 0;
  padding: 0;
  width: 80%;
}

.select-list .selected-course .del-course {
  display: inline-block;
  margin: 0;
  padding: 0;
  width: 20%;
  text-align: center;
}

.select-list .selected-course .del-course .del-course-btn {
  margin: 0;
  padding: 0;
  width: 80px;
  height: 30px;
  font-size: 0.9rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #eee;
  box-shadow: 0 1px 0 #ccc;
}

.add-course {
  margin: 80px auto 0 auto;
  padding: 0;
  width: 100%;
}

.add-course .add-comment {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.1rem;
  font-weight: bold;
  color: #333;
  line-height: 1.8rem;
}

.add-course .add-comment .comment-red {
  color: #d42727;
}

.add-course .add-comment .comment-small {
  font-size: 0.9rem;
}

.add-course .add-notice {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 0.9rem;
  color: #333;
}

.add-course .add-course-list {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 100%;
  border: 1px solid #ddd;
}

.add-course .add-course-list .list-title {
  margin: 0;
  padding: 15px;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  background: #f0f0f0;
  box-sizing: border-box;
}

.add-course .add-course-list .list-cont {
  margin: 0 0 10px 0;
  padding: 20px 20px 10px;
  width: 100%;
  box-sizing: border-box;
}

.add-course .add-course-list .list-cont .add-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.add-course .add-course-list .list-cont .add-list > li {
  margin: 0 0 10px 0;
  padding: 8px 0;
  width: 49%;
  background: #f3f2f2;
}

.add-course .add-course-list .list-cont .add-list > li .add-name {
  display: inline-block;
  margin: 0;
  padding: 0 0 0 15px;
  width: 63%;
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  vertical-align: middle;
}

.add-course .add-course-list .list-cont .add-list > li .btn {
  margin: 0;
  padding: 0;
  width: 130px;
  height: 35px;
  font-size: 0.9rem;
  font-weight: normal;
}

.action-select {
  margin: 30px auto 60px auto;
  padding: 0;
  width: 60%;
  box-sizing: border-box;
}

.action-select .document-form {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}

.action-select .btn-back-area {
  margin: 0;
  padding: 0;
  width: 40%;
  box-sizing: border-box;
}

.action-select .btn-back-area .btn-back-list {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 50px;
  font-size: 1rem;
  color: #333;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #fefefe;
  box-shadow: 0 2px 0 #ddd;
}

.action-select .btn-back-area .btn-back-list:hover {
  background: #f7f7f7;
  transition: background-color 0.3s;
}

.action-select .btn-request-area {
  margin: 0;
  padding: 0;
  width: 58%;
  box-sizing: border-box;
}

.action-select .btn-request-area .btn {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 50px;
  box-shadow: 0 2px 0 #ae9d03;
}

.action-select .btn-request-area .btn:hover {
  background: #f8c726;
  transition: background-color 0.3s;
}

/* 資料請求 - 送付先入力 */
.init__content {
  position: relative;
}

.process-img > img {
  margin: 0 auto;
}

.req_input {
  margin-bottom: 30px;
}

.sub-title {
  margin: 60px auto 0 auto;
  padding: 0 0 30px 0;
  width: 100%;
  font-size: 1.3rem;
  color: #eb6da5;
  text-align: center;
  /* border-bottom: 1px solid #ccc; */
}

.mail-notice {
  margin: 0 0 20px 0;
  padding: 20px;
  width: 100%;
  font-size: 0.9rem;
  color: #333;
  line-height: 1.6rem;
  border: 1px solid #ddd;
}

.form__input {
  margin: 0 !important;
  border-top: none !important;
}

/* エラー表示のモーダルウィンドウ */
.errorModal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.7);
  z-index: 100;
}

.errorModal .content {
  margin: 0 auto;
  padding: 30px;
  width: 50%;
  background: #fff;
  border-radius: 5px;
}

.errorModal .content .modal-title {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.2rem;
  font-weight: bold;
  color: #d22d2d;
}

.errorModal .content .modal-title .error-num {
  display: inline-block;
  margin: 0 5px;
  padding: 0;
  font-size: 1.4em;
}

.errorModal .content .error-list {
  margin: 20px 0 0 0;
  padding: 0;
  width: 100%;
}

.errorModal .content .error-list .list-str {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  font-weight: bold;
  color: #333;
  list-style: disc inside;
}

.errorModal .content .error-list .list-str + .list-str {
  margin-top: 5px;
}

.errorModal .content .modal-close {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 20px auto 0 auto;
  padding: 0;
  width: 100px;
  height: 40px;
  font-size: 0.9rem;
  border: 1px solid #ccc;
  border-radius: 4px;
  background: #f0f0f0;
  box-shadow: 0 2px #ddd;
}

.show {
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 国家資格選択時のエラー表示 */
.kokka-alert {
  display: block;
  margin: 40px auto 30px auto;
  padding: 30px;
  font-size: 1rem;
  color: #fff;
  text-align: center;
  line-height: 1.6rem;
  background: #D9588E;
}

/*
* 人気資格ランキングTOP30
*==============================================================*/
.ranking_preface {
  margin: 30px auto;
  padding: 20px;
  width: 84%;
  font-size: 16px;
  line-height: 1.6rem;
  background: #dcedfb;
  border-radius: 4px;
}

.ranking_afterwords {
  margin: 30px auto;
  padding: 20px;
  width: 84%;
  font-size: 16px;
  line-height: 1.6rem;
  background: #dcedfb;
  border-radius: 4px;
}

/* ランキングページタイトル */
/* .ranking_title {
	position: relative;
	margin: 50px auto;
	padding: 0;
	width: 40%;
	height: 60px;
	font-size: 26px;
	line-height: 60px;
	text-align: center;
	color: #fff;
	background: #df3c3c;
}

.ranking_title:before,
.ranking_title:after {
	position: absolute;
	top: 0;
	display: block;
	height: 48px;
	content: '';
	border: 30px solid #df3c3c;
}

.ranking_title:before {
	left: -40px;
	border-left-width: 15px;
	border-left-color: transparent;
}

.ranking_title:after {
	right: -40px;
	border-right-width: 15px;
	border-right-color: transparent;
}

.ranking_title span {
	position: relative;
	display: block;
} */
/* ランキングページ内メニュー */
.ranking_inner_menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 40px auto;
  padding: 0;
  width: 84%;
}

.ranking_inner_menu li {
  margin: 0;
  padding: 0;
  width: 32.6666666667%;
}

.ranking_inner_menu li > a {
  display: block;
  margin: 0;
  padding: 10px 0;
  width: 100%;
  font-size: 16px;
  color: #fff;
  text-align: center;
  text-decoration: none;
}

.ranking_inner_menu li > a .rank_number {
  margin: 0 auto;
  padding: 0;
  width: 100%;
  font-size: 1.6rem;
  font-weight: bold;
  color: #fff;
}

.ranking_inner_menu li > a .rank_number .unit_txt {
  margin-left: 3px;
  font-size: 1.2rem;
}

.ranking_inner_menu li > a .link_txt {
  margin: 6px auto 0 auto;
  padding: 10px;
  width: 90%;
  font-size: 1.6rem;
  font-weight: bold;
  color: transparent;
  text-indent: 30px;
  background-size: 30px 20px;
  background-repeat: no-repeat;
  background-position: 60px center;
}

.ranking_inner_menu li.inner01 {
  background: #f3cb5d;
}

.ranking_inner_menu li.inner01 > a .link_txt {
  background-image: url("../images/ranking/ranking01_check_arrow.svg");
  background-color: #f7d577;
  color: #f1b40a;
}

.ranking_inner_menu li.inner02 {
  background: #7fa9f7;
}

.ranking_inner_menu li.inner02 > a .link_txt {
  background-image: url("../images/ranking/ranking02_check_arrow.svg");
  background-color: #98b8f3;
  color: #3c7bf1;
}

.ranking_inner_menu li.inner03 {
  background: #87c975;
}

.ranking_inner_menu li.inner03 > a .link_txt {
  background-image: url("../images/ranking/ranking03_check_arrow.svg");
  background-color: #a7d39b;
  color: #4ca335;
}

/* .ranking_menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 40px auto;
	padding: 0;
	width: 84%;
}

.ranking_menu li {
	margin: 0;
	padding: 0;
	width: calc(100% / 3);
}

.ranking_menu li + li {
	border-left: 1px solid #fff;
}

.ranking_menu li > a {
	display: block;
	margin: 0;
	padding: 10px 0;
	width: 100%;
	font-size: 16px;
	color: #fff;
	text-align: center;
	background: #324994;
	text-decoration: none;
}

.ranking_menu li > a:hover {
	background: #0b1e5a;
	transition: all 0.3s;
}

.ranking_menu li > a.current {
	background: #6688f7;
}
 */
/* ランキングコンテンツ */
.ranking_list {
  margin: 20px auto;
  padding: 0;
  width: 84%;
  border: 1px solid #ddd;
}

.ranking_list:last-of-type {
  margin-bottom: 40px;
}

.ranking_list .shikaku_name {
  position: relative;
  margin: 0;
  padding: 15px 10px 15px 90px;
  width: 100%;
  font-size: 20px;
  color: #fff;
  background: #1c5391;
}

.ranking_list .shikaku_name span {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  width: 70px;
  height: 100%;
  font-size: 36px;
  font-weight: bold;
  color: #fff;
  border-radius: 0 10px 10px 0;
  background: #042b56;
}

.ranking_list .shikaku_detail {
  margin: 0;
  padding: 10px;
  width: 100%;
}

.ranking_list .shikaku_detail .detail_cont {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0;
  padding: 0;
  width: 100%;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img {
  margin: 0;
  padding: 0;
  width: 20%;
  background: #f6f6f6;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img .img_cont {
  margin: 5px auto 0 auto;
  padding: 0;
  width: 96%;
  height: 200px;
  overflow: hidden;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img .img_cont > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img .shikaku_link {
  margin: 30px auto 0 auto;
  padding: 0;
  width: 90%;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img .shikaku_link > a {
  display: block;
  margin: 0;
  padding: 8px 0;
  width: 100%;
  font-size: 16px;
  color: #fff;
  text-align: center;
  background: #157392;
  border-radius: 5px;
  text-decoration: none;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_img .shikaku_link > a:hover {
  background: #0b5a74;
  transition: all 0.3s;
}

.ranking_list .shikaku_detail .detail_cont .shikaku_txt {
  margin: 0;
  padding: 0;
  width: 78%;
  font-size: 15px;
  color: #333;
  line-height: 1.4rem;
}

/**
* 2023年5月追記
* WEB限定キャンペーン
*--------------------------------------------------------*/
.wcamp_main_visual {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.wcamp_main_visual .img_area {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

.wcamp_main_visual .img_area > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

/* 今すぐ講座の選択をするボタン */
.go_select {
  display: none;
}

/* インフォメーションエリア */
.cp_information {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 1200px;
}

.cp_information .reason,
.cp_information .payment_method {
  position: relative;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.cp_information .reason .reason_list {
  background: #D7EEFC;
}

.cp_information .payment_method .payment_cont {
  background: #EDFCE0;
}

.cp_information .reason .reason_title,
.cp_information .payment_method .payment_title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  padding: 0;
  width: 50%;
  height: 45px;
  font-size: 22px;
  color: #fff;
  border-radius: 5px;
  z-index: 10;
}

.cp_information .reason .reason_title {
  background: #338DBA;
}

.cp_information .payment_method .payment_title {
  background: #71B537;
}

.cp_information .reason .reason_list,
.cp_information .payment_method .payment_cont {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: -22.5px auto 0 auto;
  padding: 60px 30px 30px 30px;
  width: 100%;
}

.cp_information .reason .reason_list > li,
.cp_information .payment_method .payment_cont > li {
  margin: 0 0 20px 0;
  padding: 0;
  width: 49%;
  background: #fff;
  box-sizing: border-box;
}

.cp_information .reason .reason_list > li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 30px;
}

.cp_information .reason .reason_list > li .reason_img {
  margin: 0;
  padding: 0;
  width: 120px;
  height: 100px;
  overflow: hidden;
}

.cp_information .reason .reason_list > li .reason_img > img {
  max-width: 80%;
  height: auto;
}

.cp_information .reason .reason_list > li .reason_txt {
  margin: 0;
  padding: 0;
  width: 71%;
}

.cp_information .reason .reason_list > li .reason_txt > dt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 22px;
  font-weight: bold;
  color: #C72E2E;
}

.cp_information .reason .reason_list > li .reason_txt > dd {
  margin: 10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 14px;
  color: #333;
  line-height: 1.6rem;
}

.cp_information .payment_method .payment_cont .list_contents {
  margin: 0;
  padding: 0;
  width: 100%;
}

.cp_information .payment_method .payment_cont .list_contents > dt {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 20px;
  width: 100%;
  height: 40px;
  font-size: 18px;
  color: #fff;
  background: #86C153;
  box-sizing: border-box;
}

.cp_information .payment_method .payment_cont .list_contents > dd {
  margin: 0;
  padding: 15px 30px;
  width: 100%;
}

.cp_information .payment_method .payment_cont .list_contents > dd > p {
  display: inline-block;
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 14px;
  color: #333;
  line-height: 1.6rem;
}

.cp_information .payment_method .payment_cont .list_contents > dd .txt_list {
  margin: 10px 0;
  padding: 0;
  width: 100%;
}

.cp_information .payment_method .payment_cont .list_contents > dd .txt_list > li {
  margin: 0 0 8px 1.5em;
  padding: 0;
  width: 100%;
  font-size: 14px;
  color: #333;
  list-style-position: outside;
  list-style-type: disc;
}

.cp_information .payment_method .payment_cont .list_contents > dd .payment_img {
  margin: 25px auto 10px auto;
  padding: 0;
  width: 70%;
  overflow: hidden;
}

.cp_information .payment_method .payment_cont .list_contents > dd .payment_img > img {
  max-width: 100%;
  height: auto;
}

/* コンテンツラッパー */
.contents_wrapper {
  margin: 50px auto 0 auto;
  padding: 0;
  width: 1200px;
}

/* 選択タイトル */
.select_title {
  position: relative;
  margin: 0 auto;
  width: 70%;
  height: 60px;
  padding: 0 2rem;
  color: #fff;
  text-align: center;
  line-height: 60px;
  background: #fa4141;
}

.select_title:before,
.select_title:after {
  position: absolute;
  top: 0;
  display: block;
  height: 48px;
  content: "";
  border: 30px solid #fa4141;
}

.select_title:before {
  left: -40px;
  border-left-width: 15px;
  border-left-color: transparent;
}

.select_title:after {
  right: -40px;
  border-right-width: 15px;
  border-right-color: transparent;
}

/* アクション説明文 */
.select_explain {
  display: block;
  margin: 25px auto 0 auto;
  padding: 0;
  width: 70%;
  font-size: 1.4rem;
  font-weight: bold;
  color: #000;
  text-align: center;
}

/* 選択可能講座説明文 */
.select_num_msg {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 70%;
  font-size: 1.2rem;
  font-weight: bold;
  color: #ed3333;
  text-align: center;
}

.select_num_msg .select_num {
  margin-right: 3px;
  font-size: 1.8rem;
}

/* 選択コース */
.select_course {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 60px auto;
  padding: 0;
  width: 70%;
}

.select_course .course_list {
  margin: 0;
  padding: 0;
  width: 48%;
}

.select_course .course_list > dt {
  margin: 0;
  padding: 10px 0;
  width: 100%;
  font-size: 1.5rem;
  font-weight: bold;
  color: #fff;
  text-align: center;
}

.select_course .course_list > dd {
  margin: 0;
  padding: 20px;
  width: 100%;
}

.select_course .course_list > dd .first_txt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.1rem;
  font-weight: bold;
  color: #000;
  text-align: center;
}

.select_course .course_list > dd .second_txt {
  margin: -10px 0 0 0;
  padding: 0;
  width: 100%;
  font-size: 2.2rem;
  font-weight: bold;
  text-align: center;
}

.select_course .course_list > dd .second_txt .large_txt {
  margin-right: 3px;
  font-size: 2.8rem;
  color: #E247A0;
}

.select_course .course_list > dd .default_fee {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  color: #333;
  text-align: center;
  text-decoration: line-through;
}

.select_course .course_list > dd .triangle {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1rem;
  color: #DE4040;
  text-align: center;
}

.select_course .course_list > dd .campaign_fee {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 2.2rem;
  font-weight: bold;
  color: #D92F2F;
  text-align: center;
}

/* コース選択ラジオボタン */
.select_radio {
  margin: 10px auto 0 auto;
  padding: 0;
  width: 80%;
}

/* input[type=radio] {
	display: none;
} */
input[name=campaign_course] {
  display: none;
}

.select_radio .select_label {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 50px;
  font-size: 1.1rem;
  font-weight: bold;
  background: #d9ca28;
  border-radius: 4px;
  cursor: pointer;
}

input[name=campaign_course]:not(:checked) + label:hover {
  background: #ecde41;
  transition: all 0.3s;
}

input[name=campaign_course]:checked + label {
  background: #c71c1c;
  color: #fff;
}

.course_list.c_master {
  background: #CCEDF8;
}

.course_list.c_master > dt {
  background: #3895B5;
}

.course_list.c_takumi {
  background: #FCF8C8;
}

.course_list.c_takumi > dt {
  background: #D6CA34;
}

.select_course .course_list.c_master > dd .second_txt {
  color: #3895B5;
}

.select_course .course_list.c_takumi > dd .second_txt {
  color: #D6CA34;
}

/* 講座リスト */
.kouza_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 30px auto 0 auto;
  padding: 0;
  width: 100%;
}

.kouza_list > li {
  margin: 0 0 20px 0;
  padding: 0;
  width: 32%;
  background: #e6fae8;
}

.kouza_list > li .kouza_category {
  position: relative;
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 20px;
  width: 100%;
  height: 45px;
  font-size: 1.1rem;
  font-weight: bold;
  color: #fff;
  background: #56b45d;
  border-bottom-style: solid;
  border-bottom-width: 3px;
}

.kouza_list > li .kouza_contents {
  margin: 0;
  padding: 15px 20px;
  width: 100%;
}

.kouza_list > li .kouza_contents > li {
  margin: 0 0 10px 0;
  padding: 7px 7px 7px 2rem;
  width: 100%;
  font-size: 1rem;
  background: #fff;
}

.kouza_list > li .kouza_contents > li .n_fee {
  font-size: 0.9rem;
  color: #666;
}

/* input[type='checkbox'] {
	margin-left: -1.3rem;
} */
.kouza_list > li .kouza_contents input[type=checkbox] {
  margin-left: -1.3rem;
}

/* 選択された講座表示エリア */
.selected_kouza {
  position: fixed;
  bottom: -100%;
  left: 0;
  margin: 0;
  padding: 15px 0;
  width: 100vw;
  height: auto;
  background: rgba(33, 75, 160, 0.9);
  transition: all 0.5s;
}

.selected_kouza.panel-active {
  bottom: 0;
}

.selected_kouza .area_container {
  margin: 0 auto;
  padding: 0;
  width: 80%;
}

.selected_kouza .area_container .selected_kouza_txt {
  margin: 0;
  padding: 0;
  width: 100%;
  font-size: 1.2rem;
  color: #fff;
  text-align: center;
}

.selected_kouza .area_container .s_kouza_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 20px auto 20px auto;
  padding: 0;
}

.selected_kouza .area_container .s_kouza_list.k2 {
  width: 70%;
}

.selected_kouza .area_container .s_kouza_list.k2 #s_kouza3 {
  display: none;
}

.selected_kouza .area_container .s_kouza_list.k3 {
  width: 100%;
}

.selected_kouza .area_container .s_kouza_list.k2 .s_kouza {
  width: 49%;
}

.selected_kouza .area_container .s_kouza_list.k3 .s_kouza {
  width: 32.6666666667%;
}

.selected_kouza .area_container .s_kouza_list .s_kouza {
  margin: 0;
  padding: 5px 8px;
  width: 100%;
  height: 32px;
  font-size: 0.9rem;
  color: #fff;
  text-align: center;
  line-height: 1.5rem;
  background: #8a3838;
  overflow: hidden;
}

.selected_kouza .area_container .s_kouza_list .s_kouza.add_kouza {
  color: #000;
  -moz-text-align-last: left;
       text-align-last: left;
  background: #fff;
}

.selected_kouza .area_container .action_area .submit_btn {
  margin: 0 auto 20px auto;
  padding: 0;
  width: 100%;
}

.selected_kouza .area_container .action_area .submit_btn .action_btn {
  position: relative;
  margin: 0 auto;
  padding: 0;
  width: 30%;
  height: 60px;
  font-size: 1.4rem;
  font-weight: bold;
  color: #fff;
  background: #ea7b0c;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}

.selected_kouza .area_container .action_area .submit_btn .action_btn::after {
  content: "\f101";
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
}

.selected_kouza .area_container .action_area .submit_btn .action_btn:hover {
  background: #c23903;
  transition: all 0.3s;
}

/* モーダルダイアログ */
.select-alert {
  display: none;
  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
  z-index: 100;
}

.alert_bg {
  position: absolute;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.8);
}

.alert_msg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 20px;
  width: 30%;
  font-size: 1rem;
  line-height: 1.6rem;
  background: #fbeffa;
  border-radius: 5px;
}

.alert_close {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 20px auto 0 auto;
  padding: 0;
  width: 50%;
  height: 40px;
  font-size: 1rem;
  color: #fff !important;
  background: #ff963a;
  border-radius: 4px;
  text-decoration: none;
}

.alert_close:hover {
  text-decoration: none;
  background: #e07f29;
  transition: all 0.3s;
}


/**
* スマートフォン
*------------------------------------------------------------*/
@media screen and (max-width: 480px) {

  /**
  ** 見出し
  **
  ===================================================================*/
  
  /*
  * 資格講座一覧表示ページタイトル
  *-----------------------------------------------*/
  .kouza_list_head_area {
    margin: 20px auto 0 auto;
    padding: 0;
  }
  
  .kouza_list_head_area .kouza_list_title {
    font-size: 1.625rem;
    line-height: 2.4rem;
  }
  
  .kouza_list_head_area .kouza_list_en_title {
    font-size: 1.125rem;
  }
  
  .kouza_list_head_area .kouza_list_lead {
    width: 92%;
    font-size: 0.875rem;
    line-height: 1.6rem;
  }
  
  /*
  * 【固定ページ】ページタイトル
  *-----------------------------------------------*/
  .one_column_title {
    margin: 20px auto;
  }
  
  .one_column_title .main_title {
    font-size: 1.5rem;
  }
  
  .one_column_title .title_lead {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  /*
  * 【固定ページ】ページ内セクションタイトル
  *-----------------------------------------------*/
  /* .sp_page_st_setting, */
  .page_section_title {
    font-size: 1.25rem;
  }
  
  .page_section_title .title_emp {
    font-size: 1.6rem;
  }
  
  /* .sp_page_st_setting > i, */
  .page_section_title > i {
    font-size: 1.6rem;
  }
  
  
  /**
  ** メイン画像
  **
  ===================================================================*/
  
  /*
  * 【固定ページ】ページメイン画像
  *-----------------------------------------------*/
  .page_main_image {
    margin: 0 auto;
    padding: 0;
    height: 250px;
  }
  
  .page_main_image .pagename_area {
    top: 80%;
    left: 50%;
    transform: translate(-50%, -80%);
    padding: 10px 20px;
    width: 94%;
    background: rgba(104, 135, 188, 0.8);
  }
  
  .page_main_image .pagename_area .page_category .category_name {
    padding: 3px 15px;
    width: 100%;
    font-size: 0.9rem;
    text-align: left;
  }
  
  .page_main_image .pagename_area .page_category::after {
    display: none;
  }
  
  .page_main_image .pagename_area .page_name {
    font-size: 1.2rem;
  }
  
  
  /**
  ** 資格取得講座一覧
  **
  ===================================================================*/
  
  /*
  * 一覧トップ画面カテゴリー表示
  *-----------------------------------------------*/
  .top_kouza_list_category {
    margin: 20px auto 0 auto;
    width: 94%;
  }
  
  .top_kouza_list_category li {
    margin: 0 auto 10px auto;
    width: calc(98% / 2);
    height: 120px;
  }
  
  .top_kouza_list_category li > a .category_title {
    font-size: 14px;
  }
  
  /*
  * 各講座一覧ページ内資格カテゴリー
  *-----------------------------------------------*/
  .other_course_category {
    margin: 30px auto 0 auto;
    padding: 30px 3% 10px 3%;
    width: 94%;
  }
  
  .other_course_category .list_title {
    font-size: 1.2rem;
  }
  
  
  .kouza_list_category {
    margin: 0 auto;
    width: 100%;
  }
  
  .kouza_list_category li {
    height: 80px;
    width: calc(99% / 2);
  }
  
  .kouza_list_category li > a .category_title {
    height: 40px;
    font-size: 0.75rem;
  }
  
  /*
  * 資格講座コンテンツ
  *-----------------------------------------------*/
  .kouza_list_section .kouza_category_title {
    margin: 20px 0 30px 0;
    width: 90%;
    height: 50px;
  }
  
  .kouza_list_section .kouza_category_title::after {
    border-width: 25px 20px 25px 0;
  }
  
  .kouza_list_section .kouza_category_title .category_title {
    padding: 3px 0 7px 20px;
    font-size: 1.25rem;
  }
  
  .kouza_list_section .list_section_inner {
    padding: 0 15px 20px 15px;
  }
  
  .kouza_list_section .list_section_inner .kouza_list_header .list_img {
    width: 100%;
    height: 130px;
  }
  
  .kouza_list_section .list_section_inner .kouza_list_header .list_summary {
    margin-top: 10px;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .kouza_list_section .list_section_inner .list_body {
    margin: 20px auto 0 auto;
  }
  
  .kouza_list_section .list_section_inner .list_body > li {
    margin: 0;
    padding: 10px 15px;
    width: 100%;
  }
  
  .kouza_list_section .list_section_inner .list_body > li + li {
    margin-top: 10px;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_title {
    font-size: 1rem;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_img {
    height: 80px;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_lead {
    font-size: 0.8125rem;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .special_txt {
    display: none;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get {
    margin: 10px 0 0 0;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd {
    padding: 5px 15px;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd .shikaku_txt > li {
    margin: 0;
    font-size: 0.8125rem;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_shikaku_get > dd .shikaku_txt > li + li {
    margin-top: 4px;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_link_btn {
    margin: 15px auto 0 auto;
    height: 40px;
  }
  
  .kouza_list_section .list_section_inner .list_body > li .kouza_link_btn > a {
    font-size: 1rem;
  }
  
  /* 202310追記 */
  /*
  * 人気資格講座ランキング
  *-----------------------------------------------*/
  .popular_kouza {
    padding-bottom: 10px;
  }
  
  .popular_kouza .popular_title {
    font-size: 1.2rem;
    border-left-width: 56px;
  }
  
  .popular_kouza .popular_title::before {
    left: -12%;
  }
  
  .popular_kouza .popular_title::after {
    content: none;
  }
  
  .popular_kouza .popular_kouza_list {
    margin-top: 20px;
  }
  
  .popular_kouza .popular_kouza_list::after {
    content: none;
  }
  
  .popular_kouza .popular_kouza_list > li {
    width: 49%;
  }
  
  .popular_kouza .popular_kouza_list > li > a .list_contents {
    height: 140px;
  }
  
  .popular_kouza .popular_kouza_list > li > a .list_contents > dd {
    bottom: 0;
    width: 100%;
  }
  
  .popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dt {
    padding: 3px 8px;
    font-size: 0.7rem;
    border-radius: 0;
  }
  
  .popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dd {
    padding: 6px 8px;
    font-size: 0.8rem;
    border-radius: 0;
  }
  
  .popular_kouza .popular_kouza_list > li > a .list_contents > dd .kouza_info > dd::after {
    font-size: 0.7rem;
  }
  
  /* ランキングリスト */
  .kouza_ranking_list {
    margin: 30px auto 0 auto;
    width: 94%;
  }
  
  .kouza_ranking_list .ranking_list {
    margin: 0 auto 20px auto;
    padding: 10px 0 0 0;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .ranking_no {
    width: 90px;
    height: 70px;
  }
  
  .kouza_ranking_list .ranking_list.ranking_1 .contents_title_area .ranking_no,
  .kouza_ranking_list .ranking_list.ranking_2 .contents_title_area .ranking_no,
  .kouza_ranking_list .ranking_list.ranking_3 .contents_title_area .ranking_no,
  .kouza_ranking_list .ranking_list.ranking_4-10 .contents_title_area .ranking_no {
    background-size: 90px 60px;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .ranking_no .rank_num {
    font-size: 1.75rem;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .ranking_no .rank_unit {
    margin: 0 0 0 4px;
    padding: 7.5px 0 0 0;
    font-size: 1.2rem;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .title_area {
    width: 69%;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .title_area .kouza_category {
    width: 90%;
    font-size: 0.75rem;
  }
  
  .kouza_ranking_list .ranking_list .contents_title_area .title_area .kouza_name {
    font-size: 1.1rem;
    line-height: auto;
  }
  
  .kouza_ranking_list .ranking_list .detail_area {
    padding: 15px 10px 10px 10px;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .photo_course {
    width: 100%;
    height: 120px;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .get_shikaku_title {
    height: 30px;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .shikaku_list {
    padding: 15px 15px 10px 15px;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents li {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn {
    flex-wrap: wrap;
    margin: 15px auto 0 auto;
    padding: 0;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn .detail_link {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .link_btn .document_link {
    width: 100%;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .recommend,
  .kouza_ranking_list .ranking_list .detail_area .txt_contents .recommend_area .working {
    margin-bottom: 7px;
    width: 100%;
  }
  
  .kouza_ranking_list .ranking_list .detail_area .kouza_explain {
    margin: 15px 0 0 0;
    padding: 15px 20px;
  }
  
  .more_ranking {
    height: 50px;
  }
  
  .more_ranking > a {
    width: 94%;
  }
  
  
  /**
  ** スクールについて
  **
  ===================================================================*/
  
  /*
  * スクールについてページメニュー
  *---------------------------------------------------*/
  .school_page_menu {
    margin-bottom: 10px;
    width: 96%;
  }
  
  .school_page_menu > li {
    margin-bottom: 5px;
    height: 45px;
  }
  
  .school_page_menu > li > a {
    font-size: 0.8rem;
  }
  
  .school_page_menu > li.inner:first-child {
    width: 100%;
  }
  
  .school_page_menu > li.inner:not(:first-child) {
    width: calc(98% / 2);
  }
  
  .school_page_menu > li.outer {
    width: calc(98% / 2);
  }
  
  /*
  * スクールについて概要
  *---------------------------------------------------*/
  .school_head {
    padding: 30px 20px;
  }
  
  .school_head .summary_area {
    width: 100%;
  }
  
  .school_head .summary_area .summary_txt {
    margin: 10px auto 0 auto;
    font-size: 0.875rem;
    line-height: 1.6rem;
  }
  
  .school_head .ryo_meaning {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  /*
  * 諒設計アーキテクトラーニング概要
  *---------------------------------------------------*/
  .school_tbl {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .school_tbl tr th,
  .school_tbl tr td {
    display: block;
    width: 100%;
  }
  
  .school_tbl th {
    padding: 7px 15px;
    font-size: 0.9375rem;
  }
  
  .school_tbl td {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .school_tbl .td_01 {
    width: 100%;
  }
  
  .school_tbl .td_02 {
    padding: 7px 80px;
    width: 100%;
    border: none;
  }
  
  /*
  * 諒設計とは？
  *---------------------------------------------------*/
  .sekkei_summary {
    margin: 20px auto 0 auto;
    padding: 0;
  }
  
  .sekkei_summary > dt {
    font-size: 1.125rem;
  }
  
  .sekkei_summary > dd {
    margin: 10px auto 0 auto;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .sekkei_tbl {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .sekkei_tbl tr th,
  .sekkei_tbl tr td {
    display: block;
    width: 100%;
  }
  
  .sekkei_tbl th {
    padding: 7px 15px;
    font-size: 0.9375rem;
  }
  
  .sekkei_tbl td {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .sekkei_tbl .td_01 {
    width: 100%;
  }
  
  .sekkei_tbl .td_02 {
    padding: 7px 80px;
    width: 100%;
    border: none;
  }
  
  /*
  * 沿革
  *---------------------------------------------------*/
  .history_area {
    margin: 30px auto 0 auto;
    width: 96%;
  }
  
  .history_area .history_row + dl {
    margin-top: 20px;
  }
  
  .history_area .history_row > dt {
    width: 100%;
  }
  
  .history_area .history_row > dd {
    margin: 10px auto 0 auto;
    width: 100%;
    font-size: 0.875rem;
    font-weight: normal;
    line-height: 1.5rem;
  }
  
  /*
  * ページリンクエリア
  *---------------------------------------------------*/
  .others_link_area {
    margin: 20px auto 50px auto;
    width: 94%;
  }
  
  .others_link_area > a .link_cont > dt {
    font-size: 0.875rem;
  }
  
  .others_link_area > a .link_cont > dd {
    font-size: 1.125rem;
  }
  
  .others_link_area > a .link_cont > dd::after {
    right: 15%;
  }
  
  /*
  * お申し込み・お支払いについて
  *---------------------------------------------------*/
  
  /*
  * お申し込み
  *---------------------------------------------------*/
  .order_tel_title {
    margin: 20px auto 0 auto;
    width: 100%;
    font-size: 1rem;
  }
  
  .order_tel_summary {
    margin: 9px auto 0 auto;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .tel_fax_number {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .tel_fax_number > li {
    width: 100%;
  }
  
  .tel_fax_number > li + li {
    margin-top: 10px;
  }
  
  .tel_fax_number > li .number_body > dt {
    font-size: 0.9375rem;
  }
  
  .kouza_order > a {
    width: 80%;
    height: 40px;
  }
  
  /*
  * お支払いについて
  *---------------------------------------------------*/
  .payment_summary {
    margin: 10px auto 0 auto;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .payment_list {
    width: 100%;
  }
  
  .payment_list > li {
    margin-bottom: 5px;
    width: calc(98.5% / 2);
    height: 50px;
  }
  
  .payment_list > li > a {
    display: block;
    padding-top: 7px;
    text-align: center;
  }
  
  .payment_list > li > a::after {
    top: 70%;
    right: 45%;
  }
  
  .payment_list > li > a:hover {
    background: #d6d895;
  }
  
  /*
  * オススメのお支払い
  *---------------------------------------------------*/
  .payment_recommend {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .payment_recommend > dt {
    font-size: 0.875rem;
    line-height: 1.6rem;
  }
  
  .payment_recommend > dt .pay_emp {
    font-size: 0.75rem;
  }
  
  .payment_recommend > dd {
    margin: 5px auto 0 auto;
    line-height: 1.5rem;
  }
  
  /*
  * 代金引換
  *---------------------------------------------------*/
  .pay_daibiki {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .pay_daibiki > dt {
    padding: 5px 15px;
    font-size: 1rem;
  }
  
  .pay_daibiki > dd {
    padding: 20px 15px;
  }
  
  .pay_daibiki > dd .e-collect_img {
    display: flex;
    justify-content: center;
    margin-bottom: 8px;
    width: 100%;
  }
  
  .pay_daibiki > dd .e-collect_img > img {
    max-width: 40%;
  }
  
  .pay_daibiki > dd .txt_lead {
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .daibiki_method {
    padding: 0 10px 20px 10px;
    width: 100%;
  }
  
  .daibiki_method > li {
    width: 100%;
  }
  
  .daibiki_method > li + li {
    margin-top: 10px;
  }
  
  .daibiki_method > li .method_body .pay_term {
    padding: 6px 5px;
  }
  
  .daibiki_method > li .method_body .pay_term .ikkatsu {
    font-size: 0.75rem;
  }
  
  .daibiki_method > li .method_body .pay_term .bunkatsu {
    font-size: 0.75rem;
  }
  
  .daibiki_method > li .method_body .method_txt .debit .debit_txt {
    line-height: 1.2rem;
  }
  
  /*
  * 後払い
  *---------------------------------------------------*/
  .pay_atobarai {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .pay_atobarai > dt {
    padding: 5px 15px;
    font-size: 1rem;
  }
  
  .pay_atobarai > dd {
    padding: 10px 15px;
  }
  
  .pay_atobarai > dd .txt_lead {
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .pay_atobarai > dd .img_atobarai {
    margin: 20px auto;
  }
  
  /*
  * クレジットカード決済
  *---------------------------------------------------*/
  .pay_credit {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .pay_credit > dt {
    padding: 5px 15px;
    font-size: 1rem;
  }
  
  .pay_credit > dd {
    padding: 10px 15px;
  }
  
  .pay_credit > dd .txt_lead {
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .pay_credit > dd .img_credit {
    margin: 20px auto;
  }
  
  /*
  * オリコの教育ローン
  *---------------------------------------------------*/
  .pay_orico {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .pay_orico > dt {
    padding: 5px 15px;
    font-size: 1rem;
  }
  
  .pay_orico > dd {
    padding: 10px;
  }
  
  .pay_orico > dd .orico_process {
    padding: 15px 5px;
  }
  
  .pay_orico > dd .orico_process > dt {
    position: relative;
    display: flex;
    align-items: center;
    padding: 0 0 5px 50px;
    height: 50px;
    font-size: 0.875rem;
  }
  
  .pay_orico > dd .orico_process > dt .process_no {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    width: 40px;
    height: 45px;
  }
  
  .pay_orico > dd .orico_process > dd {
    margin: 0 auto;
    width: 94%;
  }
  
  .pay_orico > dd .orico_process > dd .process_img {
    display: flex;
    justify-content: center;
    margin: 15px 0;
    width: 100%;
  }
  
  .pay_orico > dd .orico_process > dd .process_txt {
    width: 100%;
  }
  
  .orico_simu_notice {
    margin: 30px auto 0 auto;
  }
  
  .orico_simu_notice .orico_simu {
    padding: 0;
    width: 100%;
  }
  
  .orico_simu_notice .orico_notice {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .orico_simu_notice .orico_notice > dd {
    padding: 10px 15px;
    font-size: 0.8125rem;
    line-height: 1.2rem;
  }
  
  /*
  * メディア掲載実績
  *---------------------------------------------------*/
  
  /*
  * タイトルリード小文字
  *---------------------------------------------------*/
  .smt {
    font-size: 0.8125rem;
    line-height: 1.2rem;
  }
  
  /*
  * カテゴリタイトル
  *---------------------------------------------------*/
  .jisseki_cat_title {
    padding: 8px 0;
    font-size: 1.125rem;
    text-indent: 20px;
  }
  
  .jisseki_cat_title:not(:first-child) {
    margin-top: 20px;
  }
  
  .jisseki_contents {
    width: 100%;
  }
  
  .jisseki_contents > li {
    width: 100%;
  }
  
  .jisseki_contents > li .contents_list > dt {
    padding: 8px 20px;
    min-height: auto;
  }
  
  .jisseki_contents > li .contents_list > .cont_body .cont_img {
    width: 100%;
    height: 80px;
    overflow: hidden;
  }
  
  .jisseki_contents > li .contents_list > .cont_body .cont_img > img {
    object-fit: cover;
    width: 100%;
    height: 80px;
  }
  
  .jisseki_contents > li .contents_list > .cont_body .cont_txt {
    margin: 10px auto 0 auto;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  
  /**
  * 口コミ評判
  *-------------------------------------------*/
  
  /*
  * 一覧ページカテゴリーリスト
  *---------------------------------------------------*/
  .voice_category_list {
    padding: 30px 15px;
  }
  
  .voice_category_list li {
    margin-bottom: 15px;
    width: 100%;
  }
  
  
  /**
  * カテゴリーリスト
  *-------------------------------------------*/
  .kouza_category_list {
    padding: 15px 20px;
  }
  
  .kouza_category_list::after {
    width: calc(98% / 2);
  }
  
  .kouza_category_list > li {
    height: 60px;
    width: calc(98% / 2);
    text-align: center;
  }
  
  .kouza_category_list > li > a {
    padding: 20px 0 0 0;
    font-size: 0.75rem;
  }
  
  .kouza_category_list > li > a::after {
    display: none;
  }
  
  /*
  * 口コミ一覧リスト
  *---------------------------------------------------*/
  
  /**
  * 口コミカテゴリータイトル
  *-------------------------------------------*/
  .kuchikomi_category_title_area {
    margin: 0 auto 30px auto;
  }
  
  .kuchikomi_category_title_area .kuchikomi_category_title {
    font-size: 1.5rem;
  }
  
  .kuchikomi_category_title_area .kuchikomi_category_title::before {
    font-size: 1.75rem;
  }
  
  .kuchikomi_category_title_area .kuchikomi_en_title {
    margin: 0 auto;
    font-size: 1.125rem;
  }
  
  /*
  * 口コミリスト
  *---------------------------------------------------*/
  .kuchikomi_list .kuchikomi_title {
    display: block;
    position: relative;
    padding: 10px 20px;
    height: auto;
    font-size: 1rem;
  }
  
  .kuchikomi_list .kuchikomi_title::before {
    margin-right: 10px;
    font-size: 1.25rem;
  }
  
  .kuchikomi_list .kuchikomi_title::after {
    display: none;
  }
  
  .kuchikomi_list .kuchikomi_body {
    padding: 20px 15px;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner {
    padding: 0;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .person_profile {
    display: grid;
    grid-template-rows: 50px 50px;
    grid-template-columns: 40% 60%;
    width: 100%;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_photo {
    grid-column: 1;
    grid-row: 1 / 3;
    width: 100%;
    height: 100px;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_name {
    grid-row: 1;
    grid-column: 2;
    padding: 18px 0 0 0;
    width: 100%;
    font-size: 1.125rem;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .person_profile .person_age {
    grid-column: 2;
    grid-row: 2;
    padding: 0;
    width: 100%;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt {
    margin: 10px auto 0 auto;
    width: 100%;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_lead {
    margin: 0;
    height: auto;
    font-size: 1rem;
    line-height: 1.6rem;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li {
    width: 100%;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dt {
    padding: 0 15px;
    font-size: 1rem;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dt::before {
    font-size: 1.25rem;
  }
  
  .kuchikomi_list .kuchikomi_body .body_inner .kuchikomi_txt .kuchikomi_txt_list > li .txt_body dd {
    margin: 10px 0 15px 0;
    padding: 0;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .kuchikomi_list .kuchikomi_body .link_area > li {
    width: 100%;
  }
  .kuchikomi_list .kuchikomi_body .link_area > li + li {
    margin-left: 0;
    margin-top: 8px;
  }
  
  .kuchikomi_list .kuchikomi_body .link_area > li > a {
    padding: 8px 0;
    height: auto;
  }
  
  
  /*
  * 受講サポート
  *---------------------------------------------------*/
  
  /*
  * サポートイラスト
  *---------------------------------------------------*/
  .support_illust {
    display: flex;
    justify-content: center;
    margin: 10px auto 0 auto;
    width: 100%;
  }
  
  .support_illust > img {
    max-width: 40%;
    height: auto;
  }
  
  /*
  * スクールアピール（ここが違う！）
  *---------------------------------------------------*/
  .support_school_appeal {
    margin: 40px auto 0 auto;
    padding: 0;
    width: 94%;
  }
  
  .support_school_appeal .appeal_list li {
    margin: 0;
    width: 100%;
    padding: 0 20px 40px 20px;
  }
  
  .support_school_appeal .appeal_list li + li {
    margin-top: 100px;
  }
  
  .support_school_appeal .appeal_list li .appeal_body dt {
    height: auto;
    font-size: 1.25rem;
  }
  
  .support_school_appeal .appeal_list li .appeal_body dd {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  /*
  * スクールポイント
  *---------------------------------------------------*/
  .support_list {
    margin: 80px 0 0 0;
  }
  
  .support_list .list_contents {
    width: 94%;
  }
  
  .support_list .list_contents > li {
    width: 100%;
  }
  
  .support_list .list_contents > li + li {
    margin-top: 15px;
  }
  
  .support_list .list_contents > li .contents_body > dt {
    padding-bottom: 15px;
    height: auto;
    font-size: 1.125rem;
    line-height: 1.6rem;
  }
  
  .support_list .list_contents > li .contents_body .contents_txt {
    margin: 15px 0 0 0;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .support_list .list_contents > li .contents_body .horizontal .horizontal_body .body_txt {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .support_list .document_txt {
    margin: 30px auto 0 auto;
    width: 92%;
    font-size: 1rem;
    line-height: 1.8rem;
  }
  
  /*
  * 無料で資料請求
  *---------------------------------------------------*/
  .docu_request_area {
    padding: 60px 0 50px 0;
  }
  
  .docu_request_area .area_inner {
    width: 92%;
  }
  
  .docu_request_area .area_inner .req_txt {
    width: 100%;
  }
  
  .docu_request_area .area_inner .req_txt > dt {
    font-size: 1.25rem;
  }
  
  .docu_request_area .area_inner .req_txt .sub_txt {
    font-size: 0.875rem;
  }
  
  .docu_request_area .area_inner .req_txt .req_btn {
    margin: 20px auto 0 auto;
    width: 80%;
  }
  
  .docu_request_area .area_inner .req_txt .req_btn > a {
    padding: 10px 20px 10px 0;
    font-size: 1.25rem;
  }
  
  .docu_request_area .area_inner .req_txt .guidebook {
    margin: 30px auto 0 auto;
    padding: 20px 30px;
    width: 100%;
  }
  
  .docu_request_area .area_inner .req_txt .guidebook .guidebook_body .book_img {
    width: 30%;
  }
  
  .docu_request_area .area_inner .req_txt .guidebook .guidebook_body .book_txt {
    width: 65%;
    font-size: 1rem;
    line-height: 1.6rem;
  }
  
  .docu_request_area .area_inner .pamphlet_img {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  
  /*
  * 受講生専用ページ
  *---------------------------------------------------*/
  
  /*
  * コンテンツエリア
  *---------------------------------------------------*/
  .student_support {
    position: relative;
    margin: 0 auto;
    padding: 0;
    width: 92%;
    background: #fff;
    border-radius: 5px;
  }
  
  /*
  * カテゴリータイトル
  *---------------------------------------------------*/
  .st_category_title {
    font-size: 1.25rem;
  }
  
  .st_category_title:not(:first-child) {
    margin-top: 30px;
  }
  
  .st_category_title::before {
    font-size: 1.5rem;
  }
  
  /*
  * サポートリスト
  *---------------------------------------------------*/
  .st_support_list {
    margin: 60px auto 0 auto;
    width: 96%;
  }
  
  .st_support_list > li {
    padding: 30px 20px;
    width: 100%;
  }
  
  .st_support_list > li + li {
    margin-top: 50px;
  }
  
  .st_support_list > li .list_body {
    margin: 15px auto 0 auto;
  }
  
  .st_support_list > li .list_body > dt {
    font-size: 1.125rem;
  }
  
  .st_support_list > li .list_body > .list_txt {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .st_support_list > li .list_body .link_btn_area .link_btn {
    width: 80%;
    font-size: 0.875rem;
  }
  
  
  /*
  * 人気資格ランキング
  *---------------------------------------------------*/
  
  /*
  * ランキングタイトル
  *---------------------------------------------------*/
  .ranking_title_area {
    /* margin: 0 auto 20px auto; */
    margin: 20px auto;
  }
  
  .ranking_title_area .ranking_title {
    font-size: 1.375rem;
    text-align: left;
  }
  
  .ranking_title_area .ranking_title .title_head_img {
    margin-top: -3px;
    margin-right: 10px;
  }
  
  .ranking_title_area .ranking_en_title {
    font-size: 1.125rem;
  }
  
  /*
  * ランキングページタイトル
  *--------------------------------------------*/
  .ranking_page_title {
    display: none;
  }
  
  
  /*
  * ランキングカテゴリーリスト
  *---------------------------------------------------*/
  /* .ranking_category_list {
    margin: 0 auto 20px auto;
    padding: 15px 0;
  }
  
  .ranking_category_list .category_list li {
    width: calc(98% / 2);
    height: 80px;
  }
  
  .ranking_category_list .category_list li:nth-of-type(3) .ranking_title br {
    display: none;
  }
  
  .ranking_category_list .category_list li > a .ranking_title {
    height: 40px;
    font-size: 0.75rem;
  } */
  
  .ranking_category_list,
  .ranking_category_list.rank30_page {
    margin: 0 auto 20px auto;
    padding: 10px;
    width: 96%;
  }
  
  .ranking_category_list .category_list_main {
    width: 100%;
  }
  
  .ranking_category_list .category_list_main > li {
    margin: 0 0 5px 0;
    height: 100px;
  }
  
  .ranking_category_list .category_list_main > li > a .ranking_title {
    font-size: 0.9rem;
  }
  
  .ranking_category_list .category_list {
    width: 100%;
  }
  
  .ranking_category_list .category_list li {
    width: calc(98% / 2);
    height: 80px;
  }
  
  .ranking_category_list .category_list li.dummy {
    display: none;
  }
  
  .ranking_category_list .category_list li:nth-of-type(3) .ranking_title br {
    display: none;
  }
  
  .ranking_category_list .category_list li > a .ranking_title {
    height: 40px;
    font-size: 0.7rem;
  }
  
  /*
  * ランキングリスト
  *---------------------------------------------------*/
  
  /* 1〜3位 */
  .ranking_contents {
    margin: 0 auto 20px auto;
    padding: 15px 0 0 0;
  }
  
  .ranking_contents .contents_title_area .ranking_no {
    padding: 4px 0;
    width: 26%;
    height: 50px;
  }
  
  .ranking_contents .contents_title_area .ranking_no::after {
    border-width: 25px 20px 25px 0;
  }
  
  .ranking_contents .contents_title_area .ranking_no .rank_num {
    font-size: 1.75rem;
    line-height: 36px;
  }
  
  .ranking_contents .contents_title_area .ranking_no .rank_num::after {
    font-size: 1.25rem;
  }
  
  .ranking_contents .contents_title_area .title_area {
    width: 69%;
  }
  
  .ranking_contents .contents_title_area .title_area .kouza_category {
    width: 90%;
    font-size: 0.75rem;
  }
  
  .ranking_contents .contents_title_area .title_area .kouza_name {
    font-size: 1.25rem;
    line-height: 1.8rem;
  }
  
  .ranking_contents .detail_area {
    padding: 15px 10px 10px 10px;
  }
  
  .ranking_contents .detail_area .photo_course {
    width: 100%;
  }
  
  .ranking_contents .detail_area .photo_course dt {
    height: 120px;
  }
  
  .ranking_contents .detail_area .photo_course dd {
    margin: 15px auto 0 auto;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info th {
    padding: 3px 0 3px 10px;
    font-size: 0.75rem;
    border-bottom: 2px solid #fff;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info .term::before {
    margin-right: 5px;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info .course::before {
    margin-right: 5px;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info td {
    padding: 3px 0 3px 10px;
    font-size: 1rem;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info td .special_exam {
    margin: 0 0 0 5px;
    padding: 2px 6px 4px 6px;
    font-size: 0.625rem;
  }
  
  .ranking_contents .detail_area .photo_course dd .course_info .term_txt::after {
    font-size: 0.75rem;
  }
  
  .ranking_contents .detail_area .txt_contents {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .ranking_contents .detail_area .txt_contents .kouza_summary {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  
  .ranking_contents .detail_area .txt_contents .get_shikaku_title {
    font-size: 0.875rem;
  }
  
  .ranking_contents .detail_area .txt_contents .get_shikaku_list li {
    padding: 5px 0;
    width: 100%;
    font-size: 0.875rem;
  }
  
  .ranking_contents .detail_area .txt_contents .get_shikaku_list li + li {
    margin-top: 5px;
  }
  
  .ranking_contents .detail_area .txt_contents .kouza_explain {
    margin: 10px auto 0 auto;
    padding: 10px 15px;
    font-size: 0.8125rem;
    line-height: 1.4rem;
  }
  
  .ranking_contents .detail_area .txt_contents .link_btn {
    flex-wrap: wrap;
    margin: 15px auto 0 auto;
    padding: 0;
  }
  
  .ranking_contents .detail_area .txt_contents .link_btn .detail_link {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .ranking_contents .detail_area .txt_contents .link_btn .document_link {
    width: 100%;
  }
  
  /* 202310追記 */
  .ranking_contents .kouza_point_area {
    width: 96%;
  }
  
  .ranking_contents .kouza_point_area .kouza_title {
    padding: 6px 0;
    font-size: 1rem;
  }
  
  .ranking_contents .kouza_point_area .kouza_title .rank_num {
    margin-right: 10px;
    padding-left: 25px;
    background-size: 20px;
  }
  
  .ranking_contents .kouza_point_area .point_inner {
    margin-top: 16px;
    width: 100%;
  }
  
  .ranking_contents .kouza_point_area .point_inner .recommend_point {
    width: 100%;
  }
  
  .ranking_contents .kouza_point_area .point_inner .recommend_point .recommend_title {
    margin-bottom: 20px;
    padding-top: 3px;
    width: 100%;
    height: 40px;
    font-size: 1.1rem;
  }
  
  .ranking_contents .kouza_point_area .point_inner .recommend_point .point_cont {
    margin-bottom: 8px;
    padding-left: 30px;
    width: 96%;
    font-size: 0.9rem;
    background-size: 26px;
    background-position: top left;
  }
  
  .ranking_contents .kouza_point_area .point_inner .point_img {
    margin-top: 14px;
    width: 100%;
  }
  
  
  /*
  * リライトページ
  *-------------------------*/
  .kouza_img {
    padding: 5px 10px 10px 10px;
  }
  
  .ranking_contents .link_btn_new {
    display: block;
    margin: 15px 0 0 0;
  }
  
  .ranking_contents .link_btn_new .detail_link {
    /* margin: 0 10px 0 0;
    width: 250px;
    height: 40px; */
    margin: 0 0 10px 0;
    width: 100%;
  }
  
  .ranking_contents .link_btn_new .document_link {
    width: 100%;
  }
  
  
  /* 4位〜5位 */
  .next_ranking li {
    width: 100%;
  }
  
  .next_ranking li .next_ranking_contents {
    margin: 0 auto 20px auto;
    padding: 15px 0 0 0;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .ranking_no {
    padding: 4px 0;
    width: 26%;
    height: 50px;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .ranking_no::after {
    border-width: 25px 20px 25px 0;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .ranking_no .rank_num {
    font-size: 1.75rem;
    line-height: 36px;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .ranking_no .rank_num::after {
    font-size: 1.25rem;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .title_area {
    width: 69%;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .title_area .kouza_category {
    margin: 0;
    width: 90%;
    font-size: 0.75rem;
  }
  
  .next_ranking li .next_ranking_contents .contents_title_area .title_area .kouza_name {
    font-size: 1.25rem;
    line-height: 1.8rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area {
    padding: 15px 10px 10px 10px;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .kouza_photo {
    height: 120px;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .kouza_summary {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .get_shikaku_title {
    font-size: 0.875rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .get_shikaku_list li {
    padding: 5px 0;
    width: 100%;
    font-size: 0.875rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .get_shikaku_list li + li {
    margin-top: 5px;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info {
    margin: 15px 0 0 0;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info th {
    padding: 3px 0 3px 10px;
    font-size: 0.75rem;
    border-bottom: 2px solid #fff;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info .term::before {
    margin-right: 5px;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info .course::before {
    margin-right: 5px;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info td {
    padding: 3px 0 3px 10px;
    font-size: 1rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info td .special_exam {
    margin: 0 0 0 5px;
    padding: 2px 6px 4px 6px;
    font-size: 0.625rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .course_info .term_txt::after {
    font-size: 0.75rem;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .link_btn {
    flex-wrap: wrap;
    margin: 15px auto 0 auto;
    padding: 0;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .link_btn .detail_link {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .next_ranking li .next_ranking_contents .detail_area .link_btn .document_link {
    width: 100%;
  }
  
  
  /* 202302追記 */
  
  /* 1〜20位 */
  .ranking_top30_1-20 {
    margin: 0 auto 20px auto;
    padding: 15px 0 0 0;
  }
  
  .ranking_top30_1-20 .contents_title_area .ranking_no {
    width: 90px;
    height: 70px;
  }
  
  .ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no {
    width: 90px;
    height: 60px;
  }
  
  
  .ranking_top30_1-20.ranking_1 .contents_title_area .ranking_no,
  .ranking_top30_1-20.ranking_2 .contents_title_area .ranking_no,
  .ranking_top30_1-20.ranking_3 .contents_title_area .ranking_no,
  .ranking_top30_1-20.ranking_4-10 .contents_title_area .ranking_no,
  .ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no {
    background-size: 90px 60px;
  }
  
  .ranking_top30_1-20 .contents_title_area .ranking_no .rank_num {
    font-size: 1.75rem;
  }
  
  .ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no .rank_num {
    font-size: 1.7rem;
  }
  
  .ranking_top30_1-20 .contents_title_area .ranking_no .rank_unit {
    margin: 0 0 0 4px;
    padding: 7.5px 0 0 0;
    font-size: 1.2rem;
  }
  
  .ranking_top30_1-20.ranking_11-20 .contents_title_area .ranking_no .rank_unit {
    margin-left: 4px;
    padding: 6px 0 0 0;
    font-size: 1rem;
  }
  
  
  .ranking_top30_1-20 .contents_title_area .title_area {
    width: 69%;
  }
  
  .ranking_top30_1-20 .contents_title_area .title_area .kouza_category {
    width: 90%;
    font-size: 0.75rem;
  }
  
  .ranking_top30_1-20 .contents_title_area .title_area .kouza_name,
  .ranking_top30_1-20.ranking_11-20 .contents_title_area .title_area .kouza_name {
    font-size: 1.2rem;
    line-height: 1.5rem;
  }
  
  .ranking_top30_1-20 .detail_area {
    padding: 15px 10px 10px 10px;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course {
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dt {
    height: 120px;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd {
    margin: 15px auto 0 auto;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info th {
    padding: 3px 0 3px 10px;
    font-size: 0.75rem;
    border-bottom: 2px solid #fff;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info .term::before {
    margin-right: 5px;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info .course::before {
    margin-right: 5px;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info td {
    padding: 3px 0 3px 10px;
    font-size: 1rem;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info td .special_exam {
    margin: 0 0 0 5px;
    padding: 2px 6px 4px 6px;
    font-size: 0.625rem;
  }
  
  .ranking_top30_1-20 .detail_area .photo_course dd .course_info .term_txt::after {
    font-size: 0.75rem;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents {
    margin: 15px auto 0 auto;
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .get_shikaku_title {
    height: 30px;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .shikaku_list {
    padding: 15px 15px 10px 15px;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .get_shikaku_list .shikaku_list .list_contents li {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .link_btn {
    flex-wrap: wrap;
    margin: 15px auto 0 auto;
    padding: 0;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .link_btn .detail_link {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .link_btn .document_link {
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .txt_contents .recommend_area .recommend,
  .ranking_top30_1-20 .detail_area .txt_contents .recommend_area .working {
    margin-bottom: 7px;
    width: 100%;
  }
  
  .ranking_top30_1-20 .detail_area .kouza_explain {
    margin: 15px 0 0 0;
    padding: 15px 20px;
  }
  
  
  /* 21位〜30位 */
  .ranking_top30_21-30 li {
    width: 100%;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents {
    margin: 0 auto 20px auto;
    padding: 10px 0 0 0;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no {
    width: 90px;
    height: 60px;
    background-size: 90px 50px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no .rank_num {
    font-size: 1.4rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .ranking_no .rank_num::after {
    margin-left: 0;
    padding-top: 3px;
    font-size: 1rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area {
    margin-top: 4px;
    width: 69%;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area .kouza_category {
    margin: 0;
    width: 90%;
    font-size: 0.75rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .contents_title_area .title_area .kouza_name {
    font-size: 1.1rem;
    line-height: 1.5rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area {
    padding: 15px 10px 10px 10px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .kouza_photo {
    height: 120px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .kouza_summary {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_title {
    font-size: 0.875rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_list li {
    padding: 5px 0;
    width: 100%;
    font-size: 0.875rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .get_shikaku_list li + li {
    margin-top: 5px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info {
    margin: 15px 0 0 0;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info th {
    padding: 3px 0 3px 10px;
    font-size: 0.75rem;
    border-bottom: 2px solid #fff;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .term::before {
    margin-right: 5px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .course::before {
    margin-right: 5px;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info td {
    padding: 3px 0 3px 10px;
    font-size: 1rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info td .special_exam {
    margin: 0 0 0 5px;
    padding: 2px 6px 4px 6px;
    font-size: 0.625rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .course_info .term_txt::after {
    font-size: 0.75rem;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn {
    flex-wrap: wrap;
    margin: 15px auto 0 auto;
    padding: 0;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .detail_link {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .ranking_top30_21-30 li .ranking21-30_contents .detail_area .link_btn .document_link {
    width: 100%;
  }
  
  /* 202305追記 */
  .main_midashi {
    padding: 5px 10px;
    width: 96%;
    font-size: 1.2rem;
  }
  
  .section_lead {
    font-size: 0.9rem;
    line-height: 1.6rem;
  }
  
  .img_midashi {
    width: 96%;
    font-size: 1.1rem;
  }
  
  .syumi_img {
    margin: 0 auto 40px auto;
    width: 96%;
  }
  
  .ranking_summary {
    padding: 15px;
    width: 96%;
    font-size: 0.9rem;
    line-height: 1.6rem;
  }
  
  /* ランキングタイトル：趣味におすすめ */
  .syumi_ranking_title_area {
    margin: 30px auto 20px auto;
    width: 96%;
  }
  
  .syumi_ranking_title_area .ranking_title {
    font-size: 1.2rem;
    text-align: left;
  }
  
  /* 202305追記ここまで */
  
  /* 202310追記 */
  .article_area {
    margin-top: 40px;
  }
  
  .article_area .ranking_article_title {
    font-size: 1.1rem;
  }
  
  .article_area .article_img {
    margin-top: 10px;
    height: 260px;
  }
  
  .article_area .article_summary {
    margin-top: 10px;
    font-size: 0.9rem;
    line-height: 1.4rem;
  }
  
  .article_area .article_midashi {
    margin-top: 20px;
    font-size: 1rem;
  }
  
  .article_area .article_body_txt {
    font-size: 0.9rem;
    line-height: 1.4rem;
  }
  
  /* 202310追記ここまで */
  
  /*
  * 著作権・免責事項について
  *---------------------------------------------------*/
  ul.chosaku_notice {
    padding: 20px 15px;
    width: 100%;
  }
  
  ul.chosaku_notice > li.japanese {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  /*
  * 個人情報の取り扱いについて
  *---------------------------------------------------*/
  .privacy_list {
    margin: 30px auto 0 auto;
    width: 100%;
  }
  
  .privacy_list > dt {
    padding: 2px 15px;
    font-size: 0.9375rem;
  }
  
  .privacy_list > dd {
    padding: 15px;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .privacy_contact {
    padding: 15px;
    width: 100%;
  }
  
  .privacy_contact > dt {
    font-size: 0.875rem;
  }
  
  .privacy_contact > dd {
    font-size: 0.9375rem;
    text-align: center;
  }
  
  /*
  * 特定商取引法に基づく表示
  *---------------------------------------------------*/
  .tokusho_lead {
    margin: 20px auto 0 auto;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  .tokusho_lead .up_date {
    margin: 15px auto 0 auto;
  }
  
  .tokusho_tbl {
    margin: 30px auto 0 auto;
    width: 100%;
  }
  
  .tokusho_tbl tr th,
  .tokusho_tbl tr td {
    display: block;
    width: 100%;
  }
  
  .tokusho_tbl th {
    padding: 5px 20px;
    font-size: 0.875rem;
  }
  
  .tokusho_tbl td {
    line-height: 1.5rem;
  }
  
  
  /*
  * 受講前のお問い合わせ
  * 学習内容に関するお問い合わせ
  * 各種お手続きに関するお問い合わせ
  *---------------------------------------------------*/
  
  /*
  * コンテンツエリア（コンタクトフォーム共通）
  *---------------------------------------------------*/
  .contact_area {
    padding: 20px 15px;
    width: 96%;
  }
  
  .contact_area + section {
    margin-top: 10px;
  }
  
  /*
  * コンタクトフォームエリアタイトル
  *---------------------------------------------------*/
  .contact_title {
    font-size: 1.25rem;
  }
  
  .contact_title::before {
    margin-right: 8px;
    font-size: 1.25rem;
  }
  
  /*
  * コンタクト注意事項
  *---------------------------------------------------*/
  .notice_area {
    margin: 20px auto 0 auto;
    padding: 20px 15px;
    width: 100%;
  }
  
  .notice_area ul.notice_list {
    margin: 0 auto;
    padding: 0 0 0 15px;
    width: 96%;
  }
  
  /*
  * 他のフォームへのリンク
  *---------------------------------------------------*/
  .other_contact_link {
    width: 100%;
  }
  
  .other_contact_link .link_cont {
    padding: 15px 20px;
  }
  
  .other_contact_link .link_cont > dt {
    font-size: 0.8125rem;
  }
  
  .other_contact_link .link_cont > dd {
    margin: 5px 0 0 0;
  }
  
  .other_contact_link .link_cont > dd > a {
    font-size: 1rem;
  }
  
  .other_contact_link .link_cont > dd > a::after {
    right: 2%;
  }
  
  /*
  * コンタクトテキスト
  *---------------------------------------------------*/
  .contact_txt {
    padding: 10px 15px;
    width: 100%;
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
  
  .contact_txt .form_notice {
    padding: 5px 10px;
    width: 100%;
    font-size: 0.9rem;
  }
  
  
  /*
  * 問い合わせフォーム
  *---------------------------------------------------*/
  .form_area {
    margin: 20px auto 0 auto;
    padding: 20px 15px;
    width: 100%;
  }
  
  .form_area .form_body {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    padding: 0;
    width: 100%;
  }
  
  .form_area .form_body > dt {
    margin: 0 0 15px 0;
    padding: 0;
    width: 100%;
    font-size: 0.9375rem;
    border-bottom: none;
  }
  
  .form_area .form_body > dt .must {
    position: static;
    margin: 5px 10px 0 0;
  }
  
  .form_area .form_body > dd {
    padding: 0 0 20px 0;
    width: 100%;
    font-size: 0.875rem;
  }
  
  .form_area .form_body > dd .sizeS,
  .form_area .form_body > dd.q_area .inner_question > dd .sizeS {
    width: 30%;
  }
  
  .form_area .form_body > dd .sizeL,
  .form_area .form_body > dd.q_area .inner_question > dd .sizeL {
    width: 100%;
  }
  
  .submit_btn {
    margin: 30px auto 0 auto;
  }
  
  .submit_btn input[type="submit"] {
    padding: 10px 0;
    width: 80%;
    font-size: 1rem;
  }
  
  /* 質問箇所追加 */
  .form_area .form_body > dd.q_area {
    padding: 20px 15px;
  }
  
  .form_area .form_body > dd.q_area .inner_question > dt {
    margin: 0 0 15px 0;
    padding: 0;
    width: 100%;
    font-size: 0.95rem;
    border-bottom: none;
  }
  
  .form_area .form_body > dd.q_area .inner_question.no-padding > dt {
    padding: 0;
  }
  
  .form_area .form_body > dd.q_area .inner_question > dt .must {
    position: static;
    margin: 5px 10px 0 0;
    padding: 5px 10px;
  }
  
  .form_area .form_body > dd.q_area .inner_question > dd {
    padding: 0 0 20px 0;
    width: 100%;
    font-size: 0.875rem;
  }
  
  
  /* 送信未許可メッセージ */
  .form_limit {
    margin: 40px auto;
    width: 100%;
  }
  
  /* 利用規約 */
  .policy_area {
    margin: 20px auto 10px auto;
    padding: 10px 0 10px 10px;
    width: 100%;
  }
  
  .policy_area .policy_title {
    font-size: 1.2rem;
  }
  
  .policy_area .policy_cont > dd > ol > li {
    margin: 0 auto;
    width: 94%;
    font-size: 0.9rem;
  }
  
  .policy_area .policy_cont > dd > ol > li .inner_list > li + li {
    margin-top: 2px;
  }
  
  .policy_check {
    width: 100%;
  }
  
  
  /*
  * 受講体験談
  *---------------------------------------------------*/
  
  /*
  * 選考と謝礼について
  *---------------------------------------------------*/
  .exp_notice {
    margin: 20px auto 0 auto;
    padding: 15px;
    width: 100%;
  }
  
  .exp_notice > dt {
    font-size: 1.125rem;
  }
  
  .exp_notice > dd {
    font-size: 0.875rem;
    line-height: 1.4rem;
  }
  
  /*
  * お問い合わせ送信完了
  *---------------------------------------------------*/
  .complete_txt {
    width: 100%;
    font-size: 0.875rem;
  }
  
  /*
  * 卒業証明・修了証明バナー
  *---------------------------------------------------*/
  
  /*
  * コンテンツエリア
  *---------------------------------------------------*/
  .proof_area {
    padding: 10px;
    width: 96%;
  }
  
  /*
  * コンテンツ
  *---------------------------------------------------*/
  .area_title {
    padding: 10px 0;
    font-size: 1rem;
  }
  
  ul.intro_area .intro_txt {
    display: none;
  }
  
  ul.intro_area .intro_img {
    width: 100%;
  }
  
  ul.intro_area::after {
    border-width: 30px 40px 0 40px;
  }
  
  .appeal_txt {
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  
  ul.proof_merit li {
    width: 100%;
  }
  
  ul.proof_merit li + li {
    margin-top: 20px;
  }
  
  ul.proof_merit li .merit_content {
    margin: 0 auto;
    padding: 0;
    width: 100%;
  }
  
  ul.proof_merit li .merit_content > dt {
    display: flex;
    justify-content: center;
  }
  
  .blog_intro {
    padding: 15px;
  }
  
  .blog_intro dt.lead_title {
    font-size: 1rem;
  }
  
  .blog_intro dd.lead_txt {
    font-size: 0.875rem;
    line-height: 1.5rem;
    text-align: left;
  }
  
  ul.recommend_blog {
    width: 100%;
  }
  
  ul.recommend_blog li {
    width: 100%;
  }
  
  ul.recommend_blog li + li {
    margin-top: 15px;
  }
  
  .get_proof .get_title {
    padding: 50px 15px 0 15px;
    font-size: 1.25rem;
  }
  
  .get_proof .get_lead {
    margin: 10px auto 0 auto;
    font-size: 0.875rem;
    text-align: left;
  }
  
  .get_proof .shikaku_select {
    margin: 20px auto 0 auto;
  }
  
  .get_proof .shikaku_select .shikaku_list {
    width: 100%;
  }
  
  .get_proof .shikaku_select .shikaku_list > dd .shikaku_contents > li {
    margin: 0 auto;
    width: 100%;
  }
  
  .get_proof .shikaku_select .shikaku_list > dd .shikaku_contents > li + li {
    margin-top: 7px;
  }
  
  .view_title {
    margin: 20px auto 0 auto;
    font-size: 1rem;
  }
  
  .view_area .get_address {
    margin: 20px auto 0 auto;
    padding: 15px;
    width: 100%;
  }
  
  .view_area .get_address .banner_address .address_url {
    width: 100%;
    height: 120px;
    font-size: 0.8125rem;
  }
  
  .view_area .get_address .copy_btn {
    margin: 10px auto;
  }
  
  .view_area .get_address .copy_btn > button {
    width: 100%;
  }
  
  .view_area .notice {
    margin: 20px auto 10px auto;
  }
  
  .view_area .notice > dd {
    text-align: left;
    line-height: 1.5rem;
  }
  
  
  /*
  * 自分に合う講座を探す
  *---------------------------------------------------*/
  .shikaku_find_area {
    width: 96%;
  }
  
  .shikaku_find_area ul.inner_menu {
    margin: 0 auto 30px auto;
  }
  
  .shikaku_find_area ul.inner_menu > li {
    padding: 10px 15px;
    height: 120px;
  }
  
  .shikaku_find_area ul.inner_menu > li > a {
    display: block;
    padding-top: 50px;
    font-size: 0.75rem;
    text-align: center;
  }
  
  .shikaku_find_area ul.inner_menu > li > a::before {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
  }
  
  .shikaku_find_area ul.inner_menu > li > a::after {
    top: 88%;
    left: 50%;
    transform: translateX(-50%);
  }
  
  .shikaku_find_area .test_find {
    margin: 20px auto 30px auto;
    padding: 20px 15px;
  }
  
  .shikaku_find_area .test_find .test_txt {
    margin: 10px auto 0 auto;
    width: 100%;
  }
  
  .shikaku_find_area .test_find .test_txt .txt_body {
    width: 100%;
    font-size: 1rem;
  }
  
  .shikaku_find_area .test_find .test_txt .link_btn {
    margin: 10px auto 0 auto;
    width: 100%;
  }
  
  .shikaku_find_area .test_find .test_txt .link_btn > a > button {
    height: 50px;
    font-size: 1rem;
  }
  
  .shikaku_find_area .test_find .test_txt .link_btn > a > button::before {
    left: 10%;
    font-size: 1.25rem;
  }
  
  .shikaku_find_area .test_find .test_txt .link_btn > a > button::after {
    right: 7%;
  }
  
  .shikaku_find_area .ranking_find {
    margin: 20px auto 30px auto;
    padding: 20px 15px;
  }
  
  .shikaku_find_area .ranking_find .lead_txt {
    font-size: 0.85rem;
    line-height: 1.5rem;
  }
  
  .shikaku_find_area .ranking_find .ranking_list {
    margin: 20px auto 0 auto;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li {
    margin: 0;
    width: 100%;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li + li {
    margin-top: 15px;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li .ranking_title {
    height: auto;
    font-size: 1rem;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li .ranking_img {
    height: 80px;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li .ranking_lead {
    font-size: 0.8rem;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn {
    margin: 15px auto 0 auto;
    height: 40px;
  }
  
  .shikaku_find_area .ranking_find .ranking_list > li .ranking_link_btn > a {
    font-size: 0.9rem;
  }
  
  .shikaku_find_area .voice_find {
    margin: 20px auto 30px auto;
    padding: 0;
  }
  
  .shikaku_find_area .voice_find .lead_txt {
    font-size: 0.85rem;
    line-height: 1.5rem;
  }
  
  .shikaku_find_area .voice_find .voice_list_part {
    margin: 40px auto 0 auto;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li {
    margin: 0 auto;
    width: 94%;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li + li {
    margin-top: 40px;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_img {
    height: 35px;
    font-size: 1rem;
    line-height: 32px;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_img::before {
    width: 50px;
    height: 50px;
    font-size: 1.6rem;
    line-height: 45px;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_img::after {
    border-width: 17.5px;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_body {
    margin: 10px auto 0 auto;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_body dt {
    height: auto;
    font-size: 1rem;
    line-height: 1.8rem;
  }
  
  .shikaku_find_area .voice_find .voice_list_part li .list_body dd {
    margin: 15px 0 0 0;
  }
  
  .shikaku_find_area .voice_find .link_btn {
    margin: 25px auto 0 auto;
    width: 94%;
  }
  
  .shikaku_find_area .voice_find .link_btn > a > button {
    height: 50px;
    font-size: 1rem;
  }
  
  .shikaku_find_area .voice_find .link_btn > a > button::before {
    left: 10%;
    font-size: 1.25rem;
  }
  
  .shikaku_find_area .voice_find .link_btn > a > button::after {
    right: 7%;
  }
  
  
  /*
  * 講座検索結果
  *---------------------------------------------------*/
  .search_list_body {
    margin: 30px auto 0 auto;
  }
  
  .search_list_body > li {
    margin: 0;
    padding: 15px 20px;
    width: 100%;
    height: auto;
  }
  
  .search_list_body > li + li {
    margin-top: 15px;
  }
  
  .search_list_body > li .kouza_title {
    font-size: 1rem;
  }
  
  .search_list_body > li .kouza_img {
    height: 80px;
  }
  
  .search_list_body > li .kouza_link_btn {
    margin: 15px auto 0 auto;
    height: 40px;
  }
  
  .search_list_body > li .kouza_link_btn > a {
    font-size: 1rem;
  }
  
  /* 該当講座なし */
  .no_result {
    margin: 30px auto 0 auto;
    padding: 15px 20px;
    width: 100%;
    font-size: 0.875rem;
  }
  
  
  /*
  * 記事監修者一覧
  *---------------------------------------------------*/
  .author_list {
    padding: 30px 10px;
    width: 96%;
  }
  
  .author_list > li {
    margin: 0 auto 15px auto;
    width: 94%;
  }
  
  .author_list > li .author_list_cont > dt {
    height: 150px;
  }
  
  .author_list > li .author_list_cont > dt > img {
    object-fit: contain;
    height: 100%;
    object-position: center center;
  }
  
  
  
  /*
  * 利用規約・教材について
  *---------------------------------------------------*/
  .usage_area {
    margin: 30px auto 0 auto;
  }
  
  .usage_area .usage_row > dt {
    font-size: 1rem;
  }
  
  .usage_area .usage_row > dt::before {
    top: 6%;
  }
  
  .usage_area .usage_row > dd {
    font-size: 0.9rem;
  }
  
  .enactment {
    margin: 0 auto;
    width: 100%;
  }
  
  
  /**
  * NEW - 無料資料請求
  *------------------------------------------------------------*/
  
  .doc-container .btn-select {
    font-size: 0.8rem;
  }
  
  /**
  * 資料請求 - 全講座選択画面
  */
  .doc-container .ttl__header {
    padding: 0 0 6px 0;
    font-size: 1.4rem;
    text-align: center;
  }
  
  .doc-container .doc-notice {
    font-size: 0.9rem;
  }
  
  .doc-container h3.area-title {
    margin: 30px auto 20px auto;
    font-size: 1.1rem;
  }
  
  /* キーワード検索 */
  .doc-container .search-wrapper #keyword-search {
    padding-left: 40px;
    font-size: 1rem;
  }
  
  .doc-container .search-wrapper > i {
    font-size: 1.4rem;
  }
  
  .doc-container .search-wrapper > .roupe {
    top: 50%;
    transform: translateY(-50%);
    left: 10px;
  }
  
  /* 閲覧した講座 */
  .history__name {
    font-weight: normal !important;
    white-space: normal !important;
    text-align: left;
  }
  
  /* カテゴリー */
  .doc-container .util-area .category-area .category-list .list__category-item {
    margin: 0 0 5px 0;
    width: calc(98% / 2);
    height: 45px;
  }
  
  .doc-container .util-area .category-area .category-list .list__category-item:after {
    display: none;
  }
  
  .doc-container .util-area .category-area .category-list .list__category-item > a {
    font-size: 0.8rem;
  }
  
  .doc-container #search-area .category-title {
    /* margin: 30px auto 15px auto; */
    font-size: 1rem;
  }
  
  .line .category__item {
    width: 100%;
  }
  
  .category__item .item__name > a {
    font-size: 0.9rem;
  }
  
  .category__item .btn {
    font-size: 0.8rem;
  }
  
  .category__item .btn-select.selected {
    font-size: 0.8rem;
  }
  
  /* 下部講座選択エリア */
  .nav__controller .nav_txt {
    font-size: 1rem;
  }
  
  .nav__controller .row .course__list {
    height: auto;
  }
  
  .course__list .selected__course {
    margin: 0 auto;
    width: 94%;
  }
  
  .document-form .btn-request {
    margin: 10px auto 20px auto;
    padding: 8px 0;
    font-size: 1.1rem;
  }
  
  .document-form .btn-request::after {
    content: '\f101';
    font-family: "Font Awesome 5 Free";
    position: absolute;
    top: 50%;
    right: 10%;
    transform: translateY(-50%);
    font-weight: 900;
  }
  
  /* 講座追加時のポップアップウィンドウ */
  .info-window {
    left: -80%;
    width: 80%;
  }
  
  .info-message {
    padding: 0 0 0 10px;
    font-size: 1rem;
  }
  
  
  /* 資料請求 - 講座追加画面 */
  .select-document .select-txt {
    font-size: 0.9rem;
  }
  
  .select-list {
    margin: 10px auto 0 auto;
  }
  
  .select-list .list-title {
    height: 35px;
  }
  
  .select-list .selected-course {
    padding: 0 10px;
    font-size: 0.9rem;
  }
  
  .select-list .selected-course .course-name {
    width: 75%;
  }
  
  .add-course {
    margin: 40px auto 0 auto;
  }
  
  .add-course .add-comment {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  
  .add-course .add-notice {
    margin: 7px 0 0 0;
  }
  
  .add-course .add-course-list .list-title {
    padding: 10px 15px;
    font-size: 0.9rem;
    line-height: 1.3rem;
  }
  
  .add-course .add-course-list .list-cont {
    padding: 10px;
  }
  
  .add-course .add-course-list .list-cont .add-list > li {
    width: 100%;
  }
  
  .add-course .add-course-list .list-cont .add-list > li .add-name {
    font-size: 0.9rem;
  }
  
  .add-course .add-course-list .list-cont .add-list > li .btn {
    width: 100px;
    font-size: 0.8rem;
  }
  
  .action-select {
    margin: 20px auto 40px auto;
    width: 100%;
  }
  
  
  /* 資料請求 - 送付先入力 */
  .doc-container {
    position: relative;
  }
  
  .req_input {
    margin-bottom: 0;
  }
  
  .redirect-alert {
    top: 50%;
    padding: 30px 0 0 0;
    width: 96%;
    height: 120px;
  }
  
  .sub-title {
    margin: 20px auto 0 auto;
    padding: 0 0 15px 0;
  }
  
  .mail-notice {
    margin: 0 0 10px 0;
    padding: 15px 10px;
    font-size: 0.9rem;
  }
  
  .form__input {
    margin: 0 !important;
    border-top: none !important;
  }
  
  #zip {
    margin: 0;
  }
  
  .select-wrapper {
    margin: 0 !important;
  }
  
  .select-wrapper .select-pref {
    margin: 0 !important;
  }
  
  #input__group .form-group input[type="text"],
  #input__group .form-group select {
    font-size: 0.9rem;
  }
  
  #input__group .form-group .telnumber {
    display: block;
  }
  
  #input__group .form-group .form-field #tel1,
  #input__group .form-group .form-field #tel2,
  #input__group .form-group .form-field #tel3 {
    width: 24%;
  }
  
  .form__policy {
    width: 100% !important;
    font-size: 0.9rem;
  }
  
  /* エラー表示のモーダルウィンドウ */
  .errorModal .content {
    padding: 30px 20px;
    width: 90%;
  }
  
  .errorModal .content .modal-title {
    font-size: 1rem;
  }
  
  .errorModal .content .modal-title .error-num {
    font-size: 1.2rem;
  }
  
  .errorModal .content .error-list .list-str {
    font-size: 0.9rem;
  }
  
  .errorModal .content .modal-close {
    margin: 30px auto 0 auto;
  }
  
  /* 国家資格選択時のエラー表示 */
  .kokka-alert{
    margin: 40px auto 10px auto;
    padding: 20px;
    font-size: 0.9rem;
    line-height: 1.4rem;
  }
  
  
  /*
  * 人気資格ランキングTOP30
  *==============================================================*/
  .ranking_preface,
  .ranking_afterwords {
    margin: 20px auto;
    width: 96%;
    font-size: 14px;
    line-height: 1.4rem;
  }
  
  /* ランキングページタイトル */
  .ranking_title {
    margin: 30px auto;
    width: 78%;
    font-size: 16px;
  }
  
  /* ランキングページ内メニュー */
  .ranking_inner_menu {
    margin: 20px auto;
    width: 100%;
  }
  
  .ranking_inner_menu li > a .rank_number {
    font-size: 1.2rem;
  }
  
  .ranking_inner_menu li > a .rank_number .unit_txt {
    font-size: 0.9rem;
  }
  
  .ranking_inner_menu li > a .link_txt {
    padding: 6px;
    font-size: 1rem;
    text-indent: 24px;
    background-size: 16px 10px;
    background-position: 14px center;
  }
  
  .ranking_menu li {
    margin: 0 0 1px 0;
    width: calc(100% / 3);
  }
  
  /* ランキングコンテンツ */
  .ranking_list {
    width: 96%;
  }
  
  .ranking_list .shikaku_name {
    font-size: 18px;
  }
  
  .ranking_list .shikaku_name span {
    font-size: 30px;
  }
  
  .ranking_list .shikaku_detail .detail_cont .shikaku_img {
    width: 100%;
  }
  
  .ranking_list .shikaku_detail .detail_cont .shikaku_img .img_cont {
    height: 140px;
  }
  
  .ranking_list .shikaku_detail .detail_cont .shikaku_img .shikaku_link {
    margin: 15px auto 0 auto;
    width: 96%;
  }
  
  .ranking_list .shikaku_detail .detail_cont .shikaku_txt {
    margin: 15px auto 0 auto;
    width: 96%;
    font-size: 14px;
  }
  
  
  /**
  * 2023年5月追記
  * WEB限定キャンペーン
  *--------------------------------------------------------*/
  /* 講座選択に飛ぶボタン */
  .go_select {
    display: block;
    margin: 0 auto 30px auto;
    padding: 30px 0;
    width: 100%;
    background: #ecf6fb;
  }
  
  .go_select > a {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    padding: 0;
    width: 90%;
    height: 40px;
    font-size: 1.2rem;
    font-weight: bold;
    color: #fff;
    background: #395fb0;
    border-radius: 4px;
    text-decoration: none;
  }
  
  /* インフォメーションエリア */
  .cp_information {
    margin: 30px auto 0 auto;
    width: 96%;
  }
  
  .cp_information .reason .reason_title,
  .cp_information .payment_method .payment_title {
    width: 94%;
    font-size: 16px;
  }
  
  .cp_information .reason .reason_list,
  .cp_information .payment_method .payment_cont {
    padding: 50px 15px 15px 15px;
  }
  
  .cp_information .reason .reason_list > li,
  .cp_information .payment_method .payment_cont > li {
    width: 100%;
  }
  
  .cp_information .reason .reason_list > li {
    padding: 20px;
  }
  
  .cp_information .reason .reason_list > li .reason_img {
    width: 100%;
    height: 80px;
    text-align: center;
  }
  
  .cp_information .reason .reason_list > li .reason_img > img {
    width: auto;
    height: 100%;
  }
  
  .cp_information .reason .reason_list > li .reason_txt {
    margin: 20px auto 0 auto;
    width: 100%;
  }
  
  .cp_information .payment_method .payment_cont .list_contents > dt {
    font-size: 16px;
  }
  
  .cp_information .payment_method .payment_cont .list_contents > dd {
    padding: 15px 20px;
  }
  
  .cp_information .payment_method .payment_cont .list_contents > dd .txt_list {
    width: 90%;
  }
  
  /* コンテンツラッパー */
  .contents_wrapper {
    margin: 30px auto 0 auto;
    width: 96%;
  }
  
  /* 選択タイトル */
  .select_title {
    width: 80%;
    height: 40px;
    font-size: 1.4rem;
    line-height: 40px;
  }
  
  .select_title:before,
  .select_title:after {
    height: 20px;
    border: 20px solid #fa4141;
  }
  
  .select_title:before {
    left: -40px;
    border-left-color: transparent;
  }
  
  .select_title:after {
    right: -40px;
    border-right-color: transparent;
  }
  
  /* アクション説明文 */
  .select_explain {
    margin: 15px auto 0 auto;
    width: 100%;
    font-size: 1.2rem;
  }
  
  /* 選択コース */
  .select_course {
    margin: 20px auto 30px auto;
    width: 94%;
  }
  
  .select_course .course_list {
    margin-bottom: 10px;
    width: 100%;
  }
  
  /* 講座リスト */
  .kouza_list {
    margin: 20px auto 0 auto;
  }
  
  .kouza_list > li {
    width: 100%;
  }
  
  .kouza_list > li .kouza_category::after {
    content: "";
    display: block;
    position: absolute;
    top: 38%;
    right: 25px;
    width: 8px;
    height: 8px;
    border-right: solid 2px #fff;
    border-top: solid 2px #fff;
    transform: rotate(135deg);
    transition: transform .3s ease-in-out, top .3s ease-in-out;
  }
  
  .kouza_list > li .kouza_category.open::after {
    top: 45%;
    transform: rotate(-45deg);
  }
  
  .kouza_list > li .kouza_contents {
    display: none;
  }
  
  .kouza_list > li .kouza_contents > li {
    font-size: 0.9rem;
  }
  
  /* 選択された講座表示エリア */
  .selected_kouza .area_container {
    width: 94%;
  }
  
  .selected_kouza .area_container .selected_kouza_txt {
    font-size: 1rem;
  }
  
  .selected_kouza .area_container .s_kouza_list {
    margin: 10px auto;
  }
  
  .selected_kouza .area_container .s_kouza_list.k2 {
    width: 100%;
  }
  
  .selected_kouza .area_container .s_kouza_list.k2 .s_kouza {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .selected_kouza .area_container .s_kouza_list.k3 .s_kouza {
    margin-bottom: 5px;
    width: 100%;
  }
  
  .selected_kouza .area_container .action_area .submit_btn {
    text-align-last: left;
  }
  
  .selected_kouza .area_container .action_area .submit_btn .action_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    width: 75%;
    height: 50px;
    font-size: 1.2rem;
  }
  
  .selected_kouza .area_container .action_area .submit_btn .action_btn::after {
    right: 5%;
  }
  
  /* モーダルダイアログ */
  .select-alert {
    display: none;
  }
  
  .alert_bg {
    background: rgba(0,0,0,0.5);
  }
  
  .alert_msg {
    width: 90%;
  }
  
  }
  