@charset "utf-8";

* {
	padding: 0;
	margin: 0;
}

html {
  height: 100%;
}

body {
	font-family: "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ ゴシック", "MS Gothic", sans-serif;
	word-wrap: break-word;
	color: #111;
	background-color: #fff;
	height: 100%;
}

.fade {
	opacity: 0;
	filter: alpha(opacity=0);
	-ms-filter: "alpha( opacity=0 )";
	transform: translateY(20px);
	-webkit-transform: translateY(20px);  
    -moz-transform: translateY(20px); 
	-webkit-transition: 1.0s ease-out;
	-moz-transition: 1.0s ease-out;
	transition: 1.0s ease-out;
}

.fade.start {
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: "alpha( opacity=100 )";
	transform: translateY(0px);
	-webkit-transform: translateY(0px);  
    -moz-transform: translateY(0px);    
}


section,
article {
	display: block;
}

img {
	vertical-align: top;
}

a img {

}

a:hover img {
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: "alpha( opacity=50 )";
}


li {
	list-style-type: none;
}

a {
	color: #0077cd;
	-webkit-transition: 0.2s linear;
	-moz-transition: 0.2s linear;
	transition: 0.2s linear;
}
a:hover {
	color: #0099cc;
	text-decoration: none;
}

/*
ヘッダー
-------------------------------------------*/
header {
	width: 100%;
background-color: rgba(255,255,255,0.8);
	position: fixed;
	z-index: 500;
}

header h1 a img {
	display: block;
	position: absolute;
	width:200px;
	font-size:12px;
}

header #social_header{
	width:100%;
	max-width:1200px;
	background:#aff;
}

header #social_btn{
	float:right;
	margin-top:27px;
	margin-right:20px;
}

header #social_btn a{
	letter-spacing: -0.5px;
	font-size:16px;
	color:#000;
	margin-right:4px;
}

header #social_btn a:hover{
	opacity: 0.5;
	filter: alpha(opacity=50);
	-ms-filter: "alpha( opacity=50 )";
}


/*
メインコンテンツ
-------------------------------------------*/
.main {
	width: 100%;
	background-color: #fff;
	padding-top: 50px;
	padding-bottom: 10px;
}

#main_top {
	padding-top: 70px;
}

.contents {
	max-width: 1200px;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}

#main_banner {
	height: 100%;
	width: 100%;
	position: relative;
	overflow: hidden;
}

#main_banner ul.sm-slider {
	position: relative;
}

#main_banner #catch {
	position: absolute;
	top: 37%;
	z-index: 10;
	text-align: center;
	width: 100%;
	color: #fff;
}

#main_banner #catch h2 {
	font-size: 40px;
	letter-spacing: 2px;
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "Sawarabi Mincho", "HG明朝E",  "ＭＳ Ｐ明朝", "MS PMincho", serif;
	font-weight: normal;
	padding-bottom:20px;
	padding-right:20px;
	padding-left:20px;
}

#main_banner #catch p {
	font-size: 30px;
	padding-top:20px;
	padding-right:20px;
	padding-left:20px;
}

#catch h2 img {
	width:100%;
	max-width:570px;
}

.main h3 {
	position: relative;
	font-size: 23px;
	line-height: 30px;
	margin-bottom: 20px;
	font-weight: normal;
	color: #b8860b;
	text-align: center;
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "Sawarabi Mincho", "HG明朝E",  "ＭＳ Ｐ明朝", "MS PMincho", serif;
	padding-top: 0px;
	padding-right: 10px;
	padding-bottom: 0px;
	padding-left: 10px;
	clear: both;
}

.slick_container h3{
	position: relative;
	font-size: 25px;
	line-height: 34px;
	margin-top: 30px;
	margin-bottom: 0px;
	font-weight: normal;
	color: #2e8b47;
	text-align: center;
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "Sawarabi Mincho", "HG明朝E",  "ＭＳ Ｐ明朝", "MS PMincho", serif;
	padding-top: 0px;
	padding-right: 10px;
	padding-bottom: 0px;
	padding-left: 10px;
	clear: both;
}

.main h2 {
	position: relative;
	font-size: 28px;
	line-height: 30px;
	margin-bottom: 40px;
	font-weight: bold;
	color: #111;
	text-align: center;
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "Sawarabi Mincho", "HG明朝E",  "ＭＳ Ｐ明朝", "MS PMincho", serif;
	padding-top: 15px;
	padding-right: 10px;
	padding-bottom: 15px;
	padding-left: 10px;
	clear: both;
}

.main h2::after {
    position: absolute;
    border-bottom: 1px solid #707070;
    width: 40px;
    height: 1px;
    content: '';
    bottom: -5px;
    left: 0;
    right: 0;
    margin: 0 auto;
}

.main p {
	font-size: 16px;
	line-height: 1.8;
	padding: 10px;
	margin-bottom: 20px;
	margin-top: 20px;
	margin-right: 20px;
	margin-left: 20px;
}

/*
画像関係
-------------------------------------------*/

.slick-dots {

}

.slick_container img{
	max-width:500px;
	width:100%;
	height:100%;
}

.float_right {
	float: right;
	max-width:500px;
	padding-right: 30px;
	padding-left: 20px;
	padding-top: 0px;
	padding-bottom: 30px;
}

.float_right img{
	max-width:500px;
	width:100%;
	height:100%;
	margin-top: -12px;
}

/*-----トップへ戻るボタン------*/

