@charset "UTF-8";
/*トップページ*/
.top-mv {
	position: relative;
	height: 434px;
}
.top-mv__slider {
	height: 434px;
}
.top-mv__slider--inner {
	height: 100%;
}
.top-mv::before {
	content: "";
	display: block;
	width: 100%;
	height: 156px;
	background: transparent linear-gradient(180deg, #FFFFFF 0%, #242424 100%) 0% 0% no-repeat padding-box;
	mix-blend-mode: multiply;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 10;
}
.top-mv__title {
	font-size: 18px;
	font-weight: 300;
	letter-spacing: 0.6em;
	color: #FFF;
	text-align: center;
	position: absolute;
	width: 100%;
	left: 50%;
	top: 36px;
	transform: translateX(-50%);
	z-index: 10;
	text-shadow: rgba(0,0,0,0.85) 0 0 6px;
}
.top-mv img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-mv__description {
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	font-size: 14px;
	color: #FFF;
	letter-spacing: 0.05em;
	text-shadow: rgba(0,0,0,0.85) 0 0 6px;
	width: 100%;
	padding: 36px;
}
.top-mv__catch {
	font-size: 20px;
	line-height: 1.5;
	letter-spacing: 0.2em;
	margin-bottom: 17px;
}
.top-nayami__title--wrapper {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 96px;
}
.top-nayami__title {
	text-align: center;
	color: #41BAA8;
	font-size: 21px;
	line-height: 1.33;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.top-nayami__content--wrapper {
	padding-top: 60px;
}
.top-nayami__photo {
	height: 364px;
}
.top-nayami__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-nayami__list--wrapper {
	background: #F8F4EF;
	padding: 40px 0 40px 32px;
}
.top-nayami__item {
	display: flex;
	align-items: center;
	line-height: 1.3125;
	grid-column-gap: 14px;
}
.top-nayami__item::before {
	content: "";
	display: block;
	width: 31.27px;
	height: 29px;
	background: url(../../img/ico-check.png) center center no-repeat;
	background-size: contain;
	vertical-align: -8px;
}
.top-nayami__item + .top-nayami__item {
	margin-top: 24px;
}
.top-kaiketsu {
	padding-block: 60px;
}
.top-kaiketsu__title {
	text-align: center;
	color: #EA5854;
	font-size: 21px;
	font-weight: 700;
	margin-bottom: 36px;
}
.top-miryoku {
	background: #F8F4EF;
	padding-block: 40px;
}
.top-miryoku__title {
	text-align: center;
	color: #41BAA8;
	font-size: 21px;
	font-weight: 700;
	margin-bottom: 18px;
	border-bottom: #242424 1px solid;
	padding-bottom: 12px;
}
.top-miryoku__photo {
	margin-left: -36px;
}
.top-miryoku__photo img {
	border-left: #41BAA8 6px solid;
	border-top-right-radius: 20px;
	border-bottom-right-radius: 20px;
}
.top-miryoku__text {
	margin-bottom: 40px;
}
.top-miryoku__text-title {
	font-size: 18px;
	font-weight: 700;
	color: #41BAA8;
	display: flex;
	align-items: center;
	grid-column-gap: 13px;
	line-height: 1.33;
	margin-block: 12px;
}
.top-miryoku__text-title--number {
	color: #FFF;
	font-size: 2.4em;
}
.top-course__tabpanel-title {
	font-size: 24px;
	font-weight: 700;
	margin-bottom: 14px;
	line-height: 1;
}
.top-course__tabpanel-title span {
	font-size: 16px;
	font-weight: 400;
	display: block;
	margin-bottom: 14px;
}
.top-course__tabpanel-photo {
	margin: 40px -36px;
}
.top-course__tabpanel-effect {
	margin-bottom: 60px;
}
.top-course__other-program--wrapper {
	margin-bottom: 24px;
}
.top-course__other-program {
	background: #FFF;
	border-radius: 20px;
}
.top-course__other-program + .top-course__other-program  {
	margin-top: 12px;
}
.top-course__other-program-photo img {
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
	width: 100%;
}
.top-course__other-program-title {
	background: #EC6E88;
	color: #FFF;
	text-align: center;
	font-size: 18px;
	font-weight: 700;
}
.top-course__other-program-description {
	padding: 16px 18px 24px 18px;
}
.top-course__other-program-description .caution {
	color: #EA5854;
	font-weight: 500;
}
.top-course__other-program--2 .top-course__other-program-title {
	background: #B67DCB;
}
.top-course__other-program--3 .top-course__other-program-title {
	background: #66C6E3;
}
.top-course__schedule {
	margin-top: 60px;
}
.top-course__schedule-table--wrapper {
	overflow-x: scroll;
	padding-bottom: 8px;
	margin-block: 16px 60px;
}
.top-course__schedule-table--wrapper::-webkit-scrollbar{
	   width: 12px;
	}
.top-course__schedule-table--wrapper::-webkit-scrollbar-track{
	   background-color: #FFF;
	   border-radius: 6px;
	}
.top-course__schedule-table--wrapper::-webkit-scrollbar-thumb{
	   background-color: #C9C9C9;
	   border-radius: 6px;
	}
.top-course__schedule-table {
	width: 938px;
	border-collapse: separate;
	border-spacing: 8px 4px;
}
.top-course__schedule-table th,
.top-course__schedule-table td {
	padding: 2px;
	line-height: 2.19;
}
.top-course__schedule-table .youbi {
	background: #41BAA8;
	color: #FFF;
	text-align: center;
	border-radius: 5px;
}
.top-course__schedule-table .time {
	background: #FFF;
	text-align: center;
	border-radius: 5px;
	border: #41BAA8 2px solid;
}
.top-course__schedule-table .program {
	background: #FFF;
	text-align: center;
	border-radius: 5px;
	border: #66C6E3 2px solid;
	color: #66C6E3;
	font-weight: 700;
}
.top-course__schedule-table .program2 {
	border-color: #EC6E88;
	color: #EC6E88;
}
.top-course__schedule-table .program3 {
	border-color: #B67DCB;
	color: #B67DCB;
}
.top-course__schedule-table .program4 {
	border-color: #E8BC09;
	color: #E8BC09;
}
.top-course__plan-item {
	border: #41BAA8 1px solid;
	margin-top: 12px;
	margin-bottom: 18px;
	text-align: center;
	background: #FFF;
	box-shadow: rgba(0,0,0,0.16) 3px 3px 6px;
}
.top-course__plan-title {
	font-size: 18px;
	color: #FFF;
	font-weight: 700;
	text-align: center;
	background: #41BAA8;
	padding: 4px;
}
.top-course__plan-memo {
	font-size: 14px;
	padding: 6px 12px;
	text-align: left;
	min-height: 48px;
}
.top-course__plan-div {
	background: #E2F5F2;
	display: flex;
	justify-content: space-between;
	grid-column-gap: 48px;
	padding: 12px 20px;
	text-align: left;
}
.top-course__plan-dd {
	font-weight: 700;
}
.top-course__plan-note {
	text-align: right;
}
.top-course__stamp-title {
	text-align: center;
	color: #EA5854;
	font-size: 18px;
	font-weight: 700;
	margin-block: 36px 18px;
}
.top-course__stamp-list {
	margin-bottom: 24px;
}
.top-course__stamp-item {
	color: #FFF;
	background: #EA5854;
	font-weight: 700;
	text-align: center;
	padding: 8px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-height: 64px;
}
.top-course__stamp-item + .top-course__stamp-item {
	margin-top: 10px;
}
.top-course__voice {
	margin-block: 60px 40px;
}
.top-course__voice-item {
	margin-block: 20px;
	position: relative;
}
.top-course__voice-item a::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: transparent linear-gradient(180deg, #FFFFFF00 0%, #FFFFFF 100%) 0% 0% no-repeat padding-box;
	z-index: 2;
}
.top-course__voice-item a::after {
	content: "詳しく見る";
	position: absolute;
	width: clamp(166px, calc(10.375rem + ((1vw - 3.75px) * 2.0712)), 198px);
  min-height: 0vw;
	height: 42px;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	font-weight: 700;
	font-size: 14px;
	color: #FFF;
	background: #41BAA8;
	border-radius: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 3;
}
.featherlight-box {
	display: none;
}
.featherlight-inner {
	max-width: 796px;
	margin-inline: auto;
}
.featherlight:last-of-type {
	background: #FFF!important;
}
.featherlight .featherlight-content {
	position: static !important;
	font-size: 18px;
	line-height: 1.78;
}
.featherlight .featherlight-close-icon {
	width: 48px!important;
	height: 48px!important;
	font-size: 48px;
	top: 30px !important;
	right: 30px !important;
}
.voice-photo {
	margin-bottom: 48px;
}
.top-course__instructor-list--wrapper {
	width: 281px;
	height: 327px;
	position: relative;
	left: 14px;
}

.top-course__instructor-item--inner {
	background: #FFF;
	border-radius: 15px;
	padding: 27px 19px;
	width: 257px;
	box-shadow: rgba(0,0,0,0.16) 3px 3px 6px;
}
.top-course__instructor-photo {
	width: 160px;
	height: 160px;
	margin-inline: auto;
}
.top-course__instructor-name {
	font-size: 18px;
	padding-bottom: 12px;
	border-bottom: #707070 1px solid;
	margin-bottom: 11px;
}
.swiper--wrapper {
	position: relative;
}
/* 前へ次への矢印カスタマイズ */
.swiper-button-prev,
.swiper-button-next {
  height: 37px!important;;
  width: 37px!important;;
  left: 0 !important;
}
.swiper-button-next {
	left: auto!important;
	right: -6px!important;
}
/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: ""!important;
  height: 37px!important;
  margin: auto;
  width: 37px!important;
}
/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
  background-image: url(../../img/slider-nav-left.png);
}
/* 次への矢印カスタマイズ */
.swiper-button-next::after {
  background-image: url(../../img/slider-nav-right.png);
}
.top-contact-tel {
	padding-bottom: 60px;
}
.top-contact-tel__number {
	text-align: center;
}
.top-contact-tel__anchor {
	color: #50BFD3;
	font-size: 38px;
	font-weight: 700;
	display: block;
}
.top-contact-tel__anchor::before {
	content: "";
	display: inline-block;
	width: 31.18px;
	height: 31.18px;
	margin-right: 11px;
	background: url(../../img/ico-side-tel-normal.png) center center no-repeat;
	background-size: contain;
}
.top-bnr__contact--div2 {
		margin-top: 40px;
	}
