@charset "UTF-8";
/*--------------------------------------------------------------------
=== [common] ====================================
 -------------------------------------------------------------------*/
body {
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  padding-top: 0;
}
body.opened_menu {
  overflow: hidden;
}
.inner {
  max-width: 1100px;
  margin: 0 auto;
}
.main_inner {
  padding: 0;
}
/*--------------------------------------------------------------------
=== [header] ====================================
 -------------------------------------------------------------------*/
header {
  z-index: 9999;
  }
header.seminar_header {
  position: relative !important;
}
header#seminar_header.active {
    position: fixed !important;
    top: 0;
    left: 0;
}
.headerUpr {
  padding: 8px 34px;
  font-size: 12px;
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #EAECEF;
}
.headerUpr h1 {
  color: #6B707C;
}
.headerUpr p {
  color: #6B707C;
}
.headerUpr .uprMenu ul {
  display: flex;
}
.headerUpr .uprMenu ul a {
  color: #6B707C;
}
.headerUpr .uprMenu ul a:hover {
  color: #C21C29;
}
.headerUpr .uprMenu ul li {
  margin-left: 25px;
}
.headerUpr .uprMenu ul a[target=_blank]::after {
  content: "\e900";
  font-size: 0.9rem;
  font-weight: normal;
  font-family: "icomoon";
  color: #C21C29;
  display: inline-block;
  margin-left: 5px;
}
header .header_seminar {
  border-top: 0px solid #EAECEF;
  border-bottom: 1px solid #EAECEF;
}
header .head_container {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
header .header_logo {
  margin: 15px 0 15px 34px;
  width: 142px;
  height: 45px;
}
header .header_menu ul {
  display: flex;
  font-size: 16px;
  font-weight: bold;
}
header .header_menu ul > li > ul {
  opacity: 0;
  flex-direction: column;
  position: absolute;
  white-space: nowrap;
  padding: 20px;
  background-color: #FAFAFA;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  font-weight: normal;
  font-size: 15px;
  top: 75px;
  line-height: normal;
  transition: 0.3s;
  height: 0;
  overflow: hidden;
  padding: 0;
}
.scroll header .header_menu ul > li > ul {
}
header .header_menu ul > li:first-child:hover > ul {
  opacity: 1;
  padding: 20px;
  height: auto;
}
header .header_menu > ul > li {
  margin-right: 60px;
  line-height: 75px;
}
header .header_menu ul > li a:hover, header .header_menu ul > li span:hover, header .header_menu ul > li:has(ul):hover span {
  color: #C21C29;
}
header .header_menu ul > li span:after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 100%;
  height: 3px;
  background-color: #C21C29;
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
}
header .header_menu ul > li span:hover:after, header .header_menu ul > li span:hover:after, header .header_menu ul > li:has(ul):hover span:after {
  visibility: visible;
  opacity: 1;
}
header .header_menu ul > li span {
  cursor: pointer;
  position: relative;
  display: block;
}
header .header_menu ul > li > ul li:first-child {
  border-bottom: 1px solid #E8E8E8;
  padding-bottom: 15px;
  margin-bottom: 15px;
  width: 215px;
}
header .header_menu ul > li > ul li a:hover {
  color: #C21C29;
}
header .header_menu ul > li > ul li a {
  position: relative;
  display: block;
  padding-right: 12px;
}
header .header_menu ul > li > ul li a:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #1E1E1E;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
header .header_menu ul > li > ul li a:hover:before {
  border-color: transparent transparent transparent #C21C29;
}
header .header_right {
  display: flex;
  line-height: 75px;
}
header .header_right .sem_account_link a {
  color: #A4A7AD;
  font-size: 14px;
  display: block;
}
header .header_right a:hover {
  opacity: 0.8;
}
header .header_right .sem_account_link a:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_user.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 16px;
  height: 18px;
  vertical-align: text-bottom;
  margin-right: 8px;
}
header .header_right .sem_contact_link a {
  color: #fff;
  font-size: 12px;
  background-color: #C21C29;
  display: block;
  padding: 15px 10px 0 15px;
  margin-left: 30px;
  position: relative;
  height: 75px;
}
header .header_right .sem_contact_link a:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_contact.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 29px;
  height: 23px;
  vertical-align: text-bottom;
  top: 15px;
  left: 0;
  right: 0;
  margin: auto;
  position: absolute;
}

.mode_guest .is_customer {
  display: none;
}

.mode_customer .is_guest {
  display: none !important;
}

.mode_customer .is_customer {
}

.sem_account_link {
  display: flex;
}

.sem_account_link.is_customer {
  gap: 10px;
  color: #A4A7AD;
}

header .header_right .sem_account_link a.logout_link:before {
  background-image: url(../img/icon_logout.svg);
  margin-right: 3px;
  height: 19px;
  width: 21px;
}

.accountLink {
  display: flex;
}

/*--------------------------------------------------------------------
=== [footer] ====================================
 -------------------------------------------------------------------*/ 
.page_inner_l.mode_footer_inner {
  max-width: 1100px;
}

.footer_menu .flex {
    justify-content: flex-end;
}

.footer_menu_sns_list {
}

.footer_menu_sns_list ul {
  gap: 12px;
  font-size: 18px;
  align-items: center;
}

.footer_menu_sns_list ul li span {
  margin-right: 15px;
}







/*--------------------------------------------------------------------
=== [mvArea] ====================================
 -------------------------------------------------------------------*/
