@charset "utf-8";


/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td {
	border: 0;
	font-family: inherit;
	font-size: 100%;
	font-style: inherit;
	font-weight: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	vertical-align: baseline;
}

:focus {
	outline: 0;
}

ol,
ul {
	list-style: none;
}

table {
	border-collapse: separate;
	border-spacing: 0;
}

caption,
th,
td {
	font-weight: normal;
	text-align: left;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: "";
}

blockquote,
q {
	quotes: "" "";
}

a img {
	border: 0;
}

figure {
	margin: 0
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

/* -------------------------------------------------------------- */

body {
	color: #333;
	font-size: 14px;
	font-family: "ヒラギノ丸ゴ ProN W4", "Hiragino Maru Gothic ProN", "Meiryo", Sans-Serif;
	line-height: 1.5;
	background: #fff;
	-webkit-text-size-adjust: 100%;
}

html {
	background: #fff;
}


/* リンク設定
------------------------------------------------------------*/
a {
	color: #5a6f2e;
	text-decoration: none;
	font-weight: bold;
}

a:hover {
	color: #354a08;
	font-weight: bold;
}

a:active,
a:focus {
	outline: 0;
}


/* 全体
------------------------------------------------------------*/
#wrapper {
	margin: 20px auto;
	padding: 0 1%;
	width: 98%;
	position: relative;
}

.inner {
	margin: 0 auto;
	width: 100%;
}


/*************
/* ヘッダー
*************/
h1 {
	font-size: 13px;
	line-height: 1.6;
	font-weight: normal;
	color: #696969;
	background-color: #fff;
}

#header {
	overflow: hidden;
	color: #696969;
	background: #fff;
}

* html #header {
	height: 1%;
}


/*************
/* ロゴ
*************/
#header .logo {
	float: left;
	padding: 6px 0px 0px 0px;
}

#header a {
	color: #696969;
}

#header a:hover {
	color: #354a08;
}

.logo a {
	font-size: 16px;
	font-weight: bold;
	line-height: 1;
	color: #696969;
}

.logo span {
	font-size: 15px;
	font-weight: bold;
	color: #ffa500;
}

.info {
	float: right;
	padding: 10px 0px 0px 0px;
	font-size: 13px;
	font-weight: bold;
	line-height: 1.7;
}

.tel strong {
	font-size: 13px;
	font-weight: bold;
}

/**************************
/* トップナビゲーション
**************************/
ul#topnav {
	clear: both;
	overflow: hidden;
	margin: 0 auto;
	background: #5a6f2e;
	border-radius: 5px 5px 0 0;
}

* html ul#topnav {
	height: 1%;
}

ul#topnav li {
	float: left;
	text-align: center;
}

ul#topnav a {
	width: 156px;
	font-size: 14px;
	font-weight: normal;
	display: block;
	padding: 10px 0;
	color: #eee;
	border-left: 1px solid #354a08;
}

ul#topnav li:first-child a,
ul#topnav li:last-child a {
	width: 155px;
}

ul#topnav li.active a {
	color: #ccc;
}
ul#topnav a:hover {
	color: #fff;
}


/**************************
/* メイン画像（トップページ+サブページ）
**************************/
#mainBanner {
	clear: both;
	line-height: 0;
	background: linear-gradient(#fff, #fff, #dcdcdc);
}

#mainBanner .inner {
	position: relative;
}

#mainBanner img {
	max-width: 100%;
	height: auto;
}

.slogan {
	position: absolute;
	max-width: 100%;
	height: auto;
	bottom: 10px;
	left: 10px;
	padding: 5px 10px;
	line-height: 1.4;
	z-index: 100;
}

.subImg .slogan {
	left: auto;
	right: 10px;
}

.slogan h2 {
	padding-bottom: 5px;
	color: #8b4513;
	font-size: 14px;
	font-weight: bold;
}

.slogan h3 {
	font-size: 12px;
	color: #000000;
}


/**************************
/* グリッド
**************************/
.gridWrapper {
	clear: both;
	padding: 10px 0px 10px 0px;
	overflow: hidden;
}

.gridWrapper2 {
	clear: both;
	padding: 20px 0px 0px 0px;
	overflow: hidden;
}

.gridWrapper3 {
	clear: both;
	padding: 20px 0px 10px 0px;
	overflow: hidden;
}

* html .gridWrapper {
	height: 1%;
}

.grid {
	float: left;
}

