@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 {
	font-size:16px;
	color:#333;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳＰ明朝", "MS PMincho", "ＭＳ明朝", "MS Mincho", serif;
	line-height:1.8;
	background-color: #fff;
background-image: url(../images/back.jpg);
background-repeat: repeat;
}

/*================================================
 *  ヘッダー
 ================================================*/
header {
	padding:10px 0 0;
	height: 110px;
	box-sizing:border-box;
	position:relative;
	width:100%;
}
.inner {
	position:relative;
	width:1200px;
	margin:0 auto;
}

.summary {
	position:absolute;
	top:0;
	right:10px;
	margin:0;
	font-size:12px;
}

nav {
width: 100%;
background-color: rgba(255,255,255,0.7);
⁄zoom: 1;
}
nav:after {
	content:'';
	display:block;
	clear:both;
}

#contents {
	overflow:hidden;
	width:1200px;
	margin:0 auto 10px;
}

#main {
	box-sizing:border-box;
	overflow:hidden;
	float:left;
	width:68%;
}

.main_wide {
	box-sizing:border-box;
	overflow:hidden;
	width:100%;
}
.content {
	box-sizing:border-box;
	overflow:hidden;
	width:100%;
	margin:0 0 20px;
}
.content p {
	padding:0 10px;
}
.content2 {
	box-sizing:border-box;
	width:100%;
	margin:0 0 20px;
}

#sub {
	box-sizing:border-box;
	overflow:hidden;
	float:right;
	width:28%;
}

footer {
	box-sizing:border-box;
	width:100%;
	margin:0 auto;
}

a {
	color: #0074FF;
	text-decoration: none;
}
a:hover {
	color: #FF4000;
	text-decoration: none;
}

	hr {
		border: none;
		border-top: 3px double #333;
		color: #333;
		overflow: visible;
		text-align: center;
		height: 5px;
	}
 
	hr:after {
		content: '　';
		padding: 0 4px;
		position: relative;
		top: -16px;
	}

#contents a img, header a img  {
-webkit-transition: opacity 0.5s ease-out;
-moz-transition: opacity 0.5s ease-out;
-ms-transition: opacity 0.5s ease-out;
transition: opacity 0.5s ease-out;
}
#contents a:hover img, header a:hover img {
opacity: 0.5;
-webkit-opacity: 0.5;
-moz-opacity: 0.5;
filter: alpha(opacity=50);	/* IE lt 8 */
-ms-filter: "alpha(opacity=50)"; /* IE 8 */
}

#top_logo a {
	width:400px;
	height: 90px;
	position:absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	margin: 0 auto;
	padding:0;
	background-image: url(../images/top_logo.svg);
	display: block;
	z-index: 6;
	text-indent: -9999px;
	background-size: cover;
}
#logo a {
	width:400px;
	height: 85px;
	position:absolute;
	top:5px;
	left:10px;
	margin: 0;
	padding:0;
	background-image: url(../images/logo.svg);
	display: block;
	z-index: 6;
	text-indent: -9999px;
	background-size: cover;
}h1 {
font-weight: normal;
line-height: 1.5;
}
h1.noimage {
margin: 1em 0;
padding: 0;
font-size: 36px;
word-spacing: 0.3em;
text-align: center;
}
h1 img {
	width:100%;
	height: auto;
	margin:0 auto 25px;
	padding:0;
}

h2 {
margin-bottom: 0.5em;
padding: 0;
font-size: 27px;
color: #333;
font-weight: normal;
word-spacing: 0.2em;
line-height: 1.3;
}

h3 {
margin-bottom: 0.5em;
padding: 0;
font-size: 22px;
font-weight: normal;
line-height: 1.2;
}

h4 {
	margin-bottom: 0.4em;
	padding: 0 8px;
	font-size: 18px;
	color: #555;
	line-height: 1.2;
	font-weight: normal;
}

h4.titlelist {
	margin: 0 0 0.4em;
	padding: 0;
	font-size: 15px;
	color: #666;
	line-height: 1.3;
	font-weight: bold;
	text-align: center;
}
.titlelist2 {
	margin: 0 0 0.4em;
	font-weight: bold;
    padding: 0.3em 0.8em;
    text-decoration: none;
	font-size: 15px;
    color: #fff;
    background: #2e2e2e;
    border-radius: 15px;
    transition: .4s;
	text-align: center;
	display: inline-block;
}
p.sub {
	margin: 0.2em 0 0.3em;
	padding: 0;
	font-size: 90%;
	font-weight: nomal;
}

