@charset "UTF-8";

/**************
   reset css
***************/
.clearfix{ zoom : 1; }
.clearfix:after{ content : ''; display : block; clear : both; height:0; }

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
font: inherit;
vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
display: block;
}
body {
line-height: 1;
}
ol, ul {
list-style: none;
}
blockquote, q {
quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
content: '';
content: none;
}
table {
border-collapse: collapse;
border-spacing: 0;
}

input, textarea, select, label {
margin:0;
font-size: 100%;
font-family: inherit;
vertical-align: middle;
}
a {
margin:0;
padding:0;
font-size:100%;
vertical-align:baseline;
background:transparent;
}
/* change colours to suit your needs */
ins {
background-color:#ff9;
color:#000;
text-decoration:none;
}
/* change colours to suit your needs */
mark {
background-color:#ff9;
color:#000;
font-style:italic;
font-weight:bold;
}
del {
text-decoration: line-through;
}
abbr[title], dfn[title] {
border-bottom:1px dotted;
cursor:help;
}
table {
border-collapse:collapse;
border-spacing:0;
}
/* change border colour to suit your needs */
hr {
display:block;
height:1px;
border:0;
border-top:1px solid #cccccc;
margin:1em 0;
padding:0;
}
input, textarea, select, label {
margin:0;
font-size: 100%;
font-family: inherit;
vertical-align: middle;
}
ol, ul {
list-style: none;
}
img {
vertical-align:bottom;
}

/*font size reset*/
body{
font:16px 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
color:#333333;
-webkit-font-smoothing: antialiased;
background-color: #ffffff;
}




/*******************
   template css
   共通部分
********************/

.body_template .btn{
	background: #ed6579;
	border-radius: 10px;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
	-o-border-radius: 10px;
	-ms-border-radius: 10px;
	border:none;
	-moz-box-shadow: 0 1px 3px rgba(0,0,0,0.6);
	-webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.6);
	-o-box-shadow: 0 1px 3px rgba(0,0,0,0.6);
	-ms-box-shadow: 0 1px 3px rgba(0,0,0,0.6);
	min-height: 32px;
}

.body_template .btn:hover{
	background: #f97f91;
}
@media screen and (max-width: 768px) {
	.body_template .btn:hover{
		background: #f97f91;
	}
}

.body_template .inner{
	width:954px;
	margin:0 auto;
}
@media screen and (max-width: 768px) {
	.body_template .inner{
		width:auto;
		padding:0 3%;
	}
}

.body_template{
	/*背景画像*/
	background: url(../images/bg.gif) center top repeat;
}

.body_template .sp-show{
	display: none;
}
@media screen and (max-width: 768px) {
	.body_template .sp-show{
		display: block;
	}
}
@media screen and (max-width: 768px) {
	.body_template .pc-only{
		display: none;
	}
}

.body_template span{
	color:#ed6579;
}

/**************
     header
***************/

.body_template header{
	/*背景色*/
	background: url(../images/mainvisual_bg.jpg) 0 0 no-repeat;
    background-size: cover;
	padding-top:34px;
	padding-bottom:70px;
}
@media screen and (max-width: 768px) {
	.body_template header{
		background: url(../images/mainvisual_bg_sp.jpg) 0 0 no-repeat;
		background-size: cover;
		padding-top:15px;
		padding-bottom:15px;
	}
}

.body_template h1{
	/*背景画像*/
	background: url(../images/pc_title.png) center top no-repeat;
	width:690px;
	height:306px;
	text-indent: -9999px;
	float:left;
}
@media screen and (max-width: 768px) {
	.body_template h1{
		background: url(../images/sp_title.png) center top no-repeat;
		background-size: contain;
		width:100%;
		padding-top:57%;
		height:auto;
		float:none;
		margin-bottom:0;
	}
}

.body_template header .pop{
	/*背景画像*/
	background: url(../images/pc_pop.png) center top no-repeat;
	width:213px;
	height:213px;
	text-indent: -9999px;
	float:right;
	margin-top:90px;
}
@media screen and (max-width: 768px) {
	.body_template header .pop{
		background: url(../images/sp_pop.png) center top no-repeat;
		background-size: contain;
		width: 45%;
		margin: 0 auto;
		padding-top: 35.6%;
		height:auto;
		float:none;
	}
}


/**************
     intro
***************/
.body_template .intro h2{
	font-size:24px;
	padding: 40px 0 0 0;
	text-align:center;
	line-height:1.4em;
}
@media screen and (max-width: 768px) {
	.body_template .intro h2{
		font-size: 14px;
		padding: 28px 0 8px 0;
		line-height: 1.3em;
	}
}

.body_template .intro span{
	font-weight:600;
}


