@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&display=swap');

body {
	font-family: 'Helvetica Neue' , Helvetica , 'Noto Sans JP', sans-serif;
	font-size:21px;
	text-align:center;
	line-height:1.5;
	color:#29273c;
}

a {
	transition : opacity 0.4s;
	-webkit-transition : opacity 0.4s;
	opacity:1;
	outline:none;
}
a:hover {
	opacity: 0.7;
}

img{
	max-width:100%;
}

.only_smart,
.only_smart_i{
	display:none !important;
}

#wrapper{
	min-width:1024px;
}


/* header */
header{
	width:100%;
	min-width:1024px;
	background-color:#fff;
	box-shadow:0 0 5px rgba(0,0,0,0.3);
	position:fixed;
	z-index:100;
}
header:after{
	content:'';
	display:block;
	clear:both;
}
header > div:first-of-type{
	width:calc(100% - 560px);
	line-height:110px;
	margin:auto;
	padding: 0 0 0 5%;
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
	float:left;
}
header > div:first-of-type > a{
	width:355px;
}
header > div:first-of-type nav{
}
header > div:first-of-type nav ul{
}
header > div:first-of-type nav ul li{
	display:inline-block;
	vertical-align:middle;
	margin-left:40px;
	line-height:1;
}
header > div:first-of-type nav ul li a{
	color:#29273c;
	font-size:20px;
	font-weight:bold;
}
header > a{
	display:block;
	width:490px;
	line-height:110px;
	padding-right:50px;
	background-color:#424242;
	font-size:36px;
	font-weight:bold;
	letter-spacing:0.03em;
	color:#fff;
	float:right;
	position:relative;
}
header > a:before{
	content:'';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 50px 110px 0;
	border-color: transparent #424242 transparent transparent;
	position:absolute;
	right:100%;
}
header > a img{
	width:32px;
	margin-right:10px;
}
@media screen and (max-width:1560px){
	header > div:first-of-type{
		width:calc(100% - 320px);
		padding: 0 0 0 10px;
	}
	header > div:first-of-type > a{
		width:240px;
	}
	header > div:first-of-type nav ul li{
		margin-left:20px;
	}
	header > div:first-of-type nav ul li a{
		font-size:18px;
	}
	header > a{
		width:250px;
		padding-right:0;
		font-size:28px;
	}
	header > a img{
		width:25px;
	}
}



/* article */
article{
	padding-top:110px;
}


/* #mv */
#mv{
	position:relative;
}
#mv p{
	width:80%;
	position:absolute;
	bottom:15%;
	left:50%;
	transform:translateX(-50%);
}
#mv p a{
	display:block;
	width:500px;
	line-height:80px;
	border-radius:40px;
	background-color:#fff;
	color:#000;
	border:2px solid #000;
	font-size:30px;
	font-weight:bold;
	position:relative;
	z-index:1;
}
#mv p a img{
	width:51px;
	margin-right:15px;
}
@media screen and (max-width:1560px){
	#mv p{
		width:90%;
	}
	#mv p a{
		width:400px;
		line-height:70px;
		border-radius:35px;
		font-size:24px;
	}
	#mv p a img{
		width:40px;
		margin-right:10px;
	}
}


/* #cont0 */
#cont0{
	margin-top:2%;
	padding:6% 0 0;
	background:
		url(../images/cont0_bg.png)no-repeat center top;
	background-size:1700px auto;
	position:relative;
	z-index:1;
}
#cont0 h2{
	max-width:1500px;
	margin:auto;
	padding:0 20px;
	text-align:left;
}
#cont0 h2 img{
	width:516px;
}
#cont0 p{
	width:660px;
	margin:150px auto 0;
	font-size:50px;
	font-weight:bold;
	text-align:left;
	letter-spacing:0.09em;
}
#cont0 p span{
	display:block;
	text-align:right;
}
@media screen and (max-width:1560px){
	#cont0{
		background-size:108% auto;
	}
	#cont0 h2 img{
		width:30%;
	}
	#cont0 p{
		width:56%;
		margin:15% auto 0;
		font-size:4.2vw;
	}
}
@media screen and (max-width:1024px){
	#cont0 p{
		width:530px;
		font-size:40px;
	}
}