h5 {
	position:relative;
	margin-bottom:0.25em;
	padding-left:10px;
	color:#044eaa;
	font-size:14px;
	font-weight:bold;
}
h5:before {
	content:"";
	margin-top:-7px;
	position:absolute;
	top:50%;
	left:0;
	width:5px;
	height:14px;
	background:#5f8e1f;
}

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

p {
	margin:0 0 1em 0;
}
p.center {
	margin: 0 0 1em 0;
	text-align: center;
}
p.contline {
	margin: 0 0 1.5em 0;
	padding-bottom: 5px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
}
.dup_price {
	color:#000;
	font-size:14px;
	font-weight:bold;
}
img {
	vertical-align:bottom;
	max-width: 100%; 
    height:auto;
}

em {
	font-weight:bold;
}

strong {
	font-weight:bold;
	color:#2e2e2e;
	font-size:110%;
}

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;
}

dl {
	padding: 5px 10px;
	list-style: none;
	line-height: 1.4;
	display: block;
	border-bottom: 1px solid #C0C0C0;
}
dt {
	float: left;
	width: 8em;
	margin: 0;
	font-size: 90%;
}

dd {
	margin: 0 0 0 8em;
	padding: 0;
	vertical-align: middle;
}
dt img {
	margin: 0;
	padding: 0 0 0 3px;
	vertical-align: middle;
}
dd img {
	margin: 0;
	padding: 0 0 0 5px;
	float:right;
}
dd:after {
  content:'';
  display:block;
  clear:both;
}

dl.price {
	padding: 5px 10px;
	list-style: none;
	line-height: 1.4;
	display: block;
	background: none;
}
dl.price dt {
	float: left;
	width: 50%;
	margin: 0 0 7px;
	font-size: 100%;
}

dl.price dd {
	margin: 0 0 7px;
	padding: 0 0 0 53%;
	vertical-align: middle;
	border-bottom: 1px dotted #9C9C9C;
	font-weight: bold;
	font-size: 100%;
	text-align: right;
}

dl.price dd.cap {
	margin: -3px 0 7px;
	padding: 0 5px;
	color: #626262;
	font-weight: normal;
	font-size: 90%;
	border: none;
	text-align: left;
}
dl.price dd:after {
  content:'';
  display:block;
  clear:both;
}

table.cont {
	width:100%;
	margin-bottom:1em;
	border-collapse:collapse;
	border:1px solid #999;
}
table.cont th {
	padding:10px;
	text-align:center;
	vertical-align:middle;
	border:1px solid #999;
	background:#eee;
}
table.cont td {
	padding: 10px;
	text-align: left;
	border: 1px solid #999;
	vertical-align: middle;
}
table.cont td.tablatitle {
	color: #fff;
	padding: 10px;
	text-align: center;
	border: 1px solid #999;
	background-color: rgba(0,180,187,0.8);
	font-weight: bold;
	vertical-align: middle;
}
table.cont h4 {
	margin: 0 0 0.4em;
	padding: 0;
	font-size: 16px;
	color: #666;
	line-height: 1;
	font-weight: bold;
	text-align: left;
}
table.pricelist {
	width:100%;
	margin-bottom:1em;
	border-collapse:collapse;
	border:1px solid #999;
}
table.pricelist th {
	padding:10px;
	text-align:center;
	vertical-align:middle;
	border:1px solid #999;
	background:#eee;
}
table.pricelist td.bglist {
	padding:10px;
	text-align:center;
	vertical-align:middle;
	border:1px solid #999;
	background:#eee;
}
table.pricelist td {
	padding: 10px;
	text-align:center;
	border: 1px solid #999;
	vertical-align: middle;
}
table.pricelist td.tablatitle {
	color: #fff;
	padding: 10px;
	text-align: center;
	border: 1px solid #999;
	background-color: rgba(0,180,187,0.8);
	font-weight: bold;
	vertical-align: middle;
}
table.pricelist h4 {
	margin: 0 0 0.4em;
	padding: 0;
	font-size: 16px;
	color: #666;
	line-height: 1;
	font-weight: bold;
	text-align:center;
}

/*================================================
 *  グローバルナビゲーション
 ================================================*/