#mvArea .swiper {
  margin-top: 45px;
  margin-top: 30px;
}
#mvArea .swiper img {
  width: 100%;
  border: 4px solid #E5E5E5;
}
#mvArea.swiperWrap {
  position: relative;
}
#mvArea .swiper-pagination {
  bottom: -35px !important;
}
.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 8px !important;
}
.swiper-pagination-bullet-active {
  background: #C21C29 !important;
}
#mvArea .swiper-button-next, #mvArea .swiper-button-prev {
  color: #6B707C !important;
  width: 42px !important;
  height: 98px !important;
}
#mvArea .swiper-button-next::after, #mvArea .swiper-button-prev::after {
  font-size: 88px !important;
  background-size: contain;
  color: transparent;
}
#mvArea .swiper-button-prev, #mvArea .swiper-rtl .swiper-button-next {
  left: 19.5vw !important;
  top: 0;
  bottom: 0;
  margin: auto;
}
#mvArea .swiper-button-next, #mvArea .swiper-rtl .swiper-button-prev {
  right: 19.5vw !important;
  top: 0;
  bottom: 0;
  margin: auto;
}
#mvArea .swiper-button-next::after {
  font-size: 88px !important;
  background-image: url(../img/arrow_next.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
#mvArea .swiper-button-prev::after  {
  font-size: 88px !important;
  background-image: url(../img/arrow_prev.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
/*--------------------------------------------------------------------
=== [seminarArea] ====================================
 -------------------------------------------------------------------*/
#seminarArea {
  background-color: #F4F5F7;
  margin-top: 50px;
  padding-top: 90px;
  padding-bottom: 100px;
}
#seminarArea .hd02 {
  display: flex;
  align-items: center;
  margin-bottom: 60px;
}
#seminarArea .hd02 .ttl {
  font-size: 35px;
  font-weight: 500;
  display: flex;
  align-items: center;
  line-height: 1;
}
#seminarArea .hd02 span {
  font-size: 26px;
  margin-left: 20px;
}
#seminarArea .hd02 p {
  font-size: 16px;
  margin-left: 25px;
}
#seminarArea .hd03 {
  font-size: 21px;
  position: relative;
  overflow: hidden;
  margin-bottom: 30px;
  font-weight: 500;
}
#seminarArea .hd03:after {
  position: absolute;
  content: "";
  height: 1px;
  width: 100%;
  background-color: #C21C29;
  top: 0;
  bottom: 0;
  margin: auto 0 auto 10px;
}
#seminarArea .acceptingList {
  margin-bottom: 50px;
  margin-bottom: 72px;
}
#seminarArea .acceptingList ul li a {
  display: flex;
  flex-wrap: wrap;
  background-color: #fff;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.06);
  margin-bottom: 20px;
  box-sizing: border-box;
  padding: 20px 30px;
  position: relative;
}
#seminarArea .acceptingList ul li a:hover {
  opacity: 0.7;
}
.event_fig_cont_wrap {
    display: flex;
    flex-wrap: wrap;
    flex-grow: 1;
    width: calc(100% - 220px);
}
#seminarArea .acceptingList ul li a .date {
  line-height: 1;
  padding-right: 40px;
  padding-top: 20px;
  border-right: 1px solid #D9D9D9;
  margin-right: 30px;
}
#seminarArea .acceptingList ul li a .date .year {
  font-size: 20px;
  margin-bottom: 20px;
}
#seminarArea .acceptingList ul li a .date .day {
  font-size: 42px;
  margin-bottom: 25px;
  display: flex;
  align-items: end;
}
#seminarArea .acceptingList ul li a .date .week {
  font-size: 15px;
  font-weight: 600;
  border: 1px solid #A4A7AD;
  width: 30px;
  height: 30px;
  margin-left: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#seminarArea .acceptingList ul li a .date .time {
  font-size: 23px;
  color: #6B707C;
}
#seminarArea .acceptingList ul li a .cont {
  display: flex;
  font-weight: 600;
  align-items: center;
}
#seminarArea .acceptingList ul li a figure {
  margin-right: 20px;
  width: 114px;
}
#seminarArea .acceptingList ul li a .cont h4 {
  font-size: 23px;
}
#seminarArea .acceptingList ul li a .cont .subTtl, #seminarArea .acceptingList ul li a .cont .cap {
  font-size: 16px;
}
#seminarArea .acceptingList ul li a .cont .cat {
  font-size: 14px;
  color: #6B707C;
  margin-top: 30px;
}
.at_date_detail {
    line-height: 1.3;
    margin-top: 5px;
    font-size: 12px;
    color: #6B707C;
    font-weight: normal;
}
#seminarArea .acceptingList ul li a .cont .cat:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_map.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 13px;
  height: 16px;
  vertical-align: middle;
  margin-right: 5px;
}
#seminarArea .acceptingList ul li a .cont .limit {
  font-size: 19px;
  font-weight: 600;
  color: #fff;
  background-color: #C21C29;
  padding: 0 10px;
  position: absolute;
  top: 10px;
  right: -10px;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  line-height: 34px;
}
#seminarArea .acceptingList ul li a .cont .detail {
  font-size: 12px;
  position: absolute;
  right: 15px;
  bottom: 15px;
  color: #6B707C;
  padding-right: 15px;
}
#seminarArea .acceptingList ul li a .cont .detail:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #6B707C;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}

.acceptingList .front_event_list:not(:has(li)) {
}