.body_template .intro .logo{
	font-size:32px;
	width:350px;
	float:left;
}
@media screen and (max-width: 768px) {
	.body_template .intro .logo{
		font-size: 26px;
		width:auto;
		float:none;
		position: relative;
		margin-left: 23%;
	}
}

.body_template .intro .logo img{
	position: relative;
	left:0;
	top:30px;
	z-index: 1;
	margin-right:20px;
}
@media screen and (max-width: 768px) {
	.body_template .intro .logo img{
		width: 29%;
		height: auto;
		top: 5px;
		left: -31%;
		margin-right:0;
		position: absolute;
	}
}

.body_template .intro .copy{
	float:right;
	width:500px;
	background: #74cfcb;
	padding: 4px 0;
	-moz-border-radius: 3px;
	-webkit-border-radius: 3px;
	-o-border-radius: 3px;
	-ms-border-radius: 3px;
	text-align:center;
	color:#ffffff;
	margin-top: 80px;
}
@media screen and (max-width: 768px) {
	.body_template .intro .copy{
		width: 64%;
		margin: 0px 0 7% 25%;
		padding: 3px 15px;
	}
}

.body_template .widget-area1{
	padding-bottom:20px;
}
@media screen and (max-width: 768px) {
	.body_template .widget-area1{
		padding-bottom:8px;
	}
}

.body_template  .step-area .box{
	background: #f5f5f5;
	height:183px;
	width:462px;
	float:left;
	margin-bottom: 5px;
}
@media screen and (max-width: 768px) {
	.body_template  .step-area .box{
		float:none;
		width:100%;
		margin-bottom:18px;
		height: auto;
		padding-bottom: 16px;
	}
}

.body_template .step-area .box2{
	float:right;
}
@media screen and (max-width: 768px) {
	.body_template  .step-area .box2{
		float:none;
	}
}

.body_template .step-area h3{
	margin-top: 10px;
	padding-top:20px;
	font-size:16px;
	text-align:center;
}
@media screen and (max-width: 768px) {
	.body_template .step-area h3 {
		margin-top: 0px;
		padding-top: 10px;
		font-size: 12px;
		margin-bottom:4px;
	}
}

.body_template .step-area .box p{
	width:380px;
	margin:0 auto;
	font-size:16px;
}
@media screen and (max-width: 768px) {
	.body_template .step-area .box p{
		width: 77%;
		margin: 0 auto;
		font-size: 12px;
		text-align:center;
	}
}

.body_template .step-area .box a{
	padding:20px 40px;
	line-height:1.4em;
	color:#ffffff;
	display: inline-block;
	text-decoration: none;
}
@media screen and (max-width: 768px) {
	.body_template .step-area .box a{
		padding:2% 0;
		line-height:1.4em;
		color:#ffffff;
		display: inline-block;
		width:100%;
		text-decoration: none;
	}
}

.body_template .step-area .btn span{
	font-size:24px;
	color:#fFffff;
}
@media screen and (max-width: 768px) {
	.body_template .step-area .btn span{
		font-size:14px;
	}
}
.body_template .step-area .box2 p{
	text-align:center;
}

.body_template .txt-area{
	background: #fFffff;
	border:1px solid #000000;
	margin: 0 8%;
	padding-bottom:0;
	-moz-box-shadow: 1px 1px 0 0 rgba(0,0,0,0.3) inset;
	-webkit-box-shadow: 1px 1px 0 0 rgba(0,0,0,0.3) inset;
	-o-box-shadow: 1px 1px 0 0 rgba(0,0,0,0.3) inset;
	-ms-box-shadow: 1px 1px 0 0 rgba(0,0,0,0.3) inset;
}
@media screen and (max-width: 768px) {
	.body_template .txt-area{
		margin: 0 12%;
	}
}

.body_template .box .txt-area p{
	margin-bottom:0;
	font-size:18px;
	padding:10px 0;
	color:#ed6579;
	font-weight:600;
	width:auto;
}
@media screen and (max-width: 768px) {
	.body_template .box .txt-area p{
		font-size: 16px;
		padding:9px 0;
	}

}

.body_template .link-lp{
	font-size:16px;
	padding-bottom:40px;
	clear: both;
}
@media screen and (max-width: 768px) {
	.body_template .link-lp{
		font-size:9px;
		padding-bottom:25px;
	}
}

.body_template .link-lp a {
	color:#ed6579;
	text-decoration: underline;
	display: inline;
}

.body_template .step-area .link-lp a:hover {
	text-decoration: none;
}


/**************
     btn-area
***************/

.body_template .btn-area{
	background:#ffffff;
	width:100%;
	padding:40px 0;
	margin-bottom:40px;
}
@media screen and (max-width: 768px) {
	.body_template .btn-area{
		padding: 30px 0;
		margin-bottom: 20px;
	}
}