@media print, screen and (min-width:768px) {
	nav {
	z-index: 3;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳＰ明朝", "MS PMincho", "ＭＳ明朝", "MS Mincho", serif;
	}

	/* 共通 */
	nav ul {
		margin:0;
		padding:0;
	}

	nav ul li {
		position:relative;
		margin:0;
		padding:0;
		list-style:none;
	}

	nav ul li a {
		display:block;
		margin:0;
		padding:16px 0;
		color:#000;
		font-size:18px;
		font-weight:normal;
		line-height:1;
		text-decoration:none;
		transition: .4s;
	}

	nav ul li:hover > a {
		color:#fff;
		background:#2e2e2e;
	}

	/* 1段目 */
	nav ul.gnav > li {
		position:relative;
		width:20%;
		float:left;
		margin:0;
		padding:0;
		text-align:center;
		list-style:none;
	}

	nav ul.gnav > li:first-child {
		width:20%;
	}

	nav ul.gnav > li.subnav a {
		padding-right:20px;
	}

	nav ul.gnav > li.subnav > a:after {
		position:absolute;
		content:"";
		top:20px;
		width:0;
		height:0;
		margin-left:10px;
		border:5px solid transparent;
		border-top-color:#fff;
	}

	/* 2段目 */
	nav ul li ul {
		position:absolute;
		z-index:3;
		top:100%;
		left:0;
		width:100%;
		margin:0;
		padding:0;
	}

	nav ul li ul li {
		overflow:hidden;
		width:160%;
		height:0;
		color:#fff;
		transition:.2s;
	}

	nav ul li ul li a {
		padding:12px 15px;
		text-align:left;
		background:#2e2e2e;
		font-weight:normal;
		font-size:16px;
		opacity: 0.8;
	}
	nav ul li ul li a:hover {
		opacity: 1;
	}

	nav ul li:hover > ul > li {
		overflow:visible;
		height:40px;
		border-bottom:1px solid transparent;
	}

	nav ul li:hover ul li:last-child {
		border-bottom:none;
	}

	nav ul.gnav > li:last-child > ul {
		left:-50%;
	}

	nav ul li ul li ul:before {
		position:absolute;
		content:"";
		top:13px;
		left:-20px;
		width:0;
		height:0;
		border:5px solid transparent;
		border-left-color:#fff;
	}

	nav ul.gnav > li:last-child ul li ul:before {
		position:absolute;
		content:"";
		top:13px;
		left:200%;
		margin-left:-20px;
		border:5px solid transparent;
		border-right-color:#fff;
	}

	/* 3段目 */
	nav ul li ul li ul {
		top:0;
		left:100%;
	}

	nav ul li ul li ul li {
		width:100%;
	}

	nav ul li ul li:hover > ul > li {
		border-bottom:1px solid #00a7ae;
	}

	nav ul.gnav > li:last-child > ul li ul {
		left:-100%;
	}

	nav ul li ul li ul li a {
		background:#008d93;
		font-size:16px;
	}

	nav ul li ul li ul li a:hover {
		background:#007d82;
	}

	.gnav {
		display:block !important;
	}

	#spMenu {
		display:none;
	}

	.fixed {
		position:fixed;
		top:0;
		left:0;
	}
}

/*================================================
 *  トピックパス（パンくずリスト）
 ================================================*/
#topicpath {
	font-size:12px;
	margin-bottom:20px;
	padding:2px;
	background:#f1f1f1;
}

/*================================================
 *  サブコンテンツ
 ================================================*/
  
.submenu li {
	margin:0 0 5px;
	padding:0 0 0 17px;
	list-style:none;
	background:url(../images/check.png) 0 3px no-repeat;
}
.submenu li a:hover {
	color: #FF4000;
	text-decoration: underline;
}

.bnr {
	overflow:hidden;
}
.bnr ul {
	overflow:hidden;
}
.bnr li {
	margin:0 0 5px 0;
	padding:0;
	list-style:none;
}
.bnr img {
	width:100%;
}

ul.sidemenu {
	 margin: 0 0 10px;
 }
ul.sidemenu li{
	overflow: hidden;
	margin: 0;
	text-align: left;
	padding: 0;
	border: 1px #ddd solid;
	border-bottom: 0;
	background-color: rgba(0,180,187,0.8);
	display:block;
 }
ul.sidemenu li.onb {
	background-color: rgba(0,180,187,1.0);
 }
ul.sidemenu li:first-child{
	border-radius: 8px 8px 0 0;
 }
ul.sidemenu li:last-child{
	border-radius: 0 0 8px 8px;
	border-bottom:1px #ddd solid;
 }