.acceptingList .front_event_list:not(:has(li))::after {
  content: "現在、受付中のイベントはありません。";
  content:"\73FE\5728\3001\53D7\4ED8\4E2D\306E\30A4\30D9\30F3\30C8\306F\3042\308A\307E\305B\3093\3002";
}

.scheduledList {
  display: none;
}
.scheduledList:has(li) {
    display: block;
}
#seminarArea .scheduledList ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#seminarArea .scheduledList ul .cont {
  margin-left: 20px;
  font-weight: 600;
}

#seminarArea .scheduledList ul li {
  margin-bottom: 20px;
}

#seminarArea .scheduledList ul li a {
  display: flex;
  background-color: #fff;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.06);
  /* margin-bottom: 20px; */
  box-sizing: border-box;
  padding: 20px 30px;
  position: relative;
  width: 540px;
  max-width: 540px;
  height: 100%;
  flex-wrap: wrap;
}
#seminarArea .scheduledList ul li a:hover {
  opacity: 0.7;
}

.front_event_list figure {
  width: 114px;
}

.front_event_list figure + .cont {
  width:calc(100% - 114px - 20px);
}

#seminarArea .scheduledList ul li a .date {
  line-height: 1.2;
  display: flex;
  margin-bottom: 10px;
  font-size: 15px;
}
#seminarArea .scheduledList ul li a .date .yearD {
  font-size: 15px;
  margin-right: 10px;
}
#seminarArea .scheduledList ul li a .date .week {
  font-size: 14px;
  margin-right: 10px;
}
#seminarArea .scheduledList ul li a .date .time {
  font-size: 15px;
  color: #6B707C;
}
#seminarArea .scheduledList ul li a figure {
  width: 114px;
}
#seminarArea .scheduledList ul li a .cont h4 {
  font-size: 19px;
  line-height: 1.5;
  font-weight: 600;
}
#seminarArea .scheduledList ul li a .cont .cap {
  font-size: 15px;
}
#seminarArea .scheduledList ul li a .cont .cat {
  font-size: 14px;
  color: #6B707C;
  margin-top: 30px;
}
#seminarArea .scheduledList ul li a .cont .cat:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_map.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 13px;
  height: 16px;
  vertical-align: middle;
  margin-right: 5px;
}
#seminarArea .scheduledList ul li a .cont .detail {
  font-size: 12px;
  position: absolute;
  right: 15px;
  bottom: 15px;
  color: #6B707C;
  padding-right: 15px;
}
#seminarArea .scheduledList ul li a .cont .detail:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #6B707C;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
#seminarArea .seminarBtn {
  text-align: center;
  margin-top: 60px;
}
#seminarArea .seminarBtn a {
  color: #fff;
  background-color: #C21C29;
  border-radius: 4px;
  display: inline-block;
  width: 500px;
  text-align: center;
  margin: 0 auto;
  line-height: 60px;
  font-size: 16px;
  font-weight: bold;
  position: relative;
  border: 1px solid #C21C29;
}
#seminarArea .seminarBtn a:hover {
  background-color: #fff;
  color: #C21C29;
}
#seminarArea .seminarBtn a:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 0;
  right: 30px;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
#seminarArea .seminarBtn a:hover:before {
  border-color: transparent transparent transparent #C21C29;
  right: 25px;
}
#seminarArea .seminarBtn a:after {
  content: '';
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
  width: 28px;
  height: 28px;
  border: 1px solid #fff;
  border-radius: 28px;
  transition: 0.3s;
}
#seminarArea .seminarBtn a:hover:after {
  border: 1px solid #C21C29;
  right: 15px;
}
/*--------------------------------------------------------------------
=== [bnrArea] ====================================
 -------------------------------------------------------------------*/
#bnrArea ul {
  display: flex;
}
#bnrArea ul li {
  width: 50%;
  position: relative;
}
#bnrArea ul li a {
  position: relative;
  display: block;
}
#bnrArea ul li a:hover {
  opacity: 0.7;
}
#bnrArea ul li .wrap {
  display: inline-table;
  position: absolute;
  color: #fff;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
#bnrArea ul li .wrap {
    width: 100%;
    padding-inline: 10%;
    display: block;
    height: fit-content;
}
#bnrArea ul li .wrap h4 {
  font-size: 28px;
  font-weight: bold;
  margin-bottom: 40px;
  line-height: 1.5;
}
#bnrArea ul li .wrap p {
  font-size: 14px;
}
#bnrArea ul li figure img {
  width: 100%;
  max-height: 400px;
  object-fit: cover;
}
#bnrArea ul li a:after {
  content: '';
  position: absolute;
  right: 20px;
  bottom: 30px;
  width: 50px;
  height: 50px;
  border: 1px solid #fff;
  border-radius: 28px;
  transition: 0.3s;
}
#bnrArea ul li a:before {
  content: "\e900";
  font-size: 20px;
  font-weight: normal;
  font-family: "icomoon";
  color: #fff;
  display: inline-block;
  position: absolute;
  right: 35px;
  bottom: 38px;
  z-index: 1;
}
#bnrArea ul li a:hover::after {
  background-color: #fff;
  transition: 0.3;
}
#bnrArea ul li a:hover::before {
    color: #c21d29;
  transition: 0.3;
}

/*--------------------------------------------------------------------
=== [columnArea] ====================================
 -------------------------------------------------------------------*/
