@charset "utf-8";
/*----------------------------------------
	reset-css
	----------------------------------------*/
*{
	background:transparent;
	margin: 0;
	padding: 0;
	vertical-align:baseline;
	font-size:100%;
	color: #444;
}
body {
	font-family: "Helvetica Neue","Verdana","Helvetica","メイリオ",Meiryo,sans-serif;
	line-height: 1.4;
	-webkit-text-size-adjust: 100%; /* スマホ横向きでも文字サイズ同じ */
	word-wrap: break-word;
}
input,
select,
textarea,
button {
	font-family: "Helvetica Neue","Verdana","Helvetica","メイリオ",Meiryo,sans-serif;
	background: #FFF;
}
input,
select {
	border: 1px solid #DDD;
	padding: 10px;
}
textarea {
	border: 1px solid #DDD;
	padding: 10px;
}
ol,
ul {
	list-style: none;
}
p {
	font-size:16px;
}
img {
	border:0px #FFFFFF solid;
	vertical-align: top;
	font-size:0;
	line-height: 0;
}
table {
  border-collapse:collapse;
  border-spacing:0;
}

/*----------------------------------------
	clearfix
	----------------------------------------*/
.clearfix:after {
	content: "";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
	font-size: 0;
	line-height: 0;
}
.clearfix { display: inline-block;}
/* Hides from IE-mac \*/
* html .clearfix { height: 1%; }
.clearfix { display: block; }
/* End hides from IE-mac */

.clear{
	clear:both;
	font-size:0;
	line-height:0;
	padding:0;
	margin:0;
}

/*.clearfix:before,
.clearfix:after {
	content: "";
	display: table;
}
.clearfix:after {
	clear: both;
}
.clearfix {
	*zoom: 1;
}*/


/*----------------------------------------
	header
	----------------------------------------*/
.wrap {
	width: 100%;
}
.top {
	background: #b09315;
}
.top ul {
	text-align: right;
	width: 280px;
	float: right;
}
.top li {
	color: #fff;
	font-size: 14px;
	float: left;
	padding: 5px 10px;
}
.head_inner {
	background: url(images/top_bg.jpg) no-repeat 30%;
	background-size: cover;
	width: 100%;
	border-bottom: 3px solid #b09315;
}
.head01 {
	text-align: center;
	margin: 0 auto;
}
.g_nav {
	background: #0159a0;
	margin-bottom: 40px;
	width: 100%;
}
.g_nav ul {
	width: 1200px;
	margin: 0 auto;
}
.g_nav li {
	width: 20%;
	float: left;
	border-left: 1px solid #00386f;
	position: relative;
	box-sizing: border-box;
}
.g_nav li.last {
	margin-right: 0;
	border-right: 1px solid #00386f;
}
.g_nav li a {
	color: #fff;
	font-size: 19px;
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	padding: 30px 0;
	display: block;
	transition: .4s;
}
.g_nav li a:before {
	color: #007AC9;
	font-size: 18px;
	font-weight: bold;
	content: ">";
	position: absolute;
	top: 50%;
	left: 20px;
	margin-top: -13px;
	transition: .4s;
}
.g_nav li a:hover {
	color: #fff;
	text-decoration: none;
	background: #00386f;
}
.g_nav li a:hover:before {
	color: #fff;
	margin-left: 5px;
}

/*----------------------------------------------------
	container
----------------------------------------------------*/
#container {
	width:1200px;
	margin:0 auto;
}
.section{
	margin-bottom: 20px;
}

.head02 {
	color: #0159a0;
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 20px;
	padding: 5px 0 0 15px;
	border-bottom: 1px solid #0159a0;
}
.head02:before {
	font-family: "FontAwesome";
	font-size: 28px;
	margin-right: 20px;
}
#T01 h2:before {
	content: "\f05a";
}
#T02 h2:before {
	content: "\f073";
}
#T03 h2:before {
	content: "\f207";
}
#T04 h2:before {
	content: "\f095";
}

.reservearea {
	width: 80%;
	margin: 0 auto 20px;
}
.reservearea a {
	width: 44%;
	float: left;
	margin-right: 20px;
}
.reservearea a.last {
	margin-right: 0;
}