ul.sidemenu li a{
	color: #fff;
	display: block;
	height: 44px;
	margin: 0;
	padding: 0 0 0 10px;
	overflow: hidden;
	white-space: nowrap;
	line-height: 44px;
	text-overflow: ellipsis;
	text-decoration: none;
	font-weight:bold;
	font-family:"メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",sans-serif;
	font-size:16px;
	transition: .4s;
 }
ul.sidemenu li a::before{
	content: url(../images/list_mark.png);
	float: right;
 }
ul.sidemenu li a:hover{
 	background-color: rgba(0,180,187,1.0);
 }
 
/*================================================
 *  フッター
 ================================================*/
footer {
	clear:both;
}

.footmenu {
	width: 100%;
	margin: 0 auto;
	padding: 15px 0;
	overflow: hidden;
}
.footmenu ul {
	position:relative;
	float:left;
	left:50%;
	margin:0;
	padding:0;
}
.footmenu li {
	position:relative;
	left:-50%;
	float:left;
	list-style:none;
	margin:0;
	padding:0 8px;
	font-size:13px;
	text-align:center;
}
.footmenu a {
	color:#2e2e2e;
	text-decoration:none;
}
.footmenu a:hover {
	color:#000;
	text-decoration:underline;
}
.footmenu_info {
	width:100%;
	padding:15px 0;
	overflow:hidden;
	text-align:center;
	font-size:12px;
}

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

/*================================================
 *  ページトップへの戻り
 ================================================*/
.totop {
	position:fixed;
	bottom:15px;
	right:15px;
}
.totop a {
	display:block;
	text-decoration:none;
}
.totop img {
	background:#2e2e2e;
}
.totop img:hover {
	background:#000;
}

/*================================================
 *  クラス
 ================================================*/
.list {
	padding:0 0 0 0.5em;
}
.list li {
	margin: 0;
	padding: 0 0 0 16px;
	list-style: none;
	background: url(../images/check.svg) 0px 8px no-repeat;
	background-size: 15px;
}

.info dt {
	border-bottom:none;
}
.info dd {
	padding-bottom:1em;
	border-bottom:1px solid #ddd;
}

.col_two_one {
	overflow:hidden;
}

.col_two_one ul {
	overflow:hidden;
	margin:2% -2% 0 0;
}
.col_two_one li {
	list-style:none;
	float:left;
	width:48%;
	margin:0 2% 2% 0;
}
.col_two_one li:nth-child(2n+1) {
	clear:both;
}
.col_two_one li img {
	width:100%;
	margin-bottom:2.5%;
}
.col_two_one li ul li {
	width:100%;
}

.col_two_one_top {
	overflow:hidden;
	margin:0 -2% 0 0;
}
.top_infolist {
	float: left;
	width: 48%;
	margin: 0 2% 2% 0;
	box-sizing:border-box;
}
.col_two_one_top img {
	width:100%;
}

.top_infolist p {
	padding:0 10px;
}

.top_infolist dl {
	margin: 10px 0 10px;
	padding: 5px 10px;
	list-style: none;
	line-height:1.75;
	display: block;
	background-image: url(../images/line.png);
	background-repeat: no-repeat;
	background-position: left bottom;
	overflow:hidden;
}
.top_infolist dt {
	float: left;
	width: 8em;
	margin: 0;
}

.top_infolist dd {
	margin: 0 0 0 9em;
	padding: 0;
	vertical-align: middle;
}
.top_infolist dt img {
	margin: 0;
	padding: 0 0 0 3px;
	width:auto;
	vertical-align: middle;
}
.top_infolist dd img {
	margin: 0;
	padding: 0 0 0 5px;
	float:right;
	width:auto;
}
.icon {
  display: table;
  table-layout: fixed;
  text-align: center;
  width: 100%;
  margin: 0;
  padding: 0;
}
.icon li {
  border-right: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
  display: table-cell;
  vertical-align: middle;
}
.icon li img {
  width: 100%;
  height:auto;
}
.icon li:last-child {
  border-right: 0;
}

.col_three_one {
	overflow:hidden;
}

.col_three_one ul {
	overflow:hidden;
	margin:0;
}
.col_three_one li {
	list-style: none;
	float: left;
	width: 32.3%;
	margin: 0;
}
.col_three_one li:nth-child(3n+1) {
	clear:both;
}
.col_three_one li img {
	width:100%;
}

.col_two_one li h4, .col_three_one li h4 {
	margin-bottom: 0.2em;
	padding: 0 8px;
	font-size: 16px;
	color: #555;
	line-height: 1.2;
	font-weight: normal;
}
.col_two_one li p, .col_three_one li p {
	padding: 0 8px;
	font-size: 14px;
	color: #555;
	line-height: 1.3;
	font-weight: normal;
}

