@charset "utf-8";

/*
 *
 *	reason:training style
 *
 */

/*======================================
	pageTit
======================================*/
.pageTit {
	background: url(../../images/second-tit.png), url(../images/tit-bg.jpg);
	background-position: center, center;
	background-repeat: repeat, no-repeat;
	background-size: 8px 8px, cover;
}



/*======================================
	trainingBox
======================================*/
.trainingBox :last-child {
	margin-bottom: 0;
}

.trainingBox h2 {
	position: relative;
	margin: 2.5em -1em 1.5em;
	padding: 1em .5em;
	background: #ff9400 url(../images/tit-bg.png);
	text-align: center;
	color: #fff;
}
.trainingBox h2:after {
	content: '';
	display: block;
	position: absolute;
	left: 50%;
	bottom: -16px;
	border: transparent solid 8px;
	border-top-color: #ff9400;
}
.trainingBox h2 span {
	display: inline-block;
	padding: .2em .5em;
	margin-right: .5em;
	background: #ff6464;
	border-radius: .5em;
}

.trainingBox .point {
	position: relative;
	display: inline-block;
	padding: 0 1.5em 1em;
	text-align: center;
	font-size: 1.2em;
}
.trainingBox .point:before,
.trainingBox .point:after {
	content: '';
	display: inline-block;
	position: absolute;
	top: 0;
	width: 3px;
	height: 1.5em;
	background: #ff6464;
}
.trainingBox .point:before {
	left: 0;
		-webkit-transform: rotate(-30deg);
		-moz-transform: rotate(-30deg);
		-ms-transform: rotate(-30deg);
	transform: rotate(-30deg);
}
.trainingBox .point:after {
	right: 0;
		-webkit-transform: rotate(30deg);
		-moz-transform: rotate(30deg);
		-ms-transform: rotate(30deg);
	transform: rotate(30deg);
}



/*======================================
	trainingBox:about
======================================*/
.trainingBox.about .tit {
	margin-bottom: -1.5em;
	padding: 0;
	border: none;
}

.trainingBox .greeting {
	float: left;
	margin: 0 1em 1em 0;
	box-shadow: rgba(0,0,0,.3) 2px 2px 3px;
}


/****** trainerBox ******/
.trainingBox .trainerBox {
	position: relative;
}
.trainingBox .trainerBox .txt {
	position: absolute;
	left: 49%;
	width: 28%;
	top: 6em;
	text-align: center;
	text-shadow: #fff 1px 1px 0, #fff 0 0 3px;
}
.trainingBox .trainerBox .txt h3 {
	margin-bottom: 2em;
	text-align: center;
}
.trainingBox .trainerBox .txt h3 strong {
	display: inline-block;
	position: relative;
	padding: .2em;
	font-size: 1.2em;
	color: #ff6464;
}
.trainingBox .trainerBox .txt h3 strong:after {
	content: '';
	display: block;
	position: absolute;
	bottom: -.2em;
	left: 0;
	right: 0;
	height: .3em;
	background: #f9d97c;
	opacity: .8;
}
.trainingBox .trainerBox .txt p {
	padding: .8em 0;
	border: #fff double 3px;
	background: rgba(255,255,255,.5);
	border-radius: 1em;
	text-align: center;
	font-size: 1.1em;
}


/****** voiceList ******/
.trainingBox .voiceList li {
	overflow: hidden;
	clear: both;
	margin-bottom: 1em;
}
.trainingBox .voiceList li:nth-child(odd) img {
	float: left;
}
.trainingBox .voiceList li:nth-child(even) img {
	float: right;
}
.trainingBox .voiceList li:nth-child(odd) div {
	padding-left: 55px;
}
.trainingBox .voiceList li:nth-child(even) div {
	padding-right: 55px;
}
.trainingBox .voiceList li div p {
	position: relative;
	margin-bottom: 0;
	padding: 1em .8em;
	border: #ddd solid 3px;
	border-radius: .5em;
}
.trainingBox .voiceList li div p:before,
.trainingBox .voiceList li div p:after {
	content: '';
	display: block;
	position: absolute;
	top: .5em;
	border: transparent solid 8px;
}
.trainingBox .voiceList li:nth-child(odd) div p:before {
	left: -19px;
	border-right-color: #ddd;
}
.trainingBox .voiceList li:nth-child(odd) div p:after {
	left: -15px;
	border-right-color: #fff;
}
.trainingBox .voiceList li:nth-child(even) div p:before {
	right: -19px;
	border-left-color: #ddd;
}
.trainingBox .voiceList li:nth-child(even) div p:after {
	right: -15px;
	border-left-color: #fff;
}


