/* screens smaller than 500---------------------------------------------------------- */
	/*---------------------------------------------
commmon
-----------------------------------------------*/

/*  align
-----------------------------------------------------------------------------*/
.align_r { text-align: right; }
.align_c { text-align: center; }
.align_l { text-align: left; }
.valign_m { vertical-align: middle; }
.valign_t { vertical-align: top; }

/*  float 
-----------------------------------------------------------------------------*/

.cb { overflow: hidden; clear: both; }
.cb:after { content: ""; display: block; clear: both; height: 1px; overflow: hidden; }
/*\*/
* html .cb { height: 1em; overflow: visible; }
/**/

/*  title 
-----------------------------------------------------------------------------*/
.top_main_tit{background:url(../image/common/tit_img01.gif) no-repeat 0 4px #EEEEEE; padding:8px 0 8px 18px; margin-bottom:20px; line-height:100%; font-size:120%;}
.top_main_tit2{background:url(../image/common/tit_img01.gif) no-repeat 0 4px #F8FAF7; padding:8px 0 8px 18px; margin-top:10px; line-height:100%; font-size:120%;font-weight: bold;}
.main_title{border-bottom:3px solid #eee; margin-bottom:35px; padding-bottom:20px; font-size:21px; font-weight:normal; line-height:90%;}
.main_tit{background:url(../image/common/main_tit.gif) bottom left no-repeat; padding:0 0 10px 10px; margin-bottom:20px; line-height:100%; font-size:16px; font-weight:bold;}  

/*  box 
-----------------------------------------------------------------------------*/
.box{margin-bottom:25px;}

.banner_list li{margin-bottom:10px;}

/*---------------------------------------------
layout
-----------------------------------------------*/
/*  Wrapper
-----------------------------------------------------------------------------*/
#wrapper{
	width: 320px;
	max-width: 690px;
	margin: 0 auto;
}
	#contents #main {
    width: 100%;
    float: none;
}

#h1_sub{
	display: none;
}

#header {
    width: 100%;
    height: auto;
    background:none;
}

#header #header_wrp {
    width: 100%;
    height: auto;
    background: none;
}

#header #header_wrp #top_header {
    height: 80px !important;
}

#top_header .img_header_logo {
    position: static;
    top: 0;
    left: 0px;
    width: 70%;
    height: auto;
    margin-top: 20px;
    margin-left: 5%;
}

#locator{width:90%; margin:0 auto; text-align:right; padding:15px 0 0px 0;}

#contents {
    width: 90%;
    margin: 0 auto;
    padding-top: 15px;
}

#top_header {width:100%; margin:0 auto; height:73px; position:relative; z-index:99;}
#top_header_wrp #top_header_top_box{width:100%; margin:0 auto;height: 73px;}
#h1_sub {
    font-size: 10px;
    overflow: hidden;
    text-align: left;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 100%;
}


#mainimage{position:absolute; top:0; left:0; width:100%; height:521px; overflow:hidden; z-index:100;}
#mainimage ul li img{width:100%; height:auto; max-width:none !important;}
#mainimage .bx-default-pager{display:none;}


.header_sp {
	display:block !important;
	width:100%;
	height: 84px;
	margin:0;
	padding:0;
	z-index:9000;
	background: rgba(255,255,255,0.9);
}

#sp_nav{
	width:auto;
	display: table-cell;
	float:none;
}
#sp_nav_btn {
	width:45px;
	height:45px;
	background: none;
	margin:0px;
	display:block;
	position:absolute;
	top: 6px;
	right:18px;
	background-image: url(../image/common/sp_nav_btn.png);
	background-repeat:no-repeat;
	background-size:45px 45px;
	background-position:center center;
	text-indent:-9999px;
	cursor: pointer;
}
#sp_nav .sp_nav_close {
	background: url(../image/common/sp_nav_close.png) no-repeat 0 0;
	background-size:45px 45px;
}
.sp_nav_in{
	width: 100%;
	height:auto;
	overflow: hidden;
	margin-top: 14px;
	position:absolute;
	display:block;
	left: 0;
	z-index: 9999;
}
.sp_nav_in ul{
	width:100%;
	display: block;
	display: none;
}
.sp_nav_in li{
	width:100%;
	display:block;
	text-align:left;
	margin:0;
	padding: 0;
	height: auto;
}
.sp_nav_in li a{
	background: rgba(255,255,255,0.9);
	color:#222;
	height: auto;
	display:block;
	padding: 15px;
	font-size: 12px;
	line-height:1.5;
	border-bottom: 1px solid #bcbc8f;
}




.contact_table td{
	display: block;
	width: 100%;
	text-align: center;
}

.contact_table td img{
	max-width: 100%;
	width: auto;
}

#contents #side {
    width: 100%;
    float: none;
    margin: auto;
}

.banner_list li {
    width: 90%;
    margin: 20px auto 10px;

}

#top_header .img_header_side01 {
    position: absolute;
    top: 80px;
     left: 5%; 
    width: 20%;
    height: auto;
}

#top_header .img_header_side02 {
    position: absolute;
    top: 80px;
     left: 30%; 
        width: 20%;
    height: auto;
}

#top_header .img_header_side03 {
    position: absolute;
    top: 80px;
     left: 55%; 
       width: 20%;
    height: auto;
}

#top_header .img_header_side04 {
    position: absolute;
    top: 80px;
     left: 80%; 
        width: 35%;
    height: auto;
}

#footer_company{
	width: 320px;
	max-width: 690px;
	margin: 0 auto;
}

#footer_bottom{
	width: 320px;
	max-width: 690px;
	margin: 0 auto;
}


#footer_navi_wrapper{
width: 320px;
	max-width: 690px;
	margin: 0 auto;
}

#footer_navi {
    width: 100%;
    margin: 0 auto;
}

#footer_company ul {
    width: 100%;
    margin: 0 auto;
}

#footer_company ul .fl {
    width: 90%;
    margin: 0 auto;
    float: none;
}

#footer_company ul .fl img {
    margin: 0 auto;
    width: 100%;
    height: auto;
}

.fr {
    float: none;
    width: 90%;
    margin: 20px auto 0;
}

#footer_company ul .fr img {
    margin: 0 auto;
    width: 100%;
    height: 10px auto;
}

#footer_navi ul {
    padding: 0 6px;
     float: none; 
    width: 100%;
}

#footer_navi ul li {
    background: url(../image/common/yazirusi01.jpg) no-repeat 12px 4px;
    padding: 0 0 9px 22px;
    font-size: 14px;
    line-height: 100%;
    border-bottom: 1px dotted #999;
    margin-bottom: 7px;
}

.page_top img{
	max-width: 100%;
	width: auto;
	height: auto;
}

.page_top {position: fixed; right: 42%; bottom: 20px;}