#columnArea {
  padding: 100px 0;
  overflow: hidden;
  background: linear-gradient(180deg, #fff 0%, #fff 20%, #FBF2F2 20%, #FBF2F2 100%);
  background: linear-gradient(180deg, #fff 0%, #fff 19%, #FBF2F2 19%, #FBF2F2 100%)
}
#columnArea .upr {
  display: flex;
  justify-content: space-between;
  margin-bottom: 60px;
}
#columnArea .hd02 {
  margin-bottom: 80px;
}
#columnArea .hd02 .ttl {
  font-size: 35px;
  font-weight: 500;
  line-height: 1;
}
#columnArea .hd02 span {
  font-size: 26px;
  margin-top: 20px;
  display: block;
}
#columnArea .leadTxt {
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 40px;
}
#columnArea .leftCont p {
  font-size: 14px;
}
#columnArea .rightCont a {
  display: block;
  background-color: #fff;
  padding: 20px 25px 25px;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  max-width: 500px;
}
#columnArea .rightCont a:hover {
  opacity: 0.7;
}
#columnArea .rightCont figure {
  margin-bottom: 15px;
}
#columnArea .rightCont .yearD {
  font-size: 16px;
  line-height: 20px;
}
#columnArea .rightCont .cat {
  background-color: #F05550;
  color: #fff;
  font-size: 12px;
  padding: 0 10px;
  margin-left: 10px;
  line-height: 20px;
}
#columnArea .rightCont h4 {
  font-size: 24px;
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
}
span.icoNew.re_first_new {
    font-size: 14px;
    font-weight: normal;
    display: inline-block;
    text-align: center;
    border: 1px solid #b79443;
    width: 54px;
    color: #b79443;
    padding: 2px 0;
    font-family: "Oswald", "Noto Sans JP", sans-serif;
}
#columnArea .btm {
  position: relative;
}
#columnArea .btm a {
  display: block;
  background-color: #fff;
  padding: 20px 25px 25px;
  box-shadow: 0px 3px 7px 0px rgba(0, 0, 0, 0.15);
  max-width: 364px;
}
#columnArea .btm a:hover {
  opacity: 0.7;
}
#columnArea .btm figure {
  margin-bottom: 15px;
}
#columnArea .btm .yearD {
  font-size: 15px;
  line-height: 20px;
}
#columnArea .btm .cat {
  background-color: #F05550;
  color: #fff;
  font-size: 12px;
  padding: 0 10px;
  margin-left: 10px;
  line-height: 20px;
}
#columnArea .btm h4 {
  font-size: 17px;
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
}
#columnArea .swiper-button-next, #columnArea .swiper-button-prev {
  color: #6B707C !important;
  width: 42px !important;
  height: 98px !important;
}
#columnArea .swiper-button-next::after, #columnArea .swiper-button-prev::after {
  font-size: 88px !important;
  color: transparent;
}
#columnArea .swiper-button-prev, #columnArea .swiper-rtl .swiper-button-next {
  left: -5vw !important;
  top: 0;
  bottom: 0;
  margin: auto;
}
#columnArea .swiper-button-next, #columnArea .swiper-rtl .swiper-button-prev {
  right: -5vw !important;
  top: 0;
  bottom: 0;
  margin: auto;
}
#columnArea .swiper-button-next::after {
  background-image: url(../img/arrow_next.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
#columnArea .swiper-button-prev::after  {
  background-image: url(../img/arrow_prev.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
#columnArea .columnBtn {
  text-align: center;
  margin-top: 60px;
}
#columnArea .columnBtn a {
  color: #fff;
  background-color: #C21C29;
  border-radius: 4px;
  display: inline-block;
  width: 500px;
  text-align: center;
  margin: 0 auto;
  line-height: 60px;
  font-size: 16px;
  font-weight: bold;
  position: relative;
  border: 1px solid #C21C29;
}
#columnArea .columnBtn a:hover {
  background-color: #fff;
  color: #C21C29;
}
#columnArea .columnBtn a:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 6px;
  border-color: transparent transparent transparent #fff;
  position: absolute;
  top: 0;
  right: 30px;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
#columnArea .columnBtn a:hover:before {
  border-color: transparent transparent transparent #C21C29;
  right: 25px;
}
#columnArea .columnBtn a:after {
  content: '';
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
  width: 28px;
  height: 28px;
  border: 1px solid #fff;
  border-radius: 28px;
  transition: 0.3s;
}
#columnArea .columnBtn a:hover:after {
  border: 1px solid #C21C29;
  right: 15px;
}

.swiper-slide.v_top_report {
  height: auto;
}

.swiper-slide.v_top_report > a {
  height: 100%;
}

#columnArea .btm h4 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3; /* 3行で制限 */
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.6; /* 適宜調整 */
  max-height: calc(1.6em * 3); /* 3行分の高さに */
}

/*--------------------------------------------------------------------
=== [newsArea] ====================================
 -------------------------------------------------------------------*/

#newsArea {
  padding: 70px 0;
  }

#newsArea .ttl {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px solid #6B707C;
  padding-bottom: 15px;
  }

#newsArea .ttl h2 {
  font-size: 27px;
  border-left: 4px solid #C21C29;
  padding-left: 20px;
  font-weight: 500;
  }

#newsArea .ttl .moreBtn a {
  display: block;
  border: 1px solid #C21C29;
  color: #C21C29;
  border-radius: 4px;
  padding: 10px 40px 10px 20px;
  box-sizing: border-box;
  position: relative;
  }

#newsArea .ttl .moreBtn a:before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #C21C29;
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
  transition: 0.3s;
}
#newsArea .ttl .moreBtn a:hover {
  background-color:  #C21C29;
  color: #fff;
  }