.col_five_one {
	overflow:hidden;
}

.col_five_one ul {
	overflow:hidden;
	margin:1% -1% 0 0;
}
.col_five_one li {
	list-style:none;
	float:left;
	width:19%;
	margin:0 1% 1% 0;
	border: 5px solid #DEDEDE;
	background-color: #fff;
	box-sizing:border-box;
}
.col_five_one li:nth-child(5n+1) {
	clear:both;
}
.col_five_one h3 {
	margin:0;
	padding: 0;
	background-color: #fff;
}
.col_five_one h3 img {
	width:100%;
	height:auto;
	margin:0 0 5px;
	padding: 0;
	background-color: none;
}
.col_five_one li p {
	margin: 5%;
	font-size: 13px;
	text-align: justify;
}
.col_five_one li img {
	width:100%;
	height:auto;
}

.photobox_r {
	float: right;
	width: 35%;
	margin: 0 0 2% 2%;
}
.photobox_r img {
	width: 100%;
	margin: 0 0 2%;
	height:auto;
}
.photobox_r h3 {
	margin: 0 0 2%;
	font-size: 16px;
}
.photobox_r p {
	margin: 0 0 2%;
	font-size: 13px;
}
.pagenate {
	margin: 10px 0 10px;
	text-align: center;
}
.toarchives a{
    display: inline-block;
    font-weight: normal;
    padding: 0.3em 0.8em;
    text-decoration: none;
    color: #fff;
    background: #2e2e2e;
    border-radius: 15px;
    transition: .4s;
	margin: 0;
	float: right;
 }
 .toarchives a:hover {
	color: #fff;
	background-color: #2e2e2e;
}
.small {
	font-size: 90%;
	margin: -1em 0.5em 1em;
}
.flowbox{
	padding: 10px;
	border-radius: 10px;
	margin: 0 0 1em 0.5em;
	border: 2px solid #CDA949;
	box-sizing: border-box;
	display: inline-block;
 }
 .qabox {
	background-color: #FFF5FD;
	border: 2px solid #999;
	border-radius: 10px;
	position: relative;
	padding: 12px;
	margin: 0 0 13px 0;
}
 
.qabox:before {
border:10px solid transparent;
border-top-color:#FFF5FD;
border-bottom-width:0;
bottom:-9px;
content:"";
display:block;
left:30px;
position:absolute;
width:0;
z-index:1;
}
 
.qabox:after {
border:10px solid transparent;
border-top-color:#999;
border-bottom-width:0;
bottom:-12px;
content:"";
display:block;
left:30px;
position:absolute;
width:0;
}

.qabox2 {
	background-color: #EBFEFF;
	border: 2px solid #999;
	border-radius: 10px;
	position: relative;
	padding: 12px;
	margin: 0 0 20px 0;
}
 
.qabox2:before {
border:10px solid transparent;
border-bottom-color:#EBFEFF;
border-top-width:0;
top:-9px;
content:"";
display:block;
left:45px;
position:absolute;
width:0;
z-index:1;
}
 
.qabox2:after {
border:10px solid transparent;
border-bottom-color:#999;
border-top-width:0;
top:-12px;
content:"";
display:block;
left:45px;
position:absolute;
width:0;
}

/*================================================
 *  ボタン
 ================================================*/
.pre_btn {
    position: relative;
    display: inline-block;
    font-weight: normal;
    padding: 0.25em 0.5em 0.25em 1em;
    text-decoration: none;
    color: #dedede;
    background: #508d1f;
    border-radius: 15px 0 0 15px;
    transition: .4s;
	margin: 0 1px 0 0;
  }
.mid_btn {
    position: relative;
    display: inline-block;
    font-weight: normal;
    padding: 0.25em 1em;
    text-decoration: none;
    color: #dedede;
    background: #508d1f;
    transition: .4s;
	margin: 0 1px 0 0;
  }
.next_btn {
    position: relative;
    display: inline-block;
    font-weight: normal;
    padding: 0.25em 1em 0.25em 0.5em;
    text-decoration: none;
    color: #dedede;
    background: #508d1f;
    border-radius: 0 15px 15px 0;
    transition: .4s;
  }

.next_btn:hover, .mid_btn:hover, .pre_btn:hover {
	color: #fff;
	background-color: #2e2e2e;
}

