@charset "utf-8";

/*全体
---------------------------------------------------------------------------*/
body {
	margin: 0;
	padding: 0;
	font: 16px "游ゴシック Medium",YuGothic,YuGothicM,"游ゴシック体","游ゴシック","Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;
	font-weight: 500;
	line-height: 2;
	color: #000;
	background: #fff;
	-webkit-text-size-adjust: none;
}
/*リセット
---------------------------------------------------------------------------*/
h1,h2,h3,h4,h5,p,ul,ol,li,dl,dt,dd,form,figure,form,select,textarea,input {
	margin: 0;
	padding: 0;
	font-size: 100%;
	font-weight: normal;
}
ul {
	list-style-type: none;
}
img {
	border: none;
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}
table {
	border-collapse:collapse;
	font-size: 100%;
	border-spacing: 0;
	margin: 0;
}
video {
	max-width: 100%;
}
iframe {
	width: 100%;
}
/*リンク
---------------------------------------------------------------------------*/
a {
	color: #0074ca;
}
a:hover {
	color: #05acff;
}
a:hover img {
	opacity: 0.6;
	filter: alpha(opacity=60);
	transition: 0.6s;
}
/*ヘッダー
---------------------------------------------------------------------------*/
header {
	position: fixed;
	z-index: 1;
	top: 0;	
	left: 0;	
	width: 100%;
	background: #333;
	height: 60px;
}

h1#logo img {
	position: fixed;
	top: 0;	
	left: 0;	
	width: auto;
	height: 60px;
	background: #00a968;
	z-index: 10;
}
/*PC用メニュー
---------------------------------------------------------------------------*/
#menu ul{
	height: 60px;	
	font-size: 15px;
	margin-left: 300px;
	width: 100%;
}
#menu ul li{
	display: inline;
	letter-spacing: 0.1em;
}
#menu ul li:first-child {
	margin-left: 20px;
}
#menu ul li:last-child {
	margin-right: 1%;
}
#menu ul li#current {
    color: #ffd700;
	padding: 21px 25px 20px;
}
#menu ul li a{
	line-height: 62px;
	color: #fff;
	text-decoration: none;
	padding: 21px 25px 20px;
}
#menu ul li a:hover{
	background: #666 !important;
	transition: 0.7s;
}
#menu ul li#current {
    color: #ffd700;
}

/*SPメニュー非表示*/
#menu_sp {
	display: none;
}
/*ハンバーガーボタン非表示*/
.toggle_btn, .toggle_txt {
	display: none;
}

/*コンテンツ
---------------------------------------------------------------------------*/
#contents {
	margin-top: 60px;
	padding: 3%;
}
#contents h2 {
	clear: both;
	margin-bottom: 20px;
	font-size: 120%;
	font-weight: 500;
	background: #00a968;
	color: #fff;
	line-height: 50px;
	padding-left: 25px;
}
#contents h2::first-letter {
	border-left: 3px solid #fff;
	padding-left: 15px;
}
#contents h3 {
	clear: both;
	margin-bottom: 20px;
	font-size: 120%;
	border-bottom: 2px solid #00a968;
	padding-left: 38px;
	background: url(../images/mark.png) 14px 11px / 16px 16px no-repeat;
}
#contents p {
	padding: 0 20px 20px;
}
/*他。微調整。*/
#contents p + p {
	margin-top: -5px;
}
#contents h3 + p {
	margin-top: -10px;
}
#contents section + section {
	margin-top: 30px;
}
.traffic {
	color: #008e30;
	font-size: 120%;
	font-weight: 600;
	font-family: 'Noto Serif JP', serif;
	margin-top: 30px;
}
.sp_guide {
	display: none;
}
/*リスト項目
---------------------------------------------------------------------------*/
#contents ul.law {
	padding: 0 15px 15px;
	list-style: disc inside;
}
/*フッター
---------------------------------------------------------------------------*/
footer {
	clear: both;
	text-align: center;
	margin: 0 auto;
	color: #fff;
	background: #00a968;
	font-family: -apple-system,BlinkMacSystemFont,"Helvetica Neue","游ゴシック Medium",YuGothic,YuGothicM,"游ゴシック体","游ゴシック","Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;
	font-weight: 500;
}
footer a {
	color: #fff;
	text-decoration: underline;
}
footer a:hover {
	color: #fff;
}
/*フットメニュー*/
#footmenu {
	display: block;
	padding: 10px 10px 5px;
}
#footmenu ul {
	margin: 0 auto;
	line-height: 2;
}
#footmenu ul li:first-child {
	font-size: 18px;
}
#footmenu ul li a {
	text-decoration: none;
}
#footmenu ul li a:hover {
	text-decoration: underline;
}
#footlist {
	overflow: hidden;
	padding: 20px 3%;
	font-size: 95%;
}
#footlist .lbl {
	float: left;
	width: 47%;
	padding-right: 3%;
	text-align: left;
}
#footlist .rbl {
	float: right;
	width: 47%;
	padding-left: 3%;
	text-align: left;
}
/*コピーライト*/
#copyright {
	clear: both;
	text-align: center;
	padding:4px 0 15px;
	font-size: 90%;
}
#copyright a img {
	height: 40px;
	width: auto;
}

