/*===============================================
●mobile.css  画面の横幅が640pxまで
===============================================*/


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


img{
max-width: 100%;
height: auto;
width /***/:auto;
}
#container{
width:100%;
}


/*------------body------------*/

html {
overflow-y: scroll;
}

body {
font-family: "Meiryo",serif;
font-size: 12px;
line-height: 1.8;
color: #4d4d4d;
}

#wrap{
min-width: 100%;
position: relative;
overflow: hidden;
box-sizing: border-box;
}

a:hover,a li:hover {
filter:alpha(opacity=60);
-moz-opacity: 0.6;
opacity: 0.6;
}

video {display:none;}

/*-------------fede 表示------------*/
.list li {
transition: .8s;
}

.list-mv{
opacity: 0;
transform: translate(0,60px); 
-webkit-transform: translate(0,60px); 
}

.mv{
opacity: 1.0;
transform: translate(0,0); 
-webkit-transform: translate(0,0);
}

.list-mv2{
opacity: 0;
}
.mv2{
opacity: 1.0;
}

/*----------header------------*/

#header {
background: #fff;
display: block;
padding: 0px;
}

.inner-wrap {
width: 100%;
margin: 0;
padding: 0;
}

.inner_header {
overflow: hidden;
position: relative;
padding-top: 0px;
}

p#logo {
text-align: center;
}

/*--------g-navi-------------*/

.menu-nav-container {
display: none;
}

ul#menu-nav {
display: table;
margin: 20px auto;
}

li.menu-item {
display: table-cell;
vertical-align: middle;
font-size: 4vw;
line-height: 1.3;
text-align: center;
}

#menu-nav li {
list-style: none;
}

li.menu-item a {
padding: 8px 16px;
display: block;
position: relative;
border-bottom: 1px solid transparent;
transition: 1s;
}

li.menu-item a:hover {
opacity: 1.0;
border-bottom:solid 1px #4d4d4d;
}

li.menu-item a:after {
}

/*----------検索フォーム----------*/
#searchform {
display:none;
text-align: center;
margin-top: 10px;
margin-bottom: 20px;
}

.screen-reader-text {
display: none;
}

#s{
border: 1px solid #4d4d4d;
margin: 0 0 0 10px;
height: 24px;
width: 210px;
padding: 2px 5px;
}

#searchsubmit{
border: 1px solid #4d4d4d;
background: #4d4d4d;
padding: 6px 20px;
color: #FFFFFF;
font-size: 0.9em;
}

/*--------------breadcrumb----------------*/
#breadcrumb {
display: none;
}

#breadcrumb ul {

}

#breadcrumb li {
display: block;
float: left;
margin-right: 30px;
font-size: 0.9em;
}

span.breadmark {
margin-left: 30%;
}

/*-----------top page main content--------------*/
/*video {display:block;}*/
 
/*#bg-video {
position:fixed;
right:0;
bottom:0;
min-width:100%;
min-height:100%;
width:auto;
height:auto;
z-index:-1;
}*/

#main {
display: block;
height: 100vh;
width: 100vw;
/*height: 600px;*/
position: relative;
}

.main_screen{
transition: 1.6s;
opacity: 1;
height:100%;
width: 100%;
animation-name: fadeInUp;
background: #fff;
}

#top_logo {
position: absolute;
top:40%;
margin-top: -20%;
text-align: center;
width: 100%;
}

#top_logo img{
width: 90%;
}

.text_wrap{
}

h1.copy_title {
opacity: 1;
letter-spacing:-0.1em;
font-size: 4.7vw;
width: 100%;
margin: 20px auto;
line-height: 1.6;
text-align: center;
}

.sub_title {
transition: 0.7s;
font-size: 3vw;
margin: 0 auto;
text-align: center;
}

.topMainbtn{
opacity:1;
margin: 30px auto;
}

.topMainbtn li {
padding: 0;
font-size: 5vw;
font-weight:bold;
height: 80px;
width:100%;
text-align: center;
}

.topMainbtn a {
}

.topMainbtnleft {
margin-top: 50px;
}

.topMainbtnright {
margin-top: 50px;
}


.banarea {
border-top: solid 1px dotted #4b4b4b;
width: 100%;
margin: 0px auto 0px;
background: #fff;
}

.banarea li {
width: 100%;
margin-right: 0px;
text-align: center;
height: 100%;
}

.banarea li img {
width: 60%;
}

.banarea li:last-child {

}

.banarea img {
width: 100%;
height: 100%;
}

/*----------------page content---------------------*/

.contentBody {
}

#page_content_wrap {
width: 100%;
padding: 0;
margin: 0;
}

