@charset "UTF-8";

/*================================================
 *  CSSリセット
 ================================================*/
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight:normal;}body{line-height:1}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:none}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0}input,select{vertical-align:middle}

/*================================================
 *  一般・共通設定
 ================================================*/
body {
	width:100%;
	margin:0 auto;
	font-size:14px;
	color:#000;
	font-family:"メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
}

header {
	width:100%;
	margin:10px auto;
}

nav {
	width:100%;
}

#bg1 {
	background:#fff;
}

/* .viewer
------------------------- */
.viewer {
    margin: 0 auto;
    width: 100%;
    position: relative;
    overflow: hidden;
}
.viewer ul {
    width: 100%;
    overflow: hidden;
    position: relative;
}
.viewer ul li {
    top: 0;
    left: 0;
    width: 100%;
    position: absolute;
}
.viewer ul li img {
    width: 100%;
}
 
/* sideNavi
------------------------- */
.viewer .btnPrev,
.viewer .btnNext {
    margin-top: -25px;
    top: 50%;
    width: 50px;
    height: 50px;
    position: absolute;
    z-index: 101;
}
.viewer .btnPrev {
    left: 10px;
    background: #ccc url(../images/nav_prev_on.png) no-repeat center center;
}
.viewer .btnNext {
    right: 10px;
    background: #ccc url(../images/nav_next_on.png) no-repeat center center;
}
 
 
/* =======================================
    ClearFixElements
======================================= */
.viewer ul:after {
    content: ".";
    height: 0;
    clear: both;
    display: block;
    visibility: hidden;
}
 
.viewer ul {
    display: inline-block;
    overflow: hidden;
}

#bg2 {
	padding: 30px 0;
	background:#fff;
}

#bg3 {
	padding: 30px 0;
	background:#e3e2e1;
}

#bg4 {
	padding: 30px 0;
	background:#fff;;
}

#bg5 {
	height: 290px;
 　 position: relative;
    background: url("../images/bg5-g.jpg") no-repeat center;
}



.main {
	width:960px;
	margin:50px auto;
	text-align: center;
}

.main2 {
	width:960px;
	margin:10px auto;
	text-align: left;
}

.boxA {
	width:960px;
	margin:10px auto;
	text-align: center;
}

.boxB {
	width:450px;
	margin:50px auto;
	text-align: center;
}


#contents {
	width:960px;
	margin:10px auto;
}

#main {
	float:right;
	width:65.625%;
}

#sub {
	float:left;
	width:31.25%;
}

#subnav {
	display:none;
}

a {
	text-decoration:none;
	color:#fff;
}
a:hover {
	color:#ccc;
}

h1 {
	color:#fff;
	font-size:28px;
	line-height:1.2;
}
h1 a {
	color:#000;
	text-decoration:none;
}
h1 a:hover {
	color:#e78f00;
	text-decoration:underline;
}

h2 {
	margin-left: 5px;
	margin-bottom:0.5em;
	padding-left:10px;
	font-size:18px;
	color:#000;
	border-left:5px solid #101F3C;
	text-align:left;
}

h3 {
	padding: 0.5em 1em;
    margin: 2em 0;
    font-weight: bold;
    border: solid 1px #333;
	color:#333;
	font-size:18px;
	font-family: "Times New Roman", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, serif;
	border-bottom:1px solid #333;
}

h4 {
	margin-bottom:0.25em;
	font-size:16px;
	color:#333;
}
h4:before {
	content:"\002605";
	color:#f19500;
}

h5 {
	margin-bottom:0.25em;
	padding:2px;
	color:#000;
	font-size:16px;
	border-top:1px dotted #999;
	border-bottom:1px dotted #999;
	background:#f1f1f1;
}

h6 {
	margin-bottom:0.25em;
	color:#382400;
	font-size:14px;
	font-weight:bold;
}

p {
	margin:0 0 1em 0;
	text-align: left;
}

p2 {
	float:left;
	margin:0 0 1em 0;
	text-align: left;
}

img {
	vertical-align:top;
}

em {
	font-weight:bold;
}

strong {
	font-weight:bold;
	color:#f19500;
}

pre {
	margin:1em 0;
	padding:1em;
}

blockquote {
	margin-bottom:1em;
	padding:1em;
	border:1px dotted #ddd;
	border-left:5px solid #ddd;
}

ul,ol,dl {
	margin:0 0 1em 0;
}
ol li {
	list-style:decimal;
}
li {
	text-align:left;
}

dt {
	margin-bottom:0.5em;
	border-bottom:1px dotted #ddd;
}
dt:before {
	content:"\0025a0";
}
dd {
	margin-bottom:1em;
}

table {
	width:100%;
	margin-bottom:1em;
	border-collapse:collapse;
	border:1px solid #ddd;
}
th {
	white-space: nowrap;
	padding:10px;
	text-align:center;
	vertical-align:middle;
	border:1px solid #ddd;
	background:#101F3C;
	color:#fff;
}
td {
	padding:10px;
	text-align:left;
	border:1px solid #ddd;
	background:#fff;
}

td a {
	color:#000;
}

.text br {
  display: none;
}