.back-to-top {
	float: right;
	background-color: #5a6f2e;
	color: #fff;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	padding-right: 10px;

}

.colDark,
.colLight {
	padding-bottom: 10px;
	color: #333333;
	background: #f0f8ff;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}

.colLight {
	background: #fffff0;
}

.colDark h2,
.colLight h2 {
	margin: 10px 10px 5px 10px;
	font-size: 15px;
	font-weight: bold;
	border-bottom: 1px solid #696969;
}

.colDark h3,
.colLight h3 {
	margin: 10px 10px 5px 10px;
	font-size: 15px;
	border-bottom: 1px solid #696969;
}

.colDark a,
.colLight a {
	display: block;
	color: #696969;
}

.colDark a:hover,
.colLight a:hover {
	color: #354a08;
}

.grid p {
	padding: 5px 15px 2px 10px;
}

.grid ul {
	margin: 5px 10px;
	font-size: 13px;
}

.grid li {
	padding: 5px 0;
	list-style: inside;
	border-bottom: 1px dashed #ebebeb;
}

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

/* フッター内のグリッド(3カラム) */
#footer .grid {
	color: #fff;
	background: transparent;
}

#footer .copyright {
	color: #ccc;
	background: transparent;
}

#footer .col3 ul {
	margin: 0 0 10px 5px;
	text-align: left;
}

#footer .col3 li {
	padding: 0 7px 0 5px;
	margin-bottom: 3px;
	list-style: none;
	border-bottom: 0;
	display: inline-block;
	border-right: 1px solid #fff;
	line-height: 1.4;
}
#footer .col3 a {
	color: #eee;
	font-weight: normal;
}

#footer .col3 a:hover {
	color: #fff;
	font-weight: normal;
}

/*************
メイン コンテンツ
*************/
section.content {
	margin-bottom: 20px;
	font-size: 15px;
	line-height: 1.7;
	overflow: hidden;
}

* html section.content {
	height: 1%;
}

section.content p {
	padding: 0 5px;
	margin-bottom: 17px;
}

h2.heading,
#sub .grid h2 {
	padding: 5px 10px;
	margin-bottom: 10px;
	font-size: 16px;
	color: #fff;
	background: #5a6f2e;
	border-left: 7px solid #354a08;
	border-right: 7px solid #354a08;
}

h3.heading,
#sub .grid h3 {
	padding: 5px 10px;
	margin-bottom: 10px;
	font-size: 16px;
	color: #fff;
	background: #5a6f2e;
	border-left: 7px solid #354a08;
	border-right: 7px solid #354a08;
}

h4 {
	padding: 10px 0 0 6px;
	font-size: 14px;
	line-height: 1;
	font-weight: bold;
	color: #808080;
}

h5 {
	padding: 10px 0 0 10px;
	font-size: 14px;
	line-height: 1;
	font-weight: bold;
	color: #ff0000;
}

.hr2 {
	border: 0;
	height: 1px;
	margin-left: 0;
	width: 97%;
	background-color: #ccc;
}

.hr3 {
	border: 0;
	height: 1px;
	background-color: #ccc;
}

#sub .grid h3 {
	margin-right: 10px;
}

.alignleft {
	float: left;
	clear: left;
	margin: 3px 10px 10px 5px;
}

.alignright {
	float: right;
	clear: right;
	margin: 3px 5px 10px 10px;
}

img.frame,
#gallery img {
	border: 4px solid #fff;
	box-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
	-webkit-box-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
}

#gallery .gridWrapper {
	padding: 0;
}

#gallery img {
	margin: 5px;
}

section#gallery {
	overflow: visible;
}

.new{
color: #ff4500;
font-weight: bold;
}

/*************
テーブル
*************/
table.table {
	border-collapse: collapse;
	width: auto;
	margin: 15px 5px;
}

table.table th,
table.table td {
	padding: 5px;
	border: 1px solid #fff;
}

table.table tr:first-child th,
table.table tr:first-child td {
	border-top: #fff 1px solid
}

table.table th {
	letter-spacing: 1px;
	white-space: nowrap;
	color: #696969;
	font-weight: bold;
	background: #eee;
}

table.table2 {
	border-collapse: collapse;
	width: auto;
	margin: 15px 5px;
}

table.table th2,
table.table td {
	padding: 5px;
	border: 1px solid #fff;
}