#newsArea .ttl .moreBtn a:hover:before {
    border-color: transparent transparent transparent #fff;
  right: 15px;
}

#newsArea ul li {
  padding: 20px 0;
  border-bottom: 1px solid #D7D9DD;
  font-size: 15px;
  }

#newsArea ul li .yearD {
  font-size: 14px;
  margin-bottom: 10px;
  }

#newsArea ul li p {
      display: -webkit-box;
      -webkit-line-clamp: 1;
      -webkit-box-orient: vertical;
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: normal;
      line-height: 1.7;
}

/*--------------------------------------------------------------------
=== [ftBnrArea] ====================================
 -------------------------------------------------------------------*/
#ftBnrArea {
  background-color: #F4F5F7;
  padding: 45px 0;
  }
#ftBnrArea ul {
  display: flex;
  justify-content: space-between;
}

#ftBnrArea ul li a {
  display: block;
  }

#ftBnrArea ul li a:hover {
  opacity: 0.7;
  }

#ftBnrArea ul li a figure {
  background-color: #fff;
  border: 1px solid #A4A7AD;
  width: 345px;
  height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  }

#ftBnrArea ul li:nth-child(1) img {
  width: 175px;
  }
#ftBnrArea ul li:nth-child(2) img {
  width: 166px;
  }
#ftBnrArea ul li:nth-child(3) img {
  width: 186px;
  }
#ftBnrArea ul li a p {
  font-size: 15px;
  margin-top: 10px;
  }
#ftBnrArea ul li a p:after {
  content: "\e900";
  font-size: 0.9rem;
  font-weight: normal;
  font-family: "icomoon";
  color: #C21C29;
  display: inline-block;
  margin-left: 5px;
  vertical-align: middle;
}

/*--------------------------------------------------------------------
=== [SP] ====================================
 -------------------------------------------------------------------*/

.pcHide {
display: none;
}

.spHide {
display: block;
}




/** Mini pc
===================================*/
@media screen and (max-width: 1139px) {
.headerUpr {
    padding-inline: 12px;
}

header .header_logo {
    margin-left: 12px;
}

header .header_menu > ul > li {
    margin-right: 10px;
}

header .header_menu ul {
    display: flex;
    font-size: 14px;
    font-weight: bold;
    gap: 12px;
}

.inner {
    padding-inline: 12px;
    max-width: 1124px;
}

#seminarArea .scheduledList ul li {
    width: 49%;
}

#seminarArea .scheduledList ul li a {
    width: auto;
}

#newsArea ul li a:hover {
  color: #C21C29;
}

#ftBnrArea ul li {
    width: 32%;
}

#ftBnrArea ul li a figure {
    width: auto;
}


}/* @media */






/** Tablet
===================================*/
@media screen and (max-width: 1024px) {
header .header_right .sem_account_link a {
    font-size: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}

#seminarArea .hd02 {
    display: block;
}

#seminarArea .hd02 .ttl {
  font-size: 25px;
  margin-bottom: 20px;
  }
#seminarArea .hd02 span {
  font-size: 18px;
  margin-left: 15px;
}
  
#seminarArea .hd02 p {
  font-size: 14px;
  margin-left: 0;
}
#seminarArea .hd03 {
  font-size: 16px;
  margin-bottom: 20px;
}


#bnrArea ul li .wrap h4 {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 20px;
    line-height: 1.5;
}


/* footer */
.footer_body {
    align-items: baseline;
}

.footer_menu__sns {
    width: 100%;
    justify-content: flex-end;
    display: flex;
    margin-top: 20px;
}





}/* @media */







@media (max-width: 767px){
  
.pcHide {
display: block;
}

.spHide {
display: none;
}
  
body {
}
  
.inner {
  /* margin: 0 12px; */
}	

/*--------------------------------------------------------------------
=== [header] ====================================
 -------------------------------------------------------------------*/  
.headerUpr {
}

.headerUpr {
}

nav.uprMenu {
    display: none;
}

.headerUpr {
    padding: 5px 12px;
}

.headerUpr h1 {
   font-size: 11px;
}

.headerUpr p {
   font-size: 11px;
}

#spHeader {
width: 100%;
  }
#spHeader .headerInner {
/* box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.1);
box-shadow: 0px 5px 13px 0px rgba(0, 0, 0, 0.05); */
background-color: #fff;
}
#spHeader h1, #spHeader p {
  font-size: 11px;
  color: #6B707C;
  padding: 0 12px;
  line-height: 25px;
  border-bottom: 1px solid #EAECEF;
  }

.gloval__nav_sticky.active {
  box-shadow: 0px 5px 13px 0px rgba(0, 0, 0, 0.05);
}
  
#spHeader .headerMid {
  padding: 0 0 0 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #EAECEF;
  }
  
#spHeader .headerMid .headerLogo {
  width: 107px;
  }

.accountLink {
    display: flex;
    gap: 5px;
  }

.mode_customer .is_customer.accountLink {
      color: #A4A7AD;
      flex-direction: column;
      gap: 10px;
  }
  
#spHeader .headerMid .accountLink a {
  font-size: 12px;
  color: #A4A7AD;
  }
  
#spHeader .headerMid .wrap {
  display: flex;
  }
  
