body{
    font-family:"meiryo","Hiragino Kaku Gothic ProN", sans-serif;
}
p{
/*	font-family: "meiryo","Hiragino Kaku Gothic ProN", sans-serif;*/
}
a{
	text-decoration: none;
	-webkit-transition: all .3s;
	transition: all .3s;
}
h1, h2, h3, h4, h5, h6{
/*	font-family: 'Amiri', serif;*/
}



.fo{
font-family: "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
.slidewrapper {
	position: relative;
	z-index: 1000 !important;
}

/*Header*/
.navbar-default .navbar-nav>li>a {
	color: #333;
}
.navbar-default .navbar-nav>li>a:hover{
	color: #2449a2;
}
header{
	/*background: url(../images/header_bg.jpg);
	background-size: cover;
	background-repeat: no-repeat;*/
}
.section_overlay{
	background: rgba(74, 72, 72, 0.5);
}
.home_text{
	padding-top: 310px;
	padding-bottom: 210px;
}
.home_text h2{
	color: #fff;
	font-size: 38px;
	
	letter-spacing: 13px;
	line-height:50px;
}
.home_text h2 span{
	font-size: 20px;
}
.home_text h3 {
	font-weight: 400;
	font-size: 14px;
	letter-spacing: 2px;
	color: #404040;
}
.home_text ul {
	padding: 0;
	list-style: none;
	margin: 30px 0 0;
}
.home_text ul li {
	margin-bottom: 20px;
}
.home_text ul li a {
	color: #010101;
	border: 1px solid #010101;
	border-radius: 2px;
	padding: 5px 15px;
	transition: all .3s ease;
    -webkit-transition: all .3s ease;
}
.home_text ul li a:hover {
	text-decoration: none;
	background: #fff;
	padding: 7px 17px;
	font-size: 15px;
}
.scroll_down {
	padding-bottom: 50px;
}
.scroll_down h4 {
	font-size: 12px;
	color: #000;
/*	font-family: 'Open Sans', sans-serif;*/
	
}
.scroll_down img:hover {
	animation: shake 0.2s linear infinite;
    -webkit-animation: shake 0.2s linear infinite;
}
@keyframes shake {
    0% { transform: translate(3px, 2px) rotate(0deg); }
    10% { transform: translate(-2px, -3px) rotate(-1deg); }
    20% { transform: translate(-4px, 0px) rotate(1deg); }
    30% { transform: translate(0px, 3px) rotate(0deg); }
    40% { transform: translate(2px, -2px) rotate(1deg); }
    50% { transform: translate(-2px, 3px) rotate(-1deg); }
    60% { transform: translate(-4px, 2px) rotate(0deg); }
    70% { transform: translate(3px, 2px) rotate(-1deg); }
    80% { transform: translate(-2px, -2px) rotate(1deg); }
    90% { transform: translate(2px, 4px) rotate(0deg); }
    100% { transform: translate(2px, -3px) rotate(-1deg); }
}
nav ul li a i {
	transition: all .5s ease;
    -webkit-transition: all .5s ease;
}
nav ul li a:hover i {
	transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
}
nav ul li.nav_facebook a:hover i {
	color: #3b5998; 
}
nav ul li.nav_twitter a:hover i {
	color: #55acee; 
}
nav ul li.nav_google a:hover i {
	color: #dd4b39; 
}
nav ul li {
	position: relative;
/*    font-family: 'Amiri', serif;*/
}
.tooltips {
	opacity: 0;
	position: absolute;
	top: 40px;
	left: 0;
	z-index: 9999;
	width: 100px;
	padding: 5px 0;
  	color: #fff;
  	background: #000;
	text-align: center;
	transition: all .5s ease;
    -webkit-transition: all .5s ease;
}
.tooltips:after {
 	content: "";
  	display: block;
  	position: absolute;
  	left: 25%;
  	top: -4px;
  	border-top: 4px solid transparent;
  	border-left: 4px solid #000;
}
nav ul li:hover .tooltips {
  display: block;
  opacity: 1;
}

/*Services*/
.services{
	margin-top: 50px;
	padding: 0px 0 0;
	
}

.services .container {
	border-bottom: 1px solid #ddd;
	padding-bottom: 90px;
}
.single_service{
	margin-bottom: -14px;
}
.single_service i{
	font-size: 25px;
	color: #f73b56;
}
.single_service h2{
	color: #000000;
	font-size: 20px;
	
}
.single_service p{
	color: #404040;
	font-size: 14px;
	text-align: left;
}
.single_service img {
	opacity: .8;
}
.single_progress_bar .progress {
	height: 1px;
	margin-bottom: 20px;
	overflow: hidden;
	background-color: #d5d5d5;
	border-radius: 0px;
	-webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.1);
	box-shadow: inset 0 1px 2px rgba(0,0,0,.1);
}
.single_progress_bar .progress-bar {
background-color: #2d3334;
}
.single_progress_bar h2{
	color: #000;
	font-size: 16px;
	font-weight: 400;
	line-height: 200%;
}
.single_progress_bar h2#h2{
	color: #000;
	font-size: 17px;
	font-weight: bold;
	line-height: 200%;
}
.single_progress_bar h2 a {
	color: #000;
	text-decoration: none;
}
.about_us_p{
	font-size: 18px;
	color: #272727;
	margin-top: 20px;
	margin-bottom: 10px;
	line-height: 21px;
}
.about_title h2{
	font-size: 25px;
	color: #3d3d3d;
	
	margin-top: 85px;
	letter-spacing: 6px;
	margin-bottom: 21px;
}
.about_title img{
	margin-bottom: 20px;
}
/*Testimonial*/
.testimonial{
		padding-top: 130px;
	padding-bottom: 80px;
}
.testimonial{

}
.testimonial .icon:after{
	content: "";
	position: absolute;
	width: 80px;
	height: 80px;
	background-color: #f73b56;
	top: 110px;
	left: 50%;
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	margin-left: -40px;

}
.testimonial .icon i{
	color: #fff;
	font-size: 47px;
	position: absolute;
	z-index: 555;
	left: 50%;
	margin-left: -23px;
}
.single_testimonial p{
	color: #404040;
	font-size: 15px;
	letter-spacing: 1px;
	padding: 50px 15px;
}

