@charset "utf-8";
@media screen and (max-width:768px){
body {
	font-size:14px;
}

img{
	max-width:100%;
}


.only_pc{
	display:none !important;
}
.only_smart{
	display:block !important;
}
.only_smart_i{
	display:inline-block !important;
}

#wrapper{
	min-width:auto;
	min-width:initial;
}


/* header */
header{
	min-width:auto;
	min-width:initial;
	line-height:50px;
}
header > div:first-of-type{
	width:auto;
	line-height:50px;
	margin:auto;
	padding: 0 0 0 5%;
	display: -webkit-flex;
	display: block;
	float:left;
}
header > div:first-of-type > a{
	width:160px;
	display:inline-block;
}
header > div:first-of-type nav{
	position:fixed;
	width:100%;
	top:50px;
	left:0;
	background-color:#fff;
	box-shadow:0 2px 2px rgba(0,0,0,0.2);
	display:none;
}
header > div:first-of-type nav ul{
}
header > div:first-of-type nav ul li{
	display:block;
	margin-left:0;
	border-top:1px solid #ccc;
}
header > div:first-of-type nav ul li a{
	display:block;
	line-height:40px;
	font-size:16px;
}


/* #btnmenu */
#btnmenu{
	width:40px;
	height:42px;
	margin:0;
	padding:0;
	position:fixed;
	right:10px;
	top:5px;
	z-index:103;
	cursor:pointer;
}

#btnmenu span{
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	width: 30px;
	height: 4px;
	border-radius:2px;
	margin: -2px 0 0 -15px;
	background: #e22424;
	-webkit-transition: .2s;
	-moz-transition: .2s;
	-ms-transition: .2s;
	-o-transition: .2s;
	transition: .2s;
}
#btnmenu span:before,
#btnmenu span:after{
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 30px;
	height: 4px;
	background: #e22424;
	border-radius:2px;
	-webkit-transition: .3s;
	transition: .3s;
}
#btnmenu span.scroll,
#btnmenu span.scroll:before,
#btnmenu span.scroll:after{
	background-color:#23738d;
	box-shadow:0 0 1px rgba(255,255,255,0.7);
}

#btnmenu span:before{
	margin-top: -13px;
}

#btnmenu span:after{
	margin-top: 9px;
}
#btnmenu .close,
#btnmenu span.close.scroll{
	background: transparent;
	width:42px;
	height:40px;
	margin-top:-20px;
	margin-left:-20px;
	box-shadow:none
}

#btnmenu .close:before,
#btnmenu .close:after{
	margin-top: 0;
}

#btnmenu .close:before{
	width: 30px;
	height: 4px;
	margin: -2px 0 0 6px;
	border-radius:2px;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
#btnmenu .close:after{
	width: 30px;
	height: 4px;
	margin: -2px 0 0 6px;
	border-radius:2px;
	-webkit-transform: rotate(-135deg);
	transform: rotate(-135deg);
}




/* article */
article{
	padding-top:50px;
}


/* #mv */
#mv{
	padding-bottom:10%;
	position:relative;
}
#mv p{
	width:100%;
	position:static;
	bottom:auto;
	left:auto;
	transform:none;
	margin-top:-5%;
}
#mv p a{
	display:block;
	width:80%;
	max-width:400px;
	min-width:280px;
	line-height:46px;
	margin:auto;
	border-radius:23px;
	border:2px solid #000;
	font-size:18px;
}
#mv p a img{
	width:30px;
	margin-right:5px;
}


/* #cont0 */
#cont0{
	background-size:108% auto;
}
#cont0 h2 img{
	width:40%;
}
#cont0 p{
	width:80%;
	margin:15% auto 0;
	font-size:5.8vw;
}


/* #cont1 */
#cont1{
}
#cont1 > div{
	padding:0 20px 6% 15%;
}
#cont1 > div h2 img:first-child{
	width:30%;
}
#cont1 > div h2 img:last-child{
	width:60%;
}
#cont1 > div ul{
	padding:0;
}
#cont1 > div ul li{
	padding:3%;
}


/* #cont2 */
#cont2{
}
#cont2 > div{
	padding:0 20px 6% 20px;
}
#cont2 > div h2 img:first-child{
	width:60%;
}
#cont2 > div h2 img:last-child{
	width:30%;
}
#cont2 > div dl{
	width:85%;
	margin-right:0;
	padding-left:0;
	display:block;
}
#cont2 > div dl dt{
	padding:10px 10px 0;
	float:none;
}
#cont2 > div dl dd{
	padding:5px 10px 10px;
}
#cont2 > div > img{
	display:block;
	width:85%;
	max-width:420px;
	margin:5% 0 0;
}
#cont2 > div section{
	width:85%;
	margin-top:8%;
	padding:0;
}
#cont2 > div section h3{
	line-height:1.5;
	margin-bottom:3%;
	padding:3%;
	font-size:4vw;
}
#cont2 > div section ul:after{
	content:none;
}
#cont2 > div section ul li{
	width:100%;
	display:block;
	margin-top:5%;
}
#cont2 > div section ul li:first-child a{
	width:90%;
	max-width:360px;
	line-height:40px;
	margin:auto;
	border-radius:20px;
	font-size:4vw;
}
#cont2 > div section ul li a img{
	width:20px;
	margin-right:3px;
}
	#cont2 > div section ul li:last-child a{
		font-size:6vw;
	}


/* #cont3 */
#cont3{
	margin-top:15%;
}
#cont3 > div{
	padding:0 20px 6% 15%;
}
#cont3 > div h2 img:first-child{
	width:30%;
}
#cont3 > div h2 img:last-child{
	width:60%;
}
#cont3 > div dl dt{
	padding:10px 10px 0;
	float:none;
}
#cont3 > div dl dd{
	padding:5px 10px 10px;
}


/* #contact/#confirm/#thanks */
#contact,
#confirm{
	margin-top:15%;
	padding:0 0 20%;
}
#thanks{
	min-height:calc(100vh - 90px);
	margin:0;
	padding:10% 0 20%;
}

#contact h2,
#confirm h2,
#thanks h2{
	font-size:6vw;
}
#contact h2:after,
#confirm h2:after,
#thanks h2:after{
	content:'';
	display:block;
	width:60px;
	height:6px;
	background-color:#eb8383;
	margin:10px auto 0;
}

#contact form > dl,
#confirm dl{
	margin:8% auto;
	padding:0 20px;
	text-align:left;
}
#contact form > dl dt,
#confirm form > dl dt{
	padding-top:0;
	float:none;
	font-weight:bold;
}
#contact form > dl dd,
#confirm form > dl dd{
	margin:5px 0 20px;
	padding-left:0;
}

#thanks p{
	width:90%;
	max-width:500px;
	margin:1.8em auto 0;
	text-align:left;
}


/* footer */
footer{
	line-height:40px;
	font-size:12px;
}


/* top_top */
#topbtn{
	width:40px;
	line-height:40px;
	font-size:18px;
	right:20px;
}


/* #bottom_banner */
#bottom_banner{
	width:100%;
	line-height:50px;
	position:fixed;
	bottom:-60px;
	left:0;
	z-index:101;
	background-color:#424242;
	color:#fff;
	font-size:28px;
	font-weight:bold;
	-webkit-transition: bottom 0.8s;
	transition: bottom 0.8s;
}
#bottom_banner:hover{
	opacity:1;
}
#bottom_banner img{
	width:20px;
	margin-right:5px;
}


}