#page_content_main {
width: 100%;

margin: 30px 0;
}

.page_topImageWrap {
clear: both;
/*background-image: linear-gradient(rgba(254,254,254,0.5), rgba(254,254,254,0.5)),url(images/bg_pageTile1.jpg);
background-position: no-repeat top center;
height: 250px;*/
background: #f2f2f2;
height: 60px;
}

.page_topImage{
height:100%;
width: 100%;
margin:0 auto;
vertical-align: middle;
}

.page_topImage h2 {
display: block;
text-align: center;
vertical-align: middle;
font-size: 1.5rem;
font-weight: 300;
letter-spacing: 0.2em;
line-height: 60px;
}

.entry {
background: #fff;
}

.entry_wrap {
padding: 20px;
}

.post_titleWrap {
background: #e6e6e6;
height: 60px;
vertical-align: middle;
}

.post_title {
width: 980px;
margin: 0 auto;
line-height: 60px;
}

.post_title h2 {
font-size: 1.2rem;
}

.entry_wrap h3 {
padding: .5em .75em;
background-color: #f6f6f6;
box-shadow: 1px 1px 0 rgba(255, 255, 255, .5) inset;
margin-bottom: 20px;
text-align: center;
}

/*------------message page------------*/
.messagePage {
font-size: 0.9rem;
}
.messagePage .articleTitle {
margin-top:25px;
margin-bottom: 15px;
}

.messagePage .subarticleTitle {
margin-top: 30px;
}

.messagePage h3 {
font-size: 5vw;
} 

.messagePage p {
}

.messagePage h4 {
font-size: 4vw;
margin-bottom: 3px;
}

.intro {
margin-bottom: 20px;
}

.messagePage .photo1 {
width: 100%;
}

.messagePage .photo2,.messagePage .photo3 {
width: 100%;
height: 100%;
margin: 0px;
position:relative;
}

.photo2Title {
position:absolute;
top: 8%;
margin-top: 0%;
left: 7%;
font-size: 2.3vw;
z-index:1;
}

.bg_photo2Title img {
position:absolute;
margin-top: 0%;
top: 0%;
left: 0%;
width:25%;
}

.messagePage .photo2 .aligncenter {
margin-top: 15%;
margin-bottom: 1%;
}

.messagePage .photo2 .comment1 {
position:absolute;
top: 25%;
left: 25%;
margin-top: 2%;
font-size: 2.3vw;
text-align: center;
line-height: 1.2em;
height:100%;
}

.messagePage .photo2 .comment2 {
position:absolute;
top: 27%;
right: 11%;
margin-top: 2.2%;
font-size: 2.3vw;
text-align: center;
line-height: 1.2em;
}


.messagePage .photo2 {
/*float:right;*/
width: 100%;
text-align: center;
}

.messagePage .photo3 {
position: relative;
}

.photo3Title {
position:absolute;
top: 9%;
margin-top: 0%;
left: 7%;
font-size: 2.3vw;
z-index:1;
}

.bg_photo3Title img {
position:absolute;
margin-top: 0%;
top: 0%;
left: 0%;
width:25%;
}

.messagePage .photo3 .aligncenter{
margin-bottom: 1%;
margin-top: 12%;
}

.messagePage .photo3 .comment1 {
position:absolute;
top: 25%;
left: 28%;
margin-top: 7.3%;
font-size: 2.3vw;
text-align: center;
line-height: 1.2em;
height:100%;
}

.messagePage .photo3 .comment2 {
position:absolute;
top: 26%;
right: 10%;
margin-top: 6%;
font-size: 2.3vw;
text-align: center;
line-height: 1.2em;
}


.messagePage .photo4 {
position: relative;
}

.messagePage .photo4 .comment1 {
position:absolute;
top:0%;
left:0%;
font-size: 2.5vw;
background: #ddd;
padding: 2% 1% 2% 1%;
font-weight: 600;
}

.messagePage .photo4 .comment2 {
position:absolute;
top:0%;
right:0%;
font-size: 2.5vw;
background: #ddd;
padding: 3.5% 1.5% 3.5% 1.5%;
font-weight: 600;
}

/*----------------service----------------*/
.service video {
display:block;
}

.service p {
padding: 0 10px;
font-size: 0.8rem;
}

.service p.floatLeft {
width: 45%;
padding: 0 0 0 0;
font-size: 2.7vw;
margin-left: 5%
}

.service p.floatRight {
padding: 0 0 0 0;
width: 45%;
font-size: 2.7vw;
margin-right: 2%;
}

.service h3 {
margin-top: 5%;
margin-bottom: 1.5%;
font-size: 1rem;

}