/*================================================
 *  入力フォーム
 ================================================*/

form#mailform {
	padding: 5px;
}
table.mailform {
	width: 100%;
}
table.mailform tr th,table.mailform tr td {
	text-align: left;
	font-weight: normal;
	font-size: 12px;
	border-bottom: solid 1px #999999;
	padding: 7px 5px 7px 5px;
	vertical-align: middle;
}
table.mailform tr th {
	width: 25%;
}
table.mailform tr th span {
	color: #CC0000;
	font-size: 10px;
}
table.mailform tr th p {
	margin: 0px;
	padding: 0px;
	font-size: 12px;
	color: #999999;
}
table.mailform tr td textarea {
	width: 100%;
	height: 120px;
}

/*================================================
 *  スライドショー
 ================================================*/
/* スライドショー */
.slide {
	display:none;
	position:relative;
	overflow:hidden;
	margin:0;
}

.top_title {
	position: absolute;
	top: 53%;
	left: 50%;
	-webkit-transform: translate(-50%,-70%);
	-moz-transform: translate(-50%,-70%);
	-ms-transform: translate(-50%,-70%);
	-o-transform: translate(-50%,-70%);
	transform: translate(-50%,-70%);
	width: 1200px;
	height: 200px;
	background-image: url(../images/top_title.png);
	display: block;
	z-index: 1;
	text-indent: -9999px;
}

.slidePrev {
	position:absolute;
	cursor:pointer;
	z-index:2;
}

.slideNext {
	position:absolute;
	cursor:pointer;
	z-index:2;
}

.slidePrev img {
	position:absolute;
	width:50px !important;
	height:60px !important;
}

.slideNext img {
	position:absolute;
	width:50px !important;
	height:60px !important;
}

.slideInner {
	position:relative;
	margin:0 0 5px 0;
	padding:0;
}
.slideInner li {
	float:left;
	margin:0;
	padding:0;
	list-style:none;
}
.slideInner li img {
	margin:0;
	padding:0;
}

.filterPrev {
	position:absolute;
	left:0;
	opacity:0.5;
	filter:alpha(opacity=50);
	background-color:#fff;
}

.filterNext {
	position:absolute;
	right:0;
	opacity:0.5;
	filter:alpha(opacity=50);
	background-color:#fff;
}

.controlNav {
	position:relative;
	float:left;
	left:50%;
	bottom: 40px;
}
.controlNav span {
	position:relative;
	left:-50%;
	float:left;
	margin:5px;
	-webkit-border-radius:5px;
	-moz-border-radius:5px;
	border-radius:5px;
	width:10px;
	height:10px;
	overflow:hidden;
	background:#ccc;
	text-indent:-9999px;
	vertical-align:middle;
}
.controlNav span:hover {
	background:#999;
	cursor:pointer;
}
.controlNav span.current {
	background-color: #2e2e2e;
}

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

	#contents {
		box-sizing:border-box;
		width:100%;
		padding:0 10px;
	}

	footer {
		width:100%;
	}
}


/*================================================
 *  スマートフォン向けデザイン
 ================================================*/
@media screen and (max-width:767px) {
	.lock {
		overflow:hidden;
	}

	header {
		z-index:2;
		box-sizing:border-box;
		top:0;
		left:0;
		width:100%;
		padding:5px 10px;
		height: 80px;
		position:absolute;
	}
	#logo a {
	width:250px;
	height: 53px;
	position:absolute;
	top:10px;
	left:5px;
	margin: 0;
	padding:0;
	background-image: url(../images/logo_sp.svg);
	display: block;
	z-index: 6;
	text-indent: -9999px;
	background-size: cover;
}

    /*================================================
 *  ページトップへの戻りスマートフォン向け
 ================================================*/
.totop {
	position:fixed;
	bottom:50px;
	right:15px;
    z-index: 11;
}
.totop a {
	display:block;
	text-decoration:none;
}
.totop img {
	background:#2e2e2e;
}
.totop img:hover {
	background:#000;
}

	.summary {
		width:35%;
		position:absolute;
	top:35px;
	right:0;
	margin:0;
	font-size:10px;
	}
	.summary img {
		width:100%;
		height:auto;
	margin:0;
	}
	.top_title {
	display: none;
}
	
h1 img {
		height:220px;
		margin: 0 0 10px;
	padding:0;
	object-fit: cover;
}
h1.noimage {
	margin: 0.5em 0;
	padding: 0;
	font-size: 22px;
	text-align: center;}
