@charset"utf-8";

/*[ about_area ] ------------------------------------------*/

.about_area {
	padding: 0;
	background: #fff;
	position: relative;
}
.about_area .page-title {
	padding: 5vw 0;
	margin-bottom: 10vw;
	background: #FFDA00;
	position: relative;
}
.about_area .page-title h2 {
	font-size: 1.25rem;
}
.about_area .page-title strong {
	font-size: 1.5rem;
}
.about_area .page-title:after {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: #FFDA00;
	position: absolute; z-index: 0;
bottom: -2.5vw; left: 0; right: 0; margin: auto;
}

.about_area .main-btn {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 10vw;
}
.about_area .main-btn li {
	flex-basis: 32%;
	margin-bottom: 5vw;
}
.about_area .main-btn li a {
	display: block;
	border-radius: 8px;
}
.about_area .main-btn li.current a {
	pointer-events: none;
	background: #FA4A12;
}
.about_area .main-btn li.current a img {
	mix-blend-mode: multiply;
}
.about_area .main-btn li:nth-child(4),
.about_area .main-btn li:nth-child(5) {
	flex-basis: 48.5%;
	margin-bottom: 5vw;
}
.about_area .sub-btn {
	margin: 5vw auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.about_area .sub-btn li {
	flex-basis: 48.5%;
	margin-bottom: 5vw;
}
.sub-btn a[target^="_blank"]::after,
.main-btn a[target^="_blank"]::after {
	display: none;
}



.about_area h3 {
	margin: 5vw auto;
	font-size: 1.5rem;
}
.about_area h3 strong {
	font-size: 2rem;
}
.about_area h3 strong.colored {
	color: #FA4A12;
}
.about_area h3 span {
	display: block;
}


.about_area .intro {
	margin-bottom: 15vw;
}
.about_area .intro img {
	display: block;
	text-align: center;
}
.about_area .intro figcaption {
	margin-top: 2rem;
}



@media screen and (min-width: 900px) {
.about_area {
	padding: 0;
	background: #fff;
}
.about_area .page-title:before {
	display: block;
	content: "";
	width: 100%;
	height: 1rem;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: #FA4A12;
	position: absolute;
top: -0.5rem; left: 0; right: 0; margin: auto;
}
.about_area .page-title {
	padding: 50px 0;
	margin-bottom: 10%;
	background: #FFDA00;
}
.about_area .page-title:after {
	height: 2rem; bottom: -2rem; 
}
.about_area .page-title h2 {
	font-size: 1.75rem;
}
.about_area .page-title strong {
	font-size: 2.5rem;
}

.about_area .main-btn li {
	margin-bottom: 5%;
}
.about_area .main-btn li:nth-child(4),
.about_area .main-btn li:nth-child(5) {
	margin-bottom: 5%;
}
.about_area .sub-btn li {
	margin-bottom: 5%;
}
.about_area .main-btn li,
.about_area .sub-btn li {
	transition: all .2s;
}
.about_area .main-btn li:not(.current):hover,
.about_area .sub-btn li:hover {
	transform: scale(1.1);
}

.about_area h3 {
	margin: 5% auto 2.5%;
	font-size: 2rem;
}
.about_area h3 strong {
	font-size: 3rem;
}
.about_area p.notes {
	margin-bottom: 5%;
}


.about_area .intro {
	margin-bottom: 70px;
}
.about_area .intro figure {
	display: flex;
	flex-direction: row-reverse;
	align-items: flex-start;
	margin: 50px auto;
}
.about_area .intro figure img {
	margin: 0 0 0 2rem;
	flex-basis: 50%;
	max-width: 50%;
}
.about_area .intro figcaption {
	font-size: 1.25rem;
	margin-top: 0;
}


}


/*[ about_problem ] ------------------------------------------*/

.about_problem {
	padding: 12.5vw 0 10vw;
	background: rgba(250,74,18,0.1);
	position: relative;
}
.about_problem:before {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: #fff;
	position: absolute; z-index: 0;
top: 0; left: 0; right: 0; margin: auto;
}

.about_problem ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.about_problem ul li {
	flex-basis: 100%;
	margin-bottom: 5vw;
}
.about_problem ul li dt {
	margin: 5vw auto 2.5vw;
	color: #fff; font-weight: bold;
	background: #005DAB;
	padding: 2rem 0.5rem 2rem 33%; font-size: 1.25rem;
	width: 90%; border-radius: 2rem 0 2rem 0;
	position: relative;
}
.about_problem ul li dd {
	margin: auto;
	width: 85%;
}

.about_problem ul li dt:before {
	display: block; content: "";
	width: 4rem; height: 4rem;
	position: absolute;
	left: 10%; top: 0; bottom: 0; margin: auto;
}
.elementary-info .about_problem ul li:first-child dt:before {
	background: url(../img/about/icon_clock.svg) no-repeat;
	background-size: contain;
}
.elementary-info .about_problem ul li:nth-child(2) dt:before,
.middleschool-info .about_problem ul li:nth-child(3) dt:before,
.highschool-info .about_problem ul li:nth-child(3) dt:before {
	background: url(../img/about/icon_question.svg) no-repeat;
	background-size: contain;
}
.middleschool-info .about_problem ul li:nth-child(1) dt:before,
.highschool-info .about_problem ul li:nth-child(1) dt:before {
	background: url(../img/about/icon_school.svg) no-repeat;
	background-size: contain;
}
.middleschool-info .about_problem ul li:nth-child(2) dt:before,
.highschool-info .about_problem ul li:nth-child(2) dt:before {
	background: url(../img/about/icon_down.svg) no-repeat;
	background-size: contain;
}
.elementary-info .about_problem ul li:last-child dt:before {
	background: url(../img/about/icon_timer.svg) no-repeat;
	background-size: contain;
}
.programing-info .about_problem ul li:first-child dt:before {
	background: url(../img/about/icon_route.svg) no-repeat;
	background-size: contain;
}
.programing-info .about_problem ul li:nth-child(2) dt:before {
	background: url(../img/about/icon_flag-triangle.svg) no-repeat;
	background-size: contain;
}
.programing-info .about_problem ul li:last-child dt:before {
	background: url(../img/about/icon_speech-bubble-question.svg) no-repeat;
	background-size: contain;
}

.english-info .about_problem ul li:first-child dt:before {
	background: url(../img/about/bullhorn.svg) no-repeat;
	background-size: contain;
}
.english-info .about_problem ul li:nth-child(2) dt:before {
	background: url(../img/about/hand-holding-seedling.svg) no-repeat;
	background-size: contain;
}
.english-info .about_problem ul li:last-child dt:before {
	background: url(../img/about/clover.svg) no-repeat;
	background-size: contain;
}

@media screen and (min-width: 900px) {
.about_problem {
	padding: 75px 0 50px;
}
.about_problem ul {
	display: flex;
	flex-wrap: wrap;
	margin-top: 5%;
}
.about_problem ul li {
	flex-basis: 32%;
	margin-bottom: 0;
}
.about_problem ul li dt {
	margin: 5% auto 1rem;
}
.about_problem ul li dd {
	margin: auto;
	width: 85%;
}
}


/*[ about_feature ] ------------------------------------------*/

.about_feature {
	padding: 12.5vw 0 10vw;
	position: relative;
}
.about_feature:after {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: rgba(250,74,18,0.1);
	position: absolute;
	top: 0;
	left: 0; right: 0; margin: auto;
}
.about_feature figure {
	margin: 10vw auto;
}
.about_feature figure img {
	display: block;
	text-align: center;
	margin: 0 auto;
}
.about_feature figcaption {
	margin-bottom: 5vw;
}

@media screen and (min-width: 900px) {
.about_feature {
	padding: 75px 0 50px;
}
.about_feature figure {
	margin: 5% auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.about_feature figure img {
	width: 50%;
	flex-basis: 50%:
}
.about_feature figcaption {
	margin: 0 2rem 0 0;
	flex-basis: 50%:
}
}



/*[ about_point ] ------------------------------------------*/

.about_point {
	padding: 12.5vw 0 10vw;
	background: #FFFBE5 url(../img/top/news_bg.webp);
	background-size: 80%;
	position: relative;
}
.about_point:before {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius: 0 0 50% 50% / 0 0 100% 100%;
background:#fff;
position: absolute;
top: 0; z-index: 0;
	left: 0; right: 0; margin: auto;
}
.about_point h3 span {
	display: inline-block;
	border-bottom: 1px solid #333;
}

.about_point ol {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	counter-reset: item;
	margin: 10vw auto;
}
.about_point ol li {
	flex-basis: 100%;
	position: relative;
	padding-left: 5rem;
	margin-bottom: 5vw;
	border-bottom: 1px solid #333;
	padding-bottom: 5vw;
	padding-right: 2.5vw;
	border-right: 1px solid #333;
}
.about_point ol li:before {
	text-align: center;
	margin: 0 auto;
  counter-increment: item;
  content: counter(item);
  font-weight: bold; font-size: 2rem;
  color: #333;
  position: absolute; left: 1.75rem; top: 1rem;
  z-index: 2;
}
.about_point ol li dt {
  font-weight: bold; font-size: 1.25rem;
	position: relative;
	margin-bottom: 2.5vw;
}
.about_point ol li dt:before {
	content: "POINT";
	font-size: 0.9rem; font-weight: normal;
	text-align: center;
	margin: 0 auto;
	position: absolute;
	left: -4.5rem;
	background: #FFDA00;
	padding: 0.5rem 0.5rem 2.5rem;
}

@media screen and (min-width: 900px) {
.about_point {
	padding: 75px 0 50px;
}
.about_point:before {
	height: 2rem;
}

.about_point ol {
	margin: 10% auto 5%;
}
.about_point ol li {
	flex-basis: 47.5%;
	margin-bottom: 5%;
	border-bottom: 1px solid #333;
	padding-bottom: 5%;
	padding-right: 2.5%;
	border-right: 1px solid #333;
}
.about_point ol li dt {
	margin-bottom: 2.5%;
	font-size: 1.5rem;
}
.about_point ol li dd {
	font-size: 1.1rem;
}

}


/*[ about_env ] ------------------------------------------*/

.about_env {
	padding: 12.5vw 0 10vw;
	background: rgba(0,98,171,0.1) url(../img/top/reason_bg.webp) left top no-repeat;
	background-size: 80%;
	position: relative;
}
.about_env:before {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius: 0 0 50% 50% / 0 0 100% 100%;
	background: #FFFBE5 url(../img/top/news_bg.webp);
	background-size: 80%;
position: absolute;
top: 0; z-index: 0;
	left: 0; right: 0; margin: auto;
}
.about_env ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 10vw auto;
}
.about_env ul li {
	flex-basis: 100%;
	margin-bottom: 10vw;
	padding: 1rem;
	background: #fff;
	position: relative;
}
.about_env ul li dt {
	font-size: 1.25rem;
	font-weight: bold;
	text-align: center;
	margin-bottom: 2.5vw;
}
.about_env ul li dd {
	z-index: 2;
}
.about_env .marker {
	color: #005DAB; font-weight: bold;
	font-size: 1.1rem;
	background:linear-gradient(transparent 70%, #ffda00 70%);
}
.about_env ul li:before {
	display: inline-block;
	content: "";
	position: absolute;
	width: 4rem; height: 4rem;
	padding: 1rem;
	background: #fff;
	left: -2.5vw; top: -2.5vw;
	border-radius: 50%;
}
.elementary-info .about_env ul li:nth-child(1):before,
.middleschool-info .about_env ul li:nth-child(1):before,
.highschool-info .about_env ul li:nth-child(1):before,
.english-info .about_env ul li:nth-child(1):before,
.programing-info .about_env ul li:nth-child(1):before {
	background: #fff url(../img/about/icon_elementary01.svg) center center no-repeat;
	background-size: 50%;
}
.elementary-info .about_env ul li:nth-child(2):before,
.middleschool-info .about_env ul li:nth-child(4):before,
.highschool-info .about_env ul li:nth-child(4):before {
	background: #fff url(../img/about/icon_elementary02.svg) center center no-repeat;
	background-size: 50%;
}
.elementary-info .about_env ul li:nth-child(3):before,
.english-info .about_env ul li:nth-child(3):before,
.programing-info .about_env ul li:nth-child(3):before {
	background: #fff url(../img/about/icon_elementary03.svg) center center no-repeat;
	background-size: 50%;
}
.middleschool-info .about_env ul li:nth-child(2):before,
.highschool-info .about_env ul li:nth-child(2):before,
.english-info .about_env ul li:nth-child(2):before,
.programing-info .about_env ul li:nth-child(2):before {
	background: #fff url(../img/about/icon_order.svg) center center no-repeat;
	background-size: 50%;
}
.middleschool-info .about_env ul li:nth-child(3):before,
.highschool-info .about_env ul li:nth-child(3):before {
	background: #fff url(../img/about/icon_support.svg) center center no-repeat;
	background-size: 50%;
}
.elementary-info .about_env ul li:nth-child(4):before,
.english-info .about_env ul li:nth-child(4):before,
.programing-info .about_env ul li:nth-child(4):before {
	background: #fff url(../img/about/icon_elementary04.svg) center center no-repeat;
	background-size: 50%;
}

.about_env ul li:after {
	display: inline-block;
	font-weight: 400;
	content: "\f4af";
	font-family: "Font Awesome 5 Pro";
	position: absolute;
	font-size: 1.5rem; color: #FA4A12;
	padding: 0.25rem 0.75rem;
	background: #fff;
	right: -2.5vw; bottom: -2.5vw;
	border-radius: 50%;
	z-index: 0;
}



@media screen and (min-width: 900px) {
.about_env {
	padding: 75px 0 50px;
}
.about_env:before {
	height: 2rem;
	background: #FFFBE5 url(../img/top/news_bg.webp);
	background-size: auto;
}
.about_env ul {
	margin: 10% auto 0;
}
.about_env ul li {
	flex-basis: 47.5%;
	margin-bottom: 10%;
	padding: 2rem;
}
.about_env ul li dt {
	font-size: 1.75rem;
	margin-bottom: 2.5%;
}
.about_env ul li dd {
	font-size: 1.25rem;
}
.about_env .marker {
	font-size: 1.5rem;
}
.about_env ul li:before {
	width: 6rem; height: 6rem;
	left: -2rem; top: -2rem;
	border-radius: 50%;
}

.about_env ul li:after {
	right: -1rem; bottom: -1rem;
	font-size: 2rem;
}
}


/*[ faq_area ] ------------------------------------------*/
.faq_area {
	padding: 12.5vw 0 10vw;
	position: relative;
}
.faq_area:before {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius: 0 0 50% 50% / 0 0 100% 100%;
	background: rgba(0,98,171,0.1);
position: absolute;
top: 0; z-index: 0;
	left: 0; right: 0; margin: auto;
}

.faq_area dl {
	margin: 10vw auto;
	border-bottom: 1px solid #333;
}
.faq_area dt {
	cursor: pointer;
	border-top: 1px solid #333;
	position: relative;
	padding: 2.5vw 0 0 4rem;
}
.faq_area dt:after {
	display: block;
	font-weight: 700; font-size: 0.9rem;
	content: "\f0d7";
	font-family: "Font Awesome 5 Pro";
	text-align: center;
	margin: 1rem auto 0;
	color: #005DAB;
}
.faq_area dt:before {
	display: inline-block;
	content: "Q"; font-size: 2rem; font-weight: bold;
	width: 3rem; background: #005DAB; color: #fff;
	text-align: center; margin: auto;
	position: absolute;
	left: 0;
}
.faq_area dd:before {
	display: inline-block;
	content: "A"; font-size: 2rem; font-weight: bold;
	width: 3rem; background: #FA4A12; color: #fff;
	text-align: center; margin: auto;
	position: absolute;
	left: -4rem;
}
.faq_area dt.open {
	color: #FA4A12;
}
.faq_area dt.open:after {
	content: "\f0d8";
}
.faq_area dd {
	border-top: 1px solid #ccc;
	padding: 2.5vw 0;
	position: relative;
	margin: 0 0 2.5vw 4rem;
	font-size: 0.9rem;
}



@media screen and (min-width: 900px) {
.faq_area {
	padding: 75px 0 50px;
}
.faq_area:before {
	height: 2rem;
}

.faq_area dl {
	margin: 5% auto;
}
.faq_area dt {
	padding: 2.5% 0 0 4rem;
	font-size: 1.1rem;
}
.faq_area dt:before {
}
.faq_area dd {
	padding: 2.5% 0;
	margin: 0 0 2.5% 4rem;
	font-size: 1rem;
}
}






/*[ fees_area ] ------------------------------------------*/

.fees_area {
	padding: 0 0 10vw;
	background: #fff url(../img/top/fees_bg.webp) left top;
	background-size: 80%;
	position: relative;
}

.fees_area .page-title {
	padding: 5vw 0;
	margin-bottom: 15vw;
	background: #FFDA00;
	position: relative;
}
.fees_area .page-title h2 {
	font-size: 1.25rem;
}
.fees_area .page-title strong {
	font-size: 1.5rem;
}
.fees_area .page-title:after {
	display: block;
	content: "";
	width: 100%;
	height: 2.5vw;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: #FFDA00;
	position: absolute; z-index: 0;
bottom: -2.5vw; left: 0; right: 0; margin: auto;
}

.fees_area h3 {
	margin: 5vw auto;
	font-size: 1.5rem;
}
.fees_area h3 span {
	font-size: 2rem;
	background: #ffda00;
	margin: 0 0.2rem;
	padding: 0 0.2rem;
	position: relative;
}
.fees_area h3 span::before {
position: absolute;
content: "";
width: 0.5rem;
height: 0.5rem;
border-radius: 50%;
background-color: #333;
top: -0.75rem;
left: 50%;
transform: translate(-50%, 0);
}
.fees_area p.notes {
	margin-bottom: 10vw;
	font-size: 0.9rem;
}

.fees_area .pagemenu {
	margin: 5vw auto 10vw;
	display: flex;
	text-align: center;
	justify-content: space-around;
}
.fees_area .pagemenu a {
	color: #333;
	font-weight: bold;
	font-size: 1.1rem;
	background:linear-gradient(transparent 70%, #ffda00 70%);
}

.fees_area .pagemenu a:before {
	display: inline-block;
	margin-right: 4px;
	font-weight: 700;
	content: "\f0d7";
	font-family: "Font Awesome 5 Pro";
}

.fees-box h2 {
	margin: 5vw auto;
	padding: 0.5rem;
	color: #fff;
	background: #005DAB;
}
.fees-box h2 ~ p {
	margin-bottom: 5vw;
}


.fees-box .fees,
.fees-box .middleschool-added {
	display: flex;
	flex-wrap: wrap;
}
.fees-box .fees li,
.fees-box .middleschool-added dl {
	flex-basis: 100%;
	margin-bottom: 2rem;
	border: 1px solid #333;
	background: #fff;
}
.fees-box .fees dt,
.fees-box .middleschool-added dt {
	font-size: 1.25rem; font-weight: bold;
	background: #ffda00;
	padding: 0.5rem 0;
	border-bottom: 1px solid #333;
}
.fees-box .fees dt span,
.fees-box .middleschool-added dt span {
	font-size: 1rem;
}
.fees-box .fees dt strong {
	position: relative;
}
.fees-box .fees li dt strong:before,
.fees-box .fees li dt strong:after {
	display: inline; 
	width: 2rem; height: 100%;
	content: "";
	position: absolute;
	 top: 0; bottom: 0; margin: auto;
}
.fees-box .fees li.elementary dt strong:before {
	left: -3rem;
	background:  url(../common/img/icon_elementary_g.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees li.elementary dt strong:after {
	right: -3rem;
	background:  url(../common/img/icon_elementary_b.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees li.middleschool dt strong:before {
	left: -3rem;
	background:  url(../common/img/icon_middleschool_g.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees li.middleschool dt strong:after {
	right: -3rem;
	background:  url(../common/img/icon_middleschool_b.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees li.highschool dt strong:before {
	left: -3rem;
	background:  url(../common/img/icon_highschool_g.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees li.highschool dt strong:after {
	right: -3rem;
	background:  url(../common/img/icon_highschool_b.svg) center center no-repeat;
	background-size: contain;
}
.fees-box .fees dd,
.fees-box .middleschool-added dd {
	padding: 1rem;
	font-size: 1.5rem;
	line-height: 1.4;
}
.fees-box .fees dd span,
.fees-box .middleschool-added dd span {
	font-size: 1rem;
}
.fees-box .fees dd:not(:last-child) {
	border-bottom: 1px solid #333;
}
.fees-box .fees .price,
.fees-box .middleschool-added .price {
	font-size: 1.25rem;
}
.fees-box .fees dd strong,
.fees-box .middleschool-added dd strong {
	font-size: 2rem;
}

.fees-box .fees .price strong,
.fees-box .middleschool-added .price strong {
	color: #FA4A12;
	font-size: 2.5rem;
}
.fees-box .fees .subscription .option {
	display: flex;
	justify-content: space-evenly;
	align-items: center;
	margin: 5vw auto;
}
.fees-box .fees .subscription .option span {
	display: inline-block;
	border: 1px solid #333;
	background: #f4f4f4;
	padding: 2rem 1rem;
	font-size: 1.25rem;
}

@media screen and (min-width: 900px) {
.fees_area {
	padding: 0 0 10%;
	background: #fff url(../img/top/fees_bg.webp) left top;
	background-size: auto;
}
.fees_area .page-title:before {
	display: block;
	content: "";
	width: 100%;
	height: 1rem;
	border-radius:0 0 50% 50% /0 0 100% 100%;
	background: #FA4A12;
	position: absolute;
top: -0.5rem; left: 0; right: 0; margin: auto;
}
.fees_area .page-title {
	padding: 50px 0;
	margin-bottom: 10%;
	background: #FFDA00;
}
.fees_area .page-title:after {
	height: 2rem; bottom: -2rem; 
}
.fees_area .page-title h2 {
	font-size: 1.75rem;
}
.fees_area .page-title strong {
	font-size: 2.5rem;
}


.fees_area h3 {
	margin: 5% auto 2.5%;
	font-size: 2rem;
}
.fees_area h3 span {
	font-size: 3rem;
}
.fees_area p.notes {
	margin-bottom: 5%;
}

.fees_area .pagemenu {
	margin: 5% auto 10%;
	justify-content: space-evenly;
	width: 80%;
}
.fees_area .pagemenu a {
	font-size: 1.25rem;
}

.fees-box .fees {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.fees-box .fees li {
	
}
#elementary-fees .fees li {
	flex-basis: 49.5%;
}
#middleschool-fees .fees li,
#highschool-fees .fees li {
	flex-basis: 49.5%;
}
.fees-box .fees dt {
	font-size: 2rem;
	padding: 0.75rem 0;
}
.fees-box .fees .subscription dt span {
	font-size: 1rem;
}
.fees-box .fees dd {
	padding: 1rem;
	font-size: 1.5rem;
}
.fees-box .fees .price {
	font-size: 1.5rem;
}
.fees-box .fees dd strong {
	font-size: 2.5rem;
}
.fees-box .fees .price strong {
	font-size: 3rem;
}

.fees-box .fees .kidsclass dd {
	display: inline-block;
	width: 47.5%;
	border-bottom: none;
	vertical-align: top;
}
.fees-box .fees .highschool dd {
	vertical-align: top;
}
.fees-box .fees .subscription .option {
	margin: 20px auto;
}

.fees-box .fees .kidsclass dd:first-of-type {
	border-right: 1px solid #333;
}
.fees-box .fees .kidsclass dd:last-of-type {
	border-right: none;
}

}

/*[ trial_area ] ------------------------------------------*/
.trial_area {
	padding: 12.5vw 0 10vw;
	position: relative;
	background: #fff url(../img/about/programing-trial_bg.jpg) left top repeat-x;
	background-size: 10vw auto;
	margin-top: -10vw;
}
.trial_area.trial-lp {
	margin-top: 0;
}
.trial_area h2 {
	margin: 5vw auto 2.5vw;
	font-size: 1.25rem;
	position: relative;
}
.trial_area h2 strong:before {
	display: block;
	color: #333; font-size: 1rem;
	content: "＼楽しみながら学べる／";
	line-height: 1; letter-spacing: 0.1rem;
}
.trial_area h2 strong {
	font-size: 1.75rem;
	color: #FA4A12;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 313.03 18.93"><g id="zigzag" data-name="zigzag"><g id="zigzag-2" data-name="zigzag1"><polyline points="2.01 5.46 20.19 13.46 38.37 5.46 56.54 13.46 74.72 5.46 92.89 13.46 111.06 5.46 129.23 13.46 147.41 5.46 165.58 13.46 183.76 5.46 201.94 13.46 220.12 5.46 238.29 13.46 256.47 5.46 274.65 13.46 292.83 5.46 311.01 13.46" style="fill:none;stroke:#ffda00;stroke-miterlimit:10;stroke-width:10px"/></g></g></svg>') center 95% no-repeat;
	background-size: 100% auto;
}

.trial_area .intro {
	background: #f7f7f7;
	padding: 5vw;
	margin: 10vw auto 5vw;
	border: 1px solid #ccc;
}
.trial_area .trial-date ul {
	margin: 5vw auto 2.5%;
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
}
.trial_area .trial-date ul li {
	margin: 1rem auto;
	text-align: center;
	font-size: 1.5rem;
	line-height: 1.2;
	border: 1px solid #333;
	padding: 1rem;
	width: 100%;
	flex-basis: 45%;
}
.trial_area .trial-date ul li.ended {
	color: #999;
	background: #f7f7f7;
	border: 1px solid #ddd;
}
.trial_area .trial-date ul li.active:before {
	display: block;
	color: #fff; font-size: 1rem;
	content: "募集中！"; font-weight: bold;
	text-align: center; margin: auto;
	line-height: 1; letter-spacing: 0.1rem;
	padding: 10px;
	background: #FA4A12; border-radius: 10px;
}
.trial_area .trial-date ul li.ended:before {
	display: block;
	color: #fff; font-size: 1rem;
	content: "好評につき終了"; font-weight: bold;
	text-align: center; margin: auto;
	line-height: 1; letter-spacing: 0.1rem;
	padding: 10px;
	background: #ccc; border-radius: 10px;
}
.trial_area .trial-date ul li span {
	font-size: 0.9rem;
}
.trial_area .trial-date ul li strong {
	font-size: 2.5rem; color: #FA4A12;
}
.trial_area .trial-date ul li.ended strong {
	color: #999;
}
.trial-intro ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.trial-intro li {
	flex-basis: 100%;
}

.trial_area .btn {
	margin-bottom: 2.5vw;
}
.trial_area .btn a {
	display: block;
	padding: 0.5rem 0;
	color: #fff;
	vertical-align: middle;
	font-weight: bold;
	border-radius: 4px;
	background: #FA4A12;
}
.trial_area .btn i {
	display: inline-block;
	font-size: 1.25rem;
}

.trial_area .trial-intro,
.trial_area .trial-flow {
	margin: 10vw auto 15vw;
}

.trial_area .trial-intro li {
	width: 100%;
	border: 1px solid #ccc;
	padding: 1rem;
	margin-bottom: 1rem;
}
.trial_area .trial-intro li i {
	display: block;
	text-align: center;
	font-size: 3rem;
	padding: 10px;
}
.trial_area .trial-intro li:nth-child(1) i {
	color: green;
}
.trial_area .trial-intro li:nth-child(2) i {
	color: pink;
}
.trial_area .trial-intro li:nth-child(3) i {
	color: orange;
}
.trial_area .trial-intro li dt {
	text-align: center;
	font-size: 1.5rem;
	font-weight: bold;
	margin: 0.5rem auto;
	line-height: 1.4;
}

.trial_area .trial-flow h3 span {
	display: inline;
	border-bottom: 1px solid #333;
}

.trial-flow h4 {
	font-size: 1.5rem;
	margin: 5vw auto;
}
.trial-flow h4 span {
	font-size: 1rem;
	color: #FA4A12;
}
.trial-flow p {
	margin-bottom: 10vw;
}

.trial-flow ol {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.trial-flow ol li {
	margin-bottom: 5rem;
	position: relative;
	flex-basis: 100%;
}
.trial-flow ol li span {
	text-align: center;
	display: inline-block;
	position: absolute;
	font-size: 30px;
	background: #ffda00;
	border-radius: 50%;
	padding: 10px 15px; line-height: 1;
	left: -10px; top: -10px;font-weight: bold;
}
.trial-flow ol li figure img {
	display: block;
	width: 100%;
	margin-bottom: 1rem;
}
.trial-flow ol li:not(:last-child)::after {
	display: inline-block;
	font-weight: 400;
	content: "\f063";
	font-family: "Font Awesome 5 Pro";
	position: absolute;
	right: 50%; left: 50%; margin: auto;
	bottom: -4rem;
	font-size: 2rem;
	color: #FA4A12;
}


@media screen and (min-width: 900px) {
.trial_area {
	padding: 75px 0 50px;
	background: #fff url(../img/about/programing-trial_bg.jpg) left top repeat-x;
	background-size: 60px auto;
	margin-top: -100px;
}
.trial_area.trial-lp {
	margin-top: 0;
}
.trial_area h2 {
	margin: 5% auto 2.5%;
	font-size: 40px;
}
.trial_area h2 strong {
	font-size: 60px;
}
.trial_area h2 strong:before {
	font-size: 20px;
	margin: 0 auto;
}
.trial_area .intro {
	padding: 20px;
	margin: 100px auto 20px;
}
.trial_area .intro figure {
	margin: auto;
}
.trial_area .intro figcaption {
	font-size: 1rem;
	margin: 0;
}
.trial_area .intro figure img {
	flex-basis: 25%;
	max-width: 25%;
}
.trial_area .btn {
	margin: 0 auto 2.5%;
	width: 60%;
}
.trial_area .btn a {
	display: block;
	padding: 1rem 0;
	font-size: 1.5rem;
	transition: all .2s;
}
.trial_area .btn i {
	display: inline-block;
	font-size: 2rem;
}
.trial_area .btn a:hover {
	transform: scale(1.1);
}

.trial_area .trial-date ul li {
	width: 24%;
	flex-basis: 24%;
}
.trial-intro li {
	flex-basis: 30%;
}
.trial-flow h4 {
	margin: 50px auto;
}
.trial-flow p {
	margin-bottom: 50px;
}
.trial-flow ol li {
	margin-bottom: 1rem;
	position: relative;
	flex-basis: 20%;
}
.trial-flow ol li:not(:last-child)::after {
	display: inline-block;
	font-weight: 400;
	content: "\f061";
	font-family: "Font Awesome 5 Pro";
	position: absolute;
	right: -3.5rem; left: 105%; margin: auto;
	top: 50%; bottom: 50%;
	font-size: 3rem;
	color: #FA4A12;
}

}