.contact-form {
	margin-top: 30px;
}
.contact-form__div {
	margin-bottom: 20px;
	display: flex;
}
.contact-form__dt {
	width: 98px;
}
.contact-form__dd {
	width: calc(100% - 98px);
}
.contact-form__dd .form__type--text {
	width: 100%;
}
.contact-form__dd .form--box {
	background: #FFF;
	border-radius: 0;
	border: #242424 1px solid;
	padding-block: 10px;
	font-size: 16px;
}
.contact-form__dd--sex {
	display: flex;
	grid-column-gap: 36px;
}
.contact-form__address {
	display: flex;
	justify-content: space-between;
}
.contact-form__address--pref {
	 width: calc(100% - 106px - 8px);
	 margin-bottom: 16px;
}
.contact-form__address--pref select{
 height: 41px;
 line-height: 41px;
 width: 100%;
 display: block;
}
.contact-form__dd--subject {
	display: flex;
	flex-direction: column;
	margin-bottom: 20px;
}
.form__type--textarea {
	width: calc(100vw - 36px * 2)!important;
	transform: translateX(-98px);
	margin-block: 20px;
	font-family: 'Noto Sans JP', sans-serif;
}
.contact-form__agreement a {
	color: #EA5854;
	text-decoration: underline;
	transition: none;
}
.contact-form__agreement a:hover {
	color: #4B4B4B;
}
.contact-form__submit {
	margin: 60px auto;
	max-width: 398px;
}
.contact-form__submit input {
	display: block;
	width: 100%;
	background: #FFF;
	border-radius: 200px;
	color: #41BAA8;
	font-weight: 700;
	border: #41BAA8 2px solid;
	font-size: 16px;
	padding: 11px;
}
.contact-form__submit input:hover {
	background: #41BAA8;
	color: #FFF;
}
.radio-btns label ~ .radio-btns label {
  margin-left: 15px;
}

