@charset "utf-8";

/* ==========================================================================
   common parts
========================================================================== */
/* ==========================================================================
		info
========================================================================== */
.info{
	margin-bottom: 40px;
}

.info .text{
	margin-bottom: 20px;
}

/* ==========================================================================
		voice
========================================================================== */
.voice{
	padding-bottom: 0;
}

@media print, screen and (min-width: 768px) {
	.voice{
		margin-top: 30px;
	}
}

@media screen and (max-width: 767px) {
	.voice{
		margin-top: 25px;
	}
}

/* ==========================================================================
		qa
========================================================================== */
.qa{
	padding-bottom: 0;
}

@media print, screen and (min-width: 768px) {
	.qa{
		margin-top: 80px;
	}
}

@media screen and (max-width: 767px) {
	.qa{
		margin-top: 75px;
	}
}

/* ==========================================================================
		flow
========================================================================== */
@media print, screen and (min-width: 768px) {
	.flow{
		margin-top: 80px;
	}
}

@media screen and (max-width: 767px) {
	.flow{
		margin-top: 75px;
		padding-bottom: 15px;
	}
}

/*  */
.onlyPC {
	display: block !important;
}
.onlySP {
	display: none !important;
}

@media screen and (max-width: 767px) {
	.onlyPC {
		display: none !important;
	}
	.onlySP {
		display: block !important;
	}
}

.contsInner {
	max-width: 960px;
	margin: auto;
}

@media screen and (max-width: 767px) {
	.contsInner {
		width: 92%;
	}
}

.mv .contsInner {
	position: relative;
}

@media screen and (max-width: 767px) {
	.mv .contsInner {
		width: 100%;
	}
}

@media screen and (max-width: 767px) {
	.mv img {
		width: 100%;
		height: 100%;
	}
}

.mv .areaText {
	position: absolute;
	top: 57px;
	right: 40px;
	background: rgba(255, 255, 255, 1);
	border-radius: 16px;
	width: calc( 440 / 960 * 100% );
	padding: 53px 38px 27px;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.mv .areaText {
		top: 40px;
		left: 50%;
		right: inherit;
		transform: translateX(-50%);
		width: calc( 320 / 390 * 100% );
		max-width: 320px;
		padding: 31px 10px 19px;
	}
}

@media screen and (max-width: 320px) {
	.mv .areaText {
		top: 30px;
		padding: 30px 10px 10px;
	}
}


.mv .areaText .title {
	position: absolute;
	top: -25px;
	left: 50%;
	transform: translateX(-50%);
	background: #04A9E0;
	border-radius: 10px;
	color: #ffffff;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	padding: 15px 0 4px;
	width: calc( 380 / 440 * 100% );
	box-shadow: rgba(0, 0, 0, 0.3) 0px 5px 5px 0px;
}

@media screen and (max-width: 767px) {
	.mv .areaText .title {
		top: -17px;
		font-size: 12px;
		padding: 9px 0 4px;
    width: calc(270 / 320* 100%);
	}
}

.mv .areaText .title .textLarge {
	font-size: 24px;
}

@media screen and (max-width: 767px) {
	.mv .areaText .title .textLarge {
		font-size: 16px;
	}
}

.mv .areaText .title .dot {
	position: relative;
}

.mv .areaText .title .dot::after {
	content: "";
	position: absolute;
	top: -7px;
	left: 50%;
	transform: translateX(-50%);
	width: 4px;
	height: 4px;
	background: #ffffff;
	border-radius: 50%;
}

@media screen and (max-width: 767px) {
	.mv .areaText .title .dot::after {
		top: -4px;
		width: 3px;
		height: 3px;
	}
}

.mv .areaText .text {
	color: #000000;
	font-size: 30px;
	font-weight: bold;
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.mv .areaText .text {
		font-size: 18px;
	}
}

.mv .areaText .text .textBlue {
	font-size: 42px;
}

@media screen and (max-width: 767px) {
	.mv .areaText .text .textBlue {
		font-size: 32px;
	}
}

