@charset "UTF-8";

@font-face {
	font-family: 'Montserrat Bold';
	src: url('../fonts/Montserrat-Bold.ttf');
}

/**** general ****/

html, body {
	color: #333;
    letter-spacing: 0.1em;
}
* {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
	background-repeat: no-repeat;
}
.clearfix:after {
	content: "";
	clear: both;
	display: block;
}
.clearfix::after {
	content: "";
	clear: both;
	display: table;
}
.wrap .wrap_inner{
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
}
.sp_only {
	display: none;
}

/*a {
    text-decoration: none;
}*/

strong.strong_red {
	font-weight: 600;
	color: #c00000;
}
strong.strong_black{
    font-weight: 600;
	color: #333;
}

.smallText {
    font-size: 0.8em;
}

.ls0 {
    letter-spacing: 0;
}
.ls50 {
    letter-spacing: 0.05em;
}
.ls100 {
    letter-spacing: 0.1em;
}

@media screen and (max-width: 768px) {
	img {
		max-width: 100%
	}
	
	.wrap .wrap_inner{
		width: 100%;
		padding: 0 15px;
		box-sizing: border-box;
	}

	.sp_only {
		display: block;
	}
	.pc_only {
		display: none;
	}
	.header img {
		border: none;
		vertical-align: top;
		width: 100%;
	}
}

/**** header ****/
.headerArea {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 999;
	background: #000;
	text-align: center;
	height: 65px;
}
.headerArea .logo {
	display: inline-block;
	width: 128px;
	margin-top: 14px;
	line-height: 0;
}
.headerArea .logo img {
	width: 128px;
}

@media screen and (max-width: 768px) {
	.headerArea {
		height: 55px;
	}
	.headerArea .logo {
		width: 110px;
	}
}

/**** footer ****/
.footerArea {
	padding: 30px 0;
	background: #000;
	font-size: 12px;
	color: #fff;
	text-align: center;
	line-height: 1.5;
}

@media screen and (max-width: 768px) {
	.footerArea {
		padding: 15px 0;
		font-size: 8px;
	}
}

/**** back to top ****/
#back_to_top a {
	display: none;
	position: fixed;
	right: 40px;
	bottom: 40px;
	width: 60px;
	height: 60px;
	background: #333 url('../image/icon_arrowUp_white01.png') no-repeat center center;
	border-radius: 60px;    
}

@media screen and (min-width: 769px) {
	#back_to_top a:hover {
        opacity: 0.8;
    }
}

@media screen and (max-width: 768px) {
	#back_to_top a {
		right: 15px;
		bottom: 20px;
		width: 30px;
		height: 30px;
		background-size: 10px;
		border-radius: 15px;
	}
	#back_to_top a:after {
		top: 7px;
		left: 14px;
		padding: 3px;
	}
}

/**** mainvisual ****/
.mainvisual {
	margin-top: 65px;
	margin-bottom: 90px;
	background: #c00000;
	text-align: center;
	line-height: 0;
}
.mainvisual img {
	max-width: 100%;
}
@media screen and (max-width: 768px) {
	.mainvisual {
		margin-top: 55px;
		margin-bottom: 45px;
	}
	.mainvisual .wrap_inner {
		padding: 0;
	}
}

/* SECTION 01 */
.section01 {
	padding-bottom: 100px;
	text-align: center;
}
.sec01_para01 {
	padding-bottom: 50px;
	font-size: 32px;
	font-weight: 600;
	color: #c00000;
	line-height: 1.5;
}
.sec01_para02 {
	margin-top: 40px;
	font-size: 20px;
	line-height: 2;
    text-align: left;
}

/* SECTION 02 */
.section02 {
	position: relative;
	padding: 110px 0 35px;
	background: #f2f2f2;
	text-align: center;
}
.section02 h2 {
	position: absolute;
	top: -20px;
	left: 0;
	right: 0;
	font-family: 'Montserrat Bold';
	font-size: 40px;
	text-align: center;
	color: #c00000;
	letter-spacing: 0.15em;
}
.section02 h2 span {
	display: block;
	margin: 20px 0 0;
	font-size: 20px;
	font-weight: 600;
	font-family: -apple-system, blinkMacSystemFont, "Helvetica Neue", "Segoe UI", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", Meiryo, sans-serif;
	color: #333;
}
.section02 .sec01_para02 {
     text-align: left;
}

.sec02_block01,
.sec02_block02 {
	padding: 40px 80px 80px;
	background: #fff;
	border-radius: 8px;
    margin-bottom: 100px;
	box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}
