@charset "utf-8";

@media only screen and (max-width:991px) {}
@media only screen and (max-width:767px) {}
@media only screen and (max-width:374px) {}

/*************************************************

 keyvisual

*************************************************/
.keyvisual {
	position: relative;
	z-index: 2;
}
.keyvisual img {
	width: 100%;
}
.keyvisual:before {
	position: absolute;
	bottom: 0;
	left: 50%;
	display: block;
	content: '';
	width: 37px;
	height: 37px;
	background: url(../../images/guide_exercise/arw.svg) no-repeat center center / contain;
	transform: translate(-50%,50%);
}

/*************************************************

 squaresBg

*************************************************/
.squaresBg {
	background: url(../../images/guide_exercise/bg02.jpg);
	background-size: auto 15px;
}



/*************************************************

 caseArea

*************************************************/
#caseArea {
	position: relative;
	padding: 80px 0 45px;
	text-align: center;
	color: #000;
	background: url(../../images/guide_exercise/bg01.jpg) no-repeat center top / cover;
}
#caseArea > * {
	position: relative;
	z-index: 3;
}
#caseArea:before,
#caseArea:after {
	position: absolute;
	bottom: 0;
	display: block;
	content: '';
	border-style: solid;
	border-width: 85px 25vw 85px 25vw;
}
#caseArea:before {
	left: 0;
	border-color: transparent transparent #FFD200 #FFD200;
}
#caseArea:after {
	right: 0;
	border-color: transparent #FFD200 #FFD200 transparent;
}
@media only screen and (max-width:767px) {
	#caseArea {
		padding: 70px 0 90px;
	}
	#caseArea:before,
	#caseArea:after {
		border-width: 25px 25vw 25px 25vw;
	}
}



/* title
--------------------------------------*/
#caseArea .title {
	position: relative;
	display: table;
	margin: 0 auto 50px;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 2;
}
#caseArea .title span {
	position: relative;
	display: block;
	padding: 10px 45px;
}
#caseArea .title strong {
	color: #06B4BB;
	font-size: 1.3em;
	background: rgba(0, 0, 0, 0) linear-gradient(transparent 50%, #FFF255 0%) repeat scroll;
}
#caseArea .title:before,
#caseArea .title:after,
#caseArea .title span:before,
#caseArea .title span:after {
	box-sizing: border-box;
	position: absolute;
	display: block;
	content: '';
	width: 16px;
	height: 16px;
}
#caseArea .title:before {
	left: 0;
	top: 0;
	border-top: #06B4BB solid 3px;
	border-left: #06B4BB solid 3px;
}
#caseArea .title:after {
	right: 0;
	top: 0;
	border-top: #06B4BB solid 3px;
	border-right: #06B4BB solid 3px;
}
#caseArea .title span:before {
	left: 0;
	bottom: 0;
	border-bottom: #06B4BB solid 3px;
	border-left: #06B4BB solid 3px;
}
#caseArea .title span:after {
	right: 0;
	bottom: 0;
	border-bottom: #06B4BB solid 3px;
	border-right: #06B4BB solid 3px;
}
@media only screen and (max-width:767px) {
	#caseArea .title {
		font-size: 2.2rem;
	}
	#caseArea .title span {
		padding: 15px 5px 20px;
	}
}


/* list
--------------------------------------*/
#caseArea .list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#caseArea .list li {
	position: relative;
	box-sizing: border-box;
	width: 220px;
	margin: 30px 13px 0;
	padding: 70px 10px 40px;
	background-color: #fff;
	border: #FFD200 solid 6px;
}
#caseArea .list .label {
	position: absolute;
	top: 23px;
	left: -23px;
	width: 112px;
	padding: 7px 0 9px;
	text-align: center;
	line-height: 0;
	background-color: #FF9D00;
}
#caseArea .list .label:before {
	position: absolute;
	top: 100%;
	left: 0;
	display: block;
	content: '';
	border-width: 5px 9px 5px 9px;
	border-style: solid;
	border-color: #C47400 #C47400 transparent transparent;
}
#caseArea .list .label img {
	height: 16px;
}
#caseArea .list figure {
	max-width: 80px;
	margin: 0 auto 5px;
	line-height: 0;
}
#caseArea .list .ttl {
	color: #06B4BB;
	font-size: 2rem;
	font-weight: 700;
}
#caseArea .list p {
	font-size: 1.6rem;
	font-weight: 700;
}
@media only screen and (max-width:767px) {
	#caseArea .list {
		display: block;
		margin: 0 22px;
	}
	#caseArea .list li {
		display: flex;
		width: auto;
		max-width: 380px;
		margin: 0 auto;
		padding: 30px 0;
	}
	#caseArea .list li + li {
		margin-top: 55px;
	}
	#caseArea .list .label {
		top: -20px;
		left: -16px;
	}
	#caseArea .list .label:before {
		border-width: 6px 5px 6px 5px;
	}
	#caseArea .list .icons {
		width: 38.095%;
	}
	#caseArea .list figure {
		width: 54px;
	}
	#caseArea .list .ttl {
		font-size: 1.7rem;
	}
	#caseArea .list .texts {
		box-sizing: border-box;
		width: 61.905%;
		padding-right: 10px;
		align-self: center;
	}
	#caseArea .list p {
		text-align: left;
	}
}