.service h4 {
margin-top: 20px;
text-align:center;
font-size:1.3em;
}

.service .chart {
float:left;
width: 100%;
height: 260px;
}

.service .map {
float:left;
width: 100%;
height: 230px;
font-family: sans-serif;
font-size: 9px;
text-align: right;
}

.service .axis path, .axis line {
fill: none;
stroke: #cccccc;
shape-rendering: crispEdges;
}

.service .axis text {
font-family: sans-serif;
font-size: 12px;
}

.service .zero-axis path {
fill: none;
stroke-width: 0;
}

.service .zero-axis line {
fill: none;
stroke: #666666;
shape-rendering: crispEdges;
}

.service .legend {
font-family: sans-serif;
font-size: 12px;
}

.service .line {
fill: none;
stroke: steelblue;
stroke-width: 2px;
}

.service #chartVd {
width: 100%;
}

.service .contentArticle {
margin-top: 20px;
}

.service .contentArticle p {
margin-bottom: 10px;
}

.service li {
list-style-type: disc;
margin-left: 7%;
}
	
	.service > .bhi {
		width:100%;
		float: left;
	}
	.service > .bhi > article.contentArticle > H5.BHItitle {
		font-size: 1rem;
		margin-bottom: 10px;
		text-align:center;
	}
	.service > .bhi > article.contentArticle > .about_bhi_content {
		font-size: 1em;
		width:100%;
		
	}
	.service > .bhi > article.contentArticle > .bhi_image {
		width: calc(70%);
		margin: 20px auto;
		padding: 0;
		text-align: center;
	}
	.service > .bhi > article.contentArticle > .bhi_image > span {
		font-size: 0.75em;
		padding: 6px 4px;
		border: 1px solid #999;
	}
	.service > .bhi > article.contentArticle > .bhi_image img {
		padding-top: 20px;
	}
	
	.service > p.qlik {
		clear: both;
		font-size: 0.7em;
		line-height: 1.2em;
		margin-top: 30px;
	}
	.service p.qlitek {
		font-size: 0.7em;
	}
	.service p.qlik > img {
		width:55px;
		margin-left: 3px;
		margin-bottom: -6px;
	}
	.service > .bhi_case {
		clear:right;
		width: 100%;
	}
	.service > .bhi_case > .contentArticle > H5 {
		border-top: 20px;
		font-size:1rem;
		text-align: center;
	}
	
	.service > .bhi_case li {
		list-style: none;
		float:left;
		margin: 0;
		width: calc((100% * 1/3) - 10px);
		margin-right: 10px;
	}
	.service > .bhi_case li:last-child {
		margin-right: 0;
	}	
	.service > .bhi_case li p.analysis_title {
		font-size: 0.8rem;
		font-weight: 600;
		background: #f7f7f7;
		text-align:center;
	}
	.service > .bhi_case li p.analysis_content {
		font-size: 0.8rem;
		padding: 0 5px;
		margin-top: 10px;
		height:90px;
	}
	.service > .bhi_case li p.analysis_image {
		text-align: center;
		width: 80%;
	}

/*--------------company----------------*/

.company_post_title {
background: #969696; /* Old browsers */
background: -moz-linear-gradient(top, #969696 0%, #646464 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #969696 0%,#646464 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #969696 0%,#646464 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#969696', endColorstr='#646464',GradientType=0 ); /* IE6-9 */
margin-bottom: 20px;

}

.company_post_title h3{
color: #f0f0f0;
line-height: 50px;
padding: 0 20px;
font-weight: 300;
font-size: 1.3rem;
text-shadow: 1px 1px 2px #333;
text-align: center;
}

.companyData {
font-size: 0.9rem;
margin-bottom:20px;
}

.companyData dt {
font-size: 1rem;
font-weight: bold;
width: 100%;
padding: 20px 0 0 0;
}

.companyData dd {
padding: 0 0 20px 0;
border-bottom: dotted 1px #555;
}

.companyData span {
display: block;
width: 150px;
float: left;
}

.accessTitle {
margin-top: 20px;
}

.accessPara {
padding: 0 10px 10px 10px;
font-size: 0.9rem;
}

.presusImg {
margin: 20px 0;
text-align: center;
}

/*----------------presus page------------*/

.presusTitle {
font-size:1.5em;
font-weight: bold;
}

.presusSubTitle {
font-size: 1.2em;
font-weight: bold;
}

.presusParag {
padding: 0 10px 10px 10px;
}

/*----------------access----------------*/
p.map {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}

p.map iframe,
p.map object,
p.map embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}



/*--------------search page-------------*/

