@charset "UTF-8";

body{
	background-color: #fff;
	color: #2f2725;
	-webkit-text-size-adjust: 100%;
}
.wrap {
	position: relative;
	margin: auto;
	padding: 0;
}
.lato{
	font-family: 'Lato', sans-serif;
}

ul#context_ul {
	margin-bottom: 0;
}
p.notice_0901 {
	margin: 0 0 20px 30px;
}

main {
	margin-top: 30px;
}









/*------------------------------------------ header */
header #header_inner{
	padding: 0;
	height: 58px;
	border-bottom: 1px solid #2f2725;
}
header #header_logo{
	float: left;
	margin:  0 0 0 2.8125%;
	padding: 15px 0 0;
	width: 125px;
}
header ul#header_utility{
	display: none;
}
header .menu-trigger{
	float: right;
	width: 38px;
	margin: 0 2.8125% 0 0;
	padding: 9px 0 0;
	font-family: 'Lato', sans-serif;
	font-weight: bold;
}
header .menu-trigger a,
header .menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
header .menu-trigger a{
	position: relative;
	width: 38px;
	height: 40px;
	color: #898989;
	text-decoration: none;
}
header .menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #898989;
	border-radius: 4px;
}
header .menu-trigger span:nth-of-type(1) {
	top: 0;
}
header .menu-trigger span:nth-of-type(2) {
	top: 10px;
}
header .menu-trigger span:nth-of-type(3) {
	top: 20px;
}
header .menu-trigger.active span {
	height: 2px;
	left: 0;
	right: 0;
	background-color: #322b29;
}
header .menu-trigger.active span:nth-of-type(1) {
	width: 30%;
	-webkit-transform: translate3d(10px, 11px, 0) rotate(45deg);
	transform: translate3d(10px, 11px, 0) rotate(45deg);
}
header .menu-trigger.active span:nth-of-type(2) {
	width: 56%;
	-webkit-transform: translate3d(9px, 5px, 0) rotate(-45deg);
	transform: translate3d(9px, 5px, 0) rotate(-45deg);
}
header .menu-trigger.active span:nth-of-type(3) {
	width: 30%;
	-webkit-transform: translate3d(18px, -1px, 0) rotate(45deg);
	transform: translate3d(18px, -1px, 0) rotate(45deg);
}
header .menu-trigger p {
	position: absolute;
	bottom: 0;
	margin: 0;
	width: 38px;
	text-align: center;
	line-height: 1;
}
header .menu-trigger.active p {
	color: #6d6c6c;
}
header #gmenu_sp {
	position:absolute;
	display: none;
	width: 100%;
	background-color: #fff;
	box-shadow:0px 8px 8px 0px #aaaaaa;
	-moz-box-shadow:0px 8px 8px 0px #aaaaaa;
	-webkit-box-shadow:0px 8px 8px 0px #aaaaaa;
	z-index: 100;
	overflow: hidden;
}
header #gmenu_sp ul {
	list-style-type: none;
	margin: 0;
}
header #gmenu_sp ul li {
	border-bottom: 1px solid #322b29;
	font-size: 119%;
	font-weight: bold;
}
header #gmenu_sp ul li a {
	position: relative;
	display: block;
	padding: 1em 13px 1em 27px;
	color: #322b29;
	text-decoration: none;
}
header #gmenu_sp ul li a::before,
header #gmenu_sp ul li a::after{
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	content: "";
	vertical-align: middle;
}
header #gmenu_sp ul li a::before{
	left: 13px;
	width: 5px;
	height: 5px;
	border-top: 2px solid #807f7f;
	border-right: 2px solid #807f7f;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
header #gmenu_sp ul li ul {
	border-top: none;
}
header #gmenu_sp ul li ul li {
	border-bottom: none;
	font-weight: normal;
	font-size: 100%;
}
header #gmenu_sp ul li ul li a {
	padding-left: 50px;
}
header #gmenu_sp ul li ul li a::before{
	left: 36px;
}
header #gmenu_sp p.btn_close {
	font-family: 'Lato', sans-serif;
	font-size: 137%;
	text-align: center;
}
header #gmenu_sp p.btn_close span {
	position: relative;
	padding: 0 15px 0 32px;
	border: 1px solid #a5a5a5;
	background-color: #5c5a5a;
	color: #fff;
}
header #gmenu_sp p.btn_close span:before,
header #gmenu_sp p.btn_close span:after {
	content:"";
	position:absolute;
	display:inline-block;
	top: 0.1em;
	left:16px;
	width:1.5px;
	height:16px;
	border:0;
	margin:0;
	padding:0;
	background-color: #fff;
}
header #gmenu_sp p.btn_close span:before{
	-moz-transform:rotate(45deg);
	-webkit-transform:rotate(45deg);
	transform:rotate(45deg);
}
header #gmenu_sp p.btn_close span:after {
	-moz-transform:rotate(-45deg);
	-webkit-transform:rotate(-45deg);
	transform:rotate(-45deg);
}
header #gmenu_pc,
header #sub_gmenu_pc {
	display: none;
}