.textBlue {
	color: #04A9E0;
}

.textOrange {
	color: #FF5800;
}

.visit {
	padding: 27px 0 52px;
}

@media screen and (max-width: 767px) {
	.visit {
		padding: 38px 0 20px;
	}
}

.visit .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.visit .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.visit .textBlue {
		font-size: 32px;
	}
}

.visit .description {
	margin-top: 22px;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.visit .description {
		margin-top: 18px;
		text-align: left;
	}
}

.textIndent {
	text-indent: -1em;
	padding-left: 1em;
}

.visit .note {
	margin-top: 24px;
}

@media screen and (max-width: 767px) {
	.visit .note {
		margin-top: 20px;
	}
}

.learn {
	background: #F2F1E6;
	border-radius: 16px;
	padding: 16px 34px 31px;
	max-width: 960px;
	margin: 0 auto;
}

@media screen and (max-width: 767px) {
	.learn {
		background: #F2F1E6;
		padding: 19px 9px 31px;
		width: 92%;
		margin: 0 auto;
	}

	.learn .contsInner {
		width: 100%;
	}	
}

.learn .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.learn .title {
		font-size: 20px;
	}
}

.learn .title .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.learn .title .textBlue {
		font-size: 32px;
	}
}

.learn ul.list {
	display: flex;
	justify-content: space-between;
	margin-top: 29px;
}

@media screen and (max-width: 767px) {
	.learn ul.list {
		display: block;
		margin-top: 8px;
	}
}

.learn ul.list li {
	position: relative;
	background: #ffffff;
	border-radius: 8px;
	width: calc( 284 / 892 * 100% );
	padding: 36px 0 30px;
}

@media screen and (max-width: 767px) {
	.learn ul.list li {
		width: calc(100% - 16px);
		margin-left: 16px;
		padding: 8px 10px 8px 25px;
	}

	.learn ul.list li:nth-child(n+2) {
		margin-top: 8px;
	}
}

.learn ul.list li .number {
	position: absolute;
	top: -21px;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	justify-content: center;
	align-items: center;
	background: #04A9E0;
	border-radius: 50%;
	color: #ffffff;
	font-size: 22px;
	font-weight: bold;
	width: 40px;
	height: 40px;
}

@media screen and (max-width: 767px) {
	.learn ul.list li .number {
		top: 50%;
		left: -16px;
		transform: translateY(-50%);
		font-size: 18px;
		width: 32px;
		height: 32px;
	}
}

.learn ul.list li .text {
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.learn ul.list li .text {
		font-size: 14px;
		text-align: left;
	}
}

.learn ul.list li .text .textBlue {
	font-size: 20px;
}

@media screen and (max-width: 767px) {
	.learn ul.list li .text .textBlue {
		font-size: 18px;
	}
}

.areaBtn {
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.areaBtn {
		padding: 30px 0 66px;
	}
}

.areaBtn .text {
	font-weight: bold;
	text-align: center;
}

.areaBtn .text .insText {
	position: relative;
	display: inline-block;
}

.areaBtn .text .insText::before, 
.areaBtn .text .insText::after {
	content: "";
	position: absolute;
	top: -4px;
	background: #FF5800;
	border-radius: 50%;
	width: 2px;
	height: 74px;
}

.areaBtn .text .insText::before {
	right: -22px;
	transform: rotate3d(1, 1, 1, 68deg);
}

@media screen and (max-width: 767px) {
	.areaBtn .text .insText::before {
		right: -14px;
	}
}

.areaBtn .text .insText::after {
	top: 7px;
	left: -15px;
	transform: rotate3d(1, 1, 1, -42deg);
	height: 53px;
}

.areaBtn .btn {
	margin: 16px auto 0;
	width: 100%;
}

.areaBtn .btn a {
	display: block;
	background: #FFF0BE url(/kyoshitsu/kengaku/img/ico_btn.png) no-repeat;
	background-size: 16px;
	background-position: center right .7em;
	border-radius: 50px;
	border: 4px solid #F0AB00;
	color: #000000;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	padding: .75em 2em;
	width: 100%;
}