.info {
	width: 80%;
	margin: 0 auto;
	padding: 10px 20px;
	border: 1px solid #ccc;
}
.info dl {
	margin-top: 10px;
	border-bottom: 1px dotted #ddd;
}
.info dt {
	color: #999;
	font-size: 13px;
	float: left;
	padding: 0 5px;
}
.info dd {
	font-size: 14px;
	float: left;
	padding: 0 10px;
}

.reserve_area {
	width: 30%;
	margin: 10px auto;
	padding: 10px 20px;
}
a.reserve {
	color: #fff;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
	text-decoration: none;
	background: #f38600;
	padding: 5px 5px 5px 35px;
	border-radius: 5px;
	display: block;
	position: relative;
	transition: .4s;
	box-shadow: 0 4px 0 #D56F09;
}
a.reserve:before {
	color: #fff;
	font-size: 28px;
	font-weight: normal;
	font-family: 'FontAwesome';
	position: absolute;
	top: 50%;
	left: 20px;
	margin-top: -13px;
	transition: .4s;
}
a.reserve:hover {
	text-decoration: none;
	background: #ff5c26;
}
a.reserve:hover:before {
	margin-left: 5px;
}
a.reserve.dep:before {
	content: "\f072   \f178";
}
a.reserve.arr:before {
	content: "\f0f7   \f178";
}

.pcBtnReserve { width:560px; margin:18px auto 0;}
.pcBtnReserve a { padding:14px 5px 14px 35px;}
.pcBtnReserve a.reserve:before {
	content: "\f109   \f178";
	margin-top:-15px;
}
@media screen and (max-width: 768px){
    .pcBtnReserve { width:80%; margin:18px auto 0;}
    .pcBtnReserve a.reserve:before {margin-top:-12px;}
}


.timetable_area ul {
	width: 80%;
	margin: 20px auto 32px;
}
.timetable_area li a {
	background: #dfdfdf;
	text-align: center;
	text-decoration: none;
	width: 50%;
	float: left;
	padding: 20px 0;
	display: block;
	transition: .3s;
	position: relative;
}
.timetable_area li a:hover {
	opacity: .9;
}
.timetable_area li.active a {
	color: #fff;
	font-weight: bold;
	background: #0159a0;
}
.timetable_area li.active a::after {
	content: "";
	position: absolute;
	display: block;
	border-style: solid;
	border-color: #0159a0 transparent transparent transparent;
	border-width: 8px 8px 0 8px;
	top: auto;
	right: auto;
	left: 50%;
	bottom: -8px;
}
.timetable div,
.map div {
	width: 86%;
	margin: 0 auto;
}
h3 {
	color: #fff;
	font-size: 17px;
	background: #0159a0;
	width: 80%;
	margin: 0 auto 15px;
	padding: 15px 20px; padding-right: 10px;
}
.timetable h3,
.map h3 {
	width: 64%;
	float: left;
	margin-right: 2%;
    color: #fff;
    box-sizing: border-box;
}
.timetable h3.en,
.map h3.en {
	width: 100%;
    margin-right: 0;
}
.timetable h3 * { color: #fff;}
.timetable h3 p { float: left; margin-right: 10px; }
.timetable h3 div { overflow: auto; width: auto; margin: 0;}
.timetable h3 div span { display: inline-block; white-space: nowrap;}


.timetable a.reserve,
.map a.reserve {
	width: 34%;
	float: left;
    box-sizing: border-box;
}
.table_area {
	padding-bottom: 30px;
}
.timetable table {
	font-size: 15px;
	width: 100%;
	border-collapse:collapse;
	border-right:1px solid #ccc;
}
.timetable table th,
.timetable table td {
	text-align: center;
	width: 23%;
	padding: 5px 10px;
	background-color:#FFF;
	border-top:1px solid #ccc;
	border-left:1px solid #ccc;
	border-bottom:1px solid #ccc;
}
.timetable table .arrow {
	font-size: 24px;
	background: #fff;
	width: 8%;
	padding: 5px;
	border: none;
	border-left:1px solid #ccc;
}
.timetable table th {
	font-size: 14px;
	background: #f3f3f3;
	vertical-align: middle;
}
.timetable table .dep {
	background: #C5E1A5;
}
.timetable table .arr {
	background: #FFE082;
}
.timetable table .time {
	font-weight: bold;
	text-align: center;
}
.even .time {
	background: #FFF0F0;
}

.map {
	margin-bottom: 30px;
}
.maparea {
	width: 80%;
	margin: 10px auto 40px;
}
.maparea div {
	text-align: center;
	width: 50%;
	float: left;
	box-sizing: border-box;
}
.maparea h4 {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	width: 87.5%;
	margin: 10px auto;
	padding: 10px 0;
	border: 2px solid #007AC9;
}
.maparea a {
	transition: .4s;
}
.maparea a:hover {
	opacity: .8;
}

.inquiry {
	text-align: center;
}

/*----------------------------------------
	page
	----------------------------------------*/
#contents {
	font-size: 14px;
	width: 900px;
	margin: 0 auto 20px;
	padding: 0 25px;
}

