@charset "utf-8";
/* CSS Document */

footer {
	min-height: 240px;
}
footer .container {
	display: table;
}

footer nav {
	float: right;
	display: inline-block;
	width: 780px;
	margin: 25px 0 0;
	position: relative;
}
footer .btn_menu {
	display: none;
}
footer nav ul.menu li a {
	color: #333333;
	font-size: 12px;
	line-height: 20px;
	text-decoration: none;
}
footer nav ul.menu > li {
	position: relative;
	display: inline-block;
	vertical-align: top;
	width: 130px;		
}
footer nav ul.menu > li:before {
	content: "";
	position: absolute;
	left: 3px;
	top: 5px;
	border: 4px solid transparent;
	border-left: 4px solid #B265B2;	
}
footer nav ul.menu > li a {
	font-weight: bold;
	padding: 0 0 0 1em;
}
footer nav ul.sub-menu > li:before {
	content: "├";
	color: #333333;
	font-size: 12px;
	line-height: 20px;
	padding: 0 0 0 1em;
}
footer nav ul.sub-menu > li:last-child:before {
	content: "└";
}
footer nav ul.sub-menu > li a {
	font-weight: normal;
	padding: 0 0 0 0.5em;
}
footer nav ul.menu > li.schedule {
	display: block;
	position: absolute;
	top: 25px;
	left: 520px;
}
footer nav ul.menu > li.pamphlet {
	display: block;
	position: absolute;
	top: 50px;
	left: 520px;
}
footer nav ul.menu > li.access {
	display: block;
	position: absolute;
	top: 75px;
	left: 520px;
}
footer nav ul.menu > li.route {
	display: block;
	position: absolute;
	top: 0;
	left: 650px;
}
footer nav ul.menu > li.aboutus {
	display: block;
	position: absolute;
	top: 25px;
	left: 650px;
}
/* pc only*/
@media screen and (min-width: 1200px) {
	
	footer nav ul li a:hover {
		text-decoration: underline;
	}
		
}
/* pc tablet */
@media screen and (max-width: 1199px) {
	
	footer nav {
		width: 680px;
	}
	footer nav ul.menu > li.aboutus {
		display: inline-block;
		top: 155px;
		left: 0px;
	}
	
}
/* tablet */
@media screen and (max-width: 1023px) {
	
	footer nav {
		float: none;
		display: block;
		margin: 25px auto;
	}	
	
}
/* tablet sp */
@media screen and (max-width: 767px) {
	
	footer .btn_menu {
		display: block;
		position: fixed;
		z-index: 1001;
		top: 0;
		right: 0;
		width: 60px;
		height: 60px;
		background: url(../img/header/btn_menu.png) no-repeat;
		background-size: 60px 60px;
		cursor: pointer;
	}
	footer nav {
		display: none;
		position: fixed;
		z-index: 1000;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		margin: 0;
		padding: 60px 0;
		text-align: center;
		background-color: rgba(102,51,153,0.9);
	}
	footer nav ul.menu {
		width: 100%;
		border-top: #663399 groove 2px;
	}
	footer nav ul.menu > li:before {
		border: none;
	}
	footer nav ul.menu li a {
		display: block;
		color: #FFFFFF;
		font-size: 14px;
		line-height: 40px;
		text-decoration: none;
		padding: 0;
	}
	footer nav ul.menu > li.theme,
	footer nav ul.menu > li.area {
		display: block;
		width: 100%;
		height: auto;
		border-bottom: #663399 groove 2px;
	}
	footer nav ul.sub-menu {
		width: 100%;
		height: auto;
		background-color: rgba(255,142,199,0.5);
	}
	footer nav ul.sub-menu > li {
		display: inline-block;
		width: 50%;
		height: 40px;
	}
	footer nav ul.sub-menu > li:before {
		content: "";
		padding: 0;
	}
	footer nav ul.sub-menu > li:last-child:before {
		content: "";
	}
	footer nav ul.menu > li.newevent,
	footer nav ul.menu > li.information,
	footer nav ul.menu > li.geospot,
	footer nav ul.menu > li.route,
	footer nav ul.menu > li.schedule,
	footer nav ul.menu > li.pamphlet,
	footer nav ul.menu > li.access,
	footer nav ul.menu > li.sitemap,
	footer nav ul.menu > li.aboutus {
		position: static;
		display: inline-block;
		width: 50%;
		height: auto;
		border-bottom: #663399 groove 2px;
	}
	
}
footer h1 a {
	display: inline-block;
	/*width: 220px;*/
	/*height: 90px;*/
	/*background: url(../img/footer/flogo.png) no-repeat;*/
	width: 177px;
	height: 80px;
	background: url(../img/footer/h_logo.png) no-repeat;
	overflow: hidden;
	text-indent: 100%;
	white-space: normal;
}
footer address {
	height: 120px;
}
footer address p {
	font-size: 12px;
	line-height: 15px;
	margin: 0 0 1em;
}
footer address p strong {
	font-size: 12px;
	line-height: 15px;
	margin: 0 0 1em;
}
/* pc tablet */
@media screen and (max-width: 1199px) {
	
	footer h1 a,
	footer address {
		width: 320px;
	}	
	
}
/* tablet */
@media screen and (max-width: 1023px) {
	
	footer h1 a {
		width: 365px;
		margin: 0 10px 0 0;
		vertical-align: top;
		/*background-position: right;*/
	}
	footer address {
		width: 365px;
		margin: 0 0 0 10px;
		vertical-align: top;
		display: inline-block;
	}	
	
}
/* tablet sp */
@media screen and (max-width: 767px) {
	
	footer h1 a {
		width: 100%;
		margin: 0;
		background-position: center;
	}
	footer address {
		width: 100%;
		margin: 0;
		text-align: center;
	}	
	
}

footer .copyright {
	height: 30px;
	text-align: center;
	color: #FFFFFF;
	font-weight: bold;
	font-size: 12px;
	line-height: 30px;
	background-color: #B265B2;
}