@charset "UTF-8";
/*------------------------------------------------------------------------------
    config
------------------------------------------------------------------------------*/
/***  media ***/
/***  color ***/
/*** font ***/
p {
  line-height: 1.5;
}
.case {
  margin-top: 65px;
  padding-top: 80px;
  padding-bottom: 65px;
  background: url(../img/service/ser_item_bg.jpg) no-repeat center / contain;
  background-size: cover;
}
@media screen and (max-width: 818px) {
  .case {
    margin-top: 35px;
    padding-top: 40px;
    padding-bottom: 30px;
  }
}
.case p {
  text-align: left;
  padding: 0 50px;
}
@media screen and (max-width: 818px) {
  .case p {
    padding: 0;
  }
}
.case dl {
  padding-left: 50px;
  padding-right: 120px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .case dl {
    display: block;
    padding-left: 0;
    padding-right: 0;
  }
}
.case dl dt {
  width: 56%;
}
@media screen and (max-width: 818px) {
  .case dl dt {
    width: 100%;
    margin-bottom: 20px;
  }
}
.case dl dd {
  width: 44%;
}
@media screen and (max-width: 818px) {
  .case dl dd {
    width: 100%;
  }
}
.case_list {
  margin-top: 200px;
}
@media screen and (max-width: 818px) {
  .case_list {
    margin-top: 120px;
  }
}
.case_list ul {
  display: block;
}
.case_list ul li {
  padding-right: 120px;
  display: flex;
}
@media screen and (max-width: 818px) {
  .case_list ul li {
    display: block;
    padding-right: 0;
  }
}
.case_list ul li + li {
  margin-top: 180px;
}
@media screen and (max-width: 818px) {
  .case_list ul li + li {
    margin-top: 100px;
  }
}
.case_list ul li .txt {
  width: 59%;
}
@media screen and (max-width: 818px) {
  .case_list ul li .txt {
    width: 100%;
  }
}
.case_list ul li .txt .ttl {
  text-align: left;
  font-size: 32px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 30px;
}
@media screen and (max-width: 818px) {
  .case_list ul li .txt .ttl {
    margin-bottom: 15px;
    font-size: 18px;
  }
}
.case_list ul li .txt p {
  margin-bottom: 30px;
  text-align: left;
  padding-right: 50px;
}
@media screen and (max-width: 818px) {
  .case_list ul li .txt p {
    padding-right: 0;
    margin-bottom: 20px;
  }
}
.case_list ul li .txt .txt_btn {
  max-width: 300px;
  width: 100%;
  display: block;
  border-radius: 60px;
  line-height: 60px;
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  color: #000000;
  margin: auto;
  margin-left: 13px;
  border: 1px solid #000000;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 818px) {
  .case_list ul li .txt .txt_btn {
    margin-left: auto;
    font-size: 14px;
    line-height: 50px;
    max-width: 100%;
  }
}
.case_list ul li .txt .txt_btn:hover {
  background: #000000;
  color: #ffffff;
  opacity: 1;
}
.case_list ul li .txt .txt_item {
  padding-left: 50px;
}
@media screen and (max-width: 818px) {
  .case_list ul li .txt .txt_item {
    padding-left: 0;
  }
}
.case_list ul li .img {
  width: 41%;
}
@media screen and (max-width: 818px) {
  .case_list ul li .img {
    margin-top: 25px;
    width: 100%;
  }
}
.seminar {
  margin-top: 200px;
}
@media screen and (max-width: 818px) {
  .seminar {
    margin-top: 100px;
  }
}
.seminar .v_slide {
  margin-top: 30px;
  padding: 0 20px;
  position: relative;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide {
    margin-top: 20px;
    padding: 0 15px;
  }
}
.seminar .v_slide .swiper-button-next-seminar {
  z-index: 50;
  position: absolute;
  top: 45%;
  right: 0;
}
.seminar .v_slide .swiper-button-next-seminar img {
  width: 12px;
  height: 24px;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide .swiper-button-next-seminar img {
    width: 8px;
    height: 16px;
  }
}
.seminar .v_slide .swiper-button-prev-seminar {
  z-index: 50;
  position: absolute;
  top: 45%;
  left: 0;
}
.seminar .v_slide .swiper-button-prev-seminar img {
  width: 12px;
  height: 24px;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide .swiper-button-prev-seminar img {
    width: 8px;
    height: 16px;
  }
}
.seminar .v_slide .v_slide_item .img {
  position: relative;
  height: 155px;
}
.seminar .v_slide .v_slide_item .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.seminar .v_slide .v_slide_item .img .tag {
  position: absolute;
  right: 0;
  bottom: -15px;
  z-index: 10;
  background: #1D50A1;
  color: #ffffff;
  padding: 0 10px;
  border-radius: 4px;
  width: fit-content;
  font-size: 12px;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide .v_slide_item .img .tag {
    bottom: -10px;
  }
}
.seminar .v_slide .v_slide_item .data {
  font-size: 10px;
  font-weight: 400;
  text-align: left;
  margin-top: 17px;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide .v_slide_item .data {
    margin-top: 12px;
  }
}
.seminar .v_slide .v_slide_item .ttl {
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  margin-bottom: 15px;
}
@media screen and (max-width: 818px) {
  .seminar .v_slide .v_slide_item .ttl {
    margin-bottom: 10px;
    font-size: 16px;
  }
}
.seminar .v_slide .v_slide_item .txt {
  text-align: left;
}
.seminar .seminar_item {
  margin-top: 60px;
  background: #E7ECF5;
  padding: 70px 60px 70px 50px;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
  display: flex;
  align-items: center;
}
@media screen and (max-width: 818px) {
  .seminar .seminar_item {
    padding: 30px;
    display: block;
    margin-top: 30px;
  }
}
.seminar .seminar_item dt {
  width: 58%;
  text-align: left;
}
@media screen and (max-width: 818px) {
  .seminar .seminar_item dt {
    width: 100%;
  }
}
.seminar .seminar_item dd {
  width: 42%;
}
@media screen and (max-width: 818px) {
  .seminar .seminar_item dd {
    margin-top: 20px;
    width: 100%;
  }
}
.service_single .s_main_img {
  margin-top: 16px;
}
.service_single .s_main_txt {
  max-width: 944px;
  margin: auto;
  margin-top: 30px;
  box-shadow: 0px 0px 7px 0px rgba(0, 0, 0, 0.55);
  background: #ffffff;
  padding: 60px 0 90px;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 818px) {
  .service_single .s_main_txt {
    margin-top: 20px;
    max-width: 90%;
    padding: 20px;
    box-shadow: 0px 0px 3.5px 0px rgba(0, 0, 0, 0.55);
  }
}
.service_single .s_main_txt .txt {
  max-width: 655px;
  text-align: left;
  margin: auto;
}
.service_single .s_main_txt .txt .t_ttl {
  margin-bottom: 70px;
}
@media screen and (max-width: 818px) {
  .service_single .s_main_txt .txt .t_ttl {
    margin-bottom: 30px;
  }
}
.service_single .s_main_txt a {
  display: block;
  max-width: 300px;
  margin: auto;
  color: #ffffff !important;
  background: #BF0071;
  line-height: 60px;
  border-radius: 10px;
  width: 100%;
  text-align: center;
  font-weight: bold;
  margin-top: 30px;
}
@media screen and (max-width: 818px) {
  .service_single .s_main_txt a {
    margin-top: 20px;
    font-size: 14px;
    max-width: 90%;
    line-height: 50px;
    border-radius: 8px;
  }
  .service_single .s_main_txt a + a {
    margin-top: 20px;
  }
}
.service_single .s_main_txt a:hover {
  background: #1D50A1;
  opacity: 1;
}
.service_single .s_main_txt_notop {
  margin-top: 0;
}
.service_single .sub_case {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .sub_case {
    padding-top: 50px;
  }
}
.service_single .sub_case dl {
  position: relative;
  margin-top: 16px;
  display: flex;
  padding-top: 45px;
  padding-bottom: 50px;
}
@media screen and (max-width: 818px) {
  .service_single .sub_case dl {
    display: block;
    padding-top: 25px;
    padding-bottom: 30px;
  }
}
.service_single .sub_case dl::after {
  position: absolute;
  content: "";
  width: 300%;
  height: 100%;
  left: 42%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 50%;
  background: #FAFAFA;
  background-size: 100% 100%;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 818px) {
  .service_single .sub_case dl::after {
    left: 10%;
  }
}
.service_single .sub_case dl dt {
  position: relative;
  z-index: 10;
  width: 50%;
  padding-right: 12px;
}
@media screen and (max-width: 818px) {
  .service_single .sub_case dl dt {
    width: 100%;
    padding-right: 0;
  }
}
.service_single .sub_case dl dd {
  position: relative;
  z-index: 10;
  width: 50%;
  text-align: left;
  padding-left: 12px;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .service_single .sub_case dl dd {
    width: 100%;
    margin-top: 15px;
    padding-left: 0;
  }
}
.service_single .schedule {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .schedule {
    padding-top: 50px;
  }
}
.service_single .schedule .h3_ttl {
  margin-bottom: 40px;
}
@media screen and (max-width: 818px) {
  .service_single .schedule .h3_ttl {
    margin-bottom: 20px;
  }
}
.service_single .schedule dl {
  display: flex;
}
.service_single .schedule dl dt {
  background: #1D50A1;
  color: #ffffff;
  width: 275px;
  border: 1px solid #ffffff;
  text-align: left;
  padding: 10px;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .service_single .schedule dl dt {
    padding: 8px;
    width: 100px;
  }
}
.service_single .schedule dl dd {
  width: calc(100% - 275px);
  text-align: left;
  border: 1px solid #E2E2E2;
  font-weight: 400;
  padding: 10px;
}
@media screen and (max-width: 818px) {
  .service_single .schedule dl dd {
    padding: 8px;
    width: calc(100% - 100px);
  }
}
.service_single .tuition {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .tuition {
    padding-top: 60px;
  }
}
.service_single .tuition .h3_ttl {
  margin-bottom: 40px;
}
@media screen and (max-width: 818px) {
  .service_single .tuition .h3_ttl {
    margin-bottom: 20px;
  }
}
.service_single .tuition dl {
  max-width: 353px;
  border: 1px solid #C5C5C5;
  margin: auto;
}
.service_single .tuition dl dt {
  line-height: 58px;
  background: #1D50A1;
  color: #ffffff;
  text-align: center;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .service_single .tuition dl dt {
    line-height: 48px;
  }
}
.service_single .tuition dl dd {
  border-top: 1px solid #C5C5C5;
  padding: 35px 15px;
  font-size: 28px;
  font-weight: 400;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}