/*************************************************

 recommend

*************************************************/
#recommend {
	position: relative;
	padding: 30px 0 80px;
}
#recommend:before,
#recommend:after {
	position: absolute;
	left: 0;
	display: block;
	content: '';
}
#recommend:before {
	top: 0;
	width: 100%;
	height: calc(100% - 160px);
	background-color: #FFD200;
}
#recommend:after {
	bottom: 0;
	border-width: 160px 50vw 0 50vw;
	border-style: solid;
	border-color: #FFD200 transparent transparent transparent;
}
#recommend .title {
	position: relative;
	margin: 0 22px;
	line-height: 0;
	z-index: 5;
}
#recommend .title img {
	display: block;
	width: 620px;
	margin: 0 auto;
}
@media only screen and (max-width:767px) {
	#recommend {
		padding: 50px 0 90px;
	}
	#recommend:before {
		height: calc(100% - 50px);
	}
	#recommend:after {
		border-top-width: 50px;
	}
	#recommend .title img {
		width: 400px;
	}
}


/*************************************************

 merit

*************************************************/
#merit {
	position: relative;
	padding: 55px 0 100px;
	text-align: center;
}
#merit > * {
	position: relative;
	z-index: 5;
}
#merit:before,
#merit:after {
	position: absolute;
	bottom: 0;
	display: block;
	content: '';
	border-style: solid;
	border-width: 85px 25vw 85px 25vw;
}
#merit:before {
	left: 0;
	border-color: transparent transparent #C7EBED #C7EBED;
}
#merit:after {
	right: 0;
	border-color: transparent #C7EBED #C7EBED transparent;
}
#merit .title {
	padding: 0 22px;
	line-height: 0;
}
#merit .title img {
	display: block;
	width: 550px;
	margin: 0 auto;
}
@media only screen and (max-width:767px) {
	#merit:before,
	#merit:after {
		border-width: 25px 25vw 25px 25vw;
	}
	#merit .title {
		margin-bottom: 30px;
	}
}


/* list
--------------------------------------*/
#merit .list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
#merit .list li {
	width: 255px;
	margin: 45px 50px;
}
#merit .list .ttl {
	margin-bottom: 10px;
	line-height: 0;
	text-align: center;
}
#merit .list .ttl img {
	height: 70px;
	margin: 0 auto;
}
#merit .list p {
	margin-top: 20px;
	font-size: 1.6rem;
	font-weight: 700;
}
@media only screen and (max-width:767px) {
	#merit .list {
		display: block;
		margin: 0 22px;
	}
	#merit .list li {
		width: auto;
		margin: 0;
	}
	#merit .list li + li {
		margin-top: 35px;
	}
	#merit .list .ttl {
		margin-bottom: 20px;
	}
	#merit .list figure {
		max-width: 222px;
		margin: 0 auto;
	}
	#merit .list p {
		text-align: left;
	}
	#merit .list p br {
		display: none;
	}
}



