@charset "UTF-8";

/*--------*/
/* 共通設定 */
/*--------*/
@media print, screen and (min-width: 768px) {
	.block-page-freespace--caption .Common-Inner,
	.block-page-freespace--top .Common-Inner,
	.Contents-Inner,
	.Contents-area.Common-Wrap > section:not(.FullSize),
	.MainVisual-Lead {
		max-width: 900px;
	}
	.FullSize > *:not(.Common-Wrap):not(.Common-Inner) {
		max-width: 750px;
	}
}
.Contents-area.Common-Wrap aside + .FullSize {
	margin-top: 60px;
}
@media screen and (max-width: 767px) {
	.block-page-block:not(:has(*)) {
		margin-bottom: 0 !important;
	}
}
/*----------*/
/* //共通設定 */
/*----------*/


/* 共通レイアウト調整 */
.Note-Text {
	display: block;
}
.Note-Text + .Note-Text,
figure + .Note-Text,
.swiper + .Note-Text {
	margin-top: 10px;
}

.marker {
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ecda65), color-stop(100%, #ecda65));
	background: linear-gradient(#ecda65 0%, #ecda65 100%);
}

/* アンカー */
.Anchor {
	margin: 60px auto 0;
}
@media print, screen and (min-width: 768px) {
	.Anchor {
		max-width: 500px;
	}
}
.Anchor a {
	display: block;
}

/* レビュー */
.Review {
	margin-top: 60px;
	padding: 40px;
	background-color: #E9F3F1;
}
@media screen and (max-width: 767px) {
	.Review {
		padding: 4.8vw;
	}
}
.Review-Title {
	color: #009E8A;
	font-size: 18px;
	text-align: center;
}
.Review-Title + * {
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	.Review-Title + * {
		margin-top: 4.8vw;
	}
}
.Review-Block {
	margin-top: 40px;
}
.Review-List dl {
	display: flex;
	flex-direction: row-reverse;
	align-items: flex-start;
}
.Review-List dl + dl {
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	.Review-List dl,
	.Review-List .Flexbox > * + * {
		margin-top: 4.8vw;
	}
}
.Review-List-Item dt {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	flex: 0 0 15%;
}
@media screen and (max-width: 767px) {
	.Review-List-Item dt {
		flex-basis: 16vw;
	}
}
.Review-List-Item dt img {
	margin: 0;
}
@media screen and (max-width: 767px) {
	.Review-List-Item dt img {
		width: 13.333333vw;
	}
}
.Review-List-Item dt::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 0 10px 15px;
	border-color: transparent transparent transparent #fff;
}
@media screen and (max-width: 767px) {
	.Review-List-Item dt::after {
		border-width: 2vw 0 2vw 2vw;
	}
}
.Review-List dl:nth-child(even),
.Review-List dl:nth-child(even) dt {
	flex-direction: row;
}
.Review-List dl:nth-child(even) dt::after {
	border-width: 10px 15px 10px 0;
	border-color: transparent #fff transparent transparent;
}
@media screen and (max-width: 767px) {
	.Review-List dl:nth-child(even) dt::after {
		border-width: 2vw 2vw 2vw 0;
	}
}
.Review-List-Item dd {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 5.6em;
	padding: 1em;
	background-color: #FFFFFF;
	flex: 1;
}
.Review-List-Title {
	color: #009E8A;
}
.Review .Note-Text {
	margin-top: 20px;
}
@media print, screen and (min-width: 768px) {
	.Review .Note-Text {
		text-align: right;
	}
}
.Review .Flexbox figure {
	flex: 0 0 100px;
}
@media print, screen and (min-width: 768px) {
	.Review .Flexbox figure {
		margin-top: -1.75em;
	}
}

/* インフォーメーション */
.Info {
	margin-top: 40px;
	padding: 40px;
	background-color: #F5F6FA;
}
@media screen and (max-width: 767px) {
	.Info {
		padding: 4.8vw;
	}
}
.Info-Title {
	margin-bottom: 1em;
	padding-bottom: 0.5em;
	border-bottom: 1px solid #009E8A;
	color: #009E8A;
}
@media print, screen and (min-width: 768px) {
	.Info-Image {
		margin-left: 30px;
		flex: 0 0 120px;
	}
}
@media screen and (max-width: 767px) {
	.Info-Image {
		margin-top: 4.8vw;
	}
	.Info-Image img {
		width: 100px;
	}
}



.MainVisual .Note-Text {
	text-align: right;
}
@media screen and (max-width: 767px) {
	.MainVisual figure {
		margin-left: -4.8vw;
		margin-right: -4.8vw;
	}
}