#spHeader .headerMid .contactLink a {
  color: #fff;
  font-size: 11px;
  background-color: #C21C29;
  display: block;
  position: relative;
  height: 58px;
  min-width: 58px;
  text-align: center;
  padding-top: 32px;
  padding-inline: 5px;
}
#spHeader .headerMid .contactLink a:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_contact.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 23px;
  height: 18px;
  vertical-align: text-bottom;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  position: absolute;
}	
#spHeader .headerMid .menuOpen span {
  color: #fff;
  font-size: 11px;
  background-color: #000000;
  display: block;
  position: relative;
  height: 58px;
  width: 58px;
  text-align: center;
  padding-top: 32px;
}
#spHeader .headerMid .menuOpen span:before {
  content: "";
  display: inline-block;
  background-image: url("../img/ico_menu_open.svg");
  background-size: contain;
  background-repeat: no-repeat;
  width: 23px;
  height: 18px;
  vertical-align: text-bottom;
  top: 10px;
  left: 0;
  right: 0;
  margin: auto;
  position: absolute;
  transition: 0.3s;
}	
  
#spHeader .headerMid .menuOpen.on span:before {
  background-image: url("../img/ico_menu_close.svg");
  width: 24px;
  height: 15px;	
  top:12px;
  }
  
#spHeader .headerBtm {
  padding: 10px 12px;
  }
#spHeader .headerBtm ul {
  display: flex;
  font-size: 12px;
  font-weight: bold;
  justify-content: space-between;
  }

    .headerBtm {
      padding: 10px 12px;
      box-shadow: 0px 5px 13px 0px rgba(0, 0, 0, 0.05);
  }
.headerBtm ul {
    display: flex;
    font-size: 12px;
    font-weight: bold;
    justify-content: space-between;
    }

#spHeader .menu {
  /* background: linear-gradient(to right, #777777 0%, #777777 10.7%, #fff 10.7%, #fff 100%); */
  /* padding: 40px 32px 40px 64px; */
  position: absolute;
  width: 100%;
  top:58px;
  box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.1);
  opacity: 0;
  transition: 0.3s;
  visibility: hidden;
  z-index: -1;
  display: flex;
  flex-wrap: wrap;
  }
#spHeader .menu.on {
  opacity: 1;
  visibility: visible;
  z-index: 100;
  height: calc(100vh - 58px);
  }

.menu_inner {
  background-color: #fff;
  width: 343px;
  padding: 40px 32px 60px 20px;
  height: 100%;
  overflow: auto;
}

.menu_close {
  background-color: rgba(0,0,0,0.5);
  width: calc(100% - 343px);
}
  
#spHeader .menu dt {
  font-size: 18px;
  font-weight: 500;
  border-bottom: 1px solid #B5B5B5;
  padding-bottom: 10px;
  margin-bottom: 14px;
  }
#spHeader .menu dt span {
  font-size: 16px;
  display: inline-block;
  margin-left: 10px;
  }
  
#spHeader .menu dd {
  margin-bottom: 40px;
  }
#spHeader .menu dd ul li {
  margin-bottom: 14px;
  }
#spHeader .menu dd ul li a {
  font-size: 15px;
  margin-bottom: 20px;
  position: relative;
  }
  
#spHeader .menu dd ul li a:not([target="_blank"]):before {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 4px 0 4px 7px;
  border-color: transparent transparent transparent #C21C29;
  position: absolute;
  top: 3px;
  right: -20px;
  bottom: 0;
  margin: auto;
}
#spHeader .menu dd ul li a[target="_blank"]:after {
  content: "\e900";
  font-size: 0.9rem;
  font-weight: normal;
  font-family: "icomoon";
  color: #C21C29;
  display: inline-block;
  margin-left: 5px;
}
#spHeader .menu	.btmMenu {
  margin-bottom: 30px;
  }
#spHeader .menu	.btmMenu ul {
  font-size: 13px;
  display: flex;
  flex-wrap: wrap;
  }
#spHeader .menu .btmMenu ul + ul {
      margin-top: 10px;
  }
#spHeader .menu	.btmMenu ul li {
  margin-right: 15px;
  }
  
#spHeader .menu	.btmMenu ul li a {
  color: #6B707C;
  }
  
#spHeader .menu .snsLink ul {
  display: flex;
  }
#spHeader .menu .snsLink ul li {
  margin-right: 12px;
  }
/*--------------------------------------------------------------------
=== [mvArea] ====================================
 -------------------------------------------------------------------*/  	
#mvArea .swiper {
     margin-top: 24px;
 }
  
 #mvArea .swiper-button-next::after, #mvArea .swiper-button-prev::after {
  font-size: 44px !important;
}
#mvArea .swiper-button-prev, #mvArea .swiper-rtl .swiper-button-next {
  left: 2.5vw !important;
}
#mvArea .swiper-button-next, #mvArea .swiper-rtl .swiper-button-prev {
  right: 2.5vw !important;
}	
#mvArea .swiper-pagination {
  bottom: -25px !important;
}
  
/*--------------------------------------------------------------------
=== [seminarArea] ====================================
 -------------------------------------------------------------------*/  	
  
#seminarArea {
  background-color: #F4F5F7;
  margin-top: 30px;
  padding-top: 40px;
  padding-bottom: 70px;
}
  
#seminarArea .hd02 {
  display: block;
  margin-bottom: 30px;
}	
  
#seminarArea .hd02 .ttl {
  font-size: 25px;
  margin-bottom: 20px;
  }
#seminarArea .hd02 span {
  font-size: 18px;
  margin-left: 15px;
}
  