.single_testimonial h4{
	color: #404040;
	font-size: 14px;
	
/*	font-family: 'Montserrat', sans-serif;*/
	letter-spacing: 1px;
	margin-bottom: 40px;
}

/*Googlemap*/

.container.map {
	padding: 30px 0 0;
	border-bottom: 1px solid #ddd;
}
.map .col-md-8 {
	margin-top: 20px;
	margin-bottom: 50px;
}
.youtube {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
}
 
.youtube iframe,
.youtube object,
.youtube embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


/*owl-carousel*/

.owl-carousel .owl-item .imgWrapper {
	height: 210px;
}
.owl-carousel .owl-item img {
	width: 200px;
	height: auto;
	margin: 0 auto;
	border-radius: 200px;
	-webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.owl-carousel .owl-item img:hover {
	width: 210px;
	height: auto;
}

/*Fun Facts*/
.fun_facts{
	background: url(../images/about_bg.jpg) no-repeat;
	background-attachment: fixed !important;
	background-size: cover;
	margin-top: 110px;
}
.fun_facts .section_overlay{
	background: rgba(71,71,71,.8);
	padding-bottom: 30px;
}
.single_count{
padding-top: 120px;	
}
.single_count i{
	color: #f73b56;
	font-size: 24px;
}
.single_count h3{
/*	font-family: 'Amiri', serif;*/
	color: #fff;
	font-size: 23px;
	font-weight: bold;
	margin-bottom: 0px;	
}
.single_count h3#h3{
	margin-bottom: 20px;
}
.single_count p{
/*	font-family: 'Amiri', serif;*/
	color: #fff;
	font-size: 14px;
	
	position: relative;
}
.single_count p:before{
	content: "";
	position: absolute;
	width: 16px;
	height: 1px;
	left: 0;
	bottom: -4px;
	background: #bd9828;
}
.logo{
	position: relative;
	margin-top: -40px;	
}
.logo img{
	width: 100%;
	height: auto;
	margin-top: 30px;
	opacity: .8;
}

