@charset "utf-8";
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
html{font-family:Arial,Hiragino Kaku Gothic ProN,ヒラギノ角ゴ ProN W3,Meiryo,Helvetica,メイリオ,sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;vertical-align:baseline;background:transparent}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{color:#000;background-color:transparent;text-decoration:none}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}dfn{font-style:italic}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0;-ms-interpolation-mode:bicubic;vertical-align:bottom;max-width:100%;height:auto}svg:not(:root){overflow:hidden}figure{margin:0}hr{box-sizing:content-box;height:0}pre{overflow:auto}code,kbd,pre,samp{font-family:monospace;font-size:1em}li{list-style:none}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}button{overflow:visible}button,select{text-transform:none}button,html input[type="button"],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input{line-height:normal}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type="number"]::-webkit-inner-spin-button,input[type="number"]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}input[type="search"]::-webkit-search-cancel-button,input[type="search"]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{border:0;padding:0}textarea{overflow:auto}optgroup{font-weight:700}table{border-collapse:collapse;border-spacing:0}td,th{padding:0}img {backface-visibility: hidden;}


/* template style ----------------------*/
body {
	overflow-x: hidden;
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	margin: auto;
	padding: 0;
}
h1,h2,h3,h4,h5,h6,th,p,strong {
	font-weight: normal;
}
.tc { text-align: center !important; }
.tl { text-align: left !important; }
.tr { text-align: right !important; }
.cf:before,.cf:after { content: ""; display: table; }
.cf:after { clear: both; }
.cf { zoom: 1; }

.flex{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}
.flex.nowrap{ flex-wrap: nowrap; }
.flex.reverse{ flex-direction: row-reverse; }
.flex.reverse > *{ min-height: 0; }
.flex.jc-c{ justify-content: center; }
.flex.jc-s{ justify-content: flex-start; }
.flex.jc-e{ justify-content: flex-end; }
.flex.ai-c{ align-items: center; }
.flex.ai-e{ align-items: flex-end; }
.flex.ai-st{ align-items: stretch; }
#header img,#main img,#footer img{ width: 100%; }

.sp-bl, .sp-il, .tablet-bl, .w1060-bl {
	display: none;
}

.inner {
	width:95%;
	max-width: 1200px;
	margin-right:auto;
	margin-left:auto;
	position:relative;
}


.opa {
	transition: 0.3s ease-in-out;
	display: block;
}
.opa:hover {
	opacity: 0.8;
}

@media screen and (max-width:1060px) {
	.w1060-bl { display: block; }
}

@media screen and (max-width:768px) {
	.pc { display:none !important; }
	.sp-bl { display:block; }
	.sp-il { display:inline; }

	.inner {
		width:85%;
		max-width:560px;
	}

	.opa:hover { opacity: 1; }
}


/* fonts ----------------------*/
#header, #main, #footer{
	color: #000;
	font-size: 10px;
	font-family: YakuHanMP, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Noto Serif JP","ＭＳ 明朝",serif;
	font-feature-settings: "palt";
	letter-spacing: .15em;
	line-height: 2;
}


/* header ----------------------*/
#header {
	width: 100%;
	height: 100px;
	margin: 0 auto;
	background-color: #FFF;
}
	#header .inner {
		max-width: 1500px;
		margin: 0 auto;
	}
		#header .inner .logo {
			width: 88px;
			margin: 10px 0;
		}
		#header .inner .headerInfo {
		}
			#header .inner .headerInfo .headerTel {
				width: 290px;
				margin-right: 30px;
				pointer-events: none;
			}
			#header .inner .headerInfo .headerHour {
				font-size: 15px;
				font-weight: 700;
				line-height: 1;
			}
			#header .inner .headerInfo .headerHour p:not(:last-child) {
				margin-bottom: 10px;
			}
				#header .inner .headerInfo .headerHour p span {
					display: inline-block;
					width: 72px;
					text-align: justify;
					text-align-last: justify;
				}

@media screen and (max-width:768px) {
	#header {
		height: 60px;
	}
		#header .inner {
			width: 90%;
		}
			#header .inner .logo {
				width: 52px;
				margin: 6px 0;
			}
			#header .inner .headerInfo {
				display: block;
			}
				#header .inner .headerInfo .headerTel {
					width: 200px;
					margin-right: 0;
					margin-left: auto;
					margin-bottom: 10px;
					pointer-events: auto;
				}
				#header .inner .headerInfo .headerHour {
					font-size: 11px;
					display: flex;
					justify-content: flex-end;
				}
				#header .inner .headerInfo .headerHour p:not(:last-child) {
					margin-bottom: 0;
					margin-right: 10px;
				}
					#header .inner .headerInfo .headerHour p span {
						width: auto;
					}
}

@media screen and (max-width:374px) {
		#header .inner {
			width: 95%;
		}
				#header .inner .headerInfo .headerHour {
					font-size: 10px;
				}
}


/* footer ----------------------*/
#footer {
	position: relative;
	width: 100%;
	background-color: #FFF;
	text-align: center;
	padding: 30px 0;
}
	#footer .pageTop a {
		display: block;
		position: absolute;
		bottom: calc(100% + 20px);
		right: 20px;
		width: 80px;
		border-radius: 50px;
	}
	#footer .copyright {
		font-size: 14px;
		line-height: 1;
		letter-spacing: .05em;
		color: #000;
	}

@media screen and (max-width:768px) {
	#footer {
		padding: 15px 0 100px;
	}
		#footer .copyright {
			font-size: 10px;
		}
}


/* parts ----------------------*/
.gold {
 color: #e4d79d;
}


/* Universal animation
--------------------------------------------------*/
.animated {
	animation-duration: .5s;
	animation-fill-mode: both;
}
/* fade in */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.fadeIn { animation-name: fadeIn; animation-fill-mode:both; animation-duration:.8s; visibility: visible !important; opacity: 0;}

/* fade in up */
@keyframes fadeInUp { from { opacity: 0; transform: translate3d(0, 20px, 0); } to { opacity: 1; transform: none; }}
.fadeInUp { animation-name: fadeInUp; animation-fill-mode:both; animation-duration:1s; visibility: visible !important; opacity: 0;}

/* fade in down */
@keyframes fadeInDown { from { opacity: 0; transform: translate3d(0, -20px, 0); } to { opacity: 1; transform: none; }}
.fadeInDown { animation-name: fadeInDown; animation-fill-mode:both; animation-duration:1s; visibility: visible !important; opacity: 0;}

/* fade in right */
@keyframes fadeInRight { from { opacity: 0; transform: translate(30px,0); } to { opacity: 1; transform: none; } }
.fadeInRight { animation-name: fadeInRight; animation-fill-mode:both; animation-duration:1s; visibility: visible !important; opacity: 0;}

/* fade in left */
@keyframes fadeInLeft {
from { opacity: 0; transform: translate(-30px,0); }to { opacity: 1; transform: none; }}
.fadeInLeft { animation-name: fadeInLeft; animation-fill-mode:both; animation-duration:1s; visibility: visible !important; opacity: 0;}

/* fade out */
@keyframes fadeOut { from { opacity: 1; }  to { opacity: 0; }}
.fadeOut { animation-name: fadeOut; }