#seminarArea .hd02 p {
  font-size: 14px;
  margin-left: 0;
}
#seminarArea .hd03 {
  font-size: 16px;
  margin-bottom: 20px;
}

#seminarArea .acceptingList {
  margin-bottom: 50px;
}

#seminarArea .scheduledList ul .cont {
    margin-left: 20px;
    font-weight: 400;
}

.front_event_list figure + .cont {
    width: calc(100% - 90px - 20px);
}

#seminarArea .acceptingList ul li a .cont {
  font-weight: 400;
}
  
#seminarArea .acceptingList ul li a .cont .limit {
  font-size: 14px;
  line-height: 26px;
}	
  
#seminarArea .acceptingList ul li a {
  padding: 20px 20px 40px;
  flex-wrap: wrap;
  justify-content: space-between;
}

#seminarArea .acceptingList ul li a {
    position: relative;
}

#seminarArea .acceptingList ul li a .date {
  line-height: 1;
  padding-top: 40px;
  border: none;
}	
#seminarArea .acceptingList ul li a figure {
  width: 120px;
  margin-right: 0px;
  border-left: 1px solid #D9D9D9;
  padding-left: 20px;}
#seminarArea .acceptingList ul li a figure {
      position: absolute;
      right: 20px;
      top: 20px;
  }
#seminarArea .acceptingList ul li a .cont {
  margin-top: 20px;
  width: 100%;
}
#seminarArea .acceptingList ul li a .cont .cat {
  position: absolute;
  margin-top: 0px;
  top: 20px;
  left:20px;
  width: 60%;
  font-size: 11px;
  text-overflow: ellipsis;
  line-height: 1.5;
}
#seminarArea .acceptingList ul li a .date .year {
  font-size: 18px;
  margin-bottom: 10px;
}	
  
#seminarArea .acceptingList ul li a .date .day {
  font-size: 34px;
  margin-bottom: 15px;
}	
  
#seminarArea .acceptingList ul li a .cont .subTtl, #seminarArea .acceptingList ul li a .cont .cap {
  font-size: 14px;
}
#seminarArea .acceptingList ul li a .cont h4 {
  font-size: 17px;
}	
#seminarArea .acceptingList ul li a .cont .ttl {
  margin-bottom: 20px;
  }
#seminarArea .acceptingList ul li a .cont .detail {
  right: 0;
  left: 0;
  margin: auto;
  bottom: 0;
  text-align: center;
  border-top:1px solid #D9D9D9;
  padding-top: 10px;
  padding-right: 0;
  padding-bottom: 10px;
}

#seminarArea .acceptingList ul li a .cont .detail:before {
  content: none;
}
#seminarArea .acceptingList ul li a .cont .detail:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #6B707C;
  position: absolute;	
  top: 0;
  bottom:0;
  margin: auto 0 auto 10px;;
}
  
#seminarArea .scheduledList ul {
  display: block;
  }

#seminarArea .scheduledList ul li {
  width: 100%;
}

#seminarArea .scheduledList ul li a {
  display: flex;
  background-color: #fff;
  box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.06);
  margin-bottom: 20px;
  box-sizing: border-box;
  padding: 20px 20px 60px 20px;
  position: relative;
  width: 100%;
}
  
#seminarArea .scheduledList ul li a figure {
  width: 90px;
  }
#seminarArea .scheduledList ul li a .date .yearD {
  font-size: 14px;
}
#seminarArea .scheduledList ul li a .date .week {
  font-size: 12px;
}
#seminarArea .scheduledList ul li a .date .time {
  font-size: 14px;
  margin-left: auto;
}
#seminarArea .scheduledList ul li a .cont h4 {
  font-size: 15px;
  font-size: 15px;
  font-weight: 400;
  margin-bottom: 10px;
}	
#seminarArea .scheduledList ul li a .cont .cat {
  font-size: 12px;
  margin-top: 10px;
}	
  
#seminarArea .scheduledList ul li a .cont .cap {
  font-size: 13px;
  line-height: 1.5;
}	
#seminarArea .scheduledList ul li a .cont .detail {
    right: 0;
    left: 0;
    margin: auto;
    bottom: 0;
    text-align: center;
    border-top: 1px solid #D9D9D9;
    padding-top: 10px;
    padding-right: 0;
    padding-bottom: 10px;
  }

#seminarArea .scheduledList ul li a .cont .detail:before {
  content: none;
}
#seminarArea .scheduledList ul li a .cont .detail:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #6B707C;
  position: absolute;	
  top: 0;
  bottom:0;
  margin: auto 0 auto 10px;;
}
  
#seminarArea .seminarBtn {
  padding: 0 20px;
  margin-top: 20px;
}	
#seminarArea .seminarBtn a {
  width: 100%;
  line-height: 45px;
  font-size: 14px;
}	

.event_fig_cont_wrap {
    width: calc(100%);
}
  
/*--------------------------------------------------------------------
=== [bnrArea] ====================================
 -------------------------------------------------------------------*/  
  
#bnrArea ul {
  display: block;
}
#bnrArea ul li {
  width: 100%;
}
#bnrArea ul li .wrap {
    padding-inline: 12px;
}

#bnrArea ul li figure img {
  height: 280px;
}
#bnrArea ul li .wrap h4 {
  font-size: 21px;
  margin-bottom: 20px;
}
#bnrArea ul li a:after {
  right: 12px;
  bottom: 12px;
  width: 34px;
  height: 34px;
  border-radius: 17px;
}
#bnrArea ul li a:before {
  font-size: 16px;
  right: 21px;
  bottom: 15px;
}	
  
  
/*--------------------------------------------------------------------
=== [columnArea] ====================================
 -------------------------------------------------------------------*/ 	