/*------------------------------------------ contents */
div#contents{
	margin-bottom: 90px;
}
div#contents h1{
	margin-top: 1em;
	font-family: 'Lato', sans-serif;
	font-size: 190%;
	font-weight: bold;
	text-align: center;
}
div#contents h2{
	font-family: 'Lato', sans-serif;
	font-size: 127%;
	text-align: center;
}

/*------------------------------------------ footer */

footer{
	position: relative;
	padding:  0.5em 0 0;
	background-color: #e8e8e8;
}

footer #pageTop {
	position: fixed;
	bottom: 10px;
	right: 5px;
	margin: 0;
	z-index: 50;
}
footer #pageTop img {
	width: 37px;
}
footer #footer_link #site_link,
footer #footer_link #sns_link {
	display: none;
}
footer #footer_link ul#relation_link {
	list-style-type: none;
	margin: 0.5em 0;
	padding: 0 2.8125%;
}
footer #footer_link ul#relation_link li {
	padding-bottom: 0.5em;
	padding-left: 15px;
	background: transparent url("../images/footer_arrow.gif") no-repeat left 0.3em;
	background-size: 9px auto;
}
footer #footer_link ul#relation_link li a {
	color: #2f2725;
	text-decoration: none;
}
footer #footer_info {
	padding: 1px 1.5625%;
	background-color: #f7f7f7;
}
footer #footer_info #info_tel_ad {
	margin: 0.5em 0;
}
footer #footer_info #info_tel_ad p#info_tel {
	margin: 0;
	font-size: 119%;
	font-weight: bold;
}
footer #footer_info #info_tel_ad p#info_tel a {
	color: #2f2725;
	text-decoration: none;
}
footer #footer_info #info_tel_ad p#info_ad {
	margin: 0;
	font-size: 109%;
}
footer #footer_info #business_hours {
	margin: 0.5em 0;
}
footer #footer_info #business_hours dl {
	margin: 0;
}
footer #footer_info #business_hours dl dt {
	margin: 0;
}
footer #footer_info #business_hours dl dd {
	margin: 0;
	line-height: 1.3;
}

footer #footer_info #business_hours dl dd span.ex {
	display: table;
}
footer #footer_info #business_hours dl dd span.ex_th {
	display: table-cell;
}
footer #footer_info #business_hours dl dd span.ex_td {
	display: table-cell;
}







footer #footer_info #business_hours dl dd .time_indent {
	margin-left: 14.3em;
}
footer #copyright {
	margin: 0;
	padding: 1em 0;
	font-size:96%;
	text-align: center;
}


/*------------------------------------------ topic_path */

body.second #contents ul#topic_path {
	list-style-type: none;
	margin: 0;
}
body.second #contents ul#topic_path li {
	float: left;
	margin: 0.5em 0;
	padding: 0 5px 0 0;
	font-size: 83%;
	color: #777;
}
body.second #contents ul#topic_path li a {
	margin-right: 5px;
	color: #777;
}
body.second #contents ul#topic_path li#path_home {
	background-image: none;
}


/*------------------------------------------ arrow */




/*------------------------------------------ visible hidden */

.visible-sp, .visible-pc {
	display: none !important;
}

.visible-sp {
	display: block !important;
}
.hidden-sp{
	display:none !important
}

/*------------------------------------------ hyperlink */

a:link, a:visited {
	color: #008dd7;
	text-decoration: underline;
	vertical-align: baseline;
}


/*--------------------------------------------------------------------
 *	737px以上用（PC用）の記述
 *--------------------------------------------------------------------*/
@media screen and (min-width: 737px), print {
/* 737px以上用（PC用）の記述 */

body{
	font-size: 14px;
 	display:flex;
  	flex-direction:column;
 	min-height: 100vh;
}
.wrap {
	width: 1000px;
	margin: 0 auto;
	padding: 0 40px;
}
main{
     	flex: 1;
}
ul#context_ul {
	margin-top: 26px;
	margin-bottom: 0;
}
p.notice_0901 {
	margin: 0 0 0 30px;
}