.areaBtn .btn a:hover {
	opacity: .7;
}

.areaBtn.white {
	padding: 40px 0 0;
}

.areaBtn.white .btn {
	max-width: 360px;
	margin: 0 auto;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.white .btn {
		max-width: 320px;
	}
}

.areaBtn.white .btn a {
	display: block;
	background: #ffffff url(/kyoshitsu/kengaku/img/ico_btn.png) no-repeat;
	background-size: 16px;
	background-position: center right 1em;
	border-radius: 50px;
	border: 1px solid #000000;
	color: #000000;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	padding: .65em 2em;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.white .btn a {
		font-size: 16px;
		padding: 12px 2em;
	}
}

.areaBtn.pink {
	padding: 24px 0 0;
}

@media screen and (max-width: 767px) {
	.areaBtn.pink {
		padding: 17px 0 0;
	}
}

.areaBtn.pink .btn {
	max-width: 360px;
	margin: 0 auto;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.pink .btn {
		max-width: inherit;
		margin: 0;
		width: calc( 270 / 330 * 100% );
	}
}

.areaBtn.pink .btn a {
	display: block;
	background: #F09B9E url(/kyoshitsu/kengaku/img/ico_blank.svg) no-repeat;
	background-position: center right 1em;
	border-radius: 50px;
	border: none;
	color: #ffffff;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	padding: 21px 2em;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.pink .btn a {
		font-size: 16px;
		padding: 14px 34px;
		letter-spacing: -.01em;
	}
}

@media screen and (max-width: 375px) {
	.areaBtn.pink .btn a {
		font-size: 14px;
		padding: 14px 32px;
	}
}



.areaBtn.blue {
	padding: 0;
	padding-top: 13px;
}

.areaBtn.blue .btn {
	max-width: 200px;
	margin: 0 auto;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.blue .btn {
		max-width: inherit;
		margin: 0 auto;
		width: 100%;
		min-width: 120px;
	}
}


.areaBtn.blue .btn a {
	display: block;
	background: #EAF8FF url(/kyoshitsu/kengaku/img/ico_btn.png) no-repeat;
	background-size: 16px;
	background-position: center right 1em;
	border-radius: 50px;
	border: 2px solid #04A9E0;
	color: #000000;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	padding: 13px 2em;
	width: 100%;
}

@media screen and (max-width: 767px) {
	.areaBtn.blue .btn a {
		font-size: 14px;
		background-position: center right .8em;
		background-size: 12px;
		padding: 6px 17px 6px 0;
	}
}

.recommend {
	background: #E2ECF2;
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.recommend {
		padding: 40px 0 34px;
	}
}

.recommend .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	line-height: 1.36;
}

.recommend .title .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.recommend .title .textBlue {
		font-size: 32px;
	}
}

.recommend .title .textSmall {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.recommend .insRecommend {
	display: flex;
	justify-content: space-between;
	margin-top: 32px;
	background: #ffffff;
	border-radius: 16px;
	padding: 20px 20px 14px;
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend {
		display: block;
		margin-top: 24px;
		padding: 20px 20px 36px;
	}
}

.recommend .insRecommend .left {
	width: calc( 422 / 920 * 100% );
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend .left {
		width: 100%;
	}

	.recommend .insRecommend .left img {
		width: 100%;
		height: auto;
	}
}

.recommend .insRecommend .right {
	display: flex;
	align-items: center;
	width: calc( 462 / 920 * 100% );
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend .right {
		width: 100%;
		margin-top: 30px;
	}
}

.recommend .insRecommend .right ul.checkList li {
	display: flex;
	align-items: center;
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend .right ul.checkList li {
		align-items: flex-start;
	}
}

.recommend .insRecommend .right ul.checkList li:nth-child(n+2) {
	margin-top: 23px;
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend .right ul.checkList li:nth-child(n+2) {
		margin-top: 14px;
	}
}

.recommend .insRecommend .right ul.checkList li>span {
	display: flex;
	align-items: center;
	font-weight: 400;
	font-weight: 600;
}

@media screen and (max-width: 767px) {
	.recommend .insRecommend .right ul.checkList li>span {
		display: inline;
	}
}

.recommend .insRecommend .right ul.checkList li>span:nth-child(n+2) {
	margin-left: 8px;
}

.recommend .insRecommend .right ul.checkList li .textBlue {
	font-weight: bold;
}

.steps {
	background: #FFF0BE;
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.steps {
		padding: 40px 0;
	}
}

.steps .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	line-height: 1.36;
}