h2 {
	font-size: 20px;
}

h3 {
	font-size: 18px;
}
	#main {
		float:none;
		width:100%;
	}

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

	nav {
		background:#2e2e2e;
	}
	nav ul {
		margin:0;
		padding:0;
		}

	nav .inner > ul {
		z-index:10;
		overflow:auto;
		position:fixed;
		top:53px;
		right:0;
		width:100%;
		height:88%;
		height:-webkit-calc(100% - 53px);
		height:calc(100% - 53px);
	}
	nav li {
		position:relative;
		width:100%;
		float:none;
		margin:0;
		text-align:left;
		list-style:none;
		border-bottom:1px solid #777;
		background:#2e2e2e;
	}

	nav li:first-child {
		border-top:0;
	}
	nav li:last-child {
		border-bottom:0;
	}

	nav li a {
		display:block;
		padding:10px 30px;
		color:#fff;
		text-decoration:none;
		background:#2e2e2e;
	}
	nav li a:hover {
		color:#fff;
		background:#222;
	}
	nav ul ul {
		display:none;
		position:relative;
	}
	nav li li a {
		box-sizing:border-box;
		width:100%;
		padding:10px 30px 10px 50px;
		text-align:left;
	}

	nav li li li a {
		padding:10px 30px 10px 70px;
	}

	.subnav > a:before {
		display:block;
		content:"";
		position:absolute;
		-webkit-transform:rotate(45deg);
		transform:rotate(45deg);
		top:20px;
		right:30px;
		width:10px;
		height:10px;
		margin-top:-5px;
		background:#f1f1f1;
	}
	.subnav > a:after {
		display:block;
		content:"";
		position:absolute;
		-webkit-transform:rotate(45deg);
		transform:rotate(45deg);
		top:20px;
		right:30px;
		width:10px;
		height:10px;
		margin-top:-10px;
		background:#508d1f;
	}
	.subnav a:hover:after {
	  background:#2e2e2e;
	}

	.active > a:before {
		margin-top:0;
	}
	.active > a:after {
		margin-top:5px;
	}

	.gnav {
		display:none;
	}

	#spMenu {
		display:block;
		z-index:2;
		position:fixed;
		top:10px;
		right:10px;
	}
	#spMenu:hover {
		cursor:pointer;
	}

	#navBtn {
		display:inline-block;
		position:relative;
		width:35px;
		height:35px;
		border-radius:5%;
		background:#2e2e2e;
	}
	#navBtnIcon {
		display:block;
		position:absolute;
		top:50%;
		left:50%;
		width:14px;
		height:2px;
		margin:-1px 0 0 -7px;
		background:#f1f1f1;
		transition:.2s;
	}
	#navBtnIcon:before,
	#navBtnIcon:after {
		display:block;
		content:'';
		position:absolute;
		top:50%;
		left:0;
		width:14px;
		height:2px;
		background:#f1f1f1;
		transition:0.3s;
	}
	#navBtnIcon:before {
		margin-top:-6px;
	}
	#navBtnIcon:after {
		margin-top:4px;
	}
	#navBtn .close {
		background:transparent;
	}
	#navBtn .close:before,
	#navBtn .close:after {
		margin-top:0;
	}
	#navBtn .close:before {
		transform:rotate(-45deg);
		-webkit-transform:rotate(-45deg);
	}
	#navBtn .close:after {
		transform:rotate(-135deg);
		-webkit-transform:rotate(-135deg);
	}


	.col_two_one ul {
		margin-right:0;
	}
	.col_two_one li {
		width:100%;
	}
	.col_two_one li:nth-child(2n+1) {
		clear:both;
	}
	.col_two_one_top {
	margin-right:0;
	}
	.top_infolist {
	width:100%;
	}
	.col_two_one_top img {
	width:100%;
	}

.col_three_one ul {
	margin:0;
}
.col_three_one li {
	list-style: none;
	float: left;
	width: 50%;
	margin:0;
	font-size: 12px;
}
.col_three_one li:nth-child(3n+1) {
	clear: none;
}
.col_three_one li:nth-child(2n+1) {
	clear:both;
}
.col_three_one li img {
	width:100%;
}
	
.col_five_one {
	overflow:hidden;
}