#columnArea {
  padding: 00px 0 100px 0;
  background: linear-gradient(180deg, #fff 0%, #fff 9%, #FBF2F2 9%, #FBF2F2 100%);
  background: #FBF2F2;
}
#columnArea .upr {
  display: block;
  }
#columnArea .hd02 {
  margin-bottom: 70px;
}
#columnArea .hd02 {
    margin: 0 -12px;
    padding: 40px 12px 40px;
    background-color: #fff;
}
#columnArea .hd02 .ttl {
  font-size: 25px;
  font-weight: 400;
}
#columnArea .hd02 span {
  font-size: 18px;
  margin-top: 10px;
}	
  
#columnArea .leadTxt {
  font-size: 18px;
  margin-bottom: 20px;
  padding-top: 30px;
}
#columnArea .leftCont {
  margin-bottom: 40px;
  }


#columnArea .rightCont .yearD {
  font-size: 14px;
  margin-bottom: 10px;
}
#columnArea .rightCont .cat {
  font-size: 11px;
}
#columnArea .rightCont h4 {
  font-size: 17px;
}
  
#columnArea .swiper-button-next::after, #columnArea .swiper-button-prev::after {
  font-size: 44px !important;
}
#columnArea .swiper-button-prev, #columnArea .swiper-rtl .swiper-button-next {
  left: -2.5vw !important;
}
#columnArea .swiper-button-next, #columnArea .swiper-rtl .swiper-button-prev {
  right: -2.5vw !important;
}
  
#columnArea .swiper {
  overflow: visible!important;
  }
#columnArea .btm .yearD {
  font-size: 13px;
}
#columnArea .btm .cat {
  font-size: 12px;
}
#columnArea .btm h4 {
  font-size: 14px;
}	
  
#columnArea .columnBtn {
  padding: 0 20px;
  margin-top: 40px;
}	
#columnArea .columnBtn a {
  width: 100%;
  line-height: 45px;
  font-size: 14px;
}
  
/*--------------------------------------------------------------------
=== [newsArea] ====================================
 -------------------------------------------------------------------*/ 	
#newsArea {
     padding: 64px 0 50px;
 }

#newsArea .ttl h2 {
  font-size: 22px;
  padding-left: 10px;
  line-height: 1.2;
  }

#newsArea .ttl .moreBtn a {
      padding: 3px 25px 3px 12px;
  }

#newsArea .ttl .moreBtn a:before {
      right: 10px;
      border-width: 4px 0 4px 5px;
      top: 1px;
  }

#newsArea ul li .yearD {
      font-size: 14px;
      margin-bottom: 5px;
  }

  
/*--------------------------------------------------------------------
=== [newsArea] ====================================
 -------------------------------------------------------------------*/ 		
  
#ftBnrArea {
  background-color: #F4F5F7;
  padding: 40px 0 30px;
}

#ftBnrArea ul {
  display: block;
  }

#ftBnrArea ul li {
      width: 100%;
  }

#ftBnrArea ul li a figure {
  width: 100%;
  height: 80px;
}

#ftBnrArea ul li {
  margin-bottom: 20px;
  }

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

#ftBnrArea ul li:nth-child(1) img {
  width: 142px;
  }
#ftBnrArea ul li:nth-child(2) img {
  width: 142px;
  }
#ftBnrArea ul li:nth-child(3) img {
  width: 142px;
  }	
#ftBnrArea ul li a p {
  font-size: 14px;
  margin-top: 5px;
}
  

/*--------------------------------------------------------------------
=== [footer] ====================================
 -------------------------------------------------------------------*/ 
footer {
   padding: 49px 0 22px 0;
   background-color: #1E1E1E;
   font-family: "Noto Sans JP", sans-serif;
}

footer * {
   font-family: "Noto Sans JP", sans-serif;
}

.footer_body {
    margin-bottom: 38px;
}

.footer_menu__service {
    margin-bottom: 46px;
}

.footer_menu .flex {
    flex-direction: column;
}

.footer_menu__service .footer_menu__list ul:first-child {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
}

.footer_menu__service .footer_menu__list ul:first-child li a {
  font-weight: bold;
  font-size: 14px;
}

.footer_menu__list li {
    width: 50%;
}

.footer_menu__service .footer_menu__list ul:last-child {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid #707070;
    font-size: 12px;
}

.footer_menu__service .footer_menu__list ul:last-child li a {
    font-size: 12px;
}

.footer_menu__sns {
    margin-top: 0;
    justify-content: flex-start;
}

.footer_menu__sns * {
    font-family: "Oswald", "Noto Sans JP", sans-serif;
}

.footer__name_address {
    margin-bottom: 20px;
}

.footer_info {
    margin-bottom: 0;
}

.footer_other {
    padding-top: 12px;
}




}
/* @media */





/*--------------------------------------------------------------------
=== [plus] ====================================
 -------------------------------------------------------------------*/ 	
.scroll header {
  padding: 0px 0px 0px 0;
}

.swiper {
  visibility: hidden;
}

.swiper.swiper-initialized {
  visibility: visible;
}

#columnArea .swiper.swiper-initialized {
  visibility: visible;
  overflow: visible;
}

.seminar_under_page {
    padding-bottom: 80px;
}











