@charset "utf-8";

@-ms-viewport {
  width: device-width;
}

@viewport {
  width: device-width;
}


@media screen and (max-width:768px){

* {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
	
.pc{display:none!important;}
.sp{display:block!important;}	


/*common
----------------------------------------------------*/
body {
	font-size:3.4vw;
}

.contents{
	width:90%;
	padding:12vw 0;
}

.btn_more,
.btn_more:link,
.btn_more:active,
.btn_more:visited {
  display: inline-block;
  margin:0 auto;
  padding: 4vw 6vw;
}

.btn_more::after {
  height: 12px;
  width: 6px;
  margin: 0 0 0 10px;
  background: url(../img/btn_next.png) no-repeat;
	background-size: 6px;
}

.btn_more:hover::after {
	margin-left: 15px;
	margin-right:-5px;
	background: url(../img/btn_next_b.png) no-repeat;
	background-size: 6px;
}

.mt80{ margin-top:12vw!important; }


/*header
----------------------------------------------------*/
header{
	height:80vw;
	margin-top:46px;
	background: url(../img/bg_main_sp.jpg) no-repeat center / cover;
}

header .header{
	height:46px;
	padding:10px 0;
}

header h1{
	width:40%;
}

header h1.w20per{
	width:30%!important;
}


/*sp button
-------------------------------------------------*/
#triggerBox{
    top: 2px;
    right: 10px;
}


/*navigation
-------------------------------------------------*/
#headIn{
	overflow: auto;
	position: fixed;
	height:100%;
	left: 0px;
	top: 0px;
	right: 0px;
    background: rgba(0,0,0,.85);
	background-size:100% 100%;
    -webkit-overflow-scrolling: touch;
    z-index: 10000;
}

header #headIn nav ul{
	position:absolute;
	top:0;
	bottom:0;
	margin:auto;
	height:96vw;
}

header #headIn nav ul li a{
    font-size: 5.4vw;
}


/*common
----------------------------------------------------*/
h2{
	margin-bottom:6vw;
	font-size:8vw;
}

h2 span{
	font-size:4vw;
}


/*sec01
----------------------------------------------------*/
.sec01 h2{
	font-size:6vw;
}


/*sec02
----------------------------------------------------*/
.bg_sec02{
	padding:12vw 0;
	display:block;
}

.sec02 h2{
	position:relative;
	float:none;
	width:100%;
	height:auto;
	margin:0 auto 6vw auto;
	text-align:center;
}

/*.sec02 .box_right{
	float:none;
	width:100%;
	padding:0 8vw;
}*/


#slider {
    width:100%;
	height:auto;
}

#sliderInner {
    left:50%;
    width:300%;
    margin-left:-150%;
}

#sliderInner li {
    /*width:100%;*/
	width:100vw;
	height:auto;
}
.bx-wrapper .bx-pager {
    width:100%;
}

.bx-wrapper .bx-prev,
.bx-wrapper .bx-next{
	display:none;
}

.bx-wrapper .bx-controls-direction a {
    top:140px;
}


/*sec03
----------------------------------------------------*/
.sec03 h3{
	margin-top:8vw;
	margin-bottom:6vw;
	font-size:4.7vw;
}

.sec03 ul li{
	float:left;
	width:48%;
	margin:0 4% 8% 0;
}

.sec03 ul li:nth-of-type(3n){
	margin-right:4%;
}

.sec03 ul li:nth-of-type(2n){
	margin-right:0;
}


/*sec04
----------------------------------------------------*/
.sec04 h2{
	float:none;
	width:100%;
	text-align:center;
}

.sec04 h3{
	margin-bottom:3vw;
	padding:1vw 3vw;
}

.sec04 h4{
	margin-bottom:1vw;
	padding-bottom:1vw;
}

.sec04 .box_right{
	float:none;
	width:100%;
}

.sec04 .box_right table{
	width:100%;
	margin-bottom:6vw;
}

.sec04 .box_right table th{
	width:auto;
	min-width:auto;
}

.sec04 .box_right table td{
	min-width:auto;
	text-align:right;
	word-break:keep-all;
}

.sec04 .kakomi{
	padding:3vw 6vw;
}


/*sec05
----------------------------------------------------*/
.sec05 h2{
	float:none;
	width:100%;
	text-align:center;
}

.sec05 .box_right{
	float:none;
	width:100%;
}

.sec05 .box_right .tel{
	padding:4vw 0;
	text-align:center;
}

.sec05 .box_right p{
	text-align:center;
}

.sec05 .box_right p span{
	font-size:8vw;
}

.sec05 .box_right dl{
	background:#EEE;
}

.sec05 .box_right dl dd{
	padding:10px 0 10px 1em;
}

.sec05 .box_map p{
	padding:0.5em 3%;
}

#map{
	height:80vw;
}


/*sec06
----------------------------------------------------*/
.sec06 table{
	width:100%;
}

.sec06 table th,
.sec06 table td{
	width:100%;
	display:block;
}

.sec06 input[type="submit"]{
	font-size:4.4vw;
}


/*footer
----------------------------------------------------*/
footer .contents{
	padding-bottom:18vw;
}

footer .box_left{
	float:none;
	width:100%;
	margin-bottom:8vw;
}
footer .box_right{
	float:none;
	width:320px;
	margin:0 auto 2vw auto;
	overflow:hidden;
}

footer .center .box_left{
	margin-bottom:8vw;
}

footer h2,
footer .center h2{
	width:65%;
	margin:0 auto 3vw auto;
}

footer .center h2.w10per{
	width:30%!important;
}

footer .box_left .tel{
	padding:4vw 0;
	text-align:center;
}

footer .box_left p span{
	font-size:8vw;
}

footer .box_left dl{
	margin-bottom:0.5em;
	background:#333;
}

footer .center .box_left dl{
	width:70vw;
}

footer .box_left dl dt{
	width:6em;
	background:#FFF;
	font-size:1.4rem;
	text-align:center;
	color:#000;
}

footer .box_left dl dd{
	padding-left:1em;
}

footer .box_left p a{
	padding:1em 0;
	color:#FFF;
	text-decoration:underline;
	display:inline-block;
}

footer .tel a{
	text-decoration:none!important;
}

footer .center .box_right ul li img{
	width:70%;
}

footer .sp{
	padding:40px 0;
	font-size:3.0vw;
	text-align:center;
}

footer .sp a{
	padding:1em 0;
	color:#FFF;
	text-decoration:underline;
	display:inline-block;
}


/*page top
----------------------------------------------------*/
#page-top a{
	width:40px;
	height:40px;
}

}