.steps .title .textOrange {
	font-size: 40px;
}

.steps .title .textSmall {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.steps ul.list {
	display: flex;
	justify-content: space-between;
	margin-top: 29px;
}

@media screen and (max-width: 767px) {
	.steps ul.list {
		display: block;
		margin-top: 23px;
	}
}

.steps ul.list li {
	position: relative;
	background: #F2F1E6;
	border-radius: 16px;
	width: calc( 296 / 960 * 100% );
}

.steps ul.list li:focus {
	background: #ffffff;
}

@media screen and (max-width: 767px) {
	.steps ul.list li {
		width: 100%;
		cursor: pointer;
		transition: 0.4s;
	}

	.steps ul.list li:nth-child(n+2) {
		margin-top: 20px;
	}

	.steps ul.list li .top::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    background-image: url(/kyoshitsu/kengaku/img/icon_plus_dblu.svg);
    background-repeat: no-repeat;
    width: 18px;
    height: 18px;
    right: 15px;
    margin-top: -8px;
	}

	.steps ul.list li.open .top:before {
    background-image: url(/kyoshitsu/kengaku/img/icon_minus_dblu.svg);
    margin-top: 0px;
}
}

.steps ul.list li .number {
	position: absolute;
	top: -10px;
	left: -10px;
	background: #F0AB00;
	border-radius: 50%;
	color: #ffffff;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	width: 50px;
	height: 50px;
	z-index: 1;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .number {
		width: 45px;
		height: 45px;
	}

	.steps ul.list li.open .top {
		border-radius: 16px 16px 0 0;
	}
}

.steps ul.list li .number .txt {
	display: inline-block;
	margin-top: 9px;
	font-size: 12px;
}

.steps ul.list li .number .num {
	font-size: 24px;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .number .num {
		display: inline-block;
		font-size: 20px;
	}
}


.steps ul.list li .top {
	border-radius: 16px 16px 0 0;
	padding: 24px 20px 16px;
	background: #ffffff;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .top {
		position: relative;
		display: flex;
		padding: 20px 35px 15px 30px;
		background: #ffffff;
		border-radius: 16px;
	}

	.steps ul.list li.open .top {
		border-radius: 16px 16px 0 0;
	}
}

@media screen and (max-width: 375px) {
	.steps ul.list li .top {
		padding: 20px 35px 15px 40px;
		font-size: 14px;
	}
}

.steps ul.list li .top .img {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	min-height: 66px;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .top .img {
		text-align: center;
		min-height: inherit;
		max-width: 128px;
		width: 100%;
		min-width: 55px;
		display: flex;
		justify-content: center;
		align-items: center;
	}
}

.steps ul.list li .top .img img {
	vertical-align: bottom;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .top .img img {
		max-width: 100%;
		width: auto;
		height: auto;
	}

	.steps ul.list li.step1 .top .img img {
		width: 56px;
	}

	.steps ul.list li.step2 .top .img img {
		width: 99px;
	}

	.steps ul.list li.step3 .top .img img {
		width: 94px;
	}
}

@media screen and (max-width: 400px) {
	.steps ul.list li .top .img {
		max-width: 70px;
		margin-right: 15px;
	}

	.steps ul.list li.step1 .top .img img {
		width: 40px;
	}

	.steps ul.list li.step2 .top .img img {
		width: 70px;
	}

	.steps ul.list li.step3 .top .img img {
		width: 66px;
	}
}