.col_five_one ul {
	overflow:hidden;
	margin:1% -1% 0 0;
}
.col_five_one li {
	list-style:none;
	float:left;
	width:49%;
	margin:0 1% 1% 0;
	border: 5px solid #DEDEDE;
	background-color: #fff;
	box-sizing:border-box;
}
.col_five_one li:nth-child(2n+1) {
	clear:both;
}
.col_five_one h3 {
	margin:0;
	padding: 0;
	background-color: #fff;
}
.col_five_one h3 img {
	width:100%;
	height:auto;
	margin:0 0 5px;
	padding: 0;
	background-color: none;
}
.col_five_one li p {
	margin: 5%;
	font-size: 13px;
	text-align: justify;
}
.col_five_one li img {
	width:100%;
	height:auto;
}
	
.footmenu {
	width: 100%;
	margin: 0 auto;
	padding: 15px 0;
	overflow: hidden;
	background-color: #fff;
}

.copyright {
	clear:both;
	padding:20px 0;
	font-size:11px;
	text-align:center;
	color:#fff;
	background:#74a82d;
    margin: 0 0 56px;
}

.photobox_r {
	width: 60%;
	margin: 0 auto 2%;
	float:none;
}

/* 矢印つきリスト1 */

ul.submenu {
	 margin: 10px;
 }
ul.submenu li{
	overflow: hidden;
	margin: 0;
	width: 100%;
	text-align: left;
	padding: 0;
	border: 1px #ccc solid;
	border-bottom: 0;
	background: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#f0f0f0));
	background: linear-gradient(#fff, #f0f0f0);
	display:block;
	-webkit-box-shadow:0px 3px 3px rgba(000,000,000,0.1);
	box-shadow:0px 3px 3px rgba(000,000,000,0.1);
 }
ul.submenu li:first-child{
	border-radius: 8px 8px 0 0;
 }
ul.submenu li:last-child{
	border-radius: 0 0 8px 8px;
	border-bottom:1px #ccc solid;
 }
ul.submenu li a{
	color: #333;
	display: block;
	height: 44px;
	margin: 0;
	padding: 0 0 0 10px;
	overflow: hidden;
	white-space: nowrap;
	line-height: 44px;
	text-overflow: ellipsis;
	text-decoration: none;
	font-weight:bold;
 }
ul.submenu li a::after{
	content: url(../images/list_mark1.png);
	float: right;
 }
}


/* SLIDER */
.video{
  position:relative;
  width:100%;
  padding-top:56.25%;
}
.video iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}
.swiper-container {
  width: 100%;
  height: 100vh;
 }
 .swiper-slide img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
 }
 
 .type1 {
	display: inline-block;
	font-weight: normal;
	padding: 0.3em 0.8em;
	text-decoration: none;
	color: #fff;
	background-color: #0E84D6;
	border-radius: 15px;
	transition: .4s;
	margin: 0 3px 0 0;
	float: left;
 }
  .type2 {
    display: inline-block;
    font-weight: normal;
    padding: 0.3em 0.8em;
    text-decoration: none;
    color: #fff;
    background: #2e2e2e;
    border-radius: 15px;
    transition: .4s;
	margin: 0 3px 0 0;
	float: left;
 }
  .type3 {
	display: inline-block;
	font-weight: normal;
	padding: 0.3em 0.8em;
	text-decoration: none;
	color: #fff;
	background-color: #E86B00;
	border-radius: 15px;
	transition: .4s;
	margin: 0 3px 0 0;
	float: left;
 }
 .type1 a:hover, .type2 a:hover, .type3 a:hover {
	color: #fff;
	background-color: #2e2e2e;
}

/*メニューをページ下部に固定*/
#sp-fixed-menu{
   position: fixed;
   width: 100%;
   bottom: 0px;
   font-size: 0;
   opacity: 0.9;
   z-index: 10;
}

/*メニューを横並びにする*/
#sp-fixed-menu ul{
   display: flex;
   list-style: none;
   padding:0;
   margin:0;
   width:100%;
}

#sp-fixed-menu li{
   justify-content: center;
   align-items: center;
   width: 33.3333%;
   padding:0;
   margin:0;
   font-size: 13px;
   border-right: 1px solid #fff;
background: #333;
}

/*ボタンを調整*/
#sp-fixed-menu li a{
   color: #fff;
   text-align: center;
   display:block;
   width: 100%;
   padding:16px 2px;
}

/*PCの場合にはメニューを表示させない*/
@media (min-width: 768px) {
   .for-sp{
      display:none;
    }
}


.facebook_wrap{
  margin-left: auto;
  margin-right: auto;
  width: 80%;
}

.fb-page,
.fb-page span,
.facebook_wrap iframe{
  width: 100% !important;
  height: 500px !important;
}