/*テーブル
---------------------------------------------------------------------------*/
.tb1, .tb2 {
	width: 100%;
	margin-bottom: 20px;
	table-layout: fixed;
}
.tb1, .tb2, .tb1 td, .tb2 td, .tb1 th, .tb2 th {
	border: 1px solid #aaa;
	padding: 10px;
}
.tb1 th {
	text-align: left;
	font-weight: 500;
	background: #d4f8dc;
	width: 20%;
}
.tb1 .col1 {
 	width: 20%;
}
.tb1 .col2 {
 	width: 48%;
}
.tb1 .col3 {
 	width: 16%;
}
.tb2 th {
	text-align: left;
	font-weight: 500;
	background: #d4f8dc;
	width: 20%;
}

/*画像並列
---------------------------------------------------------------------------*/
.box4 li {
	display: table-cell;
	vertical-align: top;
	width: 100%;	
}
.box4 {
	display: table;
	table-layout: fixed;	
	width: 60%;
	overflow: hidden;
	text-align: center;
	margin-bottom: 20px;
}
.box4 li a img {
	margin-left: 8px;
}
.box4 li:first-child a img {
	margin-left: 0px;
}
/*周辺観光スポット
---------------------------------------------------------------------------*/
.spot {
	overflow: hidden;
	line-height: 1.8;
	border-bottom: 1px solid #aaa;
	padding: 2% 1%;
}
.spot:first-of-type {
	border-top: 1px solid #aaa;
}
.spot:last-of-type {
	border-bottom: 0
}
.spot h4 {
	font-family: 'Noto Serif JP', serif;
	font-size: 20px;
	line-height: 1.5;
	font-weight: bold;
	margin-bottom: 10px;
}
.spot img {
	width: 35%;			/*画像幅*/
	float: left;		/*画像を左に回り込み*/
	margin-right: 3%;
}
.spot p {
	padding: 0 !important;
}
p video {
	padding-top: 10px;
}
/*メールフォーム
---------------------------------------------------------------------------*/
#formWrap {
	max-width:1000px;
	width: 100%;
	margin: 0 auto;
	padding-top: 20px;
	line-height:3.2rem;
	font-size:16px;
	text-align: center;
}
table.formTable{
	width:100%;
	margin:0 auto 20px;
	border-collapse:collapse;
	text-align: left;
	line-height:2rem;
}
table.formTable td,table.formTable th{
	border:1px solid #bfbfbf;
	padding:10px;
	font-weight:500;
}
table.formTable td{
	padding-left: 15px;
}
table.formTable td p{
	line-height: 1.5;
}
table.formTable th{
	width:280px;
	background:#dfdfdf;
	text-align:left;
}
table caption {
	border:1px solid #bfbfbf;
	border-bottom: 0;
	font-weight: bold;
	padding: 10px;
	font-size: 110%;
	background: #d4f8dc;
}
table.note caption {
	padding-bottom: 0;
}
table.note caption p {
	font-weight: normal;
	font-size: 16px;
	line-height: 1.6;
	padding:0;
}

/*PageTopボタン
---------------------------------------------------------------------------*/
#pagetop{
	display: none;
	position: fixed;
	right: 3%;
	bottom: 30px;
}
#pagetop a{
	display: block;
	font-size: 0;
	width: 50px;
	height: 50px;
	text-align: center;
	background: #333;
	background: rgba(0,0,0,0.6);
	line-height: 50px;
	border: 1px solid #fff;
	z-index: 10;
}
#pagetop a i{
	font-size: 20px;
	color:#fff;
	line-height: 50px;
}
/*マウスオン時*/
#pagetop a:hover {
	background: #666;
}