.radio-btns input[type=radio] {
  margin-right: 8px;
}

/* ラジオボタン */
.radio-btns input[type=radio] {
  display: none;
}

.radio-btns label {
  position: relative;
  padding-left: 40px;
}
.radio-btns label span::before{
	position: absolute;
  content: '';
  display: block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #FFF;
  border: 1px solid #242424;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: -1;
}
.radio-btns input[type=radio] + label::before {
  position: absolute;
  content: '';
  display: block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #41BAA8;
  border: 1px solid #242424;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  transition: .3s;
}

.radio-btns input[type=radio] + label::after {
  position: absolute;
  content: '';
  display: block;
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #FFF;
  left: 15px;
  top: 50%;
  opacity: 0;
  transition: .3s;
  transform: translateX(-50%) translateY(-50%);
}

.radio-btns input[type=radio]:checked + label::before,
.radio-btns input[type=radio]:checked + label::after {
 opacity: 1;
}
.contact-form__dd--subject-inner + .contact-form__dd--subject-inner {
	margin-top: 16px;
}








.top-contact-access {
	background: #F8F4EF;
	padding-block: 60px;
}
.top-contact-access .ggmap {
	margin-inline: -36px;
}
.top-contact-information {
	margin-top: 60px;
}
.top-contact-information__title {
	padding-block: 24px;
	border-top: #242424 1px solid;
	border-bottom: #242424 1px solid;
	font-weight: 700;
	font-size: 16px;
}
.top-contact-information__description {
	padding-block: 24px;
	border-bottom: #242424 1px solid;
}
.top-contact-company {
	text-align: center;
	font-weight: 700;
	margin-top: 36px;
}
.top-contact-company__anchor {
	color: #48B26C;
	text-decoration: underline;
	transition: none;
}
.top-contact-company__anchor:hover {
	color: #EA5854;
}