.steps ul.list li .top .text {
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .top .text {
		text-align: left;
		display: flex;
    align-items: center;
		width: calc(502 / 534 * 100%);
	}
}

@media screen and (max-width: 375px) {
	.steps ul.list li .top .text {
		letter-spacing: -.05em;
	}
}

.steps ul.list li .bottom {
	border-radius: 0 0 16px 16px;
	padding: 15px 20px 24px;
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.steps ul.list li .bottom {
    padding: 18px 20px 20px;
		display: none;
	}

	.steps ul.list li.open .bottom {
		display: block;
	}
}

.actually {
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.actually {
		padding: 0 0 64px;
	}

	.actually .contsInner {
		width: 100%;
	}
}

.actually .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	line-height: 1.36;
}

.actually .title .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.actually .title .textBlue {
		font-size: 32px;
	}
}

.actually .title .textSmall {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}

.actually ul.list {
	display: flex;
	justify-content: space-between;
	margin-top: 32px;
}

@media screen and (max-width: 767px) {
	.actually ul.list {
		display: block;
		margin-top: 20px;
	}
}

.actually ul.list li {
	width: calc( 296 / 960 * 100% );
}

@media screen and (max-width: 767px) {
	.actually ul.list li {
		width: 100%;
		display: flex;
	}

	.actually ul.list li.left {
		justify-content: left;
	}

	.actually ul.list li.right {
		justify-content: right;
	}

	.actually ul.list li:nth-child(n+2) {
		margin-top: 16px;
	}
}

.actually ul.list li .conts {
	position: relative;
	border-radius: 16px;
	background: #F2F1E6;
	padding: 20px 20px 16px;
}

@media screen and (max-width: 767px) {
	.actually ul.list li.left .conts {
		width: calc( 296 / 390 * 100% );
		margin-right: calc( 15 / 390 * 100% );
		border-radius: 0 16px 16px 0;
		padding: 32px 15px 16px 35px;
	}

	.actually ul.list li.right .conts {
		width: calc( 296 / 390 * 100% );
		margin-left: calc( 15 / 390 * 100% );
		border-radius: 16px 0 0 16px;
		padding: 32px 15px 16px 35px;
	}
}

.actually ul.list li .head {
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	text-align: center;
	min-height: 55px;
}

@media screen and (max-width: 767px) {
	.actually ul.list li .head {
		display: block;
		text-align: left;
		min-height: auto;
	}
}

.actually ul.list li .text {
	margin-top: 13px;
	height: 123px;
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.actually ul.list li .text {
		margin-top: 19px;
		height: auto;
	}
}

.actually ul.list li .sign {
	margin-top: 5px;
	font-size: 14px;
	text-align: right;
}

@media screen and (max-width: 767px) {
	.actually ul.list li .sign {
		margin-top: 8px;
	}
}

.actually ul.list li .conts::after {
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: solid transparent;
	content: "";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(136, 183, 213, 0);
	border-top-color: #F2F1E6;
	border-width: 12px;
}

@media screen and (max-width: 767px) {
	.actually ul.list li.left .conts::after {
		right: -39px;
		left: inherit;
		top: 78%;
		border: solid transparent;
		content: "";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
		border-color: rgba(242, 241, 230, 0);
		border-left-color: #F2F1E6;
		border-width: 15px;
	}

	.actually ul.list li.right .conts::after {
		left: -10px;
		top: 78%;
		border: solid transparent;
		content: "";
		height: 0;
		width: 0;
		position: absolute;
		pointer-events: none;
		border-color: rgba(242, 241, 230, 0);
		border-right-color: #F2F1E6;
		border-width: 15px;
	}
}

.actually ul.list li .img {
	margin-top: 18px;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.actually ul.list li .img {
		display: flex;
    align-items: end;
	}

	.actually ul.list li .img.onlySP {
		display: flex !important;
	}

	.actually .areaBtn.white {
		width: 92%;
		margin: 0 auto;
	}
}