#topic-path {
	width:950px;
	margin: 16px auto;
	font-size:12px;
	margin-bottom:10px;
}
#topic-path li { display:inline }
#topic-path li strong { font-weight:normal }
#topic-path li a {
	padding-right:10px;
	background:url(/images/search/path.png) no-repeat right center;
}

.page h1 {
	color: #fff;
	font-size: 24px;
	font-weight: bold;
	background: #00376c;
	width: 100%;
	margin-bottom: 20px;
	padding: 16px;
}
.page h2 {
	font-size: 20px;
	font-weight: bold;
	width: 96%;
	margin: 24px auto 16px;
	padding-left: 10px;
	border-bottom: 2px solid #00376c;
}
.page h3 {
	color: #333;
	font-size: 16px;
	font-weight: bold;
	background: transparent;
	width: 100%;
	margin-bottom: 0;
	padding: 5px 15px;
}
.page h3:before {
	color: #00376c;
	font-size: 24px;
	content: '■';
	padding-right: 5px;
}
.page dl {
	width: 96%;
	margin: 10px auto;
}
.page dt {
	font-weight: bold;
}
.page #contents ul {
	line-height: 1.8;
	width: 90%;
	margin: 10px auto;
}
.page #contents li {
	list-style: disc;
}
.page #contents li.sml {
	color: #555;
	font-size: 12px;
	list-style: none;
	text-indent: -1em;
	padding-left: 1em;
}
.page p {
	font-size: 14px;
	width: 96%;
	margin: 5px auto;
}
.page table {
	width: 96%;
	margin: 10px auto;
}
.page th,
.page td {
	line-height: 1.6;
	padding: 20px;
	border: 1px solid #ccc;
}
.page th {
	font-weight: bold;
	background: #efefef;
	vertical-align: middle;
}
.link {
	font-size: 18px;
	width: 96.8%;
	padding: 30px;
	border: 1px solid #00376c;
}
.link dt:before {
	color: #00376c;
	font-size: 30px;
	content: '■';
}
.link dd {
	margin-bottom: 20px;
}
.link dd a {
	color: #00376c;
}
.link dd a:hover {
	text-decoration: none;
}

/*追記202411～*/
a{
      transition:0.5s;
    }
    
a:hover img{
  opacity: 0.8;
  filter: alpha(opacity=80);
  -moz-opacity: 0.8;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
    }
.reserve_bar{
 text-align:center;    
 display:block;
 width:100%;
 margin:0 auto;
    
}
.reserve_bar img{
 width:25%;
 padding:20px 30px;
 
}
.kome{
    display:block;
    width:100%;
    font-size:90%;
    text-align:right;
}
/*----------------------------------------
  スマホ/タブレット
  ----------------------------------------*/