table.table tr2:first-child th,
table.table tr2:first-child td {
	border-top: #fff 1px solid
}

table.table2 th {
	letter-spacing: 1px;
	white-space: nowrap;
	color: #696969;
	font-weight: bold;
	background: #eee;
}

/*************
/* フッター
*************/
#footer {
	clear: both;
	padding: 5px 0;
	overflow: hidden;
	background: linear-gradient(#5a6f2e, #5a6f2e, #354a08);
	border-top: 3px solid #354a08;
}

* html #footer {
	height: 1%;
}

#footer a {
	color: #eee;
}

#footer a:hover {
	color: #fff;
}

#footer .copyright a {
	color: #ccc;
	font-weight: normal;
}

#footer .copyright a:hover {
	color: #c0c0c0;
	font-weight: normal;
}

#footer .copyright {
	font-size: 12px;
	text-align: right;
	padding-right: 8px;
}

.hr1 {
	border: 0;
	height: 1px;
	background-color: #eee;
}

/* PC用 */
@media only screen and (min-width:960px) {

	#wrapper,
	.inner,
	ul#topnav {
		width: 940px;
	}

	#wrapper {
		padding-bottom: 20px;
	}

	#main {
		float: right;
		width: 690px;
	}

	#subpage #sub {
		float: left;
		width: 235px;
		overflow: hidden;
	}

	/* グリッド */
	.grid {
		width: 235px;
	}

	.col2 {
		width: 470px;
	}

	.col3 {
		width: 705px;
	}

	#gallery .grid {
		width: 230px;
	}

	#subpage #sub .grid {
		width: 100%;
		float: none;
		padding-bottom: 30px;
	}
}


/* モニター幅959px以下 */
@media only screen and (max-width:959px) {
	h1 p.inner {
		padding: 0 2%;
		width: 96%
	}

	#header .logo {
		padding-left: 10px;
	}

	#header .info {
		padding-right: 10px;
	}

	ul#topnav {
		clear: both;
		width: 100%;
	}

	ul#topnav li {
		width: 33%;
		border-right: 1px solid #354a08;
		border-bottom: 1px solid #354a08;
		box-sizing: border-box;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
	}

	ul#topnav li:nth-child(3n) {
		border-right: 0;
		width: 34%;
	}

	ul#topnav li a {
		width: 100%;
		border: 0;
	}

	ul#topnav li:first-child a,
	ul#topnav li:last-child a {
		width: 100%;
	}

	.grid {
		width: 50%;
		margin: 2px 0;
	}

	.col2 {
		float: none;
		width: 100%;
		margin: 0 0 20px;
	}

	.grid img {
		float: left;
		margin-right: 5px;
	}

	#gallery .grid {
		width: 31%;
		margin: 0 1%;
		padding: 0;
	}

	#gallery .grid img {
		float: none;
	}

	section.content {
		padding: 0 10px;
	}

	section.content img {
		max-width: 90%;
		height: auto;
	}

	#sub .grid {
		padding-bottom: 0px;
	}

	#footer {
		padding: 0;
	}

	#footer .grid {
		float: none;
		width: 100%;
		text-align: left;
	}

#footer .copyright {
		margin-bottom: 5px;
	}
}


/* スマートフォン 横(ランドスケープ) */
@media only screen and (max-width:640px) {
	.grid {
		width: 100%;
	}

	.grid img {
		float: none;
		margin: 0px auto 0px;
	}

	.grid p {
		text-align: left;
	}

	img.frame,
	#gallery img {
		border-width: 2px;
	}

	.alignleft,
	.alignright {
		float: none;
		display: block;
		margin: 0 auto 10px;
	}

	#footer .grid p {
		text-align: left;
	}
	
	#footer .copyright {
		margin-bottom: 5px;
	}
}


/* スマートフォン 縦(ポートレート) */
@media only screen and (max-width:480px) {
	#header .logo {
		padding-top: 6px;
	}

	.info {
		padding: 8px 0 0;
	}

	ul#topnav li {
		width: 50%;
	}

	ul#topnav li:nth-child(3n) {
		border-right: 1px solid #354a08;
		width: 50%;
	}

	ul#topnav li:nth-child(2n),
	ul#topnav li:nth-child(6n) {
		border-right: 0;
	}

	#mainBanner h2,
	#mainBanner h3 {
		font-size: 80%;
	}
	
	#footer .copyright {
		margin-bottom: 5px;
	}
}