.sec02_para01 {
	margin: 0 0 60px;
	font-size: 28px;
	font-weight: 600;
	letter-spacing: 0.15em;
	line-height: 1.5;
}
.sec02_para02 {
	margin: 100px 0 70px;
	font-size: 20px;
    line-height: 2;
    text-align: left;
}
.sec02_block01 img {
    margin-top: 40px;
}
.sec02_block01 a img {
    box-shadow: 0 10px 40px rgba(0,0,0,0.1);
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}
@media screen and (min-width:769px) {
    .sec02_block01 a img:hover {
		opacity: 0.8;
	}
}
@media screen and (max-width:768px) {
	.sec01_para01 {
		padding-bottom: 10px;
	}
	.sec02_block01,
	.sec02_block02 {
		padding: 20px 40px 40px;
		background: #fff;
		border-radius: 4px;
		box-shadow: 0 5px 15px rgba(0,0,0,0.1);
        margin-bottom: 50px;
	}
	.sec02_block01 p:first-child,
	.sec02_block02 p:first-child {
		margin-top: 20px;
	}
	.sec02_para01 {
		margin: 0 0 30px;
		font-size: 18px;
	}
	.sec02_para02 {
		margin: 50px 0 35px;
		font-size: 12px;
	}
    .sec02_block01 img {
        margin-top: 20px;
    }
    .sec02_block01 a img {
        box-shadow: 0 10px 20px rgba(0,0,0,0.1);
    }
}

/* BUTTON 01 */
.btn01 {
	display: block;
	margin: 70px auto 0;
	max-width: 600px;
	width: 100%;
	padding: 30px;
	background: #c00000;
	border-radius: 8px;
	font-size: 20px;
	font-weight: 600;
	color: #fff;
	text-decoration: none;
    line-height: 1.5;
	box-sizing: border-box;
	box-shadow: 0 10px 40px rgba(0,0,0,0.1);
}
.btn01 span {
	display: block;
	background: url('../image/icon_arrowRight_white01.png') no-repeat center right;
}
.btn02 {
	display: block;
	margin: 70px auto 0;
	max-width: 600px;
	width: 100%;
	padding: 30px;
	background: #333;
	border-radius: 8px;
	font-size: 20px;
	font-weight: 600;
	color: #fff;
	text-decoration: none;
    line-height: 1.5;
	box-sizing: border-box;
	box-shadow: 0 10px 40px rgba(0,0,0,0.1);
}
.btn01,
.btn02 {
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.btn02 span {
	display: block;
	background: url('../image/icon_arrowRight_white01.png') no-repeat center right;
}
@media screen and (min-width:769px) {
	.btn01:hover,
	.btn02:hover {
		opacity: 0.8;
	}
}
@media screen and (max-width:768px) {
	.btn01,
	.btn02 {
		margin-top: 20px;
		padding: 19px 12px;
		font-size: 12px;
		border-radius: 4px;
		box-shadow: 0 10px 20px rgba(0,0,0,0.1);
	}
	.btn01 span,
	.btn02 span {
		background-size: 7px;
	}
}
@media screen and (max-width:374px) {
	.btn01,
	.btn02 {
		font-size: 9px;
	}
}

/* LINK 01 */
.link01 {
	display: block;
	margin: 100px auto;
	padding: 30px;
	max-width: 696px;
	border-radius: 100px;
	border: 2px solid #333;
	color: #333;
	font-weight: 600;
	font-size: 20px;
	box-sizing: border-box;
	text-align: center;
	text-decoration: none;
    -webkit-transition: all 0.5s;
	transition: all 0.5s;
}
.link01 span {
	display: block;
	background: url('../image/icon_arrowRight01.png') no-repeat center right;
}
@media screen and (min-width:769px) {
	.link01:hover {
        color: #fff;
        background: #333;
	}
    .link01:hover span {
        background: url('../image/icon_arrowRight_white01.png') no-repeat center right;
    }
}

@media screen and (max-width:768px) {
	.section01 {
		padding-bottom: 50px;
	}
	.sec01_para01 {
		font-size: 20px;
	}
	.sec01_para02 {
		margin-top: 30px;
		font-size: 12px;
	}
	.section02 {
		padding: 60px 0 17px;
	}
	.section02 h2 {
		top: -10px;
		font-size: 20px;
	}
	.section02 h2 span {
		margin: 10px 0 0;
		font-size: 12px;
	}
	.section02 .wrap_inner {
		padding: 0 13px;
	}

	.link01 {
		margin: 50px auto;
		padding: 20px 17px;
		max-width: 348px;
		border: 1px solid #4c4c4c;
		font-size: 12px;
	}
	.link01 span {
		background-size: 7px;
	}
}

@media screen and (max-width:374px) {
	.link01 {
		margin: 60px 10px;
	}
}