/****** faqList ******/
.trainingBox .faqList dt {
	position: relative;
	line-height: 1.3;
	margin: 0 0 1px;
	padding: .1em 40px .4em 2.4em;
	background: #f9d97c;
	text-indent: -1.8em;
	cursor: pointer;
}
.trainingBox .faqList dt:hover {
	opacity: .7;
}
.trainingBox .faqList dt:before {
	content: 'Q ';
	font-size: 1.6em;
	font-weight: bold;
	color: #fff;
}
.trainingBox .faqList dt:after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 15px;
	width: 15px;
	height: 15px;
	margin-top: -8px;
	border: #ff6464 solid;
	border-width: 0 0 3px 3px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
		-moz-transition: all .4s ease;
		-webkit-transition: all .4s ease;
		-ms-transition: all .4s ease;
    transition: all .4s ease;
}
.trainingBox .faqList dt.close:after {
	margin-top: -3px;
	transform: rotate(135deg);
}
.trainingBox .faqList dd {
	margin-bottom: 1em;
	padding-left: 2.4em;
	text-indent: -1.8em;
}
.trainingBox .faqList dd:before {
	content: 'A ';
	font-size: 1.6em;
	font-weight: bold;
	color: #ff6464;
}



/*======================================
	trainingBox:detail
======================================*/
.trainingBox.detail header .tit {
	padding: .5em .5em 0;
	background: #ff6464;
}
.trainingBox.detail header .tit h1 {
	float: right;
	width: 70%;
	margin: 0;
	padding: .5em 1em 0;
	background: transparent;
	border: none;
	font-size: 1.3em;
	font-weight: bold;
	color: #fff;
}
.trainingBox.detail header .tit h1 strong {
	display: block;
	font-size: 1.75em;
}
.trainingBox.detail header .tit ul {
	float: left;
	width: 30%;
}
.trainingBox.detail header .tit ul li {
	float: left;
	width: 48%;
}
.trainingBox.detail header .tit ul li:nth-child(odd) {
	clear: both;
	margin-right: 4%;
}

.trainingBox.detail header figure {
	float: left;
	width: 50%;
}
.trainingBox.detail header .copy {
	float: right;
	width: 50%;
	padding-left: 1em;
}
.trainingBox.detail header .copy h2 {
	margin: 0 0 1em;
	padding: 1.5em 0 1em;
	border-bottom: #00adbd solid 3px;
	background: none;
	color: #00adbd;
	text-align: left;
	font-weight: bold;
	font-size: 1.2em;
}
.trainingBox.detail header .copy h2:after {
	display: none;
}


/****** lessonList ******/
.trainingBox .lessonList li {
	float: left;
	width: 32%;
	margin-bottom: 1em;
}
.trainingBox .lessonList li:nth-child(3n+2) {
	margin: 0 2% 1em;
}
.trainingBox .lessonList li:nth-child(3n+1) {
	clear: both;
}
.trainingBox .lessonList li h3 {
	margin-bottom: 0;
	padding: .3em;
	background: #efefef;
	text-align: center;
	font-size: 1em;
	color: #00adbd;
	text-shadow: #fff 1px 1px 0;
}
.trainingBox .lessonList li p {
	padding: .5em;
	border: #ddd solid;
	border-width: 0 1px 1px;
	font-size: .8em;
}


/****** checkList ******/
.trainingBox .checkList li {
	position: relative;
	padding-left: 1.5em;
}
.trainingBox .checkList li:before {
	content: '';
	display: block;
	position: absolute;
	width: 1em;
	height: 1em;
	top: .25em;
	left: 0;
	border: #ddd solid 2px;
}
.trainingBox .checkList li:after {
	content: '';
	position: absolute;
	display: block;
	width: .7em;
	height: .4em;
	left: .3em;
	top: .4em;
	border: #ff6464 solid;
	border-width: 0 0 2px 2px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}