/*臨時調整、その他
---------------------------------------------------------------------------*/
.mb15 {
	margin-bottom: 15px !important;
}
.mb20 {
	margin-bottom: 20px !important;
}
.mb30 {
	margin-bottom: 30px !important;
}
.mb50 {
	margin-bottom: 50px !important;
}
.mt15 {
	margin-top: 15px !important;
}
.mt20 {
	margin-top: 20px !important;
}
.mt50 {
	margin-top: 50px !important;
}
.lh15 {
	line-height: 1.5 !important;
}
.pd0 {
	padding: 0 !important;
}
.color1, .color1 a {
	color: #0074ea !important;
}
.tac {text-align: center;}
.tar {text-align: right;}
.tal {text-align: left;}
.fl {float: left;}
.fr {float: right;}
.fw500 {
	font-weight: 500;
}
.fw600 {
	font-weight: 600;
}
.fwn {
	font-weight: normal;
}
.notice {
	background: #d4f8dc;
}
.bgc1 {
	background: #dedede;
}
.bgc2 {
	background: #cfefef;
}
.my-green {color: #008e30}
.my-darkgray {color: #555}

/*幅1024px以下の設定
------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width:1024px){

/*スマホメニュー
---------------------------------------------------------------------------*/
body {
	position: relative;
}
header {
	background: #00a968;
}
h1#logo img {
	height: 55px;
	top: 2px;
}
/*ハンバーガーアイコン*/
.toggle_btn {
	display: inline-block;
	width: 44px;
	height: 44px;
	background: url(../images/open.png) no-repeat center/44px;
	border: 2px solid #fff;	
	cursor: pointer;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	z-index: 100;
	position: fixed;
	top: 6px;	
	right: 3%;
}
.toggle_btn.selected {
	background: url(../images/close.png) no-repeat center/44px;
}
.toggle_txt {
	display: none;
}
/*メニューブロック*/
#menu_sp {
	overflow: auto;
	text-align: left;
	position: absolute;
	z-index: 100;
	top: 60px;
	width: 100%;
	background: rgba(0,0,0,0.8);
	border-top: 1px solid #fff;
	animation-name: opa1;
	animation-duration: 0.5s;
	animation-fill-mode: both;
	font-size: 16px;
	margin-top: 0;
}
#menu_sp ul li.current {
	display: block;
	padding: 14px 20px;
	border-bottom: 1px solid #fff;
	color: #ffd700;
}
#menu_sp ul li a {
	display: block;
	text-decoration: none;
	padding: 14px 20px;
	border-bottom: 1px solid #fff;
	color: #fff;
}
#menu_sp ul li a:hover {
	background: #333;
}
/*PC用メニュー非表示*/
#menu {
	display: none !important;
}

/*コンテンツ
---------------------------------------------------------------------------*/
#contents h2 {
	margin-bottom: 10px !important;
	font-weight: 600 !important;
}
.sp_guide {
	display: block;
}
.traffic {
	margin-top: 20px;
}
/*画像並列
---------------------------------------------------------------------------*/
.box4 {	
	width: 100%;
}
/*メールフォーム
---------------------------------------------------------------------------*/
#formWrap {
	width:100%;
	margin:0 auto;
	line-height:1.5rem;
}
#formWrap p{
	margin:0 auto;
}
table.formTable{
	margin:0 auto 25px;
}
table caption {
	border-bottom: 1px solid #bfbfbf;
}
table.formTable th, table.formTable td {
	width:auto;
	display:block;
}
table.formTable th {
	margin-top:5px;
	border-bottom:0;
}
input[type="text"], textarea {
	width:80%;
	padding:5px;
	font-size:110%;
	display:block;
}
}

/*幅599px以下の設定
------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width:599px){

/*全体
---------------------------------------------------------------------------*/
body {
	line-height: 1.8;
}
/*メニューナビ
---------------------------------------------------------------------------*/
#menu_sp ul li a, #menu_sp ul li.current {
	padding: 13px 15px;
}

/*コンテンツ
---------------------------------------------------------------------------*/
#contents {
	padding: 3%;	
}
/*h2タグ*/
#contents h2 {
	margin-top: 10px;
	line-height: inherit;
	padding-left: 12px;
}
/*h3タグ*/
#contents h3 {
	background: url(../images/mark.png) 8px 10px / 16px 16px no-repeat;
	padding-left: 30px;
}
/*段落タグ設定*/
#contents p {
	padding: 0 10px 20px;
}
.traf_img {
	display: none;
}
/*周辺観光スポット
---------------------------------------------------------------------------*/
.spot {
	padding: 3% 1%;
}
/*フッターメニュー
---------------------------------------------------------------------------*/
#footlist {
	padding: 3%;
}
#footlist .lbl, #footlist .rbl {
	display: block;
	width: 98%;
	padding: 2% 1%;
}
/*テーブル
---------------------------------------------------------------------------*/
.tb1, .tb2, .tb1 td, .tb2 td, .tb1 th, .tb2 th {
	padding: 5px;
}
.tb2 {
	border: none;
}
.tb2 th, .tb2 td {
	display: block;
	width: 97%;
	border: 1px solid #aaa;
}
.tb2 th {
	margin-top: 5px;
	border-bottom: 0;
}
}