/*************************************************

 pointArea

*************************************************/
#pointArea {
	position: relative;
	overflow: hidden;
	padding: 60px 0 280px;
	background-color: #C7EBED;
}
#pointArea > * {
	position: relative;
	z-index: 3;
}
#pointArea .title {
	margin-bottom: 60px;
	padding: 0 15px;
	text-align: center;
	line-height: 0;
}
#pointArea .title img {
	width: 810px;
	margin: 0 auto;
}
#pointArea:before,
#pointArea:after {
	position: absolute;
	bottom: 0;
	display: block;
	content: '';
	border-style: solid;
	border-width: 85px 25vw 85px 25vw;
}
#pointArea:before {
	left: 0;
	border-color: transparent transparent #E1F5F6 #E1F5F6;
}
#pointArea:after {
	right: 0;
	border-color: transparent #E1F5F6 #E1F5F6 transparent;
}
@media only screen and (max-width:767px) {
	#pointArea {
		padding: 30px 0 130px;
	}
	#pointArea .title {
		margin-bottom: 40px;
	}
	#pointArea {
		padding: 70px 0 90px;
	}
	#pointArea:before,
	#pointArea:after {
		border-width: 25px 25vw 25px 25vw;
	}
}


#pointArea .pointList {
	max-width: 1280px;
	margin: 0 auto;
}
#pointArea .pointList li {
	display: flex;
	align-items: flex-start;
}
#pointArea .pointList li + li {
	margin-top: 110px;
}
#pointArea .pointList li:nth-child(odd) {
	flex-direction: row-reverse;
}
#pointArea .pointList .image {
	position: relative;
	width: 54.688%;
	z-index: 2;
}
#pointArea .pointList .image:before {
	position: absolute;
	top: 20px;
	left: 20px;
	display: block;
	content: '';
	width: 100%;
	height: 100%;
	background-color: #FFF255;
}
#pointArea .pointList .image figure {
	position: relative;
	z-index: 2;
}
#pointArea .pointList .texts {
	position: relative;
	box-sizing: border-box;
	width: 37.891%;
	margin-top: 70px;
	padding: 80px 65px;
	z-index: 1;
}
#pointArea .pointList .texts > * {
	position: relative;
	z-index: 2;
}
#pointArea .pointList .texts:before {
	position: absolute;
	top: 0;
	display: block;
	content: '';
	height: 100%;
	width: 200vw;
	background-color: #fff;
}
#pointArea .pointList li:nth-child(odd) .texts:before {
	right: -180px;
}
#pointArea .pointList li:nth-child(even) .texts:before {
	left: -180px;
}

#pointArea .pointList .texts .label {
	margin-bottom: 25px;
	line-height: 0;
}
#pointArea .pointList .texts .label img {
	height: 18px;
}
#pointArea .pointList .texts .ttl {
	margin-bottom: 20px;
	color: #06B4BB;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 2;
}
#pointArea .pointList .texts .ttl span {
	background: rgba(0, 0, 0, 0) linear-gradient(transparent 50%, #FFF255 0%) repeat scroll;
}
#pointArea .pointList .texts p {
	font-size: 1.4rem;
}

@media only screen and (max-width:991px) {
	#pointArea .pointList .texts {
		width: 45.312%;
		margin-top: 40px;
		padding: 40px 35px;
	}
}
@media only screen and (max-width:767px) {

	#pointArea .pointList li {
		overflow: hidden;
		display: block;
	}
	#pointArea .pointList .image {
		width: auto;
	}
	#pointArea .pointList .image:before {
		top: 10px;
		left: 10px;
	}
	#pointArea .pointList .image figure {
		overflow: hidden;
		position: relative;
	}
	#pointArea .pointList .image figure img {
		display: block;
		max-width: 124%;
		margin: 0 -12%;
	}
	#pointArea .pointList .texts {
		width: auto;
		margin-top: 0;
		padding: 50px 22px;
	}
	#pointArea .pointList .texts:before {
		position: absolute;
		top: auto !important;
		right: auto !important;
		left: 0 !important;
		bottom: 0 !important;
		height: calc(100% + 100px);
		width: 100%;
	}
	#pointArea .pointList .texts .label img {
		height: 12px;
	}
	#pointArea .pointList .texts .ttl {
		font-size: 1.8rem;
	}
	#pointArea .pointList li:nth-child(odd) .image {
		margin-left: 35px;
	}
	#pointArea .pointList li:nth-child(even) .image {
		margin-right: 35px;
	}
	#pointArea .pointList li:nth-child(odd) .texts {
		margin-right: 50px;
	}
	#pointArea .pointList li:nth-child(even) .texts {
		margin-left: 50px;
	}
}