.questions {
	background: #E2ECF2;
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.questions {
		padding: 40px 0 64px;
	}
}

.questions .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	line-height: 1.36;
}

.questions .title .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.questions .title .textBlue {
		font-size: 32px;
	}
}

.questions .insQuestions ul {
	margin-top: 32px;
}

@media screen and (max-width: 767px) {
	.questions .insQuestions ul {
		margin-top: 24px;
	}
}

.questions .insQuestions ul li {
	background: #ffffff;
	border-radius: 16px;
	padding: 20px;
}

@media screen and (max-width: 767px) {
	.questions .insQuestions ul li {
    padding: 24px 20px;
	}
}

.questions .insQuestions ul li:nth-child(n+2) {
	margin-top: 16px;
}

.accBtn {
	display: block;
	background-color: #ffffff;
	position: relative;
	font-size: 18px;
	font-weight: bold;
	padding-left: 40px;
}

@media screen and (max-width: 767px) {
	.accBtn {
		font-size: 16px;
	}
}

.qaArea .txtQ {
	text-indent: 0;
	padding: 0px 40px 0px 42px;
}

.qaArea .txtQ:before {
	content: "Q";
	position: absolute;
}

.qaArea .txtQ:before, .qaArea .txtA:before {
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #04A9E0;
	border-radius: 50%;
	color: #ffffff;
	font-size: 14px;
	width: 24px;
	height: 24px;
}

@media screen and (max-width: 767px) {
	.qaArea .txtQ:before, .qaArea .txtA:before {
		top: 50%;
		transform: translateY(-50%);
	}

	.qaArea .by {
		font-size: 16px;
	}
}

.accBtn:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	background-image: url(/kyoshitsu/kengaku/img/icon_plus_dblu.svg);
	background-repeat: no-repeat;
	width: 18px;
	height: 18px;
	right: -2px;
	margin-top: -8px;
}

.open .accBtn:after {
	background-image: url(/kyoshitsu/kengaku/img/icon_minus_dblu.svg);
	margin-top: 0px;
}

.accIn {
	display: none;
	padding: 20px 0 0;
}

.qaArea .txtA {
	position: relative;
}

.qaArea .txtA:before {
	content: "A";
	background-color: #F7634F;
	position: absolute;
}

.qaArea .txtA, .qaArea .subA {
	font-size: 18px;
	font-weight: bold;
	text-indent: 0;
	padding: 0px 50px 2px 41px;
	line-height: 1.4;
}

@media screen and (max-width: 767px) {
	.qaArea .txtA, .qaArea .subA {
		font-size: 16px;
		padding: 0px 20px 2px 41px;
	}
}

.qaArea .txtA + .txt, .qaArea .subA + .txt {
	border-top: 1px dotted #d9d9d9;
	padding-top: 15px;
}

@media screen and (max-width: 767px) {
	.qaArea .txtA + .txt, .qaArea .subA + .txt {
		border-top: 1px dotted #d9d9d9;
		padding-top: 20px;
	}
}

.classroom {
	background: #F2F1E6;
	padding: 40px 0 72px;
}

@media screen and (max-width: 767px) {
	.classroom {
		padding: 40px 0 64px;
	}
}

.classroom .title {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	line-height: 1.36;
}

.classroom .title .textBlue {
	font-size: 40px;
}

@media screen and (max-width: 767px) {
	.classroom .title .textBlue {
		font-size: 32px;
	}
}

@media screen and (max-width: 375px) {
	.classroom .title .textBlue {
		font-size: 30px;
		letter-spacing: -.02em;
	}
}

.classroom .description {
	text-align: center;
	margin-top: 32px;
}

@media screen and (max-width: 767px) {
	.classroom .description {
    text-align: left;
    margin-top: 24px;
    font-size: 16px;
	}
}

.classroom .insClassroom {
	background: #ffffff;
	border-radius: 16px;
	padding: 30px 0 40px;
	margin-top: 25px;
}