@media screen and (max-width: 1280px){

	/* header */
  .head01 img {
    max-width: 100%;
    height: auto;
  }
	.head_inner {
		background-size: auto 100%;
	}
	.g_nav {
		margin-bottom: 10px;
	}
	.g_nav ul {
		width: 100%;
	}
	.g_nav li a {
		font-size: 10px;
		padding: 10px 0;
	}
	.g_nav li a:before {
		content: "";
	}
	.g_nav li a:hover {
		color: transparent;
		background: transparent;
	}
	.g_nav li a:hover:before {
		color: transparent;
		margin-left: 0;
	}

	/* container */
	#container {
		width: 100%;
		margin:0;
	}
	.reservearea {
		width: 98%;
		margin: 0 auto 20px;
	}
	.reservearea a {
		width: 49%;
		float: left;
		margin-right: 1%;
		box-sizing: border-box;
	}
	a.reserve {
		font-size: 13px;
		border-radius: 3px;
	}
	a.reserve:before {
		font-size: 20px;
		top: 55%;
		left: 8px;
		margin-top: -13px;
	}
	a.reserve:hover {
		text-decoration: none;
		background: transparent;
	}
	a.reserve:hover:before {
		margin-left: 0;
	}
	a.reserve.dep:before {
		content: "\f072";
	}
	a.reserve.arr:before {
		content: "\f0f7";
	}
	.head02 {
		font-size: 16px;
		width: 98%;
		margin: 0 auto 20px;
		padding: 5px 0 0 0;
	}
	.head02:before {
		font-size: 16px;
		margin: 0 5px;
	}
	.info {
		width: 90%;
		padding: 10px;
	}
	.info dl {
		margin-top: 0;
	}
	.info dt {
		font-size: 10px;
		float: none;
		padding: 0;
	}
	.info dd {
		font-size: 11px;
		float: none;
		padding: 0;
	}
	.timetable div,
	.map div {
		width: 98%;
		float: none;
		margin: 0 auto;
	}
	h3 {
		font-size: 12px;
		padding: 10px;
		box-sizing: border-box;
	}
	.timetable h3,
	.map h3 {
		width: 98%;
		float: none;
		margin: 0 auto;
	}
    .timetable h3 * { font-size: 12px;}
    
	.timetable a.reserve,
	.map a.reserve {
		width: 60%;
		float: none;
		margin: 10px auto;
	}
	.table_area {
		padding-bottom: 16px;
		overflow-x: scroll;
	}
	.timetable table {
		font-size: 8px;
	}
	.timetable table th,
	.timetable table td {
		width: auto;
		padding: 5px 10px;
		background-color:#FFF;
		border-top:1px solid #ccc;
		border-left:1px solid #ccc;
		border-bottom:1px solid #ccc;
	}
	.timetable table .arrow {
		font-size: 10px;
		background: #fff;
		width: 8%;
		padding: 5px;
		border: none;
		border-left:1px solid #ccc;
	}
	.maparea h4 {
		font-size: 12px;
		width: 80%;
		border: 1px solid #007AC9;
	}
	.maparea a:hover {
		opacity: 1;
	}
	.maparea img {
		max-width: 80%;
		height: auto;
	}
	.inquiry img {
		max-width: 100%;
		height: auto;
	}

	/* page */
	#contents {
		font-size: 14px;
		width: 98%;
		margin: 0 auto;
		padding: 5px;
		box-sizing: border-box;
	}

	#topic-path {
		font-size: 10px;
		width: 95%;
		margin: 10px auto;
	}
	#topic-path li a {
		padding-right:10px;
		background:url(/images/search/path.png) no-repeat right center;
	}

	.page h1 {
		font-size: 14px;
		width: auto;
		margin-bottom: 0;
		padding: 5px;
	}
	.page h2 {
		font-size: 14px;
		width: 96%;
		margin: 16px auto;
		padding-left: 10px;
	}
	.page h3 {
		font-size: 11px;
		padding: 5px;
	}
	.page h3:before {
		font-size: 12px;
	}
	.page p,
	.page dl,
	.page #contents ul {
		font-size: 12px;
	}
	.page dl {
		width: 90%;
	}
	.page_table {
		overflow-x: scroll;
	}
	.page table {
		width: 160%;
	}
	.page th,
	.page td {
		padding: 10px;
	}
	.link {
		font-size: 14px;
		width: 90%;
		padding: 10px;
	}
	.link dt:before {
		font-size: 14px;
	}
	.link dd {
		margin-bottom: 10px;
	}

}