@media screen and (max-width: 818px) {
  .service_single .tuition dl dd {
    font-size: 20px;
    padding: 28px 10px;
  }
}
.service_single .btn_item {
  display: flex;
  align-items: center;
  margin: auto;
  margin-top: 100px;
  column-gap: 23px;
  width: 100%;
  max-width: 623px;
}
@media screen and (max-width: 818px) {
  .service_single .btn_item {
    margin-top: 40px;
    display: block;
  }
}
.service_single .btn_item a {
  display: block;
  max-width: 300px;
  margin: auto;
  color: #ffffff !important;
  background: #BF0071;
  line-height: 60px;
  border-radius: 10px;
  width: 100%;
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 818px) {
  .service_single .btn_item a {
    font-size: 14px;
    max-width: 90%;
    line-height: 50px;
    border-radius: 8px;
  }
  .service_single .btn_item a + a {
    margin-top: 20px;
  }
}
.service_single .btn_item a:hover {
  background: #1D50A1;
  opacity: 1;
}
.service_single .teacher {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher {
    padding-top: 50px;
  }
}
.service_single .teacher .h3_ttl {
  margin-bottom: 40px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher .h3_ttl {
    margin-bottom: 20px;
  }
}
.service_single .teacher ul {
  flex-wrap: wrap;
  display: flex;
  gap: 55px;
  column-gap: 43px;
  margin-bottom: 60px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul {
    margin-bottom: 40px;
    display: block;
  }
}
.service_single .teacher ul li {
  width: calc(50% - 21.5px);
  border: 1px solid #CCCCCC;
  background: #F5F5F5;
  box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul li {
    width: 100%;
    box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.1);
  }
  .service_single .teacher ul li + li {
    margin-top: 25px;
  }
}
.service_single .teacher ul li .list_txt {
  padding: 13px 35px 50px 35px;
  text-align: left;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul li .list_txt {
    padding: 10px 20px 20px 20px;
  }
}
.service_single .teacher ul li .list_txt .list_ttl {
  font-weight: bold;
  font-size: 23px;
  margin-top: 5px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul li .list_txt .list_ttl {
    font-size: 18px;
  }
}
.service_single .teacher ul li .list_txt .tag_item {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  column-gap: 4px;
}
.service_single .teacher ul li .list_txt .tag_item span {
  width: 86px;
  background: #CE3582;
  text-align: center;
  color: #ffffff;
  line-height: 22px;
  display: block;
  font-size: 10px;
  font-weight: bold;
}
.service_single .teacher ul li .list_txt p {
  margin-top: 15px;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul li .list_txt p {
    margin-top: 10px;
  }
}
.service_single .teacher ul li:nth-child(1) .img img {
  max-width: 38.6%;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul li:nth-child(1) .img img {
    max-width: 55%;
  }
}
.service_single .teacher ul .small_box {
  width: 35%;
}
@media screen and (max-width: 818px) {
  .service_single .teacher ul .small_box {
    width: 100%;
  }
}
.service_single .teacher .sub_teacher li {
  width: calc(33.3333% - 28.666666px);
}
@media screen and (max-width: 818px) {
  .service_single .teacher .sub_teacher li {
    width: 100%;
  }
}
.service_single .teacher .sub_teacher li .img {
  max-width: 150px;
  margin: auto;
}
.service_single .teacher .sub_teacher li:nth-child(1) .img img {
  max-width: 150px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher .sub_teacher li:nth-child(1) .img img {
    max-width: 150px;
  }
}
.service_single .teacher .img_100 li .img img {
  max-width: 100% !important;
}
.service_single .teacher .img_100_center {
  justify-content: center;
}
.service_single .teacher .m_top_100 {
  margin-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher .m_top_100 {
    margin-top: 50px;
  }
}
.service_single .teacher .small_btn {
  margin-top: 75px;
}
@media screen and (max-width: 818px) {
  .service_single .teacher .small_btn {
    margin-top: 35px;
  }
}
.service_single .note {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .service_single .note {
    padding-top: 50px;
  }
}
.service_single .note .h3_ttl {
  margin-bottom: 25px;
}
@media screen and (max-width: 818px) {
  .service_single .note .h3_ttl {
    margin-bottom: 15px;
  }
}
.service_single .note .note_ttl {
  font-size: 24px;
  font-weight: bold;
  text-align: left;
  line-height: 1.45;
  padding-left: 15px;
  position: relative;
  margin-bottom: 16px;
}
@media screen and (max-width: 818px) {
  .service_single .note .note_ttl {
    font-size: 18px;
    margin-bottom: 12px;
  }
}
.service_single .note .note_ttl::after {
  position: absolute;
  content: "";
  width: 9px;
  height: 19px;
  top: 5px;
  left: 0;
  z-index: 5;
  background: #001F33;
}
@media screen and (max-width: 818px) {
  .service_single .note .note_ttl::after {
    width: 7px;
    height: 19px;
  }
}
.service_single .note p {
  text-align: left;
  font-weight: 400;
}
.service_single .note .m_t_40 {
  margin-top: 40px;
}
@media screen and (max-width: 818px) {
  .service_single .note .m_t_40 {
    margin-top: 20px;
  }
}
.txt_center {
  text-align: center;
}
.top_menu_list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  column-gap: 20px;
}
@media screen and (max-width: 818px) {
  .top_menu_list {
    gap: 5px;
    column-gap: 10px;
  }
}
.top_menu_list a {
  width: calc(20% - 16px);
}
.top_menu_list a::after {
  right: 10px;
}
@media screen and (max-width: 818px) {
  .top_menu_list a::after {
    right: 5px;
  }
}
@media screen and (max-width: 818px) {
  .top_menu_list a {
    width: calc(50% - 5px);
  }
}
.y_box {
  max-width: 944px;
  margin: auto;
  box-shadow: 0px 0 7px 0px rgba(0, 0, 0, 0.55);
  padding: 60px 20px 40px 20px;
}
@media screen and (max-width: 818px) {
  .y_box {
    padding: 30px 15px;
    box-shadow: 0px 0 4px 0px rgba(0, 0, 0, 0.45);
  }
}
.y_box .ttl {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 30px;
  line-height: 1.2;
  font-weight: 500;
  margin-bottom: 40px;
}
@media screen and (max-width: 818px) {
  .y_box .ttl {
    margin-bottom: 20px;
    font-size: 20px;
  }
}
@media screen and (max-width: 818px) {
  .y_box p {
    text-align: left;
  }
}
.y_box .sub {
  display: block;
  margin-top: 35px;
  font-size: 14px;
}
@media screen and (max-width: 818px) {
  .y_box .sub {
    font-size: 12px;
    margin-top: 20px;
  }
}
.y_box .btn {
  margin: auto;
  max-width: 301px;
  display: block;
}
.btn_flex {
  display: flex;
  column-gap: 20px;
  width: fit-content;
  margin: auto;
  margin-top: 20px;
}
@media screen and (max-width: 818px) {
  .btn_flex {
    display: block;
  }
  .btn_flex a + a {
    margin-top: 10px !important;
  }
}
.box_item {
  max-width: 1020px;
  margin: auto;
  margin-top: 30px;
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  column-gap: 40px;
}
@media screen and (max-width: 818px) {
  .box_item {
    gap: 30px;
  }
}
.box_item .box {
  width: calc(50% - 20px);
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
  padding: 20px 30px 20px 30px;
}
@media screen and (max-width: 818px) {
  .box_item .box {
    padding: 20px;
    width: 100%;
  }
}
.box_item .box .box_ttl {
  text-align: left;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 10px;
}
.box_item .box .m_t_40 {
  margin-top: 40px;
}
@media screen and (max-width: 818px) {
  .box_item .box .m_t_40 {
    margin-top: 30px;
  }
}
.box_item .box p {
  margin-top: 20px;
  text-align: left;
}
.box_item .box p span {
  font-weight: bold;
}
.box_item .box ol {
  padding-left: 20px;
}
.box_item .box ol li {
  padding-left: 5px;
  text-align: left;
}
.box_item .box ol li + li {
  margin-top: 6px;
}
.box_item .box ol li::marker {
  color: #1D50A1;
  font-weight: bold;
}
.box_item .box ul {
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 818px) {
  .box_item .box ul {
    max-width: 100%;
    padding-left: 0;
  }
}
.box_item .box ul li {
  padding-left: 0;
  text-align: left;
  padding-left: 15px;
  position: relative;
  display: flex;
}
@media screen and (max-width: 818px) {
  .box_item .box ul li {
    padding-left: 15px;
  }
}
.box_item .box ul li + li {
  margin-top: 6px;
}
.box_item .box ul li span {
  font-weight: bold;
}
.box_item .box ul li .listother {
  width: calc(100% - 112px);
}
@media screen and (max-width: 818px) {
  .box_item .box ul li .listother {
    width: calc(100% - 80px);
  }
}
.box_item .box ul li::after {
  position: absolute;
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 10px;
  left: 0;
  top: 12px;
  background: #1D50A1;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 818px) {
  .box_item .box ul li::after {
    top: 10px;
  }
}
.box100 {
  gap: 60px;
}
@media screen and (max-width: 818px) {
  .box100 {
    gap: 40px;
  }
}
.box100 .m_t_after {
  position: relative;
}
.box100 .m_t_after::after {
  position: absolute;
  content: "";
  width: 30px;
  height: 26px;
  left: calc(50% - 15px);
  top: -46px;
  background: url(../img/service/icon003.png) no-repeat center / contain;
  background-size: 100% 100%;
}
@media screen and (max-width: 818px) {
  .box100 .m_t_after::after {
    width: 20px;
    height: 17px;
    left: calc(50% - 10px);
    top: -28px;
  }
}
.box100 .box {
  width: 100% !important;
}
.box100 .box .box_ttl {
  text-align: center;
}
.box100 .box .box_ttl span {
  margin-left: 15px;
}
.box100 .box .box_ttl span img {
  max-width: 23px;
}
.box100 .box .box_ttl div {
	display: inline-block;
}
.box100 .box .box_ttl div img {
	max-width: 23px;
}
.box100 .box .ul_w_f_auto {
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 818px) {
  .box100 .box .ul_w_f_auto {
    width: 100%;
  }
}
.box100 .box .f_t_12 {
  font-size: 10px;
}
.box100 .box .m_t_50 {
  margin-top: 50px;
}
@media screen and (max-width: 818px) {
  .box100 .box .m_t_50 {
    margin-top: 30px;
  }
}
.box100 .box .flex_ul {
  display: flex;
}
@media screen and (max-width: 818px) {
  .box100 .box .flex_ul {
    display: block;
  }
}
.box100 .box .flex_ul ul {
  width: 50%;
}
@media screen and (max-width: 818px) {
  .box100 .box .flex_ul ul {
    width: 100%;
  }
}
.sub_case02 {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .sub_case02 {
    padding-top: 50px;
  }
}
.sub_case02 .inner {
  padding-left: 20px;
  padding-right: 20px;
}
.sub_case02 .txt {
  text-align: left;
  margin-top: 20px;
}
.sub_case02 .txt span {
  font-weight: bold;
}
.sub_case02 dl {
  position: relative;
  margin-top: 40px;
  display: flex;
  padding: 40px 30px;
  background: #FAFAFA;
}
@media screen and (max-width: 818px) {
  .sub_case02 dl {
    display: block;
    margin-top: 30px;
    padding: 20px;
  }
}
.sub_case02 dl dd {
  position: relative;
  z-index: 10;
  width: 35%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 818px) {
  .sub_case02 dl dd {
    width: 100%;
    margin-top: 20px;
  }
}
.sub_case02 dl dd a {
  display: block;
  max-width: 300px;
  margin: auto;
  color: #ffffff !important;
  background: #BF0071;
  line-height: 60px;
  border-radius: 10px;
  width: 100%;
  text-align: center;
  font-weight: bold;
  margin-top: 10px;
}
@media screen and (max-width: 818px) {
  .sub_case02 dl dd a {
    font-size: 14px;
    max-width: 90%;
    line-height: 50px;
    border-radius: 8px;
  }
  .sub_case02 dl dd a + a {
    margin-top: 20px;
  }
}
.sub_case02 dl dd a:hover {
  background: #1D50A1;
  opacity: 1;
}
.sub_case02 dl dt {
  position: relative;
  z-index: 10;
  width: 65%;
  text-align: left;
  font-weight: 400;
}
@media screen and (max-width: 818px) {
  .sub_case02 dl dt {
    width: 100%;
    margin-top: 15px;
  }
}
.sub_case02 dl dt span {
  font-weight: bold;
}
.sub_case02 dl dt .dt_ttl {
  text-align: left;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px;
}
@media screen and (max-width: 818px) {
  .sub_case02 dl dt .dt_ttl {
    margin-bottom: 15px;
  }
}
.sub_case02 .botn_bt dt {
  width: 60%;
}
@media screen and (max-width: 818px) {
  .sub_case02 .botn_bt dt {
    width: 100%;
  }
}
.sub_case02 .botn_bt dd {
  width: 40%;
}
@media screen and (max-width: 818px) {
  .sub_case02 .botn_bt dd {
    width: 100%;
  }
}
.sub_case02 .botn_bt dd a {
  width: 300px;
}
.sub_case05 {
  padding-top: 100px;
}
@media screen and (max-width: 818px) {
  .sub_case05 {
    padding-top: 50px;
  }
}
.sub_case05 .box_item05 {
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.16);
  padding: 20px 30px 20px 30px;
  margin-top: 20px;
}
.sub_case05 .box_item05 .list_top_ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 20px;
  text-align: left;
}
.sub_case05 .box_item05 .list_top {
  display: flex;
  flex-wrap: wrap;
  column-gap: 20px;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .list_top {
    display: block;
  }
}
.sub_case05 .box_item05 .txt_center {
  margin-bottom: 50px;
  margin-top: 20px;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .txt_center {
    margin-bottom: 30px;
  }
}
.sub_case05 .box_item05 .box {
  width: calc(33.3333% - 13.33333px);
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box {
    width: 100%;
  }
  .sub_case05 .box_item05 .box + .box {
    margin-top: 30px;
  }
}
.sub_case05 .box_item05 .box ul {
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box ul {
    max-width: 100%;
    padding-left: 0;
  }
}
.sub_case05 .box_item05 .box ul li {
  padding-left: 0;
  text-align: left;
  padding-left: 15px;
  position: relative;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box ul li {
    padding-left: 15px;
  }
}
.sub_case05 .box_item05 .box ul li + li {
  margin-top: 6px;
}
.sub_case05 .box_item05 .box ul li span {
  width: 112px;
  display: inline-block;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box ul li span {
    width: 80px;
    display: block;
  }
}
.sub_case05 .box_item05 .box ul li .listother {
  width: calc(100% - 112px);
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box ul li .listother {
    width: calc(100% - 80px);
  }
}
.sub_case05 .box_item05 .box ul li::after {
  position: absolute;
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 10px;
  left: 0;
  top: 12px;
  background: #1D50A1;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .box ul li::after {
    top: 10px;
  }
}
.sub_case05 .box_item05 .box ul .txt_r {
  text-align: right;
}
.sub_case05 .box_item05 .box_w50 {
  width: 100%;
}
.sub_case05 .box_item05 .no_after {
  width: calc(66.6666% - 7.3333px);
}
@media screen and (max-width: 818px) {
  .sub_case05 .box_item05 .no_after {
    width: 100%;
  }
}
.h4_ttl {
  font-size: 26px;
  font-weight: bold;
  line-height: 38px;
  padding-left: 15px;
  border-left: 5px solid #1D50A1;
  text-align: left;
}
@media screen and (max-width: 818px) {
  .h4_ttl {
    padding-left: 15px;
    font-size: 18px;
    line-height: 30px;
  }
}
.sub_ttl {
  font-size: 20px;
  font-weight: bold;
  padding-left: 15px;
  text-align: left;
  margin-bottom: 10px;
  position: relative;
}
@media screen and (max-width: 818px) {
  .sub_ttl {
    padding-left: 12px;
  }
}
.sub_ttl::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  left: 0;
  top: 50%;
  background: #1D50A1;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 818px) {
  .sub_ttl::after {
    width: 6px;
    height: 6px;
  }
}
@media screen and (max-width: 818px) {
  .sub_ttl {
    padding-left: 15px;
    font-size: 18px;
  }
}
.sub_case_m_50 {
  padding-top: 30px !important;
}
@media screen and (max-width: 818px) {
  .sub_case_m_50 {
    padding-top: 20px !important;
  }
}
.sub_case_m_50 li {
  font-size: 14px !important;
}
.sub_case_m_50 p {
  font-size: 14px !important;
}
.s0101 .box_item {
  max-width: 100% !important;
}
.step_list {
  display: flex;
  column-gap: 60px;
  margin-top: 65px;
}
@media screen and (max-width: 818px) {
  .step_list {
    display: block;
    margin-top: 45px;
  }
}
.step_list li {
  width: calc(33.3333% - 40px);
  border: 3px solid #1D50A1;
  padding: 45px 20px 30px 20px;
  position: relative;
}
@media screen and (max-width: 818px) {
  .step_list li {
    padding: 35px 20px 20px 20px;
    width: 100%;
  }
}
.step_list li .step_ttl {
  text-align: center;
  font-weight: bold;
  font-size: 20px;
  line-height: 1.45;
  margin-bottom: 20px;
}
@media screen and (max-width: 818px) {
  .step_list li .step_ttl {
    font-size: 18px;
    margin-bottom: 15px;
  }
}
.step_list li .txt {
  text-align: left;
}
.step_list li .icon {
  position: absolute;
  width: 70px;
  height: 70px;
  background-color: #1D50A1;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 33px;
  font-weight: bold;
  color: #ffffff;
  text-align: center;
  top: -35px;
  z-index: 10;
  left: calc(50% - 35px);
}
@media screen and (max-width: 818px) {
  .step_list li .icon {
    width: 60px;
    height: 60px;
    font-size: 26px;
    top: -30px;
    left: calc(50% - 30px);
  }
}
@media screen and (max-width: 818px) {
  .step_list li + li {
    margin-top: 64px;
  }
}
.step_list li + li::after {
  position: absolute;
  content: "";
  width: 26px;
  height: 34px;
  left: -43px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  top: 50%;
  background: url(../img/service/after.png) no-repeat center / contain;
  background-size: 100% 100%;
}
@media screen and (max-width: 818px) {
  .step_list li + li::after {
    width: 22px;
    height: 17px;
    left: calc(50% - 11px);
    top: -47px;
    background: url(../img/service/after_sp.png) no-repeat center / contain;
    background-size: 100% 100%;
  }
}
.m_t_50 {
  margin-top: 60px;
}
@media screen and (max-width: 818px) {
  .m_t_50 {
    margin-top: 50px;
  }
}
.m_t_20 {
  margin-top: 30px;
}
.m_t_0 {
  margin-top: 0px !important;
}
.tokuten_list {
  width: 100%;
  margin: auto;
  margin-top: 20px;
}
@media screen and (max-width: 818px) {
  .tokuten_list {
    max-width: 100%;
    padding-left: 0;
    margin-top: 15px;
  }
}
.tokuten_list li {
  padding-left: 0;
  text-align: left;
  padding-left: 15px;
  position: relative;
  display: flex;
}
@media screen and (max-width: 818px) {
  .tokuten_list li {
    padding-left: 15px;
  }
}
.tokuten_list li + li {
  margin-top: 6px;
}
.tokuten_list li span {
  font-weight: bold;
}
.tokuten_list li .listother {
  width: calc(100% - 112px);
}
@media screen and (max-width: 818px) {
  .tokuten_list li .listother {
    width: calc(100% - 80px);
  }
}
.tokuten_list li::after {
  position: absolute;
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 10px;
  left: 0;
  top: 12px;
  background: #1D50A1;
  transition: 0.3s ease-in-out;
}
@media screen and (max-width: 818px) {
  .tokuten_list li::after {
    top: 10px;
  }
}
@media screen and (max-width: 818px) {
  .sp_p_lr {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }
}
@media screen and (max-width: 818px) {
  .ul_list_sp_noflex {
    display: block !important;
  }
}
.t_more {
  text-align: right;
  margin-top: 10px;
  margin-left: auto;
  display: block;
}
.m_t_40 {
  margin-top: 40px !important;
}
.case_img {
  max-width: 80%;
  margin: auto;
  margin-top: 40px;
}
@media screen and (max-width: 818px) {
  .case_img {
    margin-top: 20px;
    max-width: 100%;
  }
}
.sub_case .y_box p {
  max-width: 685px;
  margin: auto;
  text-align: left !important;
}