/*------------------------------------------ header */
header #header_inner{
	position: relative;
	margin: 0 auto;
	padding: 72px 0 0;
	width: 1000px;
	height: auto;
	border-bottom: none;
}
header #header_logo{
	float: none;
	width: auto;
	margin: 0 0 72px;
	padding: 0;
	text-align: center;
	line-height: 1;
}
header #header_logo img{
	width: 200px;
}




header ul#header_utility {
	display:block;
	position: absolute;
	top: 15px;
	right: 0;
	list-style-type: none;
	margin: 0;
}
header ul#header_utility li {
	float: left;
	margin-right: 8px;
	background-color: #b5b5b6;
}
header ul#header_utility li:hover {
	background-color: #bfbfc0;
}
header ul#header_utility li:last-child {
	margin-right: 0;
}
header ul#header_utility li a {
	display: block;
	padding: 0 18px;
	color: #fff;
	text-decoration: none;
}
header ul#header_utility li#slt_lang {
	border: 1px solid #b5b5b6;
	background-color: #fff;
	color: #2f2725;
}
header ul#header_utility li#slt_lang a {
	position: relative;
	padding: 0 30px 0 12px;
	color: #2f2725;
}
header ul#header_utility li#slt_lang a:hover {
	background-color: #efefef;
}
header ul#header_utility li#slt_lang > a:after {
	content:"";
	position:absolute;
	top: 7px;
	right: 4px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 9px 5px 0 5px;
	border-color: #747374 transparent transparent transparent;
}
header ul#header_utility li#slt_lang ul {
	display: none;
	list-style-type: none;
	margin: 0;
	width: 100%;
}
header ul#header_utility li#slt_lang ul li {
	width: 100%;
}
header ul#header_utility li#slt_lang ul li:hover {
	background-color: #bfbfc0;
}
header ul#header_utility li#slt_lang ul li a {
	color: #fff;
}
header ul#header_utility li#slt_lang ul li a:hover {
	background-color: #bfbfc0;
}
header #gmenu_pc {
	display: table;
	list-style-type: none;
	margin: 0 auto;
	font-family: 'Lato', sans-serif;
	font-size: 143%;
}
header #gmenu_pc li {
	position: relative;
	display: table-cell;
	padding: 0 50px;
	height: 38px;
}
header #gmenu_pc li a {
	color: #3e3a3a;
	text-decoration: none;
}
header #gmenu_pc li a:hover {
	color: #999;
}
header #gmenu_pc li:nth-child(3):before {
	content:"";
	position:absolute;
	display:inline-block;
	bottom: 0;
	left:0;
	right: 0;
	width:2px;
	height:10px;
	border:0;
	margin:0 auto;
	padding:0;
	background-color: #adadae;
}
header #sub_gmenu_pc {
	display: block;
	min-width: 1080px;
	width: 100%;
	border-top: 1px solid #adadae;
}
header #sub_gmenu_pc ul {
	display: table;
	width: auto;
	list-style-type: none;
	margin: 15px auto 0;
	padding: 0;
}
header #sub_gmenu_pc ul li {
	display: table-cell;
	padding: 0 40px;
}
header #sub_gmenu_pc ul li a {
	display: inline-block;
	padding: 0 0 2px 36px;
	color: #2f2725;
	text-decoration: none;
	height: 22px;
	min-height: 22px;
}
header #sub_gmenu_pc ul li:nth-child(1) a {
	background: transparent url("../images/icon_cat_01.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li:nth-child(2) a {
	background: transparent url("../images/icon_cat_02.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li:nth-child(3) a {
	background: transparent url("../images/icon_cat_03.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li:nth-child(4) a {
	background: transparent url("../images/icon_cat_04.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li:nth-child(5) a {
	background: transparent url("../images/icon_cat_05.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li:nth-child(6) a {
	background: transparent url("../images/icon_cat_06.png") no-repeat left center;
	background-size: 30px auto;
}
header #sub_gmenu_pc ul li a:hover {
	color: #999;
}







header .menu-trigger {
	display: none;
}



/*------------------------------------------ contents */
div#contents{
	margin-bottom: 90px;
}
div#contents h1{
	margin-top: 2em;
	font-size: 172%;
	font-weight: bold;
}
div#contents h2{
	font-size: 172%;
}