.single_image{
	margin-right: 3px;
	position: relative;
	transition: all 1s;
}
.single_image img{
	width: 100%;
}
.single_image a {
	width: 100%;
	height: 100%;
	display: block;
}
.single_image:hover div.image_overlay{
	opacity: 1;
}

.image_overlay{
	position: absolute;
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,.8);
	left: 0;
	top: 0;
	opacity: 0;
	transition: all 1s;
}
.image_overlay .full{
	position: absolute;
	top: 20px;
	right: 20px;
	color: #bd9828;
	border: 1px solid #bd9828;
	border-radius: 30px;
	width: 30px;
	height: 30px;
	line-height: 28px;
	margin: 0;
	padding: 0;
	text-align: center;
	text-decoration: none;
		
}
.image_overlay h2{
	position: absolute;
	bottom: 28px;
	left: 20px;
	font-size: 25px;
	color: #3d3d3d;
	
	letter-spacing: 3px;	
}
.image_overlay h4{
position: absolute;
bottom: 11px;
left: 20px;
color: #3d3d3d;
font-size: 14px;
	
}
.no_padding{
	padding-left: 0px;
	padding-right: 0px;
}
.work_title{}
.work_title h1, .contact_title h1{
	font-size: 25px;
	color: #3d3d3d;
	letter-spacing: 5px;
	padding-top: 80px;
	
	margin-bottom: 20px;
}
.work_title img, .contact_title img{
	margin-bottom: 30px;
}
.work_title p {
	font-size: 14px;
	color: #000;
	margin-bottom: 100px;
}
.last_padding {
	padding-right: 0px;
}
.pad_top {
	padding-top: 2px;
}
.left h2{
	margin-top: 60px;
	margin-bottom: 20px;
	font-size: 18px;
	color: #000;
	font-weight: bold;
}
.left p{
	margin-bottom: 60px;
	font-size: 14px;
	color: #000;
}
.baton{
	margin-top: 85px;
}
.cs-btn, .cs-btn:active, .cs-btn:visited, .cs-btn:focus{
	color: #666;
	background-color: #D6D6D6;
	border-radius: 0px;
	outline: none;
	padding: 10px 40px;
	
	letter-spacing: 2px;
	transition: all 1s;
}
.cs-btn:hover{
	background: #C175FF;
	border-color: #C175FF;
	color: #fff;
}
.call_to_action .container{
	padding-bottom: 60px;
	border-bottom: 1px solid #ddd;
}

#imagelightbox {
    position: fixed;
    z-index: 9999;
}
/* OVERLAY */
#imagelightbox-overlay {
background-color: #fff;
background-color: rgba( 255, 255, 255, .9 ); /* 色と透明度 */
position: fixed;
z-index: 9998;
top: 0;
right: 0;
bottom: 0;
left: 0;
}

/*Contact*/

.single_contact_info{
	padding-bottom: 21px;	
}
.single_contact_info h2{
	
	color: #3d3d3d;
	font-size: 18px;
	letter-spacing: 3px;
	margin-bottom: 1px;	
}

.single_contact_info p{
	font-size: 15px;
	color: #3d3d3d;	
}
section.contact {
	margin-bottom: 60px;
}
.contact .container{
	padding-bottom: 40px;
}
.contact_title p {
	font-size: 14px;
	color: #000;
	margin-bottom: 40px;
}





.contact-form{
background-color: #f5f5f5;
padding: 30px;
}
.contact-form .form-control{
height: 43px;
border-radius: 0px;
margin-bottom: 10px;
border: 0px solid #fff;
}
.contact-form #message{
	height: 205px;
	margin-top: 20px;
}
.form_submit{
	width: 100%;
	background: #D6D6D6;
	border-radius: 0px;
	color: #666;
	padding-top: 13px;
	padding-bottom: 10px;
	transition: all 1s;	
}