.to_top {
	position: fixed;
	right: 20px;
	z-index: 200;
	-webkit-transition: 0.2s linear;
	-moz-transition: 0.2s linear;
	transition: 0.2s linear;
}
.to_top a {
	text-decoration: none;
	color: #fff;
	text-align: center;
	display: block;
	border-radius: 10px;
	-webkit-border-radius: 50px;
	-moz-border-radius: 50px;
	opacity: 0.9;
	filter: alpha(opacity=90);
	-ms-filter: "alpha( opacity=90 )";
	background-color: #000;
	padding: 10px;
	height: 25px;
	width: 25px;
}
.to_top a:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}

/*
フッター
-------------------------------------------*/

footer {
	background-color: rgba(0, 0, 0, 0.6);
	color: #eee;
	clear: both;
	width: 100%;
	display: block;
	padding-top: 15px;
	padding-bottom: 15px;
}

copy {
	font-size: 10px;
	font-style: normal;
	padding-top: 5px;
	padding-right: 10px;
	padding-bottom: 5px;
	padding-left: 10px;
}

footer ul.footer_social {
	display: block;
	float: left;
}
footer .footer_social li {
	display: inline;
}
footer .footer_social li a {
	display: inline-block;
	font-size: 14px;
	padding: 2px;
	text-decoration: none;
	color: #fff;
	opacity: 1.0;
	filter: alpha(opacity=100);
	-ms-filter: "alpha( opacity=100 )";
	margin-left: 10px;
	font-weight: bold;
}
footer .footer_social li a:hover {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}
footer .footer_social li a i {
	padding-right: 5px;
}

.atten {
	color: #f03600;
}




/*
地図
-------------------------------------------*/

.map {
	background-color: #fff;
	padding-right: 20px;
	padding-bottom: 20px;
	padding-left: 20px;
}

.googlemap {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.googlemap iframe,
.googlemap object,
.googlemap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}



@media screen and (min-width:960px){

body {
	font-size: 16px;
}

.sm-slider, .sm-slider::after {
	top: 0px !important;
}

header {
	height: 80px;
	box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px 0px;
	-webkit-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px 0px;
	-moz-box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 3px 0px;
	position: fixed;
	transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
}

header h1 a img {
	top: 17px;
	left: 20px;
}

header.fixed {
	height: 70px;
}

header.fixed h1 a img {
	width:160px;
}
header.fixed .h_btn a,
header.fixed .h_tel a {
	top: 5px;
}

header.fixed #social_btn{

}

header.fixed #social_btn a{
	font-size:14px;
	color:#000;
	margin-right:4px;
}



#main_banner {
	min-height: 850px;
}


/*
フッター
-------------------------------------------*/

copy {
	letter-spacing: 1px;
	text-align: right;
	display: block;
	float: right;
	padding-top: 30px;
	padding-right: 10px;
}

}

@media screen and (min-width:1200px){

header h1 a img {
	left:50%;
	margin-left: -600px;
}

}

@media screen and (max-width:960px){

body {
	font-size: 16px;
}

body.fixed {
	overflow: hidden;
}

img {
	max-width: 100%;
	height: auto;
	width: auto;
	margin-left:auto;
	margin-right:auto;
}

.main h4 {
	margin-right: 10px;
	margin-left: 10px;
}

#main_banner #catch p {
	font-size: 25px;
}

#main_banner #catch {
	position: absolute;
	top: 47%;
	z-index: 10;
	text-align: center;
	width: 100%;
	color: #fff;
}

#catch h2 img {
	width:100%;
	max-width:330px !important;
}

.float_right {
	float: right;
	max-width:330px;
	padding-right: 0px;
	padding-left: 0px;
	padding-top: 0px;
	padding-bottom: 30px;
}

.float_right img{
	max-width:330px;
	width:100%;
	height:100%;
	margin-top: -12px;
}

header {
	height: 52px;
}

header #social_btn{
	float:right;
	margin-top:14px;
	margin-right:20px;
}

header #social_btn a{
	font-size:12px;
	color:#000;
	margin-right:4px;
}

header h1 a img {
	top: 8px;
	left:20px;
	width:150px;
}


/*
フッター
-------------------------------------------*/
copy {
	text-align: center;
	padding-top: 10px;
	display: block;
	clear: both;
}

footer ul.footer_social {
	float: none;
}

footer .footer_social li a {
	font-size: 12px;
	padding: 3px;
}


}

@media screen and (max-width:640px){

header h1 a img {
	top:9px;
	width:150px;
}

#main_top {
	padding-top: 70px;
}

#main_banner #catch h2 {
	font-size: 40px;
}

#main_banner #catch p {
	font-size: 22px;
}

#catch h2 img {
	width:100%;
	max-width:230px !important;
}

.float_right {
	float: none;
	max-width:640px;
	padding-right: 0px;
	padding-left: 0px;
	padding-top: 0px;
	padding-bottom: 0px;
}

.float_right img{
	max-width:640px;
	width:100%;
	height:100%;
	margin-top: -12px;
}

.main {
	padding-top: 20px;
	padding-bottom: 20px;
}

.main p {
	margin-bottom: 20px;
	margin-top: 10px;
	margin-right: 10px;
	margin-left: 10px;
}


}

@media screen and (max-width:460px){

input,
textarea {
	max-width: 300px !important;
}

#main_banner #catch h2 {
	font-size: 30px;
}

.main h3 {
	font-size: 19px;
	letter-spacing: 0px;
	padding-bottom: 5px
}

.main h2 {
	font-size: 22px;
	letter-spacing: 0px;
	padding-bottom: 5px
}
.main h2 span {
	font-size: 12px;
}

.slick_container {
	margin-top:-10px;
	margin-bottom:-20px;
}

}