/*-------------
 	General
-------------*/

*{
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

html{
	font: normal 16px;
	color: #333;
}

ul, nav{
	list-style: none;
}

a{
	text-decoration: none;
	color: inherit;
	cursor: pointer;
	opacity: 0.9;
}

a:hover{
	opacity: 1;
}



hr{
	width: 150px;
	height: 2px;
	background-color: #2196F3;
	border: 0;
	margin-bottom: 80px;
}

section{
	-js-display: flex;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 40px 80px;
}



@media (max-width: 800px){

	section{
		padding: 40px 30px;
	}

}

section h3.title{
	color: #414a4f;
	text-transform: capitalize; 
	font: bold 32px 'Open Sans', sans-serif;
	margin-bottom: 20px;
	text-align: center;
}

section p{
	max-width: 800px;
	text-align: center;
	margin-bottom: 20px;
	padding: 0 20px;
	line-height: 2;
}

ul.grid{
	width: 100%;
	-js-display: flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}


.img-responsive{
    width:inherit;
    max-width:100%;
    height:auto;
}
.img-responsive-overwrite{
    margin: 0 auto;
}

@media screen and (min-width: 992px) {
	.br-sp { display:none; }
}
@media (max-width: 991px) {
	.br-pc { display:none; }
}


 .mobileHidden { display:none;}
 
@media only screen and (max-width: 767px){ 
    .desktopHidden { display:none;}
    .mobileHidden { display:inline;}
}

/* =======================================
	 margin set
======================================= */
.mt10{
margin-top:10px;
}
.mt20{
margin-top:20px;
}
.mt30{
margin-top:30px;
}
.mt40{
margin-top:40px;
}
.mt50{
margin-top:50px;
}
.mt60{
margin-top:60px;
}
.mt70{
margin-top:70px;
}
.mt80{
margin-top:80px;
}
.mt90{
margin-top:90px;
}
.mt100{
margin-top:100px;
}

/* =======================================
	header
======================================= */
header {
	margin-top: 0px;
} 

.header-logo-mark {
  margin-top: 10px;
  text-align:left;
}
.header-logo-mark h1 {
  margin-top: 0px;
  margin-bottom: 0px;
  text-align:left;
  font-size: 14px;
	font-weight: normal;
}
.header-logo-mark img {
  margin-top: 0px;
}
@media (max-width: 768px) {
	.header-logo-mark {
    text-align:center;
}
	.header-logo-mark h1 {
  text-align:center;
  font-size: 12px;
}
  .header-logo-mark img{
  margin-left: auto;
	margin-right: auto;
}
}
.header-sitename {
  margin-top: 10px;
  text-align:left;
}

@media screen and (min-width: 992px) {
	.br-sp { display:none; }
}
@media (max-width: 767px) {
	.br-pc { display:none; }
}

@media (max-width: 767px) {
.header-sitename img {
    margin-left: auto;
	margin-right: auto;
}
}

.header-rightbox {
  margin-top: 20px;
  padding:0px;
  height:110px;
}
.header-rightbox h1 {
  text-align:right;
  font-size: 14px;
 line-height: 26px;
}
@media (max-width: 991px) {
.header-rightbox h1 {
  text-align:center;
  font-size: 14px;
 line-height: 26px;
}
}



/*----------------
 	Hero Section
----------------*/


.hero{
	padding-top: 0%;
	color: #fff;
	text-align: center;
	width:100%;
}
.hero img{
	width:100%;
}




/*--------------------
 	Our Work Section
---------------------*/

.our-work{
	background-color: #fff;
}



.our-work h2{
 font-family: ‘Georgia’, ‘Hiragino Maru Gothic Pro’, ‘ヒラギノ丸ゴ Pro’, ‘Meiryo’, ‘メイリオ’, ‘MS PGothic’, ‘MS Pゴシック’, sans-serif;
 font-size:16px;
 font-weight:normal;
  line-height:2em;
 color:#333;
	text-align: center;
}

@media (max-width: 991px){
.our-work h2{
 font-size:14px;
  line-height:2em;
}
}




/*--------------0--------
 	Features Section
----------------------*/

.features{
	background-color: #fff;
}

.features .grid li{
	margin: 0 10px;
	padding: 15px 15px;
	flex-basis: 30%;
	background-color: #fff;
	position: relative;
	height:530px;
}



.grid_feature_title{
	width: 100%;
	-js-display: flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}



.features .grid li h4{
	color: #005d8b;
    font-size: 20px;
     margin-top: 15px;
	 margin-bottom: 0px;
	 font-weight:bold;
	text-align: center;
}


.features .grid li p{
	color: #333;
	text-align:left;
	font-size: 14px;
	line-height:1.5em;
	padding-left:0px;
	padding-right:0px;
	margin-bottom:20px;
	padding-bottom: 60px;
}


.features .grid li img{
	margin-top:20px;
	margin-bottom:20px;
    border-radius: 50%;  /* 角丸半径を50%にする(=円形にする) */
    width:  250px;       /* ※縦横を同値に */
    height: 250px;       /* ※縦横を同値に */
}
.features .grid li a img{
	opacity: 0.5;
}
.features .grid li a:hover img{
	opacity: 1;
}
.features .grid li i.link{
    font-size: 14px;
    color: #fff;
    margin-top: 10px;
}



@media (max-width: 991px){
	.features .grid li{
		flex-basis: 100%;
		margin-left:0px;
	margin-right:0px;
	margin-bottom: 40px;
		height:auto;
	}
	.grid_feature_title_left{
	flex-basis: 100%;
	text-align:center;
}
.grid_feature_title_right{
	flex-basis: 100%;
	text-align:center;
}

}


.addressinfo{
	padding-left:30px;
	padding-right:30px;
	position:absolute;bottom: 0;
  left: 0;
  right: 0;
}

@media (max-width: 991px){
	.addressinfo{
	padding-left:10px;
	padding-right:10px;
	position:relative;bottom: 0;
  left: 0;
  right: 0;
}
}


a.btn{
	color: #fff;
	border-radius: 4px;
	background-color: #005d8b;
	font-weight: bold;
	text-align: center;
	padding-left:40px;
	padding-right:40px;
	padding-top:5px;
	padding-bottom:10px;
	margin:10px;
	position:absolute;bottom: 0;
  left: 0;
  right: 0;
}
a.btn:hover{
	color: #fff;
	background-color: #003c62;

}




/*-------------
 	Footer
-------------*/

footer{
	color: #fff;
	background-color: #fff;
	padding: 30px 0;
}

footer .rayoutbox{
	width: 100%;
	-js-display: flex;
	display:inline-flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0 100px;
}
footer .rayoutbox_left{
	flex-basis: 70%;
	text-align: left;
}
footer .rayoutbox_right{
	flex-basis: 30%;
	text-align: right;
}

footer p{
	font-size: 14px;
	color: #333;
	margin-bottom: 10px;
}

footer p a{
	color: #333;
}

@media (max-width: 800px){

	footer{
		padding: 80px 15px;
	}

}


@media (max-width: 800px){
	footer .rayoutbox{
	padding: 0 10px;
}
	footer .rayoutbox_left{
	flex-basis: 100%;
	text-align: center;
}
footer .rayoutbox_right{
	flex-basis: 100%;
	text-align: center;
}
}



/* -- Page top -- */
.pagetop {
    display: none;
    position: fixed;
    bottom: 30px;
    right: 30px;
}
.pagetop a {
    display: block;
    background-color: #005d8b;
    text-align: center;
    color: #fff;
    font-size: 20px;
	line-height:50px;
    text-decoration: none;   
	filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
	border-radius: 50px;
	width: 50px;
	height: 50px;
}
.pagetop a:hover {
    display: block;
    background-color: #003c62;
    text-align: center;
    color: #fff;
    font-size: 20px;
	line-height:50px;
    text-decoration: none; 
	filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}

/* -- Demo ads -- */

@media (max-width: 1200px) {
	#bsaHolder{ display:none;}
}