/****** certificationBox ******/
.trainingBox .certificationBox {
	position: relative;
	max-width: 600px;
	margin: 5% auto 1.5em;
	padding: 1.5em;
	background-color: #FBEBBE;
	background-image: url(../images/certification-bg1.png), url(../images/certification-bg2.png), url(../images/certification-bg3.png), url(../images/certification-bg4.png);
	background-position: top left, top right, bottom left, bottom right;
	background-repeat: no-repeat;
	background-size: 50px 50px;
	border: #fff double 10px;
	border-radius: 1em;
}
.trainingBox .certificationBox:before {
	content: '';
	display: block;
	position: absolute;
	width: 40%;
	height: 40px;
	top: -45px;
	left: 30%;
	background:url(../images/certification-bg.png) center no-repeat;
	background-size: contain;
}
.trainingBox .certificationBox p {
	float: left;
	width: 75%;
	margin: 1em 0 0;
	font-size: 1.8em;
	text-shadow: #fff 1px 1px 0;
}
.trainingBox .certificationBox p strong {
	color: #ff6464;
}
.trainingBox .certificationBox figure {
	float: right;
	width: 21.26%;
	margin-bottom: -1em;
	box-shadow: rgba(0,0,0,.3) 2px 2px 3px;
		-webkit-transform: rotate(10deg);
		-moz-transform: rotate(10deg);
		-ms-transform: rotate(10deg);
	transform: rotate(10deg);
}


/****** scheduleBox ******/
.trainingBox .scheduleBox {
	margin: 1.5em 0;
}
.trainingBox .scheduleBox .dayBox {
	position: relative;
	margin-bottom: 1px;
	background-image: url(../images/schedule-bg.png);
	background-repeat: repeat;
	background-size: cover;
	padding: 30px 0;
}
.trainingBox .scheduleBox .dayBox:before {
	content: '';
	display: block;
	position: absolute;
	left: 50%;
	top: 0;
	bottom: 0;
	width: 10px;
	margin-left: -5px;
}
.trainingBox .scheduleBox .dayBox time {
	display: block;
	position: absolute;
	top: -30px;
	left: 50%;
	width: 60px;
	height: 60px;
	margin-left: -30px;
	line-height: 1.2;
	padding-top: .5em;
	border-radius: 50%;
	text-align: center;
	font-size: .8em;
	color: #fff;
}
.trainingBox .scheduleBox .dayBox time strong {
	display: block;
	text-align: center;
	font-size: 2em;
}
.trainingBox .scheduleBox .dayBox h3 {
	position: relative;
	width: 40%;
	float: left;
	margin: 0 5.5% 0 7.5%;
	padding: 1em .5em;
	border: #fff double 3px;
	text-align: center;
	color: #fff;
}
.trainingBox .scheduleBox .dayBox h3:after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: -42px;
	margin-top: -8px;
	border: transparent solid;
	border-width: 8px 20px;
}
.trainingBox .scheduleBox .dayBox h3 span {
	display: block;
	text-align: center;
	font-size: .8em;
}
.trainingBox .scheduleBox .dayBox .pointBox {
	float: left;
	width: 43%;
	padding: 1em 1em 1em 0;
	background: #fff;
	border-radius: .5em;
	box-shadow: rgba(0,0,0,.3) 2px 2px 3px;
}
.trainingBox .scheduleBox .dayBox .pointBox h4 {
	position: relative;
	display: inline-block;
	height: 30px;
	line-height: 30px;
	padding-left: .5em;
	margin: 0 0 .5em -6px;
	background: #ff6464;
	border-left: #ff6464 solid 5px;
	color: #fff;
}
.trainingBox .scheduleBox .dayBox .pointBox h4:before {
	content: '';
	display: block;
	position: absolute;
	left: -5px;
	bottom: -6px;
	border: transparent solid 3px;
	border-top-color: #d40000;
	border-right-color: #d40000;
}
.trainingBox .scheduleBox .dayBox .pointBox h4:after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	right: -30px;
	border: #FF6464 solid 15px;
	border-right-color: transparent;
}
.trainingBox .scheduleBox .dayBox .pointBox p {
	margin-left: 1em;
}