.work-with {
padding-bottom: 60px;
padding-top: 10px;
}
.work-with h3{
	font-size: 14px;
	color: #636363;
	
}
span.g-red{color: red;}
.single_contact_info a{color: #000;}
.single_service a{color: #000;}
.thanks{
	margin-top: 50px;
	padding: 60px 0;
}

/*Footer*/
footer{
background: #e5ebfa;

	padding-top: 50px;
	padding-bottom: 50px;
}
.footer_logo{}
.footer_logo img{}
.social{
	padding-top: 65px;
}
.social h2{
	
	font-size: 16px;	
}
ul.icon_list{
	margin: 0;
	padding: 0;
	list-style: none;
	text-align: center;
	margin-top: 20px;
}
ul.icon_list li{
	display: inline;
	padding-left: 3px;
	padding-right: 3px;
}
ul.icon_list li a {
	display: inline-block;
	color: #636363;
	border: 1px solid #636363;
	border-radius: 50%;
	text-align: center;
	width: 30px;
	height: 30px;
	text-align: center;
	line-height: 28px;
	transition: all 1s ease;
    -webkit-transition: all 1s ease;
}
ul.icon_list li a:hover{
	transform: rotate(720deg);
    -webkit-transform: rotate(720deg);
}
ul.icon_list li.ft_facebook a:hover {
	border: 1px solid #3b5998;
}
ul.icon_list li.ft_facebook a:hover i {
	color: #3b5998;
}
ul.icon_list li.ft_twitter a:hover {
	border: 1px solid #55acee;
}
ul.icon_list li.ft_twitter a:hover i {
	color: #55acee;
}
ul.icon_list li.ft_google a:hover {
	border: 1px solid #dd4b39;
}
ul.icon_list li.ft_google a:hover i {
	color: #dd4b39;
}
.copyright_text{
	padding-top: 80px;	
}
.copyright_text a{
	color:#636363;
	text-decoration:none;
	font-size: 12px;
}
.img_responsive {
	width: 100%;
	height: auto;
}

/*Scroll*/

#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 12px;
}
#page-top a {
    background: #2449a2;
    text-decoration: none;
    color: #fff;
    width: 50px;
	height: 50px;
	line-height: 50px;
    text-align: center;
    display: block;
/*	font-family: 'Open Sans', sans-serif;*/
}
#page-top a:hover {
    text-decoration: none;
    background: #639cd8;
	cursor: pointer;
}


@media(max-width: 767px){
	.home_text h2 {
		font-size: 28px;
		letter-spacing: 5px;
	}
	.home_text h2 span{
		font-size: 15px;
	}
	.nav>li {
		font-size: 15px;
	}
	.navbar-brand {
		float: none;
		display: block;
	}
	.navbar-brand img {
		width: 50%;
		height: auto;
		margin-top:-10px;
	}
	nav li.nav_facebook, nav li.nav_twitter, nav li.nav_blog, nav li.nav_line {
		width: 20%;
		float: left;
		text-align: center;
		background: #fff;
		border-right: 1px solid #e7e7e7;
	}
	nav li.nav_facebook a, nav li.nav_twitter a, nav li.nav_google a {
		padding-top: 10px;
		padding-bottom: 10px;
	}
	nav li.nav_google {
		border-right: none;
	}
	.navbar-nav {
  		margin: 0 -15px;
	}
	.navbar-nav>li>a {
		border-bottom: 1px solid #fff;
  		line-height: 30px;
	}
	.container {
		overflow: hidden;
	}
	.services {
		background-size: 100% auto;
	}
	.services .col-md-3 {
		margin-bottom: 40px;
	}
	.container.map {
		padding: 30px 15px;
	}
	.baton {
		margin-top: 30px;
	}
	.single_count {
		padding-top: 30px;
	}
	.single_count h3#h3{
		margin-bottom: 0px;
	}
	.pad_top {
		padding-top: 0px;
	}
	.no_padding{
		padding-top: 2px;
	}
}
 @media screen and (max-width: 600px) {
	.navbar-brand img {
		margin-top:0px;
	} 
}