/*************************************************

 flow

*************************************************/
#flow {
	padding: 80px 0 70px;
	color: #000;
	background-color: #E1F5F6;
}
@media only screen and (max-width:767px) {
	#flow {
		padding: 60px 0 80px;
	}
}

/* title
--------------------------------------*/
#flow .title {
	margin-bottom: 40px;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-align: center;
	line-height: 2;
}
#flow .title strong {
	color: #06B4BB;
	font-size: 1.3em;
	background: rgba(0, 0, 0, 0) linear-gradient(transparent 50%, #FFF255 0%) repeat scroll;
}
@media only screen and (max-width:767px) {
	#flow .title {
		margin-bottom: 35px;
		font-size: 2.2rem;
	}
}

/* flowList
--------------------------------------*/
#flow .flowList {
	max-width: 960px;
	margin: 0 auto;
	padding: 0 22px;
}
#flow .flowList .inFlex {
	display: flex;
	align-items: center;
	padding: 15px 0;
	background-color: #C7EBED;
}
#flow .flowList li + li:before {
	display: block;
	content: '';
	width: 100%;
	height: 40px;
	background: url(../../images/guide_exercise/arw02.svg) no-repeat center center / 20px auto;
}
#flow .flowList li:nth-child(even) .inFlex {
	background-color: #fff;
}
#flow .flowList .ttls {
	box-sizing: border-box;
	width: 310px;
	display: flex;
	align-items: center;
	padding-left: 15px;
	color: #06B4BB;
	line-height: 1.4;
}
#flow .flowList .ttls .ico {
	width: 48px;
	margin-right: 20px;
	line-height: 0;
}
#flow .flowList .ttls .ttl {
	width: calc(100% - 68px);
	font-size: 2.2rem;
	font-weight: 700;
}
#flow .flowList .txts {
	font-size: 1.4rem;
}
@media only screen and (max-width:767px) {
	#flow .flowList .inFlex {
		display: block;
		padding: 30px 20px 20px;
	}
	#flow .flowList .ttls {
		width: auto;
		margin-bottom: 15px;
		padding-left: 0;
	}
	#flow .flowList .ttls .ico {
		margin-right: 15px;
	}
}


/*************************************************

 contact

*************************************************/
#contact {
	position: relative;
	padding: 250px 0 115px;
	background: url(../../images/guide_exercise/contact_bg.jpg) center center / cover;
}
#contact:before {
	position: absolute;
	left: 0;
	top: 0;
	display: block;
	content: '';
	border-width: 160px 50vw 0 50vw;
	border-style: solid;
	border-color: #E1F5F6 transparent transparent transparent;
}
#contact .inner {
	position: relative;
	display: table;
	margin: 0 auto;
	padding: 0 250px;
}
#contact .title {
	margin-bottom: 45px;
	color: #fff;
	font-size: 2.5rem;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.1em;
}
#contact .title  strong {
	font-size: 1.3em;
	background: rgba(0, 0, 0, 0) linear-gradient(transparent 50%, #FF9D00 0%) repeat scroll;
}
#contact .inBtn a {
	display: block;
	max-width: 320px;
	margin: 0 auto;
	padding: 22px 0;
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	text-align: center;
	text-decoration: none;
	background-color: #FF9D00;
}
#contact .inBtn span {
	position: relative;
	display: inline-block;
	padding-left: 25px;
	background: url(../../images/common/icon_mail_w.svg) no-repeat left center / 16px auto;
}
#contact .imgs figure {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
#contact .imgs figure:nth-child(1) {
	left: 0;
}
#contact .imgs figure:nth-child(2) {
	right: 0;
}
@media only screen and (max-width:767px) {
	#contact {
		padding: 100px 0 30px;
	}
	#contact:before {
		border-width: 50px 50vw 0 50vw;
	}
	#contact .inner {
		display: block;
		padding: 0 22px;
	}
	#contact .title {
		margin-bottom: 40px;
		font-size: 2.2rem;
	}
	#contact .imgs {
		display: flex;
		align-items: flex-end;
		margin-top: 30px;
	}
	#contact .imgs figure {
		position: static;
		top: 0;
		width: 50%;
		text-align: center;
		transform: translateY(0);
	}
	#contact .imgs figure:nth-child(1) img {
		max-width: 84%;
	}
	#contact .imgs figure:nth-child(2) img {
		max-width: 80%;
	}
}