section.ItemsList .Common-Inner {
	padding: 40px;
	background-color: #fff;
}
@media screen and (max-width: 767px) {
	section.ItemsList .Common-Inner {
		padding: 40px 4.8vw;
	}
}

.ItemBox {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 40px 30px;
	margin-top: 40px;
}
@media screen and (max-width: 767px) {
	.ItemBox {
		grid-template-columns: repeat(2, 1fr);
		column-gap: 4.8vw;
	}
}
.ItemBox li {
	display: flex;
	justify-content: space-between;
	flex-direction: column;
}
.ItemBox .ItemBox-Title {
	margin-top: 15px;
	color: #5f80bf;
	text-align: center;
}
@media screen and (max-width: 767px) {
	.ItemBox .ItemBox-Title {
		min-height: 3.6em;
	}
}
.ItemBox .ItemBox-Title big {
	font-size: 20px;
}
.ItemBox .ItemBox-link a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 36px;
	margin-top: 15px;
	border-radius: 18px;
	background-color: #009e8a;
	color: #fff;
	line-height: 1;
	text-align: center;
}



/* CSS Document */

/*Comment----------*/
#sec-Comment {
	margin-top: 60px;
}
#sec-Comment .Comment-list .list-item {
	align-items: flex-start;
	background-color: #F5F6FA;
	padding: 40px;
}
@media screen and (max-width: 767px) {
	#sec-Comment .Comment-list .list-item {
		padding: 7.2vw 4.8vw;
	}
}
#sec-Comment .Comment-list .list-item .Pht-box {
	max-width: 250px;
	margin: 0 auto;
}
#sec-Comment .Comment-list .list-item .Person-list .list-Ttl .Name span {
	font-size: 125%;
}
#sec-Comment .Comment-list .list-item .Person-list .list-Capt {
	margin-top: 30px;
	color: #009E8A;
}
#sec-Comment .Comment-list .list-item .Person-list .list-Cont {
	margin-top: 20px;
}
/*SP*/
@media screen and (max-width:767px) {
	#sec-Comment .Comment-list .Person-list {
		margin-top: 4.8vw;
	}
}
/*PC*/
@media screen and (min-width:768px) {
	#sec-Comment .Comment-list .Person-list {
		margin-left: 40px;
	}
}

/*Balance----------*/
.Conv .deadline-Box {
	text-align: center;
}
.Conv .deadline-Box span {
	display: inline-block;
	background-color: #F6EDB6;
	padding: 0.5em;
}

/*Conv----------*/
.ItemsList {
	background-color: #E9F3F1;
}
.Conv .Course-box {
	margin-top: 40px;
}
.Conv .conv-box {
	padding: 40px 0;
	background-color: #fff;
}
@media screen and (max-width:767px) {
	.Conv .conv-box {
		padding: 4.8vw 0;
	}
}
/*PC*/
@media print, screen and (min-width: 768px) {
	.Conv .conv-box .Cv-Button,
	.Conv .conv-box figure {
		padding: 0 160px;
	}
}
.Conv .Cv-Button,
.Conv .Cv-Note {
	margin-top: 15px;
	padding-left: 40px;
	padding-right: 40px;
}
@media screen and (max-width:767px) {
	.Conv .Cv-Button,
	.Conv .Cv-Note {
		padding-left: 4.8vw;
		padding-right: 4.8vw;
	}
}
.Conv .Cv-Button a {
	display: block;
	margin: auto;
}
@media screen and (min-width:768px) {
	.Conv .Cv-Button a {
		max-width: 600px;
	}
}
.Conv .Cv-Note {
	margin-top: 30px;
}
.Conv .Att-box {
	margin-top: 2rem;
}
.Conv .Att-box .Att-list {
	font-size: 75%;
}



/*Caution----------*/
.Caution-area {
	font-size: 88%;
}
.Caution-list dd + dt {
	margin-top: 1.3em;
}
.Caution-list dd {
	margin-top: 0.3em;
	padding-left: 1em;
	text-indent: -1em;
}

/*Letro調整----------*/
.letroUgcsetContainer[data-contents=letro-ugcset] .letroUgcsetWrapper .letroUgcsetConsumerProtection {
	display: flex!important;
	flex-wrap:wrap;
	justify-content:center;
	margin-top: 16px!important;
	margin-bottom: 24px!important;
	font-size: 12px!important
}
.letroUgcsetDisclaimer,
.letroUgcsetPromotionLabel{
	width: 100%;
}