table.table01 {
	width:100%;
	border-right:#101F3C solid 1px;
	border-collapse: collapse;
}
table.table01 thead th {
	background:#101F3C;
	color:#FFF;
	padding:10px 15px;
	border-right:#FFF solid 1px;
	border-bottom:#FFF solid 1px;
}
table.table01 thead th:last-child {
	border-right:#101F3C solid 1px;
}
table.table01 tbody th {
	background:#101F3C;
	color:#FFF;
	padding:10px 15px;
	border-bottom:#FFF solid 1px;
	vertical-align:top;
	text-align:left;
}
table.table01 tbody tr:last-child th {
	border-bottom:#101F3C solid 1px;
}
table.table01 tbody td {
	background:#FFF;
	padding:10px 15px;
	border-left:#333 solid 1px;
	border-bottom:#101F3C solid 1px;
	vertical-align:top;
}

table.table01 tbody td a {
	color:#007fff;
}

table.table01 tbody td a:hover {
	color:#999;
}

@media screen and (max-width: 767px) {
table.table01 thead {
	display:none;
}
table.table01 tbody th {
	display:block;
}
table.table01 tbody td {
	display:block;
}
table.table01 tbody td::before {
	content: attr(label);
	float: left;
	clear:both;
	font-weight:bold;
}
table.table01 tbody td p {
	padding-left:6em;
}
}

.ggmap {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/*================================================
 *  ヘッダー
 ================================================*/
header {
	position:relative;
}
header h1 {
	margin-bottom:20px;
	margin-left:0px;
}
.summary {
	margin-left:20px;
	text-align: center;
}



/*================================================
 *  グローバルナビゲーション
 ================================================*/

/*================================================
 *  サブコンテンツ
 ================================================*/
.submenu li {
	margin:0;
	padding:0;
	list-style:none;
}
.submenu li a:before {
	content:"\0025a0";
	color:#000;
}


.submenu li a {
	display:block;
	padding:5px 2px;
	color:#000;
	border-bottom:1px dotted #ddd;
	text-decoration:none;
}
.submenu li a:hover {
	background:#eee;
}

.bnr {
	overflow:hidden;
}

.bnr ul {
	overflow:hidden;
}

.bnr li {
	margin:0 0 10px 0;
	padding:0;
	list-style:none;
}
.bnr li a:hover {
	opacity:0.8;
	filter:alpha(opacity=80);
	-ms-filter:"alpha( opacity=80 )";
}
.bnr img {
	width:100%;
}

/*================================================
 *  フッター
 ================================================*/
footer {
	clear:both;
	background-color:#101F3C;
}

.footmenu {
	width:100%;
	padding:20px 0;
	overflow:hidden;
	
}
.footmenu ul {
	position:relative;
	float:left;
	left:50%;
	margin:0;
}
.footmenu li {
	position:relative;
	left:-50%;
	float:left;
	list-style:none;
	margin:0;
	padding:5px 20px;
	font-size:14px;
	text-align:center;
}

.copyright {
	clear:both;
	padding:20px 0;
	font-size:11px;
	text-align:center;
	color:#FFF
}

/*================================================
 *  ページトップへの戻り
 ================================================*/
.totop {
	position:fixed;
	bottom:250px;
	right:15px;
	width: 50px;
    height: 50px;
    border-radius: 25px;
	background: #333;
	text-align:center;
  line-height: 50px;
  vertical-align: middle;
  font-size:30px
}
.totop a {
	display:block;
	text-decoration:none;
}
.totop img {
	background:#000;
}
.totop img:hover {
	background:#ccc;
}

/

/*================================================
 *  写真詳細ページ
 ================================================*/
/* スライドショー */
.slideWrap {
    width:960px;
    margin:0 auto;
}

.slide {
    width:100%;
    overflow:hidden;
    position:relative;
}

.slideInner {
    list-style:none;
    margin:0;
    padding:0;
}
.slideInner li {
    position:absolute;
    width:100%;
    background:#fff;
    margin:0;
    padding:0;
}
.slideInner li img {
    width:100%;
}

.slidePrev {
    position:absolute;
    width:50px;
    height:60px;
    left:0;
    cursor:pointer;
    z-index:100;
}

.slideNext {
    position:absolute;
    display:block;
    width:50px;
    height:60px;
    right:0;
    cursor:pointer;
    z-index:100;
}

.controlNav {
    position:relative;
    float:left;
    left:50%;
    bottom:0;
}
.controlNav span {
    position:relative;
    left:-50%;
    overflow:hidden;
    float:left;
    width:150px;
    height:100px;
    margin:2px;
    vertical-align:middle;
    border:2px solid #fff;
}

.controlNav span img {
    width:100%;
    height:100%;
}
.controlNav span:hover {
    border:2px solid #999;
    cursor:pointer;
}
.controlNav span.current {
    border:2px solid #333;
}

/* トップナビ */
* html .topNavi {
	height:1em;
	overflow:visible;
}

.topNavi {
	overflow:hidden;
	position:relative;
	margin-right:-1.030%;
	margin-top:20px;
	margin-bottom:20px;
}

.topNaviColumn {
	display:inline;
	width:48%;
	float:left;
}

.topNaviCon {
	position:relative;
	display:block;
	box-sizing:border-box;
	overflow:hidden;
	text-decoration:none;
	color:#000;
	transition:background 0s ease 0s, border 0.5s ease-out 0s;
	background-color:transparent;
	border-radius:4px;
}
.topNaviCon:hover {
	color:#000;
	background:#fff9f5 none repeat scroll 0 0;
	border:1px solid #f19500;
	transition:background 0s ease 0s, border 0.5s ease-out 0s;
}
.topNaviCon h2 {
	margin:10px;
	padding:0;
	font-size:14px;
	font-weight:bold;
	color:#f19500;
	border:none;
}
.topNaviCon:hover h2 {
	color:#f19500;
}
.topNaviCon p {
	margin:10px;
}

.topNaviPhoto img {
	width:100%;
}

.topNaviPhoto img:hover {
    opacity: 0.5 ;
}

.blackbox {
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	background:  rgba(0,0,0,0.5);
}

/* 3カラム（スマートフォンでは1カラム) */
.threeCol {
	overflow:hidden;
	margin-bottom:50px;
}
.threeColInner {
	overflow:hidden;
	margin-right:-3%;
}
.threeColInner div {
	width:31%;
	float:left;
	margin-right:2%;
}
.threeColInner div:nth-child(3n+1) {
	clear:both;
}
.threeColInner img {
	width:100%;
	margin-bottom:0.5em;
}

/* ボタン（タイプ1） */
.btn01 a {
	display:block;
	padding:2% 2% 2% 2%;
	color:#fff;
	text-decoration:none;
	background:#101F3C no-repeat;
	transition:all 0.2s ease 0s;
}
.btn01 a:hover {
	background:#2e2e2e no-repeat;
	transition:all 0.2s ease 0s;
}


/*================================================
 *  タブレット向けデザイン
 ================================================*/
/* スクロールバーを考慮して20px大きいサイズで切り替え */
@media screen and (max-width:979px) {
	body {
		box-sizing:border-box;
		width:100%;
		padding:0 0;
	}

	header {
		width:100%;
	}

	nav ul {
			width:100%;
	}

	#contents {
		width:100%;
	}
	
	.main {
		width:100%;
	}
	
	.main2 {
		width:100%;
	}
	
	.contact {
	position:absolute;
	top:60px;
	right:0;
	vertical-align:top;
}

 .slideWrap {
        width:100%;
    }
	
	.boxA {
	width:80%;
	margin:10px auto;
	text-align: center;
}

.boxA img{
	width:100%;
	margin:10px auto;
	text-align: center;
}

}