/* #cont1 */
#cont1{
	margin-top:380px;
	background:url(../images/cont1_base.png)repeat-y center top;
	background-size:100% auto;
	position:relative;
}
#cont1:before{
	content:'';
	display:block;
	width:100%;
	margin:auto;
	padding-top:455px;
	background:url(../images/cont1_bg.png)no-repeat center top;
	background-size:1700px auto;
	position:absolute;
	top:0;
	left:50%;
	transform:translate(-50%,-90%);
}
#cont1 > div{
	max-width:1480px;
	margin:auto;
	padding:0 40px 100px 15%;
}
#cont1 > div h2{
	transform:translateY(-50%);
	display: -webkit-flex;
	display: flex;
	 -webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont1 > div h2 img:first-child{
	width:244px;
}
#cont1 > div h2 img:last-child{
	width:777px;
}
#cont1 > div ul{
	padding:0 5%;
}
#cont1 > div ul li{
	padding:25px;
	font-weight:bold;
	text-align:left;
	border-bottom:2px solid #cdcdcd;
}
@media screen and (max-width:1560px){
	#cont1{
		margin-top:25%;
	}
	#cont1:before{
		padding-top:30%;
		background-size:108% auto;
	}
	#cont1 > div{
		padding:0 20px 6% 15%;
	}
	#cont1 > div h2 img:first-child{
		width:15%;
	}
	#cont1 > div h2 img:last-child{
		width:46%;
	}
	#cont1 > div ul li{
		padding:15px;
	}
}


/* #cont2 */
#cont2{
	margin-top:300px;
	background:url(../images/cont2_base.png)repeat-y center top;
	background-size:100% auto;
}
#cont2 > div{
	max-width:2000px;
	margin:auto;
	padding:0 5% 100px 5%;
}
#cont2 > div h2{
	width:86%;
	transform:translateY(-50%);
	display: -webkit-flex;
	display: flex;
	 -webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont2 > div h2 img:first-child{
	width:777px;
}
#cont2 > div h2 img:last-child{
	width:244px;
}
#cont2 > div dl{
	width:50%;
	margin-right:3%;
	padding-left:3%;
	display:inline-block;
	vertical-align:bottom;
	text-align:left;
}
#cont2 > div dl dt{
	padding:20px 0 20px 25px;
	font-weight:bold;
	float:left;
}
#cont2 > div dl dd{
	padding:20px 25px 20px 200px;
	border-bottom:2px solid #cdcdcd;
}
#cont2 > div > img{
	width:42%;
	vertical-align:bottom;
}
#cont2 > div section{
	max-width:1180px;
	margin-top:100px;
	padding:0 5.5%;
}
#cont2 > div section h3{
	max-width:1140px;
	line-height:92px;
	margin-bottom:50px;
	background-color:#424242;
	font-size:32px;
	color:#fff;
}
#cont2 > div section ul{
	letter-spacing:-0.4em;
	position:relative;
}
#cont2 > div section ul:after{
	content:'';
	display:block;
	width:1px;
	height:120px;
	background-color:#000;
	position:absolute;
	left:52%;
	top:50%;
	transform:translateY(-50%) rotate(30deg);
}
#cont2 > div section ul li{
	display:inline-block;
	vertical-align:middle;
	width:45%;
	letter-spacing:normal;
}
#cont2 > div section ul li:first-child{
	margin-right:10%;
}
#cont2 > div section ul li:first-child a{
	display:block;
	line-height:80px;
	border-radius:40px;
	background-color:#fff;
	color:#000;
	border:2px solid #000;
	font-size:30px;
	font-weight:bold;
}
#cont2 > div section ul li a img{
	width:51px;
	margin-right:15px;
}
#cont2 > div section ul li:last-child a{
	color:#000;
	font-size:47px;
	font-weight:bold;
	letter-spacing:0.05em;
}
#cont2 > div section ul li:last-child a img{
	margin-right:0;
}

@media screen and (max-width:1560px){
	#cont2{
		margin-top:15%;
	}
	#cont2 > div{
		padding:0 20px 6% 20px;
	}
	#cont2 > div h2 img:first-child{
		width:46%;
	}
	#cont2 > div h2 img:last-child{
		width:15%;
	}
	#cont2 > div dl dt{
		padding:10px 0 10px 15px;
		font-weight:bold;
		float:left;
	}
	#cont2 > div dl dd{
		padding:10px 15px 10px 120px;
		border-bottom:2px solid #cdcdcd;
	}
	#cont2 > div section{
		width:90%;
		margin-top:8%;
		padding:0 5.5%;
	}
	#cont2 > div section h3{
		max-width:1140px;
		line-height:80px;
		margin-bottom:30px;
		font-size:24px;
	}
	#cont2 > div section ul:after{
		height:90px;
	}
	#cont2 > div section ul li:first-child a{
		line-height:60px;
		border-radius:30px;
		font-size:21px;
	}
	#cont2 > div section ul li a img{
		width:30px;
		margin-right:10px;
	}
	#cont2 > div section ul li:last-child a{
		font-size:36px;
	}
}