/*------------------------------------------ footer */

footer{
	padding-top: 1px;
	padding-bottom: 1px;
	min-width: 1080px;
}
footer #pageTop {
	position: fixed;
	bottom: 10px;
	right: auto;
	margin: 0 0 0 944px;
	z-index: 100;
}
footer #pageTop img {
	width: 56px;
}
footer #pageTop a:hover img {
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}

footer #footer_link ul#site_link{
	display: block;
	list-style-type: none;
	margin: 20px 0 0;

}
footer #footer_link ul#site_link li{
	float: left;
	margin: 0 0 6px 0;
	padding: 0 20px;
	border-left: 1px solid #2f2725;
	line-height: 1;

}
footer #footer_link ul#site_link li:first-child{
	padding-left: 0;
	border-left: none;
}
footer #footer_link ul#site_link li:nth-child(5){
	clear: both;
	padding-left: 0;
	border-left: none;
}
footer #footer_link ul#site_link li a{
	color: #2f2725;
	text-decoration: none;
}
footer #footer_link ul#site_link li a:hover{
	color: #999;
}
footer #footer_link ul#sns_link {
	display: block;
	float: right;
	list-style-type: none;
	margin: 0 104px 0 0;
}
footer #footer_link ul#sns_link li {
	float: left;
	margin-right: 18px;
}
footer #footer_link ul#sns_link li a:hover img {
	filter:alpha(opacity=50);
	-moz-opacity: 0.5;
	opacity: 0.5;
}


footer #footer_link ul#relation_link {
	margin-top: 20px;
	margin-bottom: 20px;
	padding: 0;
	width: 720px;
}
footer #footer_link ul#relation_link li {
	padding-left: 21px;
	background-size: 14px auto;
}
footer #footer_link ul#relation_link li:first-child {
	float: right;
	width: 196px;
}

footer #footer_link ul#relation_link li:nth-child(2) {
	padding-left: 0;
	background-image: none;
}
footer #footer_link ul#relation_link li:nth-child(2) a {
	display: inline-block;
	padding-left: 156px;
	background: transparent url("../images/footer_clubon.gif") no-repeat left center;
}
footer #footer_link ul#relation_link li a:hover{
	color: #999;
}










footer #footer_info div.wrap {
	padding: 7px 0;
}
footer #footer_info #info_tel_ad {
	display: table-cell;
	width: 238px;
	border-right: 1px solid #938f8e;
	vertical-align: top;
}
footer #footer_info #info_tel_ad p#info_tel {
	font-size: 129%;
}
footer #footer_info #info_tel_ad p#info_ad {
	font-size: 100%;
}


footer #footer_info #business_hours {
	display: table-cell;
	margin: 0;
	padding-left: 26px;
	vertical-align: top;
}
footer #footer_info #business_hours dl {
	margin: 0;
}
footer #footer_info #business_hours dl dt {
	margin: 0;
	padding: 0;
	float: left;
	width: 5em;
	margin: 0 -5.5em 0 0;
}
footer #footer_info #business_hours dl dd {
	margin: 0 0 0 5.5em;
	padding: 0 0 0.5em 0;
}


footer #footer_info #business_hours dl dd .time_indent {
	margin-left: 0;
}



footer #copyright {
	margin: 0;
	padding: 1em 0;
	font-size: 100%;
	line-height: 1.3;
}




footer #copyright .visible-pc {
	display: inline !important;
}



/*------------------------------------------ visible hidden */

.visible-sp, .visible-pc {
	display: none !important;
}

.visible-pc {
	display: block !important;
}
.hidden-pc{
	display:none !important
}

/*------------------------------------------ hyperlink */

a:hover, a:active {
	color: #1cb1ff;
}

/* 737px以上用（PC用）の記述 end */
}


/*------------------------------------------ clear */
body,
.wrap,
header,
header ul#header_utility,
header #gmenu_pc,
footer,
footer #footer_link ul#site_link,
footer #footer_link ul#sns_link,
footer #footer_info #business_hours dl {
	zoom: 100%;
}

body:after,
.wrap:after,
header:after,
header ul#header_utility:after,
header #gmenu_pc:after,
footer:after,
footer #footer_link ul#site_link:after,
footer #footer_link ul#sns_link:after,
footer #footer_info #business_hours dl:after {
	content: ".";
	display: block;
	visibility: hidden;
	height: 0.1px;
	font-size: 0.1em;
	line-height: 0;
	clear: both;
}