.thanks-complete {
	padding-top: 108px;
}
.thanks-complete__title {
	color: #41BAA8;
	font-weight: 700;
	font-size: 26px;
	text-align: center;
	margin-bottom: 33px;
}
.thanks-complete__description {
	text-align: center;
	margin-bottom: 48px;
}
.thanks-complete .btn__contact--anchor {
	color: #41BAA8;
	border-color: #41BAA8;
}
.thanks-complete .btn__contact--anchor:hover {
	color: #FFF;
	background: #41BAA8;
}
.thanks-sns {
	font-size: 12px;
	text-align: center;
	padding-top: 63px;
}
.thanks-sns__list {
	display: flex;
	justify-content: center;
	grid-column-gap: 29px;
	margin-block: 16px 78px;
}
.thanks-sns__item {
	width: 36px;
	height: 36px;
}









.top-renewal {
	min-height: calc(100vh - 140px);
}
.renewal__title::before {
	content: "Under renewal";
	display: block;
	font-size: 20px;
	font-weight: 700;
	color: #EA5854;
	text-align: center;
	margin-top: 40px;
	margin-bottom: 30px;
}

.renewal__title {
	font-size: 28px;
	font-weight: 700;
	color: #333;
	line-height: 1.43;
	text-align: center;
	margin-bottom: 14px;
}
.renewal__description {
	line-height: 1.875;
	margin-bottom: 40px;
}
.renewal__contact--text::before {
	content: "";
	display: block;
	width: 100%;
	height: 1px;
	background: #707070;
	margin-bottom: 30px;
}
.renewal__contact--text {
	text-align: center;
	font-weight: 700;
	margin-bottom: 16px;
}
.renewal__contact--tel {
	text-align: center;
}
.renewal__contact--tel a {
	color: #4BB9CE;
	font-size: 30px;
	font-weight: 700;
}
.renewal__contact--time {
	text-align: center;
	font-size: 14px;
	margin-bottom: 210px;
}