.trainingBox .scheduleBox .dayBox.step1 {background-color: rgba(61,171,34,.3);}
.trainingBox .scheduleBox .dayBox.step1:before {background: rgba(61,171,34,.5);}
.trainingBox .scheduleBox .dayBox.step1 time {background: #3dab22; padding-top: 1.2em; font-size: 1em; font-weight: bold;}
.trainingBox .scheduleBox .dayBox.step1 h3 {background: rgba(61,171,34,.75);}
.trainingBox .scheduleBox .dayBox.step1 h3:after {border-left-color: rgba(61,171,34,.75);}

.trainingBox .scheduleBox .dayBox.step2 {background-color: rgba(255,148,0,.3);}
.trainingBox .scheduleBox .dayBox.step2:before {background: rgba(255,148,0,.5);}
.trainingBox .scheduleBox .dayBox.step2 time {background: #ff9400;}
.trainingBox .scheduleBox .dayBox.step2 h3 {background: rgba(255,148,0,.75);}
.trainingBox .scheduleBox .dayBox.step2 h3:after {border-left-color: rgba(255,148,0,.75);}

.trainingBox .scheduleBox .dayBox.step3 {background-color: rgba(0, 127, 209,.2);}
.trainingBox .scheduleBox .dayBox.step3:before {background: rgba(0, 127, 209,.5);}
.trainingBox .scheduleBox .dayBox.step3 time {background: #007fd1;}
.trainingBox .scheduleBox .dayBox.step3 h3 {background: rgba(0, 127, 209,.75);}
.trainingBox .scheduleBox .dayBox.step3 h3:after {border-left-color: rgba(0, 127, 209,.75);}

.trainingBox .scheduleBox .dayBox.step4 {background-color: rgba(237, 0, 96,.2);}
.trainingBox .scheduleBox .dayBox.step4:before {background: rgba(237, 0, 96,.5);}
.trainingBox .scheduleBox .dayBox.step4 time {background: #ED0060;}
.trainingBox .scheduleBox .dayBox.step4 h3 {background: rgba(237, 0, 96,.6);}
.trainingBox .scheduleBox .dayBox.step4 h3:after {border-left-color: rgba(237, 0, 96,.6);}

.trainingBox .scheduleBox .goal {
	padding: .5em;
	background: #ff6464;
	text-align: center;
	font-size: 1.8em;
	color: #fff;
}


/****** finTxt ******/
.trainingBox .finTxt {
	position: relative;
	padding: 1em 40% 1em .5em;
		background: #ff6464;
		background: -moz-linear-gradient(left, rgba(255,100,100,.3) 0%, rgba(255,148,0,.3) 50%, rgba(255,100,100,.3) 100%);
		background: -webkit-gradient(linear, left top, right top, color-stop(0%, rgba(255,100,100,.3)), color-stop(50%, rgba(255,148,0,.3)), color-stop(100%, rgba(255,100,100,.3)));
		background: -webkit-linear-gradient(left, rgba(255,100,100,.3) 0%, rgba(255,148,0,.3) 50%, rgba(255,100,100,.3) 100%);
		background: -ms-linear-gradient(left, rgba(255,100,100,.3) 0%, rgba(255,148,0,.3) 50%, rgba(255,100,100,.3) 100%);
	background: linear-gradient(to right, rgba(255,100,100,.2) 0%, rgba(255,148,0,.2) 50%, rgba(255,100,100,.2) 100%);
		-webkit-background-size: 200% 200%;
		-moz-background-size: 200% 200%;
	background-size: 200% 200%;
		-moz-transition: right .6s ease;
		-webkit-transition: right .6s ease;
		-ms-transition: right .6s ease;
    transition: right .6s ease;
		-webkit-animation: bgGrad infinite 2s linear;
		-moz-animation: bgGrad infinite 2s linear;
	animation: bgGrad infinite 2s linear;
	border-radius: .5em;
	text-align: center;
	font-size: 1.5em;
	color: #ff6464;
	text-shadow: #fff 1px 1px 0;
}
.trainingBox .finTxt img {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 41%;
}





/*============================================================================

	responsive

============================================================================*/
@media screen and (max-width:960px) {

}



@media screen and (max-width:767px) {
/*======================================
	trainingBox:about
======================================*/
/****** trainerBox ******/
.trainingBox .trainerBox .txt {
	top: 2em;
}
.trainingBox .trainerBox .txt h3 {
	margin-bottom: 1em;
	padding: 0 .5em;
	font-size: .9em;
}
.trainingBox .trainerBox .txt h3 strong {
	font-size: 1.1em;
}
.trainingBox .trainerBox .txt h3:before,
.trainingBox .trainerBox .txt h3:after {
	width: 2px;
}
.trainingBox .trainerBox .txt p {
	font-size: .9em;
}



/*======================================
	trainingBox:detail
======================================*/
.trainingBox.detail header .tit h1 {
	float: none;
	width: 100%;
	margin-bottom: .5em;
	font-size: 1.2em;
	text-align: center;
}
.trainingBox.detail header .tit h1 strong {
	text-align: center;
}
.trainingBox.detail header .tit ul {
	float: none;
	width: 100%;
	text-align: center;
}
.trainingBox.detail header .tit ul li {
	float: none;
	display: inline-block;
	width: 20%;
	max-width: 120px;
}
.trainingBox.detail header .tit ul li:nth-child(odd) {
	margin-right: 0;
}

.trainingBox.detail header figure {
	float: none;
	width: 100%;
}
.trainingBox.detail header .copy {
	float: none;
	width: 100%;
	padding-left: 0;
}
.trainingBox.detail header .copy h2 {
	margin-bottom: .5em;
	padding: .5em 0;
}


/****** lessonList ******/
.trainingBox .lessonList li {
	width: 49%;
}
.trainingBox .lessonList li:nth-child(3n+2) {
	margin-right: 0;
	margin-left: 0;
}
.trainingBox .lessonList li:nth-child(3n+1) {
	clear: none;
}
.trainingBox .lessonList li:nth-child(odd) {
	margin-right: 2%;
	clear: both;
}


/****** certificationBox ******/
.trainingBox .certificationBox {
	background-size: 40px 40px;
}
.trainingBox .certificationBox:before {
	content: '';
	display: block;
	position: absolute;
	width: 40%;
	height: 40px;
	top: -40px;
	left: 30%;
	background:url(../images/certification-bg.png) center no-repeat;
	background-size: contain;
}


/****** scheduleBox ******/
.trainingBox .scheduleBox .dayBox h3:after {
	right: -22px;
	margin-top: -4px;
	border-width: 4px 10px;
}

}



@media screen and (max-width:480px) {
/*======================================
	trainingBox:about
======================================*/
.trainingBox .greeting {
	width: 30%;
}


/****** trainerBox ******/
.trainingBox .trainerBox .txt {
	position: relative;
	width: 100%;
	left: 0;
	top: 0;
}
.trainingBox .trainerBox .txt h3 {
	margin-bottom: .5em;
	padding: 0 1em .4em;
}
.trainingBox .trainerBox .txt h3 br {
	display: none;
}
.trainingBox .trainerBox .txt p {
	padding: 0;
	border: none;
	background: none;
}



/****** voiceList ******/
.trainingBox .voiceList li img {
	width: 30px;
}
.trainingBox .voiceList li:nth-child(odd) div {
	padding-left: 40px;
}
.trainingBox .voiceList li:nth-child(even) div {
	padding-right: 40px;
}
.trainingBox .voiceList li div p {
	border-width: 2px;
}
.trainingBox .voiceList li div p:before,
.trainingBox .voiceList li div p:after {
	border-width: 6px;
}
.trainingBox .voiceList li:nth-child(odd) div p:before {
	left: -14px;
}
.trainingBox .voiceList li:nth-child(odd) div p:after {
	left: -11px;
}
.trainingBox .voiceList li:nth-child(even) div p:before {
	right: -14px;
}
.trainingBox .voiceList li:nth-child(even) div p:after {
	right: -11px;
}


/****** faqList ******/
.trainingBox .faqList dt {
	padding-right: 35px;
}
.trainingBox .faqList dt:after {
	width: 10px;
	height: 10px;
	margin-top: -7px;
	border-width: 0 0 2px 2px;
}



/*======================================
	trainingBox:detail
======================================*/
.trainingBox.detail header .tit ul li {
	width: 40%;
}


/****** certificationBox ******/
.trainingBox .certificationBox {
	padding: 1em;
	background-size: 30px;
}
.trainingBox .certificationBox:before {
	height: 30px;
	top: -35px;
}
.trainingBox .certificationBox p {
	float: none;
	width: 95%;
	margin: 0;
	font-size: 1.5em;
}
.trainingBox .certificationBox figure {
	margin: -4em -2em -1em 0;
}


/****** scheduleBox ******/
.trainingBox .scheduleBox .dayBox {
	padding: 21px 0;
}
.trainingBox .scheduleBox .dayBox:before {
	width: 6px;
	left: 18px;
}
.trainingBox .scheduleBox .dayBox time {
	top: -21px;
	width: 42px;
	height: 42px;
	left: -5px;
	margin-left: 0;
}
.trainingBox .scheduleBox .dayBox h3 {
	width: 85%;
	float: none;
	margin: 0 0 0 10%;
	padding: .5em;
	box-shadow: rgba(0,0,0,.3) 2px 2px 3px;
}
.trainingBox .scheduleBox .dayBox h3:after {
	display: none;
}
.trainingBox .scheduleBox .dayBox .pointBox {
	position: relative;
	float: none;
	width: 85%;
	margin: 0 0 0 10%;
	border-radius: 0 0 .5em .5em;
	z-index: 2;
}


/****** finTxt ******/
.trainingBox .finTxt {
	padding: 1em .5em 35%;
}
.trainingBox .finTxt img {
	width: 70%;
	right: 15%;
}

}