/* #cont3 */
#cont3{
	margin-top:300px;
	background:url(../images/cont1_base.png)repeat-y center top;
	background-size:100% auto;
}
#cont3 > div{
	max-width:1480px;
	margin:auto;
	padding:0 40px 100px 15%;
}
#cont3 > div h2{
	transform:translateY(-50%);
	display: -webkit-flex;
	display: flex;
	 -webkit-align-items: center;
	align-items: center;
	-webkit-justify-content: space-between;
	justify-content: space-between;
}
#cont3 > div h2 img:first-child{
	width:244px;
}
#cont3 > div h2 img:last-child{
	width:777px;
}
#cont3 > div dl{
	padding:0 5%;
	text-align:left;
}
#cont3 > div dl dt{
	padding:20px 0 20px 25px;
	font-weight:bold;
	float:left;
}
#cont3 > div dl dd{
	padding:20px 25px 20px 200px;
	border-bottom:2px solid #cdcdcd;
}
@media screen and (max-width:1560px){
	#cont3{
		margin-top:15%;
	}
	#cont3 > div{
		padding:0 20px 6% 15%;
	}
	#cont3 > div h2 img:first-child{
		width:15%;
	}
	#cont3 > div h2 img:last-child{
		width:46%;
	}
	#cont3 > div dl dt{
		padding:10px 0 10px 15px;
		font-weight:bold;
		float:left;
	}
	#cont3 > div dl dd{
		padding:10px 15px 10px 120px;
		border-bottom:2px solid #cdcdcd;
	}
}


/* #contact/#confirm/#thanks */
#contact,
#confirm,
#thanks{
	margin-top:100px;
	padding:0 0 200px;
}
#contact h2,
#confirm h2,
#thanks h2{
	font-size:50px;
}
#contact h2:after,
#confirm h2:after,
#thanks h2:after{
	content:'';
	display:block;
	width:72px;
	height:8px;
	background-color:#eb8383;
	margin:20px auto 0;
}

#contact form > dl,
#confirm dl{
	max-width:900px;
	margin:80px auto;
	padding:0 20px;
	text-align:left;
}
#contact form > dl dt,
#confirm form > dl dt{
	padding-top:10px;
	float:left;
	font-weight:bold;
}
#contact form > dl dt.hissu:after{
	content:'※必須';
	color:#e22424;
}
#contact form > dl dd,
#confirm form > dl dd{
	margin-bottom:40px;
	padding-left:240px;
}


#thanks p{
	margin-top:1.8em;
}


/* footer */
footer{
	line-height:50px;
	background-color:#e22424;
	font-size:14px;
	color:#fff;
}


/* top_top */
#topbtn{
	width:50px;
	line-height:50px;
	font-size:21px;
	border-radius:50%;
	color:#fff;
	background-color:#e22424;
	position:fixed;
	z-index:102;
	right:30px;
	bottom:-150px;
	-webkit-transition: bottom 0.8s;
	-moz-transition: bottom 0.8s;
	-ms-transition: bottom 0.8s;
	transition: bottom 0.8s;
}


/* fadein */
.fadein {
	opacity : 0;
	-webkit-transform : translate(0, 70px);
	transform : translate(0, 70px);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_l {
	opacity : 0;
	-webkit-transform : translate(-100px, 0);
	transform : translate(-100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.fadein_r {
	opacity : 0;
	-webkit-transform : translate(100px, 0);
	transform : translate(100px, 0);
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
}
.delay1 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.2s;
	transition-delay : 0.2s;
}
.delay2 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.4s;
	transition-delay : 0.4s;
}
.delay3 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.6s;
	transition-delay : 0.6s;
}
.delay4 {
	-webkit-transition-property: transform,opacity;
	transition-property : transform,opacity;
	-webkit-transition-duration: 1s;
	transition-duration : 1s;
	-webkit-transition-delay: 0.8s;
	transition-delay : 0.8s;
}

.fadein.scrollin,
.fadein_l.scrollin,
.fadein_r.scrollin{
	opacity : 1;
	-webkit-transform : translate(0, 0);
	transform : translate(0, 0);
}