.body_template .btn-area .btn{
	width:600px;
	margin:0 auto;
	text-align:center;
	color:#ffffff;
	font-weight:bold;
	padding: 18px 0 2px 0;
    line-height: 1em;
}
@media screen and (max-width: 768px) {
	.body_template .btn-area .btn{
		width: 100%;
		padding: 17px 0 0 0;
		font-size: 12px;
	}
}

.body_template .btn-area .btn img{
	margin-right:10px;
}

/**************
   photo-area
***************/

.body_template .photo-area h3{
	font-size:24px;
	margin-bottom:30px;
}
@media screen and (max-width: 768px) {
	.body_template .photo-area h3{
		font-size:16px;
		margin-bottom:10px;
	}
}

.body_template .photo-area h3 img{
	margin-right:10px;
}
@media screen and (max-width: 768px) {
	.body_template .photo-area h3 img{
		width:19px;
		height:auto;
		margin-right:5px;
	}
}

.body_template .attention{
	font-size:13px;
	margin-bottom:30px;
}
@media screen and (max-width: 768px) {
	.body_template .attention{
		font-size: 10px;
		margin-bottom: 30px;
		clear: both;
	}
}


/**************
      info
***************/

.body_template #info{
	background: #ffffff;
	padding-top:40px;
	padding-bottom:60px;
}

.body_template #info h3{
	font-size:24px;
	margin-bottom:30px;
	padding-bottom:5px;
	border-bottom : 1px solid #b3d67f;
	margin-bottom:30px;
}

.body_template #info p{
	margin-bottom:14px;
}
@media screen and (max-width: 768px) {
	.body_template #info p{
		font-size:14px;
	}
}


.body_template #info .about,
.body_template #info .how{
	margin-bottom:60px;
}
@media screen and (max-width: 768px) {
	.body_template #info .about,
	.body_template #info .how{
		font-size:14px;
		margin-bottom:40px;
	}
}

.body_template #info ul li{
	padding-left: 0;
	text-indent: -1em;
	margin-left:1em;
}

.body_template #info .how ul{
	width:476px;
	margin:0 auto 30px auto;
}
@media screen and (max-width: 768px) {
	.body_template #info .how ul{
		width: 96%;
		margin: 0 auto 30px auto;
	}
}

.body_template #info .how ul li{
	float:left;
	margin-right:30px;
}
@media screen and (max-width: 768px) {
	.body_template #info .how ul li{
		margin-right: 0;
		width: 44%;
	}
}
@media screen and (max-width: 768px) {
	.body_template #info .how ul img{
		width:100%;
		height:auto;
	}
}
@media screen and (max-width: 768px) {
	.body_template #info .how ul .ggl img{
		width:87%;
		height:auto;
	}
}

.body_template .left-box{
	clear: both;
	width:462px;
	float:left;
}
.body_template .left-box a {
	text-decoration: none;
}
@media screen and (max-width: 768px) {
	.body_template .left-box a {
		text-decoration: none;
	}
}
.body_template .right-box{
	width:462px;
	float:right;
}
@media screen and (max-width: 768px) {
	.body_template .left-box,.body_template .right-box{
		width:100%;
	}
}

.body_template #info .title{
	border-bottom : 1px solid #b3d67f;
	margin-bottom:20px;
}

.body_template #info .title h4{
	color:#ffffff;
	display: inline-block;
	background: #b3d67f;
	margin-bottom:0;
	padding:10px 15px 8px 15px;
}
@media screen and (max-width: 768px) {
	.body_template #info .title h4{
		padding:4px 10px 2px 10px;
	}
}

.body_template #info .btn-area{
	text-align:center;
}
@media screen and (max-width: 768px) {
	.body_template #info .btn-area{
		margin-bottom:0;
		width: 100%;
	}
}

.body_template #info .btn{
	font-size:24px;
	padding:15px 60px;
}
@media screen and (max-width: 768px) {
	.body_template #info .btn{
		font-size:14px;
		width: 100%;
		padding:6% 0;
		display: inline-block;
		min-height: 10px;
	}
}

.body_template #info .attention{
	font-size:13px;
}

/*************
   footer
***************/

.body_template footer{
	clear:both;
	width:100%;
	background: #74cfcb;
}
.body_template footer p{
	text-align:center;
	v
	color:#ffffff;
	margin-bottom:0;
	padding:5px 0;
}

/* 190128 */
.tousen{margin-top:50px;}
@media screen and (max-width: 768px) {.tousen{margin-top:50px;}}

.btn-area .inner .btn a{ color: #fff; text-decoration: none;
}
@media screen and (max-width: 768px) {
	.btn-area .inner .btn a{color: #fff; text-decoration: none;
	}
}

#process .left-box .title p.btn-area a.btn {font-size:13px;}