h2.searchTitle {
font-size:1.2rem;
position: relative;
}

h2.searchTitle span {
display: block;
position: absolute;
top:33%;
left:50%;
font-size: 0.9rem;
margin-left: -80px;
}

.single-desc{
padding: 20px 10px;
border-bottom: dotted 1px #4d4d4d;
}

/*----------------sidebar---------------*/

.sidebar {
width: 100%;
margin: 30px 0;
}

.sidebarWrap {
background: #fff;
padding: 20px;
}

.widgettitle {
border-bottom: 3px double #ccc;
font-size: 1.3rem;
}

.wedget_pages ul {
margin: 5px 0;
}

.sidebar .page_item{
position: relative;
padding: 10px 0 10px 20px;
font-size: 0.9rem;
border-bottom: dotted 1px #555;
}

.sidebar .page_item::after{
display: block;
content: '';
position: absolute;
top: 1.3em;
left: 0.5em;
width: 6px;
height: 6px;
border-right: 1px solid #666;
border-bottom: 1px solid #666;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
}

.sidebar .page_item a:hover{
color: #55ae33; 
}

.sidebar .current_page_item a {
color: #f15a24;
}

.sidebar .current_page_item::after {
border-right: 1px solid #f15a24;
border-bottom: 1px solid #f15a24;
}

/*----------------site map--------------*/
.sitemap{
}

.sitemap h3 {
margin: 10px 0 0px 30px;
padding: 0;
background: none;
position: relative;
font-size: 1.1rem;
text-align: left;
}

.sitemap h3::after,.sitemap h3::before {
display: block;
content: '';
position: absolute;
}

.sitemap h3::after {
top: .38em;
left: -1.2em;
width: 14px;
height: 14px;
background-color: #4b4b4b;
border-radius: 100%;
}

.sitemap h3::before {
z-index: 2;
top: .625em;
left: -.975em;
width: 4px;
height: 4px;
border-right: 1px solid #fff;
border-bottom: 1px solid #fff;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
}

.sitemap li {
position: relative;
font-size: 0.9rem;
margin: 0 0 10px 30px;
}

.sitemap li::after {
display: block;
content: '';
position: absolute;
top: .5em;
left: -1em;
width: 5px;
height: 5px;
background-color: #fff;
border: 1px solid #4b4b4b;
border-radius: 100%;
}



/*----------------footer----------------*/

#page-top {
    position: fixed;
    bottom: 10px;
    right: 20px;
    font-size: 77%;
    z-index:9999
}
#page-top a {
    width: 70px;
    padding: 30px 0;
    text-align: center;
    display: block;
}

footer {
clear:both;
display: block;
width:100%;
}

#footer {
background: #424242; /* Old browsers */
background: -moz-linear-gradient(top, #424242 0%, #1e1e1e 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(top, #424242 0%,#1e1e1e 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(to bottom, #424242 0%,#1e1e1e 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#424242', endColorstr='#1e1e1e',GradientType=0 ); /* IE6-9 */

padding: 40px 0;
color: #fff;

}

#footer a {
color: #fff;
list-style: none;
}

.footer_wrap {
overflow: hidden;
width: 100%;
margin: 0 auto;
}

.footer_navlist {

}

.footer_navlist ul {
padding-left: 0;
width:100%;
margin: 0 auto;
}

.footer_nav ul li {
display: block;
vertical-align: middle;
font-size: 0.9rem;
line-height: 1.3;
text-align: center;
width: 100%;
}

.footer_nav ul li a {
padding: 10px;
display: block;
position: relative;
border-bottom: none;
transition: 0.2s;
}

.footer_nav li a::after {
content: "";
position: absolute;
right: 0;
top: 30%;
width:0px;
height: 14px;
background:#fff;
margin-top: 0px;
}

.footer_nav ul li.footerHome a::before {
content: "";
position: absolute;
left: 0;
top: 30%;
width:0px;
height: 14px;
background:#fff;
margin-top: 0px;
}


.sub_footer {
padding: 20px 0;
background: #fff;
color:#4d4d4d;
font-size: 0.8rem;
}

.subfooter_wrap {
width: 100%;
margin:0 auto;
padding: 0;
}

.subfooter_leftnav {
display: block;
width: 100%;
position: relative;
top: 0;
left:0;
margin-left: 0;
margin-bottom: 20px;
}

.subfooter_leftnav li{
width: 100%;
clear:both;
text-align:center;
margin: 0 auto;
margin-bottom: 10px;
}

.copy{
clear: both;
display: block;
margin-top: 0px;
text-align: center;
font-size: 3vw;
}

}