/*================================================
 *  スマートフォン向けデザイン
 ================================================*/
@media screen and (max-width:767px) {
	.contact {
		position:absolute;
		float:right;
		margin:10px 0;
	}

	header h1 {
		margin-bottom:0;
	}

	#bg5 {
	height: 140px;
 　 position: relative;
    background: url("../images/bg5-g.jpg") no-repeat center;
}

.boxA {
	width:100%;
	margin:10px auto;
	text-align: center;
}

.boxA img{
	width:100%;
	margin:10px auto;
	text-align: center;
}

.boxB {
	width:100%;
	margin:10px auto;
	text-align: center;
}

.boxB img{
	width:70%;
	margin:10px auto;
	text-align: center;
}

.text br {
    display: inline;
  }

 .slideWrap {
        width:100%;
    }
	
	#main {
		float:none;
		width:100%;
	}
		
	.main {
		float:none;
		width:100%;
	}
	
	.main2 {
		float:none;
		width:100%;
	}

	#sub {
		float:none;
		width:100%;
	}

	.bnr ul {
		overflow:hidden;
		margin-right:-2%;
	}

	.bnr li {
		float:left;
		width:48%;
		margin:0 2% 2% 0;
	}

	/* メインメニュー */
	nav {
		display:block;
		position:relative;
		width:100%;
	}
	nav h3 {
		cursor:pointer;
		margin-bottom:0;
		color:#fff;
		background:#999;
		border:none;
	}
	nav h3:after {
		position:absolute;
		content:"\0025bc";
		top:3px;
		right:5px;
	}
	nav h3.menuOpen:after {
		position:absolute;
		content:"\0025b2";
		top:3px;
		right:5px;
	}
	nav ul {
		width:100%;
	}

	nav li {
		width:33.33%;
		margin:0;
		padding:0;
		list-style:none;
	}
	nav li:first-child a {
		width:100%;
	}

	nav li a {
		display:block;
		width:100%;
		border-bottom:1px dotted #ddd;
		text-decoration:none;
	}
	
	
	.threeCol {
		margin-bottom:30px;
	}

	.threeColInner {
		margin-right:0;
	}
	.threeColInner div {
		float:none;
		width:100%;
	}

	/* トップナビ */
	.topNavi {
		margin-right:0;
	}

	.topNaviColumn {
		display:block;
		box-sizing:border-box;
		width:100%;
		float:none;
		margin-right:0;
		margin-bottom:10px;
	}
	

}