@media screen and (max-width: 767px) {
	.classroom .insClassroom {
		background: #ffffff;
		border-radius: 16px;
		padding: 30px calc(20 / 360 * 100%) 28px;
		margin-top: 25px;
	}
}

.classroom .insClassroom .head {
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}

@media screen and (max-width: 767px) {
	.classroom .insClassroom .head {
    display: flex;
    justify-content: center;
    align-items: center;
	}

	.classroom .insClassroom .head img {
		margin-right: 8px;
	}
}

.classroom .info {
	max-width: 584px;
	width: 100%;
	margin: 0 auto;
}

.classroom .info .row.top {
	display: flex;
	justify-content: space-between;
}

.classroom .info .row.top .col {
	position: relative;
	width: calc(274 / 584* 100%);
	background: #FFF1EF;
	border-radius: 8px;
	color: #F7634F;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	padding: 23px 10px 22px;
	margin-top: 41px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.top .col {
		width: calc(152 / 320* 100%);
		margin-top: 34px;
		font-size: 18px;
		padding: 19px 2px 16px;
		line-height: 1.48;
		display: flex;
    align-items: center;
		justify-content: center;
	}
}

.classroom .info .row.top .col .small {
	font-size: 16px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.top .col .small {
		font-size: 14px;
	}
}

.classroom .info .row.top .col::after {
	content: "";
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: url(/kyoshitsu/kengaku/img/ico_check_red.svg) no-repeat;
	width: 27px;
	height: 24px;
}

.classroom .info .row.center .block {
	display: flex;
	margin-top: 24px;
	padding-bottom: 24px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .block {
		display: block;
		padding-bottom: 0;
	}
}

.classroom .info .row.center .block:nth-child(1) {
	border-bottom: 2px solid #04A9E0;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .block:nth-child(1) {
		border-bottom: none;
	}
}

.classroom .info .row.center .block:last-child {
	padding-bottom: 0;
}

.classroom .info .row.center .left {
	width: calc( 176 / 584 * 100% );
	display: flex;
	align-items: center;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .left {
		display: block;
		width: 100%;
	}
}

.classroom .info .row.center .left p {
	font-size: 18px;
	font-weight: bold;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .left p {
		font-size: 16px;
		font-weight: bold;
		text-align: center;
		position: relative;
		z-index: 1;
	}

	.classroom .info .row.center .left p::before {
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		transform: translateY(-50%);
		background: #04A9E0;
		width: 100%;
		height: 2px;
	}

	.classroom .info .row.center .left p span {
		position: relative;
		background: #ffffff;
		padding: 0 10px;
		z-index: 1;
	}
}

.classroom .info .row.center .right {
	width: calc( 408 / 584 * 100% );
	display: flex;
	justify-content: space-around;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .right {
		margin-top: 10px;
		width: 100%;
	}
}

.classroom .info .row.center .right .col {
	width: calc(124 / 408* 100%);
	background: #EAF8FF;
	border-radius: 8px;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	padding: 19px 5px 17px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .right .col {
		font-size: 10px;
		width: calc(97 / 320* 100%);
		padding: 16px 5px 16px;
	}
}

.classroom .info .row.center .right .col .textBlue {
	font-size: 22px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.center .right .col .textBlue {
		font-size: 18px;
	}
}

.classroom .info .row.bottom {
	margin-top: 22px;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.bottom {
		margin-top: 25px;
	}
}

.classroom .info .row.bottom ul li {
	display: flex;
	line-height: 1.5;
}

@media screen and (max-width: 767px) {
	.classroom .info .row.bottom ul li {
		font-size: 14px;
	}

	.classroom .info .row.bottom ul li:nth-child(n+2) {
		margin-top: 5px;
	}
}

.classroom .info .row.bottom ul li span {
	padding-right: 4px;
}

.services {
	margin-top: 22px;
	padding: 27px 0 29px;
	background: url(/kyoshitsu/kengaku/img/icon_kurokuma.svg) no-repeat;
	background-position: center right 60px;
	border-radius: 16px;
	border: 4px solid #F09B9E;
}

@media screen and (max-width: 767px) {
	.services {
    padding: 27px 15px 21px;
		background-position: bottom 21px right 5%;
    background-size: 41px;
		margin-bottom: 40px;
	}
}

.services .text {
	text-align: center;
}

@media screen and (max-width: 767px) {
	.services .text {
		font-size: 16px;
		text-align: left;
	}
}

.fl {
	display: none;
	position: relative;
}

@media print, screen and (min-width: 768px) {
	.fl.end {
		display: block !important;
	}
}

.float {
	max-width: 240px;
	width: 100%;
	position: absolute;
	bottom: 27px;
	right: 18px;
	z-index: 999;
}

@media print, screen and (min-width: 768px) {
	.fl.active .float {
		position: fixed;
	}
}

.float.dpBlock {
	display: block;
}

@media print, screen and (min-width: 768px) {
	.float.dpBlock {
		position: relative;
		margin-top: -273px;
		visibility: collapse;
	}
}

@media screen and (max-width: 767px) {
	.float {
		max-width: 100%;
		background: #04A9E0;
		display: flex;
		position: fixed;
		bottom: 0;
		width: 100%;
		padding-top: 4px;
		right: inherit;
	}
	.float.dpBlock {
		display: flex;
		position: inherit;
	}

	.float .block:first-child {
		width: calc(230 / 390 * 100%);
		background: #ffffff;
		display: flex;
    align-items: center;
		padding-left: calc(18 / 516 * 100%);
	}
	.float .block:last-child {
		width: calc(160 / 390 * 100%);
		display: flex;
    align-items: center;
		justify-content: center;
	}
}

.float .top {
	border: 4px solid #04A9E0;
	background: #04A9E0;
	color: #ffffff;
	font-size: 28px;
	border-radius: 16px 16px 0 0;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
	padding: 17px 0 5px;
}

@media screen and (max-width: 767px) {
	.float .top {
		font-size: 20px;
		text-align: left;
		border: none;
		background: #ffffff;
		color: #000000;
		border-radius: 0;
		padding: 0;
		letter-spacing: -.02em;
	}
}

@media screen and (max-width: 375px) {
	.float .top {
		font-size: 18px;
	}
}

.float .center {
	border-left: 4px solid #04A9E0;
	border-right: 4px solid #04A9E0;
	background: #ffffff;
	text-align: center;
	padding-top: 15px;
}

@media screen and (max-width: 767px) {
	.float .center {
		border-left: none;
		border-right: none;
		background: #ffffff;
		text-align: left;
		padding-top: 0;
		font-size: 12px;
		letter-spacing: -.02em;
	}
}

@media screen and (max-width: 375px) {
	.float .center {
		font-size: 10px;
	}
}

.float .bottom {
	background: #ffffff;
	text-align: center;
	border: 4px solid #04A9E0;
	border-top: none;
	border-radius: 0 0 16px 16px;
	padding: 0 5px 20px;
}

@media screen and (max-width: 767px) {
	.float .bottom {
		background: #04A9E0;
		border: none;
		border-top: none;
		border-radius: 0 0;
		box-shadow: none;
	}
}

.float .bottom .textOrange {
	font-weight: bold;
}

.underline {
	display: inline;
	background: linear-gradient(#ffffff 50%, #FFF0BE 0, #FFF0BE 100%);
}

#online_kyoshitsu {
	margin-top: 72px;
}

#online_kyoshitsu .linkArrowL:before, #online_kyoshitsu .linkArrowLr:before, #online_kyoshitsu .linkArrowLu:before, #online_kyoshitsu .linkArrowLd:before {
	background-image: url(/common_2019/img/arrow/arrow_blue_r.svg);
	margin: 0;
}

#online_kyoshitsu .linkBlank:after {
	background-image: url(/common_2019/img/icon/